mirror of
https://github.com/frappe/frappe_docker.git
synced 2024-11-08 14:21:05 +00:00
ci: Build fixes
- Simplify builds by separating dev/stable workflows - Fix Helm deploy key - Remove deploy_key.env (already using deploy key in secrets) - Fix paths matching on push and pull_request triggers - Fix possible issues with tag difference between ERPNext and Frappe (add tag resolving step before pushing) - Don't login, push Docker images and release Helm chart on forks - Don't test on version 12 (there's no test for this version) - Remove frappe-installer (from chore: use github actions #525) - Fix badges in readme
This commit is contained in:
parent
37b8ccece1
commit
2da9c02d58
5
.github/scripts/get-latest-tag.sh
vendored
5
.github/scripts/get-latest-tag.sh
vendored
@ -2,4 +2,7 @@
|
|||||||
|
|
||||||
TAGS=$(git ls-remote --refs --tags --sort='v:refname' https://github.com/$REPO "v$VERSION.*")
|
TAGS=$(git ls-remote --refs --tags --sort='v:refname' https://github.com/$REPO "v$VERSION.*")
|
||||||
TAG=$(echo $TAGS | tail -n1 | sed 's/.*\///')
|
TAG=$(echo $TAGS | tail -n1 | sed 's/.*\///')
|
||||||
echo $TAG
|
|
||||||
|
echo "GIT_TAG=$TAG" >> $GITHUB_ENV
|
||||||
|
echo "GIT_BRANCH=version-$VERSION" >> $GITHUB_ENV
|
||||||
|
echo "VERSION=$VERSION" >> $GITHUB_ENV
|
11
.github/scripts/install-deps-and-test.sh
vendored
Executable file
11
.github/scripts/install-deps-and-test.sh
vendored
Executable file
@ -0,0 +1,11 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
set -e
|
||||||
|
|
||||||
|
sudo apt-get install -y w3m
|
||||||
|
|
||||||
|
./tests/check-format.sh
|
||||||
|
./tests/docker-test.sh
|
||||||
|
|
||||||
|
# This is done to not to rebuild images in the next step
|
||||||
|
git clean -fdx
|
88
.github/workflows/build_develop.yml
vendored
Normal file
88
.github/workflows/build_develop.yml
vendored
Normal file
@ -0,0 +1,88 @@
|
|||||||
|
name: Build Develop
|
||||||
|
|
||||||
|
on:
|
||||||
|
pull_request:
|
||||||
|
branches:
|
||||||
|
- main
|
||||||
|
paths:
|
||||||
|
- .github/**
|
||||||
|
- build/**
|
||||||
|
- installation/**
|
||||||
|
- tests/**
|
||||||
|
- .dockerignore
|
||||||
|
- docker-bake.hcl
|
||||||
|
- docker-compose.yml
|
||||||
|
- env*
|
||||||
|
|
||||||
|
# Nightly builds at 12:00 am
|
||||||
|
schedule:
|
||||||
|
- cron: 0 0 * * *
|
||||||
|
|
||||||
|
workflow_dispatch:
|
||||||
|
|
||||||
|
jobs:
|
||||||
|
build_bench:
|
||||||
|
name: Bench image
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
steps:
|
||||||
|
- uses: actions/checkout@v2
|
||||||
|
- uses: docker/setup-buildx-action@v1
|
||||||
|
|
||||||
|
- uses: docker/login-action@v1
|
||||||
|
if: github.repository == 'frappe/frappe_docker' && github.event_name != 'pull_request'
|
||||||
|
with:
|
||||||
|
username: ${{ secrets.DOCKERHUB_USERNAME }}
|
||||||
|
password: ${{ secrets.DOCKERHUB_TOKEN }}
|
||||||
|
|
||||||
|
- name: Build and push
|
||||||
|
uses: docker/bake-action@v1.6.0
|
||||||
|
with:
|
||||||
|
files: docker-bake.hcl
|
||||||
|
targets: frappe-bench
|
||||||
|
push: ${{ github.repository == 'frappe/frappe_docker' && github.event_name != 'pull_request' }}
|
||||||
|
|
||||||
|
build_main:
|
||||||
|
name: Frappe and ERPNext images
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
steps:
|
||||||
|
- uses: actions/checkout@v2
|
||||||
|
- uses: docker/setup-buildx-action@v1
|
||||||
|
|
||||||
|
- uses: docker/login-action@v1
|
||||||
|
if: github.repository == 'frappe/frappe_docker' && github.event_name != 'pull_request'
|
||||||
|
with:
|
||||||
|
username: ${{ secrets.DOCKERHUB_USERNAME }}
|
||||||
|
password: ${{ secrets.DOCKERHUB_TOKEN }}
|
||||||
|
|
||||||
|
- name: Build Frappe images
|
||||||
|
uses: docker/bake-action@v1.6.0
|
||||||
|
with:
|
||||||
|
files: docker-bake.hcl
|
||||||
|
targets: frappe-develop
|
||||||
|
load: true
|
||||||
|
|
||||||
|
- name: Build ERPNext images
|
||||||
|
uses: docker/bake-action@v1.6.0
|
||||||
|
with:
|
||||||
|
files: docker-bake.hcl
|
||||||
|
targets: erpnext-develop
|
||||||
|
load: true
|
||||||
|
|
||||||
|
- name: Test
|
||||||
|
run: ./.github/scripts/install-deps-and-test.sh
|
||||||
|
|
||||||
|
- name: Push Frappe images
|
||||||
|
if: github.repository == 'frappe/frappe_docker' && github.event_name != 'pull_request'
|
||||||
|
uses: docker/bake-action@v1.6.0
|
||||||
|
with:
|
||||||
|
files: docker-bake.hcl
|
||||||
|
targets: frappe-develop
|
||||||
|
push: true
|
||||||
|
|
||||||
|
- name: Push ERPNext images
|
||||||
|
if: github.repository == 'frappe/frappe_docker' && github.event_name != 'pull_request'
|
||||||
|
uses: docker/bake-action@v1.6.0
|
||||||
|
with:
|
||||||
|
files: docker-bake.hcl
|
||||||
|
targets: erpnext-develop
|
||||||
|
push: true
|
111
.github/workflows/build_stable.yml
vendored
Normal file
111
.github/workflows/build_stable.yml
vendored
Normal file
@ -0,0 +1,111 @@
|
|||||||
|
name: Build Stable
|
||||||
|
|
||||||
|
on:
|
||||||
|
push:
|
||||||
|
branches:
|
||||||
|
- main
|
||||||
|
paths:
|
||||||
|
- .github/**
|
||||||
|
- build/**
|
||||||
|
- installation/**
|
||||||
|
- tests/**
|
||||||
|
- .dockerignore
|
||||||
|
- docker-bake.hcl
|
||||||
|
- docker-compose.yml
|
||||||
|
- env*
|
||||||
|
|
||||||
|
# Triggered from frappe/frappe and frappe/erpnext on releases
|
||||||
|
repository_dispatch:
|
||||||
|
|
||||||
|
workflow_dispatch:
|
||||||
|
|
||||||
|
jobs:
|
||||||
|
build:
|
||||||
|
name: Frappe and ERPNext images
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
strategy:
|
||||||
|
matrix:
|
||||||
|
version: [12, 13]
|
||||||
|
|
||||||
|
steps:
|
||||||
|
- uses: actions/checkout@v2
|
||||||
|
- uses: docker/setup-buildx-action@v1
|
||||||
|
- uses: docker/login-action@v1
|
||||||
|
if: github.repository == 'frappe/frappe_docker'
|
||||||
|
with:
|
||||||
|
username: ${{ secrets.DOCKERHUB_USERNAME }}
|
||||||
|
password: ${{ secrets.DOCKERHUB_TOKEN }}
|
||||||
|
|
||||||
|
- name: Setup Frappe variables
|
||||||
|
run: ./.github/scripts/get-latest-tag.sh
|
||||||
|
env:
|
||||||
|
REPO: frappe/frappe
|
||||||
|
VERSION: ${{ matrix.version }}
|
||||||
|
|
||||||
|
- name: Build Frappe images
|
||||||
|
uses: docker/bake-action@v1.6.0
|
||||||
|
with:
|
||||||
|
files: docker-bake.hcl
|
||||||
|
targets: frappe-stable
|
||||||
|
load: true
|
||||||
|
|
||||||
|
- name: Setup ERPNext variables
|
||||||
|
run: ./.github/scripts/get-latest-tag.sh
|
||||||
|
env:
|
||||||
|
REPO: frappe/erpnext
|
||||||
|
VERSION: ${{ matrix.version }}
|
||||||
|
|
||||||
|
- name: Build ERPNext images
|
||||||
|
uses: docker/bake-action@v1.6.0
|
||||||
|
with:
|
||||||
|
files: docker-bake.hcl
|
||||||
|
targets: erpnext-stable
|
||||||
|
load: true
|
||||||
|
|
||||||
|
- name: Test
|
||||||
|
if: ${{ matrix.version != 12 }}
|
||||||
|
run: ./.github/scripts/install-deps-and-test.sh
|
||||||
|
|
||||||
|
- name: Setup Frappe variables
|
||||||
|
if: github.repository == 'frappe/frappe_docker'
|
||||||
|
run: ./.github/scripts/get-latest-tag.sh
|
||||||
|
env:
|
||||||
|
REPO: frappe/frappe
|
||||||
|
VERSION: ${{ matrix.version }}
|
||||||
|
|
||||||
|
- name: Push Frappe images
|
||||||
|
if: github.repository == 'frappe/frappe_docker'
|
||||||
|
uses: docker/bake-action@v1.6.0
|
||||||
|
with:
|
||||||
|
files: docker-bake.hcl
|
||||||
|
targets: frappe-stable
|
||||||
|
push: true
|
||||||
|
|
||||||
|
- name: Setup ERPNext variables
|
||||||
|
if: github.repository == 'frappe/frappe_docker'
|
||||||
|
run: ./.github/scripts/get-latest-tag.sh
|
||||||
|
env:
|
||||||
|
REPO: frappe/erpnext
|
||||||
|
VERSION: ${{ matrix.version }}
|
||||||
|
|
||||||
|
- name: Push ERPNext images
|
||||||
|
if: github.repository == 'frappe/frappe_docker'
|
||||||
|
uses: docker/bake-action@v1.6.0
|
||||||
|
with:
|
||||||
|
files: docker-bake.hcl
|
||||||
|
targets: erpnext-stable
|
||||||
|
push: true
|
||||||
|
|
||||||
|
- name: Setup Helm deploy key
|
||||||
|
if: github.repository == 'frappe/frappe_docker'
|
||||||
|
uses: webfactory/ssh-agent@v0.5.3
|
||||||
|
with:
|
||||||
|
ssh-private-key: ${{ secrets.HELM_DEPLOY_KEY }}
|
||||||
|
|
||||||
|
- name: Release Helm Chart
|
||||||
|
if: github.repository == 'frappe/frappe_docker'
|
||||||
|
run: |
|
||||||
|
pip install --upgrade pip
|
||||||
|
git clone git@github.com:frappe/helm.git && cd helm
|
||||||
|
pip install -r release_wizard/requirements.txt
|
||||||
|
./release_wizard/wizard 13 patch --remote origin --ci
|
193
.github/workflows/docker.yml
vendored
193
.github/workflows/docker.yml
vendored
@ -1,193 +0,0 @@
|
|||||||
name: Build
|
|
||||||
|
|
||||||
on:
|
|
||||||
push:
|
|
||||||
branches:
|
|
||||||
- main
|
|
||||||
paths:
|
|
||||||
- .github/workflows/docker.yml
|
|
||||||
- build/**
|
|
||||||
- installation/**
|
|
||||||
- tests/**
|
|
||||||
- .dockerignore
|
|
||||||
- docker-bake.hcl
|
|
||||||
- docker-compose.yml
|
|
||||||
- env*
|
|
||||||
|
|
||||||
pull_request:
|
|
||||||
branches:
|
|
||||||
- main
|
|
||||||
paths:
|
|
||||||
- .github/workflows/docker.yml
|
|
||||||
- build/**
|
|
||||||
- installation/**
|
|
||||||
- tests/**
|
|
||||||
- .dockerignore
|
|
||||||
- docker-bake.hcl
|
|
||||||
- docker-compose.yml
|
|
||||||
- env*
|
|
||||||
|
|
||||||
# Nightly builds at 12:00 am
|
|
||||||
schedule:
|
|
||||||
- cron: 0 0 * * *
|
|
||||||
|
|
||||||
repository_dispatch: # Triggered from frappe/frappe and frappe/erpnext on releases
|
|
||||||
|
|
||||||
workflow_dispatch: # Manually triggered
|
|
||||||
inputs:
|
|
||||||
version:
|
|
||||||
description: Frappe and ERPNext version. Set to "12", "13" for latest stable versions or "develop" for nightly builds.
|
|
||||||
required: true
|
|
||||||
|
|
||||||
jobs:
|
|
||||||
resolve-matrix:
|
|
||||||
name: Resolve matrix configuration
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
outputs:
|
|
||||||
matrix: ${{ steps.get-matrix.outputs.matrix }}
|
|
||||||
build-target: ${{ steps.get-build-target.outputs.build-target }}
|
|
||||||
|
|
||||||
steps:
|
|
||||||
- uses: actions/checkout@v2
|
|
||||||
|
|
||||||
- name: Get matrix
|
|
||||||
id: get-matrix
|
|
||||||
run: |
|
|
||||||
if [ $GITHUB_EVENT_NAME == "repository_dispatch" ] || [ $GITHUB_EVENT_NAME == "push" ]; then
|
|
||||||
MATRIX='[{"version": "12"}, {"version": "13"}]'
|
|
||||||
elif [ $GITHUB_EVENT_NAME == "schedule" ] || [ $GITHUB_EVENT_NAME == "pull_request" ]; then
|
|
||||||
MATRIX='[{"version": "develop"}]'
|
|
||||||
elif [ $GITHUB_EVENT_NAME == "workflow_dispatch" ]; then
|
|
||||||
MATRIX='[{"version": "${{ github.event.inputs.version }}"}]'
|
|
||||||
fi
|
|
||||||
|
|
||||||
echo ::set-output name=matrix::{\"include\":$MATRIX}
|
|
||||||
echo $MATRIX
|
|
||||||
|
|
||||||
- name: Get build target
|
|
||||||
id: get-build-target
|
|
||||||
run: |
|
|
||||||
IS_DEVELOP=$(echo $MATRIX | jq 'any(.include[].version == "develop"; .)')
|
|
||||||
if [ $IS_DEVELOP == "true" ]; then
|
|
||||||
BUILD_TARGET_SUFFIX="develop"
|
|
||||||
else
|
|
||||||
BUILD_TARGET_SUFFIX="stable"
|
|
||||||
fi
|
|
||||||
echo $BUILD_TARGET_SUFFIX
|
|
||||||
echo ::set-output name=build-target::$BUILD_TARGET_SUFFIX
|
|
||||||
env:
|
|
||||||
MATRIX: ${{ steps.get-matrix.outputs.matrix }}
|
|
||||||
|
|
||||||
build_bench:
|
|
||||||
name: Bench image
|
|
||||||
needs: resolve-matrix
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
if: needs.resolve-matrix.outputs.build-target == 'develop'
|
|
||||||
|
|
||||||
steps:
|
|
||||||
- uses: actions/checkout@v2
|
|
||||||
- uses: docker/setup-buildx-action@v1
|
|
||||||
- uses: docker/login-action@v1
|
|
||||||
if: github.event_name != 'pull_request'
|
|
||||||
with:
|
|
||||||
username: ${{ secrets.DOCKERHUB_USERNAME }}
|
|
||||||
password: ${{ secrets.DOCKERHUB_TOKEN }}
|
|
||||||
|
|
||||||
- name: Build and push
|
|
||||||
uses: docker/bake-action@v1.6.0
|
|
||||||
with:
|
|
||||||
files: docker-bake.hcl
|
|
||||||
targets: frappe-bench
|
|
||||||
push: ${{ github.event_name != 'pull_request' }}
|
|
||||||
|
|
||||||
build_main:
|
|
||||||
name: Frappe and ERPNext images
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
strategy:
|
|
||||||
matrix: ${{ fromJson(needs.resolve-matrix.outputs.matrix) }}
|
|
||||||
needs: resolve-matrix
|
|
||||||
|
|
||||||
steps:
|
|
||||||
- uses: actions/checkout@v2
|
|
||||||
- uses: docker/setup-buildx-action@v1
|
|
||||||
- uses: docker/login-action@v1
|
|
||||||
if: github.event_name != 'pull_request'
|
|
||||||
with:
|
|
||||||
username: ${{ secrets.DOCKERHUB_USERNAME }}
|
|
||||||
password: ${{ secrets.DOCKERHUB_TOKEN }}
|
|
||||||
|
|
||||||
- name: Get latest Frappe tag
|
|
||||||
if: needs.resolve-matrix.outputs.build-target == 'stable'
|
|
||||||
run: |
|
|
||||||
GIT_TAG=$(./.github/scripts/get-latest-tag.sh)
|
|
||||||
echo $GIT_TAG
|
|
||||||
echo "GIT_TAG=$GIT_TAG" >> $GITHUB_ENV
|
|
||||||
echo "GIT_BRANCH=version-$VERSION" >> $GITHUB_ENV
|
|
||||||
echo "VERSION=$VERSION" >> $GITHUB_ENV
|
|
||||||
env:
|
|
||||||
REPO: frappe/frappe
|
|
||||||
VERSION: ${{ matrix.version }}
|
|
||||||
|
|
||||||
- name: Build Frappe images
|
|
||||||
uses: docker/bake-action@v1.6.0
|
|
||||||
with:
|
|
||||||
files: docker-bake.hcl
|
|
||||||
targets: ${{ format('{0}-{1}', 'frappe', needs.resolve-matrix.outputs.build-target )}}
|
|
||||||
load: true
|
|
||||||
|
|
||||||
- name: Get latest ERPNext tag
|
|
||||||
if: needs.resolve-matrix.outputs.build-target == 'stable'
|
|
||||||
run: |
|
|
||||||
GIT_TAG=$(./.github/scripts/get-latest-tag.sh)
|
|
||||||
echo $GIT_TAG
|
|
||||||
echo "GIT_TAG=$GIT_TAG" >> $GITHUB_ENV
|
|
||||||
echo "GIT_BRANCH=version-$VERSION" >> $GITHUB_ENV
|
|
||||||
echo "VERSION=$VERSION" >> $GITHUB_ENV
|
|
||||||
env:
|
|
||||||
REPO: frappe/erpnext
|
|
||||||
VERSION: ${{ matrix.version }}
|
|
||||||
|
|
||||||
- name: Build ERPNext images
|
|
||||||
uses: docker/bake-action@v1.6.0
|
|
||||||
with:
|
|
||||||
files: docker-bake.hcl
|
|
||||||
targets: ${{ format('{0}-{1}', 'erpnext', needs.resolve-matrix.outputs.build-target )}}
|
|
||||||
load: true
|
|
||||||
|
|
||||||
- name: Install test dependencies
|
|
||||||
run: sudo apt-get install -y w3m
|
|
||||||
|
|
||||||
- name: Test
|
|
||||||
if: github.event_name == 'pull_request'
|
|
||||||
run: |
|
|
||||||
./tests/check-format.sh
|
|
||||||
./tests/docker-test.sh
|
|
||||||
# This is done to not to rebuild images in the next step
|
|
||||||
git reset --hard @{u}
|
|
||||||
|
|
||||||
- name: Push Frappe images
|
|
||||||
if: github.event_name != 'pull_request'
|
|
||||||
uses: docker/bake-action@v1.6.0
|
|
||||||
with:
|
|
||||||
files: docker-bake.hcl
|
|
||||||
targets: ${{ format('{0}-{1}', 'frappe', needs.resolve-matrix.outputs.build-target )}}
|
|
||||||
push: true
|
|
||||||
|
|
||||||
- name: Push ERPNext images
|
|
||||||
if: github.event_name != 'pull_request'
|
|
||||||
uses: docker/bake-action@v1.6.0
|
|
||||||
with:
|
|
||||||
files: docker-bake.hcl
|
|
||||||
targets: ${{ format('{0}-{1}', 'erpnext', needs.resolve-matrix.outputs.build-target )}}
|
|
||||||
push: true
|
|
||||||
|
|
||||||
- name: Release Helm Chart
|
|
||||||
if: needs.resolve-matrix.outputs.build-target == 'stable'
|
|
||||||
uses: webfactory/ssh-agent@v0.5.3
|
|
||||||
with:
|
|
||||||
ssh-private-key: ${{ secrets.HELM_DEPLOY_KEY }}
|
|
||||||
run: |
|
|
||||||
pip install --upgrade pip
|
|
||||||
git clone git@github.com:frappe/helm.git && cd helm
|
|
||||||
pip install -r release_wizard/requirements.txt
|
|
||||||
./release_wizard/wizard 13 patch --remote origin --ci
|
|
@ -1,6 +1,5 @@
|
|||||||
| Stable | [![stable](https://github.com/frappe/frappe_docker/actions/workflows/docker.yml/badge.svg?event=repository_dispatch)](https://github.com/frappe/frappe_docker/actions/workflows/docker.yml) |
|
[![Build Stable](https://github.com/frappe/frappe_docker/actions/workflows/build_stable.yml/badge.svg)](https://github.com/frappe/frappe_docker/actions/workflows/build_stable.yml)
|
||||||
|---------|-----------------------------------------------------------------------------------------------------------------------------|
|
[![Build Develop](https://github.com/frappe/frappe_docker/actions/workflows/build_develop.yml/badge.svg)](https://github.com/frappe/frappe_docker/actions/workflows/build_develop.yml)
|
||||||
| Nightly | [![nightly](https://github.com/frappe/frappe_docker/actions/workflows/docker.yml/badge.svg?event=schedule)](https://github.com/frappe/frappe_docker/actions/workflows/docker.yml) |
|
|
||||||
|
|
||||||
## Getting Started
|
## Getting Started
|
||||||
|
|
||||||
|
BIN
deploy_key.enc
BIN
deploy_key.enc
Binary file not shown.
255
frappe-installer
255
frappe-installer
@ -1,255 +0,0 @@
|
|||||||
#!/usr/bin/env bash
|
|
||||||
|
|
||||||
set -euo pipefail
|
|
||||||
IFS=$'\n\t'
|
|
||||||
|
|
||||||
[[ -z "${DEBUG}" && "${DEBUG}" == 1 ]] && set -o xtrace
|
|
||||||
|
|
||||||
__dir="$(cd "$(dirname "${BASH_SOURCE[0]}")" && pwd)"
|
|
||||||
cd "$__dir"
|
|
||||||
|
|
||||||
env_url="https://raw.githubusercontent.com/frappe/frappe_docker/master/installation/env-example"
|
|
||||||
docker_nginx_url="https://github.com/evertramos/docker-compose-letsencrypt-nginx-proxy-companion"
|
|
||||||
frappe_docker_url="https://github.com/frappe/frappe_docker"
|
|
||||||
env_file="$__dir/.env"
|
|
||||||
|
|
||||||
function check_root() {
|
|
||||||
if [[ $EUID != 0 ]]; then
|
|
||||||
echo "This script must be run as root. Login as root or use sudo." >&2
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
function check_git() {
|
|
||||||
if [[ ! -x "$(command -v git)" ]]; then
|
|
||||||
echo "Git is not installed. Please install git before continuing." >&2
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
function check_docker() {
|
|
||||||
if [[ ! -x "$(command -v docker)" ]]; then
|
|
||||||
read -rp "No docker installation found. Press Enter to install docker or ctrl+c to exit." >&2
|
|
||||||
curl -fsSL https://get.docker.com | sh
|
|
||||||
fi
|
|
||||||
if [[ ! -x "$(command -v docker)" ]]; then
|
|
||||||
echo "Docker installation failed. Exiting." >&2
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
function check_env() {
|
|
||||||
if [[ ! -f "$env_file" ]]; then
|
|
||||||
cat <<CHOOSE >&2
|
|
||||||
No environment file found. This file is required for setting up Frappe/ERPNext Docker.
|
|
||||||
Would you like to fetch the default environment file?
|
|
||||||
(NOTE: You will be prompted to set it up later)
|
|
||||||
CHOOSE
|
|
||||||
read -rp "Press Enter to fetch the configuration file, or create a .env file and re-run the script."
|
|
||||||
curl -fsSL "$env_url" -o "$env_file"
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
function clone_repository() {
|
|
||||||
echo "Cloning Repository: $1"
|
|
||||||
git clone "$2"
|
|
||||||
}
|
|
||||||
|
|
||||||
function get_config() {
|
|
||||||
if [[ -n "$2" ]]; then
|
|
||||||
config_file="$2"
|
|
||||||
else
|
|
||||||
config_file="$env_file"
|
|
||||||
fi
|
|
||||||
line=$(grep -E "^$=" "$config_file")
|
|
||||||
line_result=$(echo "$line" | awk -F"=" '{print $2}')
|
|
||||||
}
|
|
||||||
|
|
||||||
function get_install_version() {
|
|
||||||
cat <<CHOOSE >&2
|
|
||||||
Choose a version you would like to setup [current: $1]:
|
|
||||||
1. develop (edge)
|
|
||||||
2. version-12
|
|
||||||
3. version-11
|
|
||||||
Please enter your choice [1-3]:
|
|
||||||
CHOOSE
|
|
||||||
select choice in "1" "2" "3"; do
|
|
||||||
case ${choice} in
|
|
||||||
1) version="edge" ;;
|
|
||||||
2) version="version-12" ;;
|
|
||||||
3) version="version-11" ;;
|
|
||||||
esac
|
|
||||||
done
|
|
||||||
}
|
|
||||||
|
|
||||||
function prompt_config() {
|
|
||||||
# inspired by discourse_docker
|
|
||||||
get_config "VERSION"
|
|
||||||
local install_version=$line_result
|
|
||||||
get_config "MYSQL_ROOT_PASSWORD"
|
|
||||||
local mysql_password=$line_result
|
|
||||||
get_config "SITES"
|
|
||||||
local sites=$line_result
|
|
||||||
get_config "LETSENCRYPT_EMAIL"
|
|
||||||
local letsencrypt_email=$line_result
|
|
||||||
|
|
||||||
echo "Would you like to setup networking for docker? [y/n]"
|
|
||||||
echo "This is required if you wish to access the instance from other machines."
|
|
||||||
select choice in "y" "n"; do
|
|
||||||
case $choice in
|
|
||||||
y) setup_networking=1 ;;
|
|
||||||
n)
|
|
||||||
setup_networking=0
|
|
||||||
setup_letsencrypt=0
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
done
|
|
||||||
if [[ -n "$letsencrypt_email" && "$setup_networking" -ne "0" ]]; then
|
|
||||||
echo "Would you like to setup LetsEncrypt? [y/n]"
|
|
||||||
select choice in "y" "n"; do
|
|
||||||
case $choice in
|
|
||||||
y)
|
|
||||||
setup_letsencrypt=1
|
|
||||||
echo "Please ensure that all the required domains point to this IP address."
|
|
||||||
read -rp "Enter an Email Address to setup LetsEncrypt with: " letsencrypt_email
|
|
||||||
;;
|
|
||||||
n)
|
|
||||||
setup_letsencrypt=0
|
|
||||||
echo "Skipping LetsEncrypt Setup."
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
done
|
|
||||||
fi
|
|
||||||
|
|
||||||
local new_value=""
|
|
||||||
local config_state="n"
|
|
||||||
|
|
||||||
echo
|
|
||||||
|
|
||||||
get_install_version "$install_version"
|
|
||||||
install_version="$version"
|
|
||||||
|
|
||||||
while [[ "$config_state" == "n" ]]; do
|
|
||||||
if [[ -n "$mysql_password" ]]; then
|
|
||||||
read -srp "Enter MySQL Password [$mysql_password]: " new_value
|
|
||||||
if [[ -n "$new_value" ]]; then
|
|
||||||
mysql_password="$new_value"
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
|
|
||||||
if [[ -n "$sites" ]]; then
|
|
||||||
read -rp "Enter sitename to setup [$sites]: " new_value
|
|
||||||
if [[ -n "$new_value" ]]; then
|
|
||||||
sites="$new_value"
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
|
|
||||||
if [[ "$setup_letsencrypt" != "0" ]]; then
|
|
||||||
read -rp "Enter email address for LetsEncrypt [$letsencrypt_email]: " new_value
|
|
||||||
if [[ -n "$new_value" ]]; then
|
|
||||||
letsencrypt_email=$new_value
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
|
|
||||||
echo "Current Configuration:"
|
|
||||||
echo "Version: $([[ "$install_version" == "edge" ]] && echo "develop" || echo "$install_version")"
|
|
||||||
echo "MySQL Root Password: $mysql_password"
|
|
||||||
echo "Sites: $sites"
|
|
||||||
|
|
||||||
if [[ "$setup_letsencrypt" != "0" ]]; then
|
|
||||||
echo "LetsEncrypt Email Address: $letsencrypt_email"
|
|
||||||
fi
|
|
||||||
|
|
||||||
echo
|
|
||||||
echo "Does this configuration look okay?"
|
|
||||||
read -rp "Press Enter to continue, 'n' to try again, or ctrl+c to exit: " config_state
|
|
||||||
done
|
|
||||||
|
|
||||||
echo "Saving the current configuration file to $env_file"
|
|
||||||
|
|
||||||
cat <<EOF >"$env_file"
|
|
||||||
VERSION=$install_version
|
|
||||||
MYSQL_ROOT_PASSWORD=$mysql_password
|
|
||||||
SITES=$sites
|
|
||||||
$([ "$setup_letsencrypt" -ne "0" ] && echo "LETSENCRYPT_EMAIL=$letsencrypt_email")
|
|
||||||
EOF
|
|
||||||
setup_configuration=$(<"$env_file")
|
|
||||||
}
|
|
||||||
|
|
||||||
setup_user() {
|
|
||||||
echo "The rest of the setup requires a user account."
|
|
||||||
echo "You may use an existing account, or set up a new one right away."
|
|
||||||
read -rp "Enter username: " username
|
|
||||||
if grep -E "^$username" /etc/passwd >/dev/null; then
|
|
||||||
echo "User $username already exists."
|
|
||||||
else
|
|
||||||
read -rsp "Enter password: " password
|
|
||||||
password="$(perl -e 'print crypt($ARGV[0], "password")' "$password")"
|
|
||||||
if useradd -m -p "$password" "$username" -s "$(command -v bash)"; then
|
|
||||||
echo "User $username has been added to the system."
|
|
||||||
else
|
|
||||||
echo "Failed to add user to the system."
|
|
||||||
echo "Please add a user manually and re-run the script."
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
|
|
||||||
if ! getent group docker >/dev/null 2>&1; then
|
|
||||||
echo "Creating group: docker"
|
|
||||||
groupadd docker
|
|
||||||
fi
|
|
||||||
echo "Adding user $username to group: docker"
|
|
||||||
usermod -aG docker "$username"
|
|
||||||
newgrp docker
|
|
||||||
}
|
|
||||||
|
|
||||||
install() {
|
|
||||||
if [[ "$setup_letsencrypt" != "0" && "$setup_networking" != "0" ]]; then
|
|
||||||
echo "Setting up NGINX Proxy for LetsEncrypt"
|
|
||||||
clone_repository "Docker Compose LetsEncrypt NGINX Proxy Companion" "$docker_nginx_url"
|
|
||||||
cd "$(basename "$docker_nginx_url")"
|
|
||||||
if [[ -f .env.sample ]]; then
|
|
||||||
cp .env.sample env
|
|
||||||
fi
|
|
||||||
./start.sh >/dev/null 2>&1
|
|
||||||
cd "$(eval echo ~"$username")"
|
|
||||||
fi
|
|
||||||
|
|
||||||
echo "Setting up Frappe/ERPNext"
|
|
||||||
clone_repository "Frappe/ERPNext Docker" "$frappe_docker_url"
|
|
||||||
cd "$(basename "$frappe_docker_url")"
|
|
||||||
echo "$setup_configuration" >.env
|
|
||||||
echo "Enter a name for the project."
|
|
||||||
read -rp "This project name will be used to setup the docker instance: [erpnext_docker]" project_name
|
|
||||||
if [[ -z "$project_name" ]]; then
|
|
||||||
echo "Setting the project name to erpnext_docker"
|
|
||||||
project_name="erpnext_docker"
|
|
||||||
fi
|
|
||||||
|
|
||||||
docker-compose \
|
|
||||||
--project-name "$project_name" \
|
|
||||||
--project-directory . up -d \
|
|
||||||
-f installation/docker-compose-frappe.yml \
|
|
||||||
-f installation/docker-compose-erpnext.yml \
|
|
||||||
-f installation/docker-compose-common.yml \
|
|
||||||
"$( ((setup_networking == 1)) && printf %s '-f installation/docker-compose-networks.yml')"
|
|
||||||
|
|
||||||
get_config "SITES" "$(pwd)/.env"
|
|
||||||
local sites=$line_result
|
|
||||||
|
|
||||||
docker exec \
|
|
||||||
-e "SITE_NAME=$sites" \
|
|
||||||
-e "INSTALL_ERPNEXT=1" \
|
|
||||||
-it "$project_name"_erpnext-python_1 docker-entrypoint.sh new
|
|
||||||
|
|
||||||
echo "Installation Complete!"
|
|
||||||
}
|
|
||||||
|
|
||||||
check_root
|
|
||||||
check_git
|
|
||||||
check_docker
|
|
||||||
check_env
|
|
||||||
|
|
||||||
prompt_config
|
|
||||||
setup_user
|
|
||||||
install
|
|
Loading…
Reference in New Issue
Block a user