mirror of
				https://github.com/iiab/iiab.git
				synced 2025-03-09 15:40:17 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			150 lines
		
	
	
	
		
			5.5 KiB
		
	
	
	
		
			Bash
		
	
	
		
			Executable file
		
	
	
	
	
			
		
		
	
	
			150 lines
		
	
	
	
		
			5.5 KiB
		
	
	
	
		
			Bash
		
	
	
		
			Executable file
		
	
	
	
	
| #!/bin/bash
 | |
| 
 | |
| DEFAULT_VARS_FILE=/opt/iiab/iiab/vars/default_vars.yml
 | |
| LOCAL_VARS_FILE=/etc/iiab/local_vars.yml
 | |
| IIAB_STATE_FILE=/etc/iiab/iiab_state.yml
 | |
| ROLE_VAR=""
 | |
| INSTALL=false
 | |
| ENABLED=false
 | |
| REINSTALL=false
 | |
| CWD=`pwd`
 | |
| #ARGS="--extra-vars {"
 | |
| ARGS="--extra-vars {\"skip_role_on_error\":False,"    # bash forces {...} to '{...}' for Ansible, SEE BOTTOM (IFS-like issue)
 | |
| INVENTORY=ansible_hosts
 | |
| PLAYBOOK=run-one-role.yml
 | |
| 
 | |
| if [ ! -f $PLAYBOOK ]; then
 | |
|     echo "Exiting: IIAB Playbook not found."
 | |
|     echo "Please run this in /opt/iiab/iiab (top level of git repo)."
 | |
|     exit 1
 | |
| fi
 | |
| 
 | |
