|
@@ -1,7 +1,7 @@
|
|
#!/usr/bin/env bash
|
|
#!/usr/bin/env bash
|
|
set -e # Exit immediately if a command exits with a non-zero status.
|
|
set -e # Exit immediately if a command exits with a non-zero status.
|
|
|
|
|
|
-ROOT_FOLDER="$(readlink -f $(dirname "${BASH_SOURCE[0]}")/..)"
|
|
|
|
|
|
+ROOT_FOLDER="$(readlink -f "$(dirname "${BASH_SOURCE[0]}")"/..)"
|
|
|
|
|
|
echo
|
|
echo
|
|
echo "======================================"
|
|
echo "======================================"
|
|
@@ -14,19 +14,54 @@ echo "=============== TIPI ================="
|
|
echo "======================================"
|
|
echo "======================================"
|
|
echo
|
|
echo
|
|
|
|
|
|
-sudo wget -O "${ROOT_FOLDER}"/scripts/pacapt https://github.com/icy/pacapt/raw/ng/pacapt
|
|
|
|
-sudo chmod 755 "${ROOT_FOLDER}"/scripts/pacapt
|
|
|
|
-sudo "${ROOT_FOLDER}"/scripts/pacapt -Sy
|
|
|
|
-sudo "${ROOT_FOLDER}"/scripts/pacapt -S docker docker-compose jq coreutils curl lsb-release -y
|
|
|
|
|
|
+OS="$(cat /etc/[A-Za-z]*[_-][rv]e[lr]* | grep "^ID=" | cut -d= -f2 | uniq | tr '[:upper:]' '[:lower:]' | tr -d '"')"
|
|
|
|
|
|
-LSB="$(lsb_release -is)"
|
|
|
|
-
|
|
|
|
-systemctl start docker.service
|
|
|
|
-systemctl enable docker.service
|
|
|
|
|
|
+if ! command -v docker >/dev/null; then
|
|
|
|
+ echo "Docker is already installed"
|
|
|
|
+else
|
|
|
|
+ echo "Installing Docker"
|
|
|
|
+ if [[ "${OS}" == "debian" ]]; then
|
|
|
|
+ sudo apt-get update
|
|
|
|
+ sudo apt-get install ca-certificates curl gnupg lsb-release -y
|
|
|
|
+ sudo mkdir -p /etc/apt/keyrings
|
|
|
|
+ curl -fsSL https://download.docker.com/linux/debian/gpg | sudo gpg --dearmor -o /etc/apt/keyrings/docker.gpg
|
|
|
|
+ echo "deb [arch=$(dpkg --print-architecture) signed-by=/etc/apt/keyrings/docker.gpg] https://download.docker.com/linux/debian $(lsb_release -cs) stable" | sudo tee /etc/apt/sources.list.d/docker.list >/dev/null
|
|
|
|
+ sudo apt-get update
|
|
|
|
+ sudo apt-get install docker-ce docker-ce-cli containerd.io docker-compose-plugin
|
|
|
|
+ elif [[ "${OS}" == "ubuntu" ]]; then
|
|
|
|
+ sudo apt-get update
|
|
|
|
+ sudo apt-get install ca-certificates curl gnupg lsb-release -y
|
|
|
|
+ sudo mkdir -p /etc/apt/keyrings
|
|
|
|
+ curl -fsSL https://download.docker.com/linux/ubuntu/gpg | sudo gpg --dearmor -o /etc/apt/keyrings/docker.gpg
|
|
|
|
+ echo "deb [arch=$(dpkg --print-architecture) signed-by=/etc/apt/keyrings/docker.gpg] https://download.docker.com/linux/ubuntu $(lsb_release -cs) stable" | sudo tee /etc/apt/sources.list.d/docker.list >/dev/null
|
|
|
|
+ sudo apt-get update
|
|
|
|
+ sudo apt-get install docker-ce docker-ce-cli containerd.io docker-compose-plugin
|
|
|
|
+ elif [[ "${OS}" == "centos" ]]; then
|
|
|
|
+ sudo yum install -y yum-utils
|
|
|
|
+ sudo yum-config-manager --add-repo https://download.docker.com/linux/centos/docker-ce.repo
|
|
|
|
+ sudo yum install -y --allowerasing docker-ce docker-ce-cli containerd.io docker-compose-plugin
|
|
|
|
+ sudo systemctl start docker
|
|
|
|
+ sudo systemctl enable docker
|
|
|
|
+ elif [[ "${OS}" == "fedora" ]]; then
|
|
|
|
+ sudo dnf -y install dnf-plugins-core
|
|
|
|
+ sudo dnf config-manager --add-repo https://download.docker.com/linux/fedora/docker-ce.repo
|
|
|
|
+ sudo dnf -y install docker-ce docker-ce-cli containerd.io docker-compose-plugin
|
|
|
|
+ sudo systemctl start docker
|
|
|
|
+ sudo systemctl enable docker
|
|
|
|
+ elif [[ "${OS}" == "arch" ]]; then
|
|
|
|
+ sudo pacman -Sy --noconfirm docker
|
|
|
|
+ sudo systemctl start docker.service
|
|
|
|
+ sudo systemctl enable docker.service
|
|
|
|
+ else
|
|
|
|
+ echo "Your OS ${OS} is not supported by this script. Please install docker and docker-compose manually."
|
|
|
|
+ exit 1
|
|
|
|
+ fi
|
|
|
|
+fi
|
|
|
|
|
|
-# if [[ "${LSB}" == "Arch" ]]; then
|
|
|
|
-# sudo "${ROOT_FOLDER}"/scripts/pacapt -S hostname -y
|
|
|
|
-# fi
|
|
|
|
|
|
+if ! command -v docker-compose >/dev/null; then
|
|
|
|
+ sudo curl -L "https://github.com/docker/compose/releases/download/v2.3.4/docker-compose-$(uname -s)-$(uname -m)" -o /usr/local/bin/docker-compose
|
|
|
|
+ sudo chmod +x /usr/local/bin/docker-compose
|
|
|
|
+fi
|
|
|
|
|
|
# Create configured status
|
|
# Create configured status
|
|
touch "${ROOT_FOLDER}/state/configured"
|
|
touch "${ROOT_FOLDER}/state/configured"
|