|  | 
|  | 1 | +#!/usr/bin/env bash | 
|  | 2 | +basefile="install" | 
|  | 3 | +logfile="general.log" | 
|  | 4 | +timestamp=`date '+%Y-%m-%d %H:%M:%S'` | 
|  | 5 | + | 
|  | 6 | +if [ "$#" -ne 1 ]; then | 
|  | 7 | + msg="[ERROR]: $basefile failed to receive enough args" | 
|  | 8 | + echo "$msg" | 
|  | 9 | + echo "$msg" >> $logfile | 
|  | 10 | + exit 1 | 
|  | 11 | +fi | 
|  | 12 | + | 
|  | 13 | +function setup-logging(){ | 
|  | 14 | + scope="setup-logging" | 
|  | 15 | + info_base="[$timestamp INFO]: $basefile::$scope" | 
|  | 16 | + | 
|  | 17 | + echo "$info_base started" >> $logfile | 
|  | 18 | + | 
|  | 19 | + echo "$info_base removing old logs" >> $logfile | 
|  | 20 | + | 
|  | 21 | + rm -f $logfile | 
|  | 22 | + | 
|  | 23 | + echo "$info_base ended" >> $logfile | 
|  | 24 | + | 
|  | 25 | + echo "================" >> $logfile | 
|  | 26 | +} | 
|  | 27 | + | 
|  | 28 | +function root-check(){ | 
|  | 29 | + scope="root-check" | 
|  | 30 | + info_base="[$timestamp INFO]: $basefile::$scope" | 
|  | 31 | + | 
|  | 32 | + echo "$info_base started" >> $logfile | 
|  | 33 | + | 
|  | 34 | + #Make sure the script is running as root. | 
|  | 35 | + if [ "$UID" -ne "0" ]; then | 
|  | 36 | + echo "[$timestamp ERROR]: $basefile::$scope you must be root to run 0ドル" >> $logfile | 
|  | 37 | + echo "==================" >> $logfile | 
|  | 38 | + echo "You must be root to run 0ドル. Try the following" | 
|  | 39 | + echo "sudo 0ドル" | 
|  | 40 | + exit 1 | 
|  | 41 | + fi | 
|  | 42 | + | 
|  | 43 | + echo "$info_base ended" >> $logfile | 
|  | 44 | + echo "================" >> $logfile | 
|  | 45 | +} | 
|  | 46 | + | 
|  | 47 | +function docker-check() { | 
|  | 48 | + scope="docker-check" | 
|  | 49 | + info_base="[$timestamp INFO]: $basefile::$scope" | 
|  | 50 | + cmd=`docker -v` | 
|  | 51 | + | 
|  | 52 | + echo "$info_base started" >> $logfile | 
|  | 53 | + | 
|  | 54 | + if [ -z "$cmd" ]; then | 
|  | 55 | + echo "$info_base docker not installed" | 
|  | 56 | + echo "$info_base docker not installed" >> $logfile | 
|  | 57 | + fi | 
|  | 58 | + | 
|  | 59 | + echo "$info_base ended" >> $logfile | 
|  | 60 | + echo "================" >> $logfile | 
|  | 61 | + | 
|  | 62 | +} | 
|  | 63 | + | 
|  | 64 | +function docker-compose-check() { | 
|  | 65 | + scope="docker-compose-check" | 
|  | 66 | + info_base="[$timestamp INFO]: $basefile::$scope" | 
|  | 67 | + cmd=`docker-compose -v` | 
|  | 68 | + | 
|  | 69 | + echo "$info_base started" >> $logfile | 
|  | 70 | + | 
|  | 71 | + if [ -z "$cmd" ]; then | 
|  | 72 | + echo "$info_base docker-compose not installed" | 
|  | 73 | + echo "$info_base docker-compose not installed" >> $logfile | 
|  | 74 | + fi | 
|  | 75 | + | 
|  | 76 | + echo "$info_base ended" >> $logfile | 
|  | 77 | + echo "================" >> $logfile | 
|  | 78 | + | 
|  | 79 | +} | 
|  | 80 | +function usage() { | 
|  | 81 | + echo "" | 
|  | 82 | + echo "Usage: " | 
|  | 83 | + echo "" | 
|  | 84 | + echo "-u: start." | 
|  | 85 | + echo "-d: tear down." | 
|  | 86 | + echo "-h: Display this help and exit." | 
|  | 87 | + echo "" | 
|  | 88 | +} | 
|  | 89 | + | 
|  | 90 | +function start-up(){ | 
|  | 91 | + | 
|  | 92 | + local scope="start-up" | 
|  | 93 | + local docker_img_name=`head -n 1 README.md | sed 's/# //'` | 
|  | 94 | + local info_base="[$timestamp INFO]: $basefile::$scope" | 
|  | 95 | + | 
|  | 96 | + echo "$info_base started" >> $logfile | 
|  | 97 | + | 
|  | 98 | + echo "$info_base starting services" >> $logfile | 
|  | 99 | + | 
|  | 100 | + sudo docker-compose up --build | 
|  | 101 | + | 
|  | 102 | + echo "$info_base ended" >> $logfile | 
|  | 103 | + | 
|  | 104 | + echo "================" >> $logfile | 
|  | 105 | +} | 
|  | 106 | +function tear-down(){ | 
|  | 107 | + | 
|  | 108 | + scope="tear-down" | 
|  | 109 | + info_base="[$timestamp INFO]: $basefile::$scope" | 
|  | 110 | + | 
|  | 111 | + echo "$info_base started" >> $logfile | 
|  | 112 | + | 
|  | 113 | + echo "$info_base starting services" >> $logfile | 
|  | 114 | + | 
|  | 115 | + sudo docker-compose down | 
|  | 116 | + | 
|  | 117 | + echo "$info_base ended" >> $logfile | 
|  | 118 | + | 
|  | 119 | + echo "================" >> $logfile | 
|  | 120 | +} | 
|  | 121 | + | 
|  | 122 | +root-check | 
|  | 123 | +docker-check | 
|  | 124 | +docker-compose-check | 
|  | 125 | + | 
|  | 126 | +while getopts ":udh" opts; do | 
|  | 127 | + case $opts in | 
|  | 128 | + u) | 
|  | 129 | + setup-logging | 
|  | 130 | + start-up ;; | 
|  | 131 | + d) | 
|  | 132 | + tear-down ;; | 
|  | 133 | + h) | 
|  | 134 | + usage | 
|  | 135 | + exit 0 ;; | 
|  | 136 | + /?) | 
|  | 137 | + usage | 
|  | 138 | + exit 1 ;; | 
|  | 139 | + esac | 
|  | 140 | +done | 
0 commit comments