Skip to content
Snippets Groups Projects
Commit 68aa0a41 authored by Hahn Axel (hahn)'s avatar Hahn Axel (hahn)
Browse files

update docker init

parent 0d868629
Branches
No related tags found
1 merge request!14Update renderer class
...@@ -11,6 +11,9 @@ ...@@ -11,6 +11,9 @@
# 2022-12-20 v1.4 <axel.hahn@unibe.ch> replace fgrep with grep -F # 2022-12-20 v1.4 <axel.hahn@unibe.ch> replace fgrep with grep -F
# 2023-03-06 v1.5 <www.axel-hahn.de> up with and without --build # 2023-03-06 v1.5 <www.axel-hahn.de> up with and without --build
# 2023-08-17 v1.6 <www.axel-hahn.de> menu selection with single key (without return) # 2023-08-17 v1.6 <www.axel-hahn.de> menu selection with single key (without return)
# 2023-11-10 v1.7 <axel.hahn@unibe.ch> replace docker-compose with "docker compose"
# 2023-11-13 v1.8 <axel.hahn@unibe.ch> UNDO "docker compose"; update infos
# 2023-11-15 v1.9 <axel.hahn@unibe.ch> add help; execute multiple actions by params; new menu item: open app
# ====================================================================== # ======================================================================
cd $( dirname $0 ) cd $( dirname $0 )
...@@ -19,7 +22,7 @@ cd $( dirname $0 ) ...@@ -19,7 +22,7 @@ cd $( dirname $0 )
# git@git-repo.iml.unibe.ch:iml-open-source/docker-php-starterkit.git # git@git-repo.iml.unibe.ch:iml-open-source/docker-php-starterkit.git
selfgitrepo="docker-php-starterkit.git" selfgitrepo="docker-php-starterkit.git"
_version="1.6" _version="1.9"
# ---------------------------------------------------------------------- # ----------------------------------------------------------------------
# FUNCTIONS # FUNCTIONS
...@@ -37,6 +40,61 @@ function h3(){ ...@@ -37,6 +40,61 @@ function h3(){
echo -e "\e[34m----- $*\e[0m" echo -e "\e[34m----- $*\e[0m"
} }
# show help for param -h
function showMenu(){
echo " $( _key g ) - remove git data of starterkit"
echo
echo " $( _key i ) - init application: set permissions"
echo " $( _key t ) - generate files from templates"
echo " $( _key T ) - remove generated files"
echo
echo " $( _key u ) - startup containers docker-compose ... up -d"
echo " $( _key U ) - startup containers docker-compose ... up -d --build"
echo " $( _key s ) - shutdown containers docker-compose stop"
echo " $( _key r ) - remove containers docker-compose rm -f"
echo
echo " $( _key m ) - more infos"
echo " $( _key o ) - open app [${APP_NAME}] $frontendurl"
echo " $( _key c ) - console (bash)"
echo
echo " $( _key q ) - quit"
}
function showHelp(){
local _self=$( basename "$0" )
cat <<EOH
INITIALIZER FOR DOCKER APP v$_version
A helper script written in Bash to bring up a PHP+Mysql application in docker.
Source : https://git-repo.iml.unibe.ch/iml-open-source/docker-php-starterkit
Docs : https://os-docs.iml.unibe.ch/docker-php-starterkit/
License: GNU GPL 3.0
(c) Institute for Medical Education; University of Bern
SYNTAX:
$_self [-h|-v]
$_self [menu key]
OPTIONS:
-h show this help and exit
-v show version exit
MENU KEYS:
In the interactive menu are some keys to init an action.
The same keys can be put as parameter to start this action.
You can add multiples keys to apply multiple actions.
$( showMenu )
EXAMPLES:
$_self starts interactive mode
$_self u bring up docker container(s) and stay in interactive mode
$_self i q set write permissions and quit
EOH
}
# function _gitinstall(){ # function _gitinstall(){
# h2 "install/ update app from git repo ${gitrepo} in ${gittarget} ..." # h2 "install/ update app from git repo ${gitrepo} in ${gittarget} ..."
# test -d ${gittarget} && ( cd ${gittarget} && git pull ) # test -d ${gittarget} && ( cd ${gittarget} && git pull )
...@@ -189,6 +247,7 @@ function _removeGeneratedFiles(){ ...@@ -189,6 +247,7 @@ function _removeGeneratedFiles(){
done done
} }
# show running containers
function _showContainers(){ function _showContainers(){
local bLong=$1 local bLong=$1
h2 CONTAINERS h2 CONTAINERS
...@@ -200,7 +259,16 @@ function _showContainers(){ ...@@ -200,7 +259,16 @@ function _showContainers(){
} }
# a bit stupid ... i think I need to delete it. # show urls for app container
function _showBrowserurl(){
echo "In a web browser open:"
echo " $frontendurl"
if grep "${APP_NAME}-server" /etc/hosts >/dev/null; then
echo " https://${APP_NAME}-server/"
fi
}
# detect + show ports and urls for app container and db container
function _showInfos(){ function _showInfos(){
_showContainers long _showContainers long
h2 INFO h2 INFO
...@@ -212,19 +280,20 @@ function _showInfos(){ ...@@ -212,19 +280,20 @@ function _showInfos(){
>/dev/tcp/localhost/${APP_PORT} 2>/dev/null && ( >/dev/tcp/localhost/${APP_PORT} 2>/dev/null && (
echo "OK, app port ${APP_PORT} is reachable" echo "OK, app port ${APP_PORT} is reachable"
echo echo
echo "In a web browser open:" _showBrowserurl
echo " $frontendurl"
) )
h3 "Check database port" if [ "$DB_ADD" != "false" ]; then
>/dev/tcp/localhost/${DB_PORT} 2>/dev/null && ( h3 "Check database port"
echo "OK, db port ${DB_PORT} is reachable" >/dev/tcp/localhost/${DB_PORT} >/dev/null 2>&1 && (
echo echo "OK, db port ${DB_PORT} is reachable"
echo
)
echo "In a local DB admin tool:" echo "In a local DB admin tool:"
echo " host : localhost" echo " host : localhost"
echo " port : ${DB_PORT}" echo " port : ${DB_PORT}"
echo " user : root" echo " user : root"
echo " password: ${MYSQL_ROOT_PASS}" echo " password: ${MYSQL_ROOT_PASS}"
) fi
echo echo
} }
...@@ -235,39 +304,26 @@ function _key(){ ...@@ -235,39 +304,26 @@ function _key(){
# helper: wait for a return key # helper: wait for a return key
function _wait(){ function _wait(){
echo -n "... press RETURN > "; read -r echo -n "... press RETURN > "; read -r -t 15
} }
# ---------------------------------------------------------------------- # ----------------------------------------------------------------------
# MAIN # MAIN
# ---------------------------------------------------------------------- # ----------------------------------------------------------------------
action=$1 action=$1; shift 1
while true; do while true; do
echo
echo -e "\e[32m===== INITIALIZER FOR DOCKER APP [$APP_NAME] v$_version ===== \e[0m\n\r"
if [ -z "$action" ]; then if [ -z "$action" ]; then
echo
echo -e "\e[32m===== INITIALIZER FOR DOCKER APP [$APP_NAME] v$_version ===== \e[0m\n\r"
_showContainers _showContainers
h2 MENU h2 MENU
echo " $( _key g ) - remove git data of starterkit" showMenu
echo
echo " $( _key i ) - init application: set permissions"
echo " $( _key t ) - generate files from templates"
echo " $( _key T ) - remove generated files"
echo
echo " $( _key u ) - startup containers docker-compose ... up -d"
echo " $( _key U ) - startup containers docker-compose ... up -d --build"
echo " $( _key s ) - shutdown containers docker-compose stop"
echo " $( _key r ) - remove containers docker-compose rm -f"
echo
echo " $( _key m ) - more infos"
echo " $( _key c ) - console (bash)"
echo
echo " $( _key q ) - quit"
echo echo
echo -n " select >" echo -n " select >"
read -rn 1 action read -rn 1 action
...@@ -275,6 +331,8 @@ while true; do ...@@ -275,6 +331,8 @@ while true; do
fi fi
case "$action" in case "$action" in
"-h") showHelp; exit 0 ;;
"-v") echo $(basename $0) $_version; exit 0 ;;
g) g)
_removeGitdata _removeGitdata
;; ;;
...@@ -289,24 +347,19 @@ while true; do ...@@ -289,24 +347,19 @@ while true; do
_removeGeneratedFiles _removeGeneratedFiles
rm -rf containers rm -rf containers
;; ;;
# not in the menu
# f)
# _removeGeneratedFiles
# _generateFiles
# _wait
# ;;
m) m)
_showInfos _showInfos
_wait _wait
;; ;;
u|U) u|U)
h2 "Bring up..."
dockerUp="docker-compose -p "$APP_NAME" --verbose up -d --remove-orphans" dockerUp="docker-compose -p "$APP_NAME" --verbose up -d --remove-orphans"
if [ "$action" = "U" ]; then if [ "$action" = "U" ]; then
dockerUp+=" --build" dockerUp+=" --build"
fi fi
echo "$dockerUp"
if $dockerUp; then if $dockerUp; then
echo "In a web browser:" _showBrowserurl
echo " $frontendurl"
else else
echo "ERROR: docker-compose up failed :-/" echo "ERROR: docker-compose up failed :-/"
docker-compose -p "$APP_NAME" logs | tail docker-compose -p "$APP_NAME" logs | tail
...@@ -316,24 +369,32 @@ while true; do ...@@ -316,24 +369,32 @@ while true; do
_wait _wait
;; ;;
s) s)
h2 "Stopping..."
docker-compose -p "$APP_NAME" stop docker-compose -p "$APP_NAME" stop
;; ;;
r) r)
h2 "Removing..."
docker-compose -p "$APP_NAME" rm -f docker-compose -p "$APP_NAME" rm -f
;; ;;
c) c)
h2 "Console"
docker ps docker ps
echo -n "id or name >" echo -n "id or name >"
read dockerid read dockerid
test -z "$dockerid" || docker exec -it $dockerid /bin/bash test -z "$dockerid" || docker exec -it $dockerid /bin/bash
;; ;;
o)
h2 "Open app ..."
xdg-open "$frontendurl"
;;
q) q)
h2 "Bye!"
exit 0; exit 0;
;; ;;
*) *)
test -n "$action" && ( echo " ACTION FOR [$action] NOT IMPLEMENTED."; sleep 1 ) test -n "$action" && ( echo " ACTION FOR [$action] NOT IMPLEMENTED."; sleep 1 )
esac esac
action= action=$1; shift 1
done done
......
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Please register or to comment