You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
71 lines
2.3 KiB
71 lines
2.3 KiB
#!/bin/bash
|
|
|
|
set -eEuo pipefail
|
|
trap 'echo "Error detected: aborting installation"' ERR
|
|
|
|
echo "Attempting to autodetect distro ..."
|
|
distro=$(lsb_release -is)
|
|
release=$(lsb_release -rs)
|
|
if [[ $distro == "Debian" ]]; then
|
|
echo "Detected distro: Debian"
|
|
if [[ $release =~ ^[0-9]+$ ]]; then
|
|
echo "Detected release: $release"
|
|
elif [[ $release == "testing" ]]; then
|
|
echo "Detected release: testing"
|
|
release=Testing
|
|
else
|
|
echo "Error: failed to detect release"
|
|
exit 2
|
|
fi
|
|
|
|
echo "Installing podman ..."
|
|
if [[ $release != "testing" && $release -lt 11 ]]; then
|
|
sudo apt install -y gnupg curl
|
|
echo "deb https://download.opensuse.org/repositories/devel:/kubic:/libcontainers:/stable/Debian_${release:?}/ /" | sudo tee /etc/apt/sources.list.d/podman.list
|
|
curl -L https://download.opensuse.org/repositories/devel:/kubic:/libcontainers:/stable/Debian_${release:?}/Release.key | sudo apt-key add -
|
|
fi
|
|
sudo apt update -y
|
|
sudo apt install -y fuse-overlayfs slirp4netns podman
|
|
else
|
|
echo "Error: failed to detect distro."
|
|
exit 2
|
|
fi
|
|
|
|
echo "Copying scripts to /usr/local/bin ..."
|
|
# copy bin files to /usr/local/bin
|
|
sudo cp .install/bin/* /usr/local/bin/
|
|
|
|
echo "Installing containers startup service ..."
|
|
# install systemd startup service
|
|
sudo cp .install/containers-startup.service /etc/systemd/system/
|
|
sudo systemctl enable containers-startup.service
|
|
# create startup.d if it doesn't exist
|
|
sudo mkdir -p /etc/containers/startup.d
|
|
|
|
echo "Configuring volumes directory ..."
|
|
sudo mkdir -p /srv/vol
|
|
sudo chown containers:containers /srv/vol
|
|
sudo chmod 700 /srv/vol
|
|
|
|
# configure containers user
|
|
name=containers
|
|
homedir=/usr/lib/containers
|
|
uid=5000
|
|
subrange="1000000-1000000000"
|
|
if [[ ! $(getent group $name) ]]; then
|
|
echo "Creating group '$name' ..."
|
|
sudo groupadd -r -g $uid $name
|
|
fi
|
|
if [[ ! $(getent passwd $name) ]]; then
|
|
echo "Creating user '$name' ..."
|
|
sudo useradd -r -u $uid -p '*' -s /sbin/nologin -d $homedir -g $name $name
|
|
fi
|
|
echo "Configuring user '$name' ..."
|
|
sudo groupmod -g $uid $name
|
|
sudo usermod -u $uid -p '*' -s /sbin/nologin -d $homedir -G '' -v $subrange -w $subrange -g $name $name
|
|
sudo loginctl enable-linger containers
|
|
echo "Creating home directory $homedir ..."
|
|
sudo mkdir -p $homedir
|
|
sudo chown $name:$name $homedir
|
|
|
|
echo "Install finished successfully."
|
|
|