From 656386c44b1d482fe03ea8aa8e7406e8a3fb3ec6 Mon Sep 17 00:00:00 2001 From: pzdge23 Date: Mon, 9 Oct 2017 08:45:52 +0530 Subject: [PATCH] added init option --- dbench | 23 +++++++++++++++++++---- 1 file changed, 19 insertions(+), 4 deletions(-) diff --git a/dbench b/dbench index 9e339a66..d51a3e8d 100755 --- a/dbench +++ b/dbench @@ -4,13 +4,27 @@ display_usage() { echo "$(basename "$0") [-h] [-c \"\"]" echo '' echo 'where:' - echo ' -h show this help text' - echo ' -c execute a command inside docker using docker exec' - echo ' -s adds site-names to /etc/hosts file in the container to facilitate multisite access' + echo ' -h show this help text' + echo ' -c execute a command inside docker using docker exec' + echo ' -s adds site-names to /etc/hosts file in the container to facilitate multisite access' + echo ' init initializes frappe-bench adds a new-site bench-manager.local and installs the bench_manager app + app onto it' } if [[ $# -eq 0 ]]; then docker exec -it frappe bash + +elif [ $1 == 'init' ] +then + docker exec -i -u root frappe bash -c "cd /home/frappe && chown -R frappe:frappe ./*" + docker exec -it frappe bash -c "cd .. && bench init frappe-bench --skip-bench-mkdir --skip-redis-config-generation && cd frappe-bench" + docker exec -it frappe bash -c "mv Procfile_docker Procfile && mv sites/common_site_config_docker.json sites/common_site_config.json" + docker exec -it -u root frappe bash -c "apt-get install vim && apt-get install sudo && usermod -aG sudo frappe && printf '# User rules for frappe\nfrappe ALL=(ALL) NOPASSWD:ALL' >> /etc/sudoers.d/frappe" + docker exec -it frappe bash -c "bench set-mariadb-host mariadb" + docker exec -it frappe bash -c "bench new-site bench-manager.local" + docker exec -it frappe bash -c "bench get-app bench_manager https://github.com/frappe/bench_manager" + docker exec -it frappe bash -c "bench --site bench-manager.local install-app bench_manager" + else while getopts ':hsc:' option; do case "$option" in @@ -19,7 +33,7 @@ else exit ;; c) - docker exec frappe bash -c "bench $OPTARG" + docker exec -it frappe bash -c "bench $OPTARG" ;; s) a=$(cd frappe-bench && ls sites/*/site_config.json | grep -o '/.\+/') @@ -28,6 +42,7 @@ else result="127.0.0.1 ${a}" echo $result docker exec -u root -i frappe bash -c "echo ${result} | tee --append /etc/hosts" + docker exec -itu root frappe bash -c "printf '# User rules for frappe\nfrappe ALL=(ALL) NOPASSWD:ALL' >> /etc/sudoers.d/frappe" ;; \?) echo "Invalid option: -$OPTARG" >&2