Compare commits
	
		
			26 Commits
		
	
	
		
			5b749d2100
			...
			dev
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| 0920493634 | |||
| 03b8169401 | |||
| cfc2694737 | |||
| fca20b31bd | |||
| 1f4abd2d6c | |||
| a42d1d05df | |||
| 07d1adc926 | |||
| 71ca410123 | |||
| c46c78519b | |||
| 816a0d4f69 | |||
| f8a60b4287 | |||
| a7f395a62a | |||
| f02aec2cdb | |||
| a94959bcf9 | |||
| 5004250f85 | |||
| 4c4d4bbef7 | |||
| d32b636a99 | |||
| a7083733cc | |||
| 97ddcc4573 | |||
| dc2ae57bd6 | |||
| 82ab31b9ea | |||
| 49ababedc5 | |||
| 0d3931d738 | |||
| 7c93f25a5d | |||
| 8445b64d6b | |||
| 8dfb3fe2a6 | 
							
								
								
									
										85
									
								
								setup.sh
									
									
									
									
									
								
							
							
						
						
									
										85
									
								
								setup.sh
									
									
									
									
									
								
							| @@ -9,13 +9,18 @@ LOCAL=$DIR/local.yml | |||||||
| URL="https://git.hyperling.com/me/env-ansible" | URL="https://git.hyperling.com/me/env-ansible" | ||||||
| BRANCH="main" | BRANCH="main" | ||||||
|  |  | ||||||
|  | config_dir="/usr/local/etc/hyperling-scm" | ||||||
|  | general_config="$config_dir/general.ini" | ||||||
|  | workstation_config="$config_dir/workstation.ini" | ||||||
|  | server_config="$config_dir/server.ini" | ||||||
|  |  | ||||||
| ## Functions ## | ## Functions ## | ||||||
|  |  | ||||||
| # Accepts 1 parameter, it is used as the exit status. | # Accepts 1 parameter, it is used as the exit status. | ||||||
| function usage { | function usage { | ||||||
| 	cat <<- EOF | 	cat <<- EOF | ||||||
|  |  | ||||||
| 	  $PROG [-l] [-b branch_name] [-h] | 	  $PROG [-l] [-b branch_name] [-g] [-w] [-s] [-h] | ||||||
| 	    Program to initialize synchronization with Hyperling's Ansible configuration. | 	    Program to initialize synchronization with Hyperling's Ansible configuration. | ||||||
| 	      $URL | 	      $URL | ||||||
|  |  | ||||||
| @@ -23,7 +28,10 @@ function usage { | |||||||
| 	      -l : Run the local playbook associated with this $PROG. | 	      -l : Run the local playbook associated with this $PROG. | ||||||
| 	             This is helpful for development or just saving bandwidth. | 	             This is helpful for development or just saving bandwidth. | ||||||
| 	             It also provides prettier colors than the plaintext from ansible-pull. ;) | 	             It also provides prettier colors than the plaintext from ansible-pull. ;) | ||||||
| 	      -b branch_name: Download and run a specific branch. Default is $BRANCH. | 	      -b branch_name : Download and run a specific branch. Default is $BRANCH. | ||||||
|  | 	      -g : Enable the General config with test contents. | ||||||
|  | 	      -w : Enable the Workstation config with test contents. | ||||||
|  | 	      -s : Enable the Server config with test contents. | ||||||
| 	      -h : Display this help text | 	      -h : Display this help text | ||||||
|  |  | ||||||
| 	EOF | 	EOF | ||||||
| @@ -32,10 +40,13 @@ function usage { | |||||||
|  |  | ||||||
| ## Parameter Parsing ## | ## Parameter Parsing ## | ||||||
|  |  | ||||||
| while getopts ":lb:h" arg; do | while getopts ":lb:gwsh" arg; do | ||||||
| 	case $arg in | 	case $arg in | ||||||
| 		l) local="Y" && echo "Running $LOCAL as the playbook." ;; | 		l) local="Y" && echo "Running $LOCAL as the playbook." ;; | ||||||
| 		b) branch="$OPTARG" && echo "Using branch $branch instead of $BRANCH." ;; | 		b) branch="$OPTARG" && echo "Using branch $branch instead of $BRANCH." ;; | ||||||
|  | 		g) create_general="Y" && echo "Requested '$general_config'." ;; | ||||||
|  | 		w) create_workstation="Y" && echo "Requested '$workstation_config'." ;; | ||||||
|  | 		s) create_server="Y" && echo "Requested '$server_config'." ;; | ||||||
| 		h) usage ;; | 		h) usage ;; | ||||||
| 		*) echo "ERROR: Parameter $OPTARG was not recognized." && usage 1 ;; | 		*) echo "ERROR: Parameter $OPTARG was not recognized." && usage 1 ;; | ||||||
| 	esac | 	esac | ||||||
| @@ -47,15 +58,32 @@ if [[ ! -z $1 && $1 != "-"* ]]; then | |||||||
| 	usage 1 | 	usage 1 | ||||||
| fi | fi | ||||||
|  |  | ||||||
| if [[ $branch == "" ]]; then | if [[ -z "$local" && "$branch" == "" ]]; then | ||||||
| 	echo "Using default branch $BRANCH." | 	echo "Using default branch $BRANCH." | ||||||
| 	branch="$BRANCH" | 	branch="$BRANCH" | ||||||
| fi | fi | ||||||
|  |  | ||||||
|  | if [[ -n "$create_general" && -f "$general_config" ]]; then | ||||||
|  | 	echo "WARNING: General configuration already exists, will not overwrite." | ||||||
|  | 	ls -lh "$general" | ||||||
|  | fi | ||||||
|  | if [[ -n "$create_workstation" && -f "$workstation_config" ]]; then | ||||||
|  | 	echo "WARNING: Workstation configuration already exists, will not overwrite." | ||||||
|  | 	ls -lh "$workstation_config" | ||||||
|  | fi | ||||||
|  | if [[ -n "$create_server" && -f "$server_config" ]]; then | ||||||
|  | 	echo "WARNING: Server configuration already exists, will not overwrite." | ||||||
|  | 	ls -lh "$server_config" | ||||||
|  | fi | ||||||
|  |  | ||||||
| ## Main ## | ## Main ## | ||||||
|  |  | ||||||
| os="$(cat /etc/os-release)" | os="$(cat /etc/os-release)" | ||||||
| os="$os $(uname -a)" | if [[ ! -f /.dockerenv ]]; then | ||||||
|  | 	# If we are not in a Docker container, also check what the kernel says. | ||||||
|  | 	os="$os $(uname -a)" | ||||||
|  | 	# Docker containers use the host kernel which gives an incorrect reading. | ||||||
|  | fi | ||||||
|  |  | ||||||
| echo "Making sure all necessary packages are installed..." | echo "Making sure all necessary packages are installed..." | ||||||
| if [[ `which ansible > /dev/null; echo $?` != 0 ]]; then | if [[ `which ansible > /dev/null; echo $?` != 0 ]]; then | ||||||
| @@ -101,6 +129,53 @@ echo "Installed!" | |||||||
| #ansible-galaxy collection install community.general | #ansible-galaxy collection install community.general | ||||||
| #echo "Added!" | #echo "Added!" | ||||||
|  |  | ||||||
|  | # Create basic layouts if configs do not exist and are requested. | ||||||
|  | if [[ -n "$create_general" | ||||||
|  | 	|| -n "$create_workstation" | ||||||
|  | 	|| -n "$create_server" ]] | ||||||
|  | then | ||||||
|  | 	sudo mkdir -pv "$config_dir" | ||||||
|  | fi | ||||||
|  | if [[ -n "$create_general" && ! -f "$general_config" ]]; then | ||||||
|  | 	function print_general_contents { | ||||||
|  | 		cat <<- EOF | ||||||
|  | 			; TEST DATA | ||||||
|  | 			enable=true | ||||||
|  | 			user=test | ||||||
|  | 			user_desc=Test | ||||||
|  | 			branch=$branch | ||||||
|  | 			; TEST DATA | ||||||
|  | 		EOF | ||||||
|  | 	} | ||||||
|  | 	print_general_contents | sudo tee "$general_config" | ||||||
|  | 	ls -lh "$general_config" | ||||||
|  | fi | ||||||
|  | if [[ -n "$create_workstation" && ! -f "$workstation_config" ]]; then | ||||||
|  | 	function print_workstation_contents { | ||||||
|  | 		cat <<- EOF | ||||||
|  | 			; TEST DATA | ||||||
|  | 			enable=true | ||||||
|  | 			coding=true | ||||||
|  | 			editing=false | ||||||
|  | 			gaming=false | ||||||
|  | 			; TEST DATA | ||||||
|  | 		EOF | ||||||
|  | 	} | ||||||
|  | 	print_workstation_contents | sudo tee "$workstation_config" | ||||||
|  | 	ls -lh "$workstation_config" | ||||||
|  | fi | ||||||
|  | if [[ -n "$create_server" && ! -f "$server_config" ]]; then | ||||||
|  | 	function print_server_contents { | ||||||
|  | 		cat <<- EOF | ||||||
|  | 			; TEST DATA | ||||||
|  | 			enable=true | ||||||
|  | 			; TEST DATA | ||||||
|  | 		EOF | ||||||
|  | 	} | ||||||
|  | 	print_server_contents | sudo tee "$server_config" | ||||||
|  | 	ls -lh "$server_config" | ||||||
|  | fi | ||||||
|  |  | ||||||
| echo "Provisioning Ansible..." | echo "Provisioning Ansible..." | ||||||
| if [[ $local == "Y" ]]; then | if [[ $local == "Y" ]]; then | ||||||
| 	sudo ansible-playbook $LOCAL | 	sudo ansible-playbook $LOCAL | ||||||
|   | |||||||
| @@ -793,16 +793,70 @@ | |||||||
|         date "+%Y%m%d" |         date "+%Y%m%d" | ||||||
|       } |       } | ||||||
|     function_backup: | |     function_backup: | | ||||||
|  |       export BACKUP_DIR="/srv/backup" | ||||||
|       function backup { |       function backup { | ||||||
|         /usr/local/bin/backup_system.sh |         /usr/local/bin/backup_system.sh | ||||||
|       } |       } | ||||||
|       alias backup-system="backup" |       alias backup-system="backup" | ||||||
|       alias system-backup="backup" |       alias system-backup="backup" | ||||||
|       alias check-backups="ll /srv/backup" |       alias check-backups="ll $BACKUP_DIR" | ||||||
|       function clean-backup { |       function clean-backup { | ||||||
|         sh -c "rm -rfv /srv/backup/*" |         sh -c "rm -rfv $BACKUP_DIR/*" | ||||||
|       } |       } | ||||||
|       alias clean-backups="clean-backup" |       alias clean-backups="clean-backup" | ||||||
|  |     function_pull_prod_backups: | | ||||||
|  |       export DOCKER="Docker" | ||||||
|  |       export SYSTEM="System" | ||||||
|  |       function pull_prod_backup { | ||||||
|  |         if [[ -z "$1" || ("$1" != "$DOCKER" && "$1" != "$SYSTEM") ]]; then | ||||||
|  |           echo "ERROR: Parameter 1 not correct, expecting '$DOCKER' or '$SYSTEM'." | ||||||
|  |           return 1 | ||||||
|  |         fi | ||||||
|  |         backup_type="$1" | ||||||
|  |         echo "Looking for '*${backup_type}*.zip'" | ||||||
|  |         ls -lh *${backup_type}*.zip 2>/dev/null | ||||||
|  |         status="$?" | ||||||
|  |         if [[ "$status" == "0" ]]; then | ||||||
|  |           echo "File already downloaded, skipping." | ||||||
|  |           return 0 | ||||||
|  |         else | ||||||
|  |           echo "File still needed, downloading to local tmp/." | ||||||
|  |         fi | ||||||
|  |         mkdir -pv tmp | ||||||
|  |         scp -P {{ prod_port }} \ | ||||||
|  |           {{ prod_user }}@{{ prod_host }}:"$BACKUP_DIR/*${backup_type}*.zip" \ | ||||||
|  |           tmp/ | ||||||
|  |         if [[ "$?" == "0" ]]; then | ||||||
|  |           echo "Succeeded!" | ||||||
|  |           mv -v tmp/*.zip ./ | ||||||
|  |           rmdir -v tmp | ||||||
|  |         else | ||||||
|  |           echo "Failed!" | ||||||
|  |           mv tmp ~/TRASH/"tmp_`now`" | ||||||
|  |         fi | ||||||
|  |       } | ||||||
|  |       function pull_prod_backups { | ||||||
|  |         dir="ProductionBackups-Pulled`today`" | ||||||
|  |         mkdir -pv "$dir" | ||||||
|  |         cd "$dir" | ||||||
|  |         pull_prod_backup "$DOCKER" | ||||||
|  |         pull_prod_backup "$SYSTEM" | ||||||
|  |         du -h *.zip | sort -h | ||||||
|  |         status="$?" | ||||||
|  |         cd .. | ||||||
|  |         if [[ "$status" != 0 ]]; then | ||||||
|  |           echo "Failed to find zip files, removing folder." | ||||||
|  |           rmdir -v "$dir" | ||||||
|  |           return 1 | ||||||
|  |         fi | ||||||
|  |         echo "Done!" | ||||||
|  |       } | ||||||
|  |       alias pull-prod-backups="pull_prod_backups" | ||||||
|  |       alias pull-backups="pull_prod_backups" | ||||||
|  |       alias prod-backups="pull_prod_backups" | ||||||
|  |       alias prod-backup="pull_prod_backups" | ||||||
|  |       alias pull-prod="pull_prod_backups" | ||||||
|  |       alias prod-pull="pull_prod_backups" | ||||||
|     function_log: | |     function_log: | | ||||||
|       function log { |       function log { | ||||||
|         echo -e "$1" |         echo -e "$1" | ||||||
| @@ -928,8 +982,18 @@ | |||||||
|         git ls-remote --heads | sort |         git ls-remote --heads | sort | ||||||
|  |  | ||||||
|         if [[ "$base" != "dev" ]]; then |         if [[ "$base" != "dev" ]]; then | ||||||
|           echo -e "\n* Switching back to dev." |           echo -e "\n* Checking if a dev branch exists." | ||||||
|           git switch dev |           git ls-remote --exit-code --heads origin dev | ||||||
|  |           dev_exists="$?" | ||||||
|  |           if [[ "$dev_exists" == 0 ]]; then | ||||||
|  |             echo -e "\n* Switching back to dev." | ||||||
|  |             git switch dev | ||||||
|  |           elif [[ "$dev_exists" == 2 ]]; then | ||||||
|  |             echo -e "\n* Switching back to main." | ||||||
|  |             git switch main | ||||||
|  |           else | ||||||
|  |             echo "*** ERROR: Unknown status for dev_exists, '$dev_exists'. ***" | ||||||
|  |           fi | ||||||
|         fi |         fi | ||||||
|  |  | ||||||
|         echo -e "\n* Verifying which branch we're on." |         echo -e "\n* Verifying which branch we're on." | ||||||
| @@ -938,8 +1002,17 @@ | |||||||
|       alias load-prod="load-branch prod" |       alias load-prod="load-branch prod" | ||||||
|       alias load-stage="load-branch stage" |       alias load-stage="load-branch stage" | ||||||
|       alias rollback-prod="load-branch prod main" |       alias rollback-prod="load-branch prod main" | ||||||
|       alias rollback-stage="load-branch stage main" |       alias rollback-stage="load-branch stage prod" | ||||||
|       alias rollback-dev="load-branch dev main" |       alias rollback-dev="load-branch dev stage" | ||||||
|  |       alias reset-prod="load-branch prod main" | ||||||
|  |       alias reset-stage="load-branch stage main" | ||||||
|  |       alias reset-dev="load-branch dev main" | ||||||
|  |     alias_reload_bash: | | ||||||
|  |       alias reload-bash="source ~/.bashrc" | ||||||
|  |       alias bash-reload="reload-bash" | ||||||
|  |       alias shell-reload="reload-bash" | ||||||
|  |       alias reload-shell="reload-bash" | ||||||
|  |       alias reload="reload-bash" | ||||||
|  |  | ||||||
| - name: General | Account Management | Users | Files | Common Variable | - name: General | Account Management | Users | Files | Common Variable | ||||||
|   set_fact: |   set_fact: | ||||||
| @@ -1011,11 +1084,13 @@ | |||||||
|       {{ alias_ansible_facts }} |       {{ alias_ansible_facts }} | ||||||
|       {{ function_now }} |       {{ function_now }} | ||||||
|       {{ function_backup }} |       {{ function_backup }} | ||||||
|  |       {{ function_pull_prod_backups }} | ||||||
|       {{ function_log }} |       {{ function_log }} | ||||||
|       {{ function_debian_upgrade }} |       {{ function_debian_upgrade }} | ||||||
|       {{ function_ebook_convert }} |       {{ function_ebook_convert }} | ||||||
|       {{ alias_sudo }} |       {{ alias_sudo }} | ||||||
|       {{ function_load_branch }} |       {{ function_load_branch }} | ||||||
|  |       {{ alias_reload_bash }} | ||||||
|  |  | ||||||
| - name: General | Account Management | Users | Files | .bashrc | - name: General | Account Management | Users | Files | .bashrc | ||||||
|   blockinfile: |   blockinfile: | ||||||
|   | |||||||
| @@ -12,7 +12,7 @@ | |||||||
|     user: ansible |     user: ansible | ||||||
|     name: "Ansible Sync" |     name: "Ansible Sync" | ||||||
|     minute: "*/30" |     minute: "*/30" | ||||||
|     job: "sleep $(( $RANDOM / 20 )); sudo {{ ansible_pull_exec.stdout }} -v -o -U {{ git_repo_http }} --checkout {{ branch }}" |     job: "bash -c 'sleep $(( $RANDOM / 20 )); sudo {{ ansible_pull_exec.stdout }} -v -o -U {{ git_repo_http }} --checkout {{ branch }}'" | ||||||
|     state: present |     state: present | ||||||
|     disabled: "{{ 'yes' if no_telem else 'no' }}" |     disabled: "{{ 'yes' if no_telem else 'no' }}" | ||||||
|  |  | ||||||
| @@ -21,6 +21,6 @@ | |||||||
|     user: ansible |     user: ansible | ||||||
|     name: "Ansible Weekly Forced Sync" |     name: "Ansible Weekly Forced Sync" | ||||||
|     special_time: daily |     special_time: daily | ||||||
|     job: "sleep $(( $RANDOM /  1 )); sudo {{ ansible_pull_exec.stdout }} -v    -U {{ git_repo_http }} --checkout {{ branch }}" |     job: "bash -c 'sleep $(( $RANDOM /  1 )); sudo {{ ansible_pull_exec.stdout }} -v    -U {{ git_repo_http }} --checkout {{ branch }}'" | ||||||
|     state: present |     state: present | ||||||
|     disabled: "{{ 'yes' if no_telem else 'no' }}" |     disabled: "{{ 'yes' if no_telem else 'no' }}" | ||||||
|   | |||||||
| @@ -43,6 +43,7 @@ | |||||||
|       - { app: "org.gimp.GIMP", name: "gimp", extra: "" } |       - { app: "org.gimp.GIMP", name: "gimp", extra: "" } | ||||||
|       - { app: "org.libreoffice.LibreOffice", name: "office", extra: "" } |       - { app: "org.libreoffice.LibreOffice", name: "office", extra: "" } | ||||||
|       - { app: "com.transmissionbt.Transmission", name: "transmission", extra: "" } |       - { app: "com.transmissionbt.Transmission", name: "transmission", extra: "" } | ||||||
|  |       - { app: "app.grayjay.Grayjay", name: "grayjay", extra: "" } | ||||||
|     flatpaks_coding: |     flatpaks_coding: | ||||||
|       - { app: "com.vscodium.codium", name: "codium-flatpak", extra: "" } |       - { app: "com.vscodium.codium", name: "codium-flatpak", extra: "" } | ||||||
|       - { app: "com.google.AndroidStudio", name: "android-studio", extra: "" } |       - { app: "com.google.AndroidStudio", name: "android-studio", extra: "" } | ||||||
|   | |||||||
| @@ -19,6 +19,7 @@ | |||||||
|                       , 'codium.desktop' |                       , 'codium.desktop' | ||||||
|                       , 'org.shotcut.Shotcut.desktop' |                       , 'org.shotcut.Shotcut.desktop' | ||||||
|                       , 'io.lmms.LMMS.desktop' |                       , 'io.lmms.LMMS.desktop' | ||||||
|  |                       , 'app.grayjay.Grayjay.desktop' | ||||||
|                       , 'io.lbry.lbry-app.desktop', 'lbry.desktop' |                       , 'io.lbry.lbry-app.desktop', 'lbry.desktop' | ||||||
|                       , 'com.valvesoftware.Steam.desktop' |                       , 'com.valvesoftware.Steam.desktop' | ||||||
|                       , 'net.lutris.Lutris.desktop' |                       , 'net.lutris.Lutris.desktop' | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user