| if [ $# -eq 0 ] || [ "$2" == "--reinstall" ] || [ "$3" == "--reinstall" ]; then
 | |
|     echo "Usage: ./runrole <name of role>"
 | |
|     echo "Usage: ./runrole --reinstall <name of role>"
 | |
|     echo
 | |
|     echo "Optional 2nd parameter is full PATH/FILENAME for logging."
 | |
|     echo "If omitted, <current directory>/iiab-debug.log is used."
 | |
|     exit 0
 | |
| fi
 | |
| 
 | |
| if [ "$1" == "--reinstall" ]; then
 | |
|     ARGS="$ARGS\"reinstall\":True,"    # Needs boolean not string so use JSON list
 | |
|     REINSTALL=true
 | |
|     shift
 | |
| fi
 | |
| 
 | |
| 
 | |
| # 4 snippets to guide -> bootstrap -> accelerate role debugging on bare OS's:
 | |
| 
 | |
| mkdir -p /etc/iiab    # -p avoids errors, effectively like '|| true'
 | |
| if [ ! -f /etc/iiab/local_vars.yml ]; then
 | |
|     echo -e "\n\e[1mEXITING: /opt/iiab/iiab/runrole REQUIRES /etc/iiab/local_vars.yml\e[0m\n" >&2
 | |
| 
 | |
|     echo -e "(1) See http://FAQ.IIAB.IO -> What is local_vars.yml and how do I customize it?" >&2
 | |
|     echo -e "(2) SMALL/MEDIUM/LARGE samples are included in /opt/iiab/iiab/vars" >&2
 | |
|     echo -e "(3) NO TIME FOR DETAILS?  RUN INTERNET-IN-A-BOX'S FRIENDLY 1-LINE INSTALLER:\n" >&2
 | |
| 
 | |
|     echo -e '    https://download.iiab.io\n' >&2
 | |
| 
 | |
|     exit 1
 | |
| fi
 | |
| 
 | |
| # In comparison, ./iiab-network and ./iiab-configure warn operators (IN RED)
 | |
| # if run without the existence of /etc/iiab/iiab_state.yml
 | |
| if [ ! -f  $IIAB_STATE_FILE ]; then    # touch $IIAB_STATE_FILE
 | |
|     echo -e "\n\e[1mCreating... $IIAB_STATE_FILE\e[0m"
 | |
|     cat > $IIAB_STATE_FILE << EOF
 | |
| # DO *NOT* MANUALLY EDIT THIS, THANKS!
 | |
| # IIAB does NOT currently support uninstalling apps/services.
 | |
| 
 | |
| EOF
 | |
| fi
 | |
| 
 | |
| if ! [[ $(command -v ansible) ]]; then
 | |
|     echo -e "\n\e[1mPlease install Ansible, by running:\n\nsudo /opt/iiab/iiab/scripts/ansible\e[0m\n"
 | |
|     exit 1
 | |
| fi
 | |
| 
 | |
| mkdir -p /etc/ansible/facts.d
 | |
| cp scripts/local_facts.fact /etc/ansible/facts.d/local_facts.fact
 | |
| 
 | |
| 
 | |
| ROLE_VAR=$1    # Ansible role name & var name sometimes differ :/
 | |
| if [ $1 == "calibre-web" ]; then 
 | |
|     ROLE_VAR=calibreweb
 | |
| elif [ $1 == "httpd" ]; then
 | |
|     ROLE_VAR=apache
 | |
| elif [ $1 == "osm-vector-maps" ]; then
 | |
|     ROLE_VAR=osm_vector_maps
 | |
| fi
 | |
| 
 | |
| echo
 | |
| if $REINSTALL; then   # Add '_' so '--reinstall calibre' doesn't zap calibreweb
 | |
|     if grep -q "^${ROLE_VAR}_" $IIAB_STATE_FILE; then
 | |
|         echo -e "\e[1mThese line(s) in $IIAB_STATE_FILE are now being deleted:\e[0m\n"
 | |
|         grep "^${ROLE_VAR}_" $IIAB_STATE_FILE; echo
 | |
|         sed -i "/^${ROLE_VAR}_/d" $IIAB_STATE_FILE
 | |
|     else
 | |
|         echo -e "\e[1mERROR: $IIAB_STATE_FILE has no line(s) that begin with '${ROLE_VAR}_'\e[0m\n"
 | |
|         echo -e "Try again without the '--reinstall' flag?\n"
 | |
|         exit 1
 | |
|     fi
 | |
| else
 | |
|     if grep -q "^${ROLE_VAR}_" $IIAB_STATE_FILE; then
 | |
|         echo -e "\e[1mWARNING: $IIAB_STATE_FILE already has these line(s):\e[0m\n"
 | |
|         grep "^${ROLE_VAR}_" $IIAB_STATE_FILE; echo
 | |
|         echo -e "If you prefer to reinstall it, run: ./runrole --reinstall $1\n"
 | |
| 
 | |
|         grep -q "^${ROLE_VAR}_enabled:\s\+[Tt]rue\b" $DEFAULT_VARS_FILE && ENABLED=true
 | |
|         grep -q "^${ROLE_VAR}_enabled:\s\+[Ff]alse\b" $LOCAL_VARS_FILE && ENABLED=false
 | |
|         grep -q "^${ROLE_VAR}_enabled:\s\+[Tt]rue\b" $LOCAL_VARS_FILE && ENABLED=true
 | |
|         if $ENABLED; then
 | |
|             echo -n "Or just continue, to enforce var '${ROLE_VAR}_enabled: True' etc? [Y/n] "
 | |
|         else
 | |
|             echo -n "Or just continue, to enforce var '${ROLE_VAR}_enabled: False' etc? [Y/n] "
 | |
|         fi
 | |
|         read ans < /dev/tty
 | |
|         echo
 | |
|         [ "$ans" = "n" ] || [ "$ans" = "N" ] &&
 | |
|             exit 1
 | |
|     fi
 | |
| fi
 | |
| 
 | |
| grep -q "^${ROLE_VAR}_install:\s\+[Tt]rue\b" $DEFAULT_VARS_FILE && INSTALL=true
 | |
| grep -q "^${ROLE_VAR}_install:\s\+[Ff]alse\b" $LOCAL_VARS_FILE && INSTALL=false
 | |
| grep -q "^${ROLE_VAR}_install:\s\+[Tt]rue\b" $LOCAL_VARS_FILE && INSTALL=true
 | |
| if ! $INSTALL; then
 | |
|     echo -e "\e[1m'${ROLE_VAR}_install: True' MUST BE SET!\e[0m\n"
 | |
|     echo -e "Usually it's best to set variables in: $LOCAL_VARS_FILE\n"
 | |
|     echo -n "Just for now, force '${ROLE_VAR}_install: True' directly to Ansible? [Y/n] "
 | |
|     read ans < /dev/tty
 | |
|     echo
 | |
|     [ "$ans" = "n" ] || [ "$ans" = "N" ] &&
 | |
|         exit 1
 | |
|     ARGS="$ARGS\"${ROLE_VAR}_install\":True,"
 | |
| fi
 | |
| 
 | |
| 
 | |
| if [ $# -eq 2 ]; then
 | |
|    export ANSIBLE_LOG_PATH="$2"
 | |
| else
 | |
|    export ANSIBLE_LOG_PATH="$CWD/iiab-debug.log"
 | |
| fi
 | |
| 
 | |
| ARGS="$ARGS\"role_to_run\":\"$1\"}"    # $1 works like \"$1\" if str type validated
 | |
| CMD="ansible-playbook -i $INVENTORY $PLAYBOOK --connection=local $ARGS"
 | |
| echo -e "\e[1mbash will now run this, adding single quotes around the {...} curly braces:\e[0m\n\n$CMD\n"
 | |
| ansible -m setup -i $INVENTORY localhost --connection=local | grep python
 | |
| $CMD
 | |
| 
 | |
| # bash forces (NECESSARY) single quotes around {} at runtime (if $ARGS contains
 | |
| # curly braces).  If you also add single quotes *within* $ARGS, Ansible will
 | |
| # FAIL as you will end up with 2-not-1 single-quotes on each side of the {}.
 | |
| # https://docs.ansible.com/ansible/latest/user_guide/playbooks_variables.html#json-string-format
 | |
| #
 | |
| # Change the top line of this file to 'bash -x' to see this happen live.  Or,
 | |
| # if you prefer the single quotes in the $ARGS var itself, run it this way:
 | |
| #
 | |
| # echo $CMD > /tmp/runrole-ansible-cmd
 | |
| # bash /tmp/runrole-ansible-cmd
 |