| 
				
			 | 
			
			
				@@ -0,0 +1,435 @@ 
			 | 
		
	
		
			
			| 
				
			 | 
			
				1
			 | 
			
			
				+#!/bin/bash 
			 | 
		
	
		
			
			| 
				
			 | 
			
				2
			 | 
			
			
				+# 
			 | 
		
	
		
			
			| 
				
			 | 
			
				3
			 | 
			
			
				+# .---.                  .              . 
			 | 
		
	
		
			
			| 
				
			 | 
			
				4
			 | 
			
			
				+# |                      |              | 
			 | 
		
	
		
			
			| 
				
			 | 
			
				5
			 | 
			
			
				+# |--- .--. .-.  .-.  .-.|  .-. .--.--. |.-.  .-. .--.  .-. 
			 | 
		
	
		
			
			| 
				
			 | 
			
				6
			 | 
			
			
				+# |    |   (.-' (.-' (   | (   )|  |  | |   )(   )|  | (.-' 
			 | 
		
	
		
			
			| 
				
			 | 
			
				7
			 | 
			
			
				+# '    '     --'  --'  -' -  -' '  '   -' -'   -' '   -  --' 
			 | 
		
	
		
			
			| 
				
			 | 
			
				8
			 | 
			
			
				+# 
			 | 
		
	
		
			
			| 
				
			 | 
			
				9
			 | 
			
			
				+#                    Freedom in the Cloud 
			 | 
		
	
		
			
			| 
				
			 | 
			
				10
			 | 
			
			
				+# 
			 | 
		
	
		
			
			| 
				
			 | 
			
				11
			 | 
			
			
				+# SKS Keyserver 
			 | 
		
	
		
			
			| 
				
			 | 
			
				12
			 | 
			
			
				+# 
			 | 
		
	
		
			
			| 
				
			 | 
			
				13
			 | 
			
			
				+# License 
			 | 
		
	
		
			
			| 
				
			 | 
			
				14
			 | 
			
			
				+# ======= 
			 | 
		
	
		
			
			| 
				
			 | 
			
				15
			 | 
			
			
				+# 
			 | 
		
	
		
			
			| 
				
			 | 
			
				16
			 | 
			
			
				+# Copyright (C) 2017 Bob Mottram <bob@freedombone.net> 
			 | 
		
	
		
			
			| 
				
			 | 
			
				17
			 | 
			
			
				+# 
			 | 
		
	
		
			
			| 
				
			 | 
			
				18
			 | 
			
			
				+# This program is free software: you can redistribute it and/or modify 
			 | 
		
	
		
			
			| 
				
			 | 
			
				19
			 | 
			
			
				+# it under the terms of the GNU Affero General Public License as published by 
			 | 
		
	
		
			
			| 
				
			 | 
			
				20
			 | 
			
			
				+# the Free Software Foundation, either version 3 of the License, or 
			 | 
		
	
		
			
			| 
				
			 | 
			
				21
			 | 
			
			
				+# (at your option) any later version. 
			 | 
		
	
		
			
			| 
				
			 | 
			
				22
			 | 
			
			
				+# 
			 | 
		
	
		
			
			| 
				
			 | 
			
				23
			 | 
			
			
				+# This program is distributed in the hope that it will be useful, 
			 | 
		
	
		
			
			| 
				
			 | 
			
				24
			 | 
			
			
				+# but WITHOUT ANY WARRANTY; without even the implied warranty of 
			 | 
		
	
		
			
			| 
				
			 | 
			
				25
			 | 
			
			
				+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the 
			 | 
		
	
		
			
			| 
				
			 | 
			
				26
			 | 
			
			
				+# GNU Affero General Public License for more details. 
			 | 
		
	
		
			
			| 
				
			 | 
			
				27
			 | 
			
			
				+# 
			 | 
		
	
		
			
			| 
				
			 | 
			
				28
			 | 
			
			
				+# You should have received a copy of the GNU Affero General Public License 
			 | 
		
	
		
			
			| 
				
			 | 
			
				29
			 | 
			
			
				+# along with this program.  If not, see <http://www.gnu.org/licenses/>. 
			 | 
		
	
		
			
			| 
				
			 | 
			
				30
			 | 
			
			
				+ 
			 | 
		
	
		
			
			| 
				
			 | 
			
				31
			 | 
			
			
				+VARIANTS='full full-vim' 
			 | 
		
	
		
			
			| 
				
			 | 
			
				32
			 | 
			
			
				+ 
			 | 
		
	
		
			
			| 
				
			 | 
			
				33
			 | 
			
			
				+IN_DEFAULT_INSTALL=0 
			 | 
		
	
		
			
			| 
				
			 | 
			
				34
			 | 
			
			
				+SHOW_ON_ABOUT=1 
			 | 
		
	
		
			
			| 
				
			 | 
			
				35
			 | 
			
			
				+ 
			 | 
		
	
		
			
			| 
				
			 | 
			
				36
			 | 
			
			
				+KEYSERVER_SKS_REPO="https://bitbucket.org/skskeyserver/sks-keyserver" 
			 | 
		
	
		
			
			| 
				
			 | 
			
				37
			 | 
			
			
				+KEYSERVER_SKS_COMMIT='0106ba2' 
			 | 
		
	
		
			
			| 
				
			 | 
			
				38
			 | 
			
			
				+KEYSERVER_WEB_REPO="https://github.com/mattrude/pgpkeyserver-lite" 
			 | 
		
	
		
			
			| 
				
			 | 
			
				39
			 | 
			
			
				+KEYSERVER_WEB_COMMIT='a038cb79b927c99bf7da62f20d2c6a2f20374339' 
			 | 
		
	
		
			
			| 
				
			 | 
			
				40
			 | 
			
			
				+KEYSERVER_PORT=11371 
			 | 
		
	
		
			
			| 
				
			 | 
			
				41
			 | 
			
			
				+KEYSERVER_ONION_PORT=8122 
			 | 
		
	
		
			
			| 
				
			 | 
			
				42
			 | 
			
			
				+KEYSERVER_DOMAIN_NAME= 
			 | 
		
	
		
			
			| 
				
			 | 
			
				43
			 | 
			
			
				+KEYSERVER_CODE= 
			 | 
		
	
		
			
			| 
				
			 | 
			
				44
			 | 
			
			
				+KEYSERVER_DUMP_URL="https://keyserver.mattrude.com/dump/current/" 
			 | 
		
	
		
			
			| 
				
			 | 
			
				45
			 | 
			
			
				+ 
			 | 
		
	
		
			
			| 
				
			 | 
			
				46
			 | 
			
			
				+vim_variables=(MY_USERNAME 
			 | 
		
	
		
			
			| 
				
			 | 
			
				47
			 | 
			
			
				+               KEYSERVER_DOMAIN_NAME 
			 | 
		
	
		
			
			| 
				
			 | 
			
				48
			 | 
			
			
				+               KEYSERVER_CODE) 
			 | 
		
	
		
			
			| 
				
			 | 
			
				49
			 | 
			
			
				+ 
			 | 
		
	
		
			
			| 
				
			 | 
			
				50
			 | 
			
			
				+function logging_on_keyserver { 
			 | 
		
	
		
			
			| 
				
			 | 
			
				51
			 | 
			
			
				+    echo -n '' 
			 | 
		
	
		
			
			| 
				
			 | 
			
				52
			 | 
			
			
				+} 
			 | 
		
	
		
			
			| 
				
			 | 
			
				53
			 | 
			
			
				+ 
			 | 
		
	
		
			
			| 
				
			 | 
			
				54
			 | 
			
			
				+function logging_off_keyserver { 
			 | 
		
	
		
			
			| 
				
			 | 
			
				55
			 | 
			
			
				+    echo -n '' 
			 | 
		
	
		
			
			| 
				
			 | 
			
				56
			 | 
			
			
				+} 
			 | 
		
	
		
			
			| 
				
			 | 
			
				57
			 | 
			
			
				+ 
			 | 
		
	
		
			
			| 
				
			 | 
			
				58
			 | 
			
			
				+function reconfigure_keyserver { 
			 | 
		
	
		
			
			| 
				
			 | 
			
				59
			 | 
			
			
				+    echo -n '' 
			 | 
		
	
		
			
			| 
				
			 | 
			
				60
			 | 
			
			
				+} 
			 | 
		
	
		
			
			| 
				
			 | 
			
				61
			 | 
			
			
				+ 
			 | 
		
	
		
			
			| 
				
			 | 
			
				62
			 | 
			
			
				+function upgrade_keyserver_sks { 
			 | 
		
	
		
			
			| 
				
			 | 
			
				63
			 | 
			
			
				+    CURR_KEYSERVER_SKS_COMMIT=$(get_completion_param "keyserver commit") 
			 | 
		
	
		
			
			| 
				
			 | 
			
				64
			 | 
			
			
				+    if [[ "$CURR_KEYSERVER_SKS_COMMIT" == "$KEYSERVER_SKS_COMMIT" ]]; then 
			 | 
		
	
		
			
			| 
				
			 | 
			
				65
			 | 
			
			
				+        return 
			 | 
		
	
		
			
			| 
				
			 | 
			
				66
			 | 
			
			
				+    fi 
			 | 
		
	
		
			
			| 
				
			 | 
			
				67
			 | 
			
			
				+ 
			 | 
		
	
		
			
			| 
				
			 | 
			
				68
			 | 
			
			
				+    if grep -q "keyserver domain" $COMPLETION_FILE; then 
			 | 
		
	
		
			
			| 
				
			 | 
			
				69
			 | 
			
			
				+        KEYSERVER_DOMAIN_NAME=$(get_completion_param "keyserver domain") 
			 | 
		
	
		
			
			| 
				
			 | 
			
				70
			 | 
			
			
				+    fi 
			 | 
		
	
		
			
			| 
				
			 | 
			
				71
			 | 
			
			
				+ 
			 | 
		
	
		
			
			| 
				
			 | 
			
				72
			 | 
			
			
				+    # update to the next commit 
			 | 
		
	
		
			
			| 
				
			 | 
			
				73
			 | 
			
			
				+    function_check set_repo_commit 
			 | 
		
	
		
			
			| 
				
			 | 
			
				74
			 | 
			
			
				+    set_repo_commit $INSTALL_DIR/keyserver "keyserver commit" "$KEYSERVER_SKS_COMMIT" $KEYSERVER_SKS_REPO 
			 | 
		
	
		
			
			| 
				
			 | 
			
				75
			 | 
			
			
				+ 
			 | 
		
	
		
			
			| 
				
			 | 
			
				76
			 | 
			
			
				+    cd $INSTALL_DIR/keyserver 
			 | 
		
	
		
			
			| 
				
			 | 
			
				77
			 | 
			
			
				+    make dep 
			 | 
		
	
		
			
			| 
				
			 | 
			
				78
			 | 
			
			
				+    make all 
			 | 
		
	
		
			
			| 
				
			 | 
			
				79
			 | 
			
			
				+    if [ ! "$?" = "0" ]; then 
			 | 
		
	
		
			
			| 
				
			 | 
			
				80
			 | 
			
			
				+        echo $'Unable to build sks-keyserver' 
			 | 
		
	
		
			
			| 
				
			 | 
			
				81
			 | 
			
			
				+        exit 836252 
			 | 
		
	
		
			
			| 
				
			 | 
			
				82
			 | 
			
			
				+    fi 
			 | 
		
	
		
			
			| 
				
			 | 
			
				83
			 | 
			
			
				+    make install 
			 | 
		
	
		
			
			| 
				
			 | 
			
				84
			 | 
			
			
				+ 
			 | 
		
	
		
			
			| 
				
			 | 
			
				85
			 | 
			
			
				+    chown -R keyserver:keyserver /var/lib/sks 
			 | 
		
	
		
			
			| 
				
			 | 
			
				86
			 | 
			
			
				+} 
			 | 
		
	
		
			
			| 
				
			 | 
			
				87
			 | 
			
			
				+ 
			 | 
		
	
		
			
			| 
				
			 | 
			
				88
			 | 
			
			
				+function upgrade_keyserver_web { 
			 | 
		
	
		
			
			| 
				
			 | 
			
				89
			 | 
			
			
				+    CURR_KEYSERVER_WEB_COMMIT=$(get_completion_param "keyserver web commit") 
			 | 
		
	
		
			
			| 
				
			 | 
			
				90
			 | 
			
			
				+    if [[ "$CURR_KEYSERVER_WEB_COMMIT" == "$KEYSERVER_WEB_COMMIT" ]]; then 
			 | 
		
	
		
			
			| 
				
			 | 
			
				91
			 | 
			
			
				+        return 
			 | 
		
	
		
			
			| 
				
			 | 
			
				92
			 | 
			
			
				+    fi 
			 | 
		
	
		
			
			| 
				
			 | 
			
				93
			 | 
			
			
				+ 
			 | 
		
	
		
			
			| 
				
			 | 
			
				94
			 | 
			
			
				+    if grep -q "keyserver domain" $COMPLETION_FILE; then 
			 | 
		
	
		
			
			| 
				
			 | 
			
				95
			 | 
			
			
				+        KEYSERVER_DOMAIN_NAME=$(get_completion_param "keyserver domain") 
			 | 
		
	
		
			
			| 
				
			 | 
			
				96
			 | 
			
			
				+    fi 
			 | 
		
	
		
			
			| 
				
			 | 
			
				97
			 | 
			
			
				+ 
			 | 
		
	
		
			
			| 
				
			 | 
			
				98
			 | 
			
			
				+    # update to the next commit 
			 | 
		
	
		
			
			| 
				
			 | 
			
				99
			 | 
			
			
				+    function_check set_repo_commit 
			 | 
		
	
		
			
			| 
				
			 | 
			
				100
			 | 
			
			
				+    set_repo_commit /var/www/$KEYSERVER_DOMAIN_NAME/htdocs "keyserver web commit" "$KEYSERVER_WEB_COMMIT" $KEYSERVER_WEB_REPO 
			 | 
		
	
		
			
			| 
				
			 | 
			
				101
			 | 
			
			
				+ 
			 | 
		
	
		
			
			| 
				
			 | 
			
				102
			 | 
			
			
				+    chown -R www-data:www-data /var/www/$KEYSERVER_DOMAIN_NAME/htdocs 
			 | 
		
	
		
			
			| 
				
			 | 
			
				103
			 | 
			
			
				+} 
			 | 
		
	
		
			
			| 
				
			 | 
			
				104
			 | 
			
			
				+ 
			 | 
		
	
		
			
			| 
				
			 | 
			
				105
			 | 
			
			
				+function upgrade_keyserver { 
			 | 
		
	
		
			
			| 
				
			 | 
			
				106
			 | 
			
			
				+    upgrade_keyserver_sks 
			 | 
		
	
		
			
			| 
				
			 | 
			
				107
			 | 
			
			
				+    upgrade_keyserver_web 
			 | 
		
	
		
			
			| 
				
			 | 
			
				108
			 | 
			
			
				+} 
			 | 
		
	
		
			
			| 
				
			 | 
			
				109
			 | 
			
			
				+ 
			 | 
		
	
		
			
			| 
				
			 | 
			
				110
			 | 
			
			
				+function backup_local_keyserver { 
			 | 
		
	
		
			
			| 
				
			 | 
			
				111
			 | 
			
			
				+    echo -n '' 
			 | 
		
	
		
			
			| 
				
			 | 
			
				112
			 | 
			
			
				+} 
			 | 
		
	
		
			
			| 
				
			 | 
			
				113
			 | 
			
			
				+ 
			 | 
		
	
		
			
			| 
				
			 | 
			
				114
			 | 
			
			
				+function restore_local_vim { 
			 | 
		
	
		
			
			| 
				
			 | 
			
				115
			 | 
			
			
				+    echo -n '' 
			 | 
		
	
		
			
			| 
				
			 | 
			
				116
			 | 
			
			
				+} 
			 | 
		
	
		
			
			| 
				
			 | 
			
				117
			 | 
			
			
				+ 
			 | 
		
	
		
			
			| 
				
			 | 
			
				118
			 | 
			
			
				+function backup_remote_keyserver { 
			 | 
		
	
		
			
			| 
				
			 | 
			
				119
			 | 
			
			
				+    echo -n '' 
			 | 
		
	
		
			
			| 
				
			 | 
			
				120
			 | 
			
			
				+} 
			 | 
		
	
		
			
			| 
				
			 | 
			
				121
			 | 
			
			
				+ 
			 | 
		
	
		
			
			| 
				
			 | 
			
				122
			 | 
			
			
				+function restore_remote_keyserver { 
			 | 
		
	
		
			
			| 
				
			 | 
			
				123
			 | 
			
			
				+    echo -n '' 
			 | 
		
	
		
			
			| 
				
			 | 
			
				124
			 | 
			
			
				+} 
			 | 
		
	
		
			
			| 
				
			 | 
			
				125
			 | 
			
			
				+ 
			 | 
		
	
		
			
			| 
				
			 | 
			
				126
			 | 
			
			
				+function remove_keyserver { 
			 | 
		
	
		
			
			| 
				
			 | 
			
				127
			 | 
			
			
				+    systemctl stop keyserver 
			 | 
		
	
		
			
			| 
				
			 | 
			
				128
			 | 
			
			
				+    systemctl disable keyserver 
			 | 
		
	
		
			
			| 
				
			 | 
			
				129
			 | 
			
			
				+    rm /etc/systemd/system/keyserver.service 
			 | 
		
	
		
			
			| 
				
			 | 
			
				130
			 | 
			
			
				+    systemctl daemon-reload 
			 | 
		
	
		
			
			| 
				
			 | 
			
				131
			 | 
			
			
				+ 
			 | 
		
	
		
			
			| 
				
			 | 
			
				132
			 | 
			
			
				+    read_config_param "KEYSERVER_DOMAIN_NAME" 
			 | 
		
	
		
			
			| 
				
			 | 
			
				133
			 | 
			
			
				+    nginx_dissite $KEYSERVER_DOMAIN_NAME 
			 | 
		
	
		
			
			| 
				
			 | 
			
				134
			 | 
			
			
				+    remove_certs ${KEYSERVER_DOMAIN_NAME} 
			 | 
		
	
		
			
			| 
				
			 | 
			
				135
			 | 
			
			
				+    if [ -f /etc/nginx/sites-available/$KEYSERVER_DOMAIN_NAME ]; then 
			 | 
		
	
		
			
			| 
				
			 | 
			
				136
			 | 
			
			
				+        rm -f /etc/nginx/sites-available/$KEYSERVER_DOMAIN_NAME 
			 | 
		
	
		
			
			| 
				
			 | 
			
				137
			 | 
			
			
				+    fi 
			 | 
		
	
		
			
			| 
				
			 | 
			
				138
			 | 
			
			
				+    if [ -d /var/www/$KEYSERVER_DOMAIN_NAME ]; then 
			 | 
		
	
		
			
			| 
				
			 | 
			
				139
			 | 
			
			
				+        rm -rf /var/www/$KEYSERVER_DOMAIN_NAME 
			 | 
		
	
		
			
			| 
				
			 | 
			
				140
			 | 
			
			
				+    fi 
			 | 
		
	
		
			
			| 
				
			 | 
			
				141
			 | 
			
			
				+    function_check remove_ddns_domain 
			 | 
		
	
		
			
			| 
				
			 | 
			
				142
			 | 
			
			
				+    remove_ddns_domain $KEYSERVER_DOMAIN_NAME 
			 | 
		
	
		
			
			| 
				
			 | 
			
				143
			 | 
			
			
				+ 
			 | 
		
	
		
			
			| 
				
			 | 
			
				144
			 | 
			
			
				+    groupdel -f keyserver 
			 | 
		
	
		
			
			| 
				
			 | 
			
				145
			 | 
			
			
				+    userdel -r keyserver 
			 | 
		
	
		
			
			| 
				
			 | 
			
				146
			 | 
			
			
				+ 
			 | 
		
	
		
			
			| 
				
			 | 
			
				147
			 | 
			
			
				+    remove_config_param KEYSERVER_DOMAIN_NAME 
			 | 
		
	
		
			
			| 
				
			 | 
			
				148
			 | 
			
			
				+    remove_config_param KEYSERVER_CODE 
			 | 
		
	
		
			
			| 
				
			 | 
			
				149
			 | 
			
			
				+    function_check remove_onion_service 
			 | 
		
	
		
			
			| 
				
			 | 
			
				150
			 | 
			
			
				+    remove_onion_service keyserver ${KEYSERVER_ONION_PORT} 
			 | 
		
	
		
			
			| 
				
			 | 
			
				151
			 | 
			
			
				+    remove_completion_param "install_keyserver" 
			 | 
		
	
		
			
			| 
				
			 | 
			
				152
			 | 
			
			
				+ 
			 | 
		
	
		
			
			| 
				
			 | 
			
				153
			 | 
			
			
				+    sed -i '/keyserver/d' $COMPLETION_FILE 
			 | 
		
	
		
			
			| 
				
			 | 
			
				154
			 | 
			
			
				+    if [ -f /usr/bin/keyserver-start ]; then 
			 | 
		
	
		
			
			| 
				
			 | 
			
				155
			 | 
			
			
				+        rm /usr/bin/keyserver-start 
			 | 
		
	
		
			
			| 
				
			 | 
			
				156
			 | 
			
			
				+    fi 
			 | 
		
	
		
			
			| 
				
			 | 
			
				157
			 | 
			
			
				+    if [ -f /usr/bin/keyserver-stop ]; then 
			 | 
		
	
		
			
			| 
				
			 | 
			
				158
			 | 
			
			
				+        rm /usr/bin/keyserver-stop 
			 | 
		
	
		
			
			| 
				
			 | 
			
				159
			 | 
			
			
				+    fi 
			 | 
		
	
		
			
			| 
				
			 | 
			
				160
			 | 
			
			
				+    groupdel -f keyserver 
			 | 
		
	
		
			
			| 
				
			 | 
			
				161
			 | 
			
			
				+    userdel -r keyserver 
			 | 
		
	
		
			
			| 
				
			 | 
			
				162
			 | 
			
			
				+} 
			 | 
		
	
		
			
			| 
				
			 | 
			
				163
			 | 
			
			
				+ 
			 | 
		
	
		
			
			| 
				
			 | 
			
				164
			 | 
			
			
				+function install_interactive_keyserver { 
			 | 
		
	
		
			
			| 
				
			 | 
			
				165
			 | 
			
			
				+    if [ ! $ONION_ONLY ]; then 
			 | 
		
	
		
			
			| 
				
			 | 
			
				166
			 | 
			
			
				+        ONION_ONLY='no' 
			 | 
		
	
		
			
			| 
				
			 | 
			
				167
			 | 
			
			
				+    fi 
			 | 
		
	
		
			
			| 
				
			 | 
			
				168
			 | 
			
			
				+ 
			 | 
		
	
		
			
			| 
				
			 | 
			
				169
			 | 
			
			
				+    if [[ $ONION_ONLY != "no" ]]; then 
			 | 
		
	
		
			
			| 
				
			 | 
			
				170
			 | 
			
			
				+        KEYSERVER_DOMAIN_NAME='keyserver.local' 
			 | 
		
	
		
			
			| 
				
			 | 
			
				171
			 | 
			
			
				+        write_config_param "KEYSERVER_DOMAIN_NAME" "$KEYSERVER_DOMAIN_NAME" 
			 | 
		
	
		
			
			| 
				
			 | 
			
				172
			 | 
			
			
				+    else 
			 | 
		
	
		
			
			| 
				
			 | 
			
				173
			 | 
			
			
				+        function_check interactive_site_details 
			 | 
		
	
		
			
			| 
				
			 | 
			
				174
			 | 
			
			
				+        interactive_site_details "keyserver" "KEYSERVER_DOMAIN_NAME" "KEYSERVER_CODE" 
			 | 
		
	
		
			
			| 
				
			 | 
			
				175
			 | 
			
			
				+    fi 
			 | 
		
	
		
			
			| 
				
			 | 
			
				176
			 | 
			
			
				+    APP_INSTALLED=1 
			 | 
		
	
		
			
			| 
				
			 | 
			
				177
			 | 
			
			
				+} 
			 | 
		
	
		
			
			| 
				
			 | 
			
				178
			 | 
			
			
				+ 
			 | 
		
	
		
			
			| 
				
			 | 
			
				179
			 | 
			
			
				+function install_keyserver { 
			 | 
		
	
		
			
			| 
				
			 | 
			
				180
			 | 
			
			
				+    apt-get -qy install build-essential gcc ocaml libdb-dev wget 
			 | 
		
	
		
			
			| 
				
			 | 
			
				181
			 | 
			
			
				+ 
			 | 
		
	
		
			
			| 
				
			 | 
			
				182
			 | 
			
			
				+    if [ ! -d /var/www/$KEYSERVER_DOMAIN_NAME ]; then 
			 | 
		
	
		
			
			| 
				
			 | 
			
				183
			 | 
			
			
				+        mkdir /var/www/$KEYSERVER_DOMAIN_NAME 
			 | 
		
	
		
			
			| 
				
			 | 
			
				184
			 | 
			
			
				+    fi 
			 | 
		
	
		
			
			| 
				
			 | 
			
				185
			 | 
			
			
				+ 
			 | 
		
	
		
			
			| 
				
			 | 
			
				186
			 | 
			
			
				+    if [ ! -d $INSTALL_DIR ]; then 
			 | 
		
	
		
			
			| 
				
			 | 
			
				187
			 | 
			
			
				+        mkdir -p $INSTALL_DIR 
			 | 
		
	
		
			
			| 
				
			 | 
			
				188
			 | 
			
			
				+    fi 
			 | 
		
	
		
			
			| 
				
			 | 
			
				189
			 | 
			
			
				+    cd $INSTALL_DIR 
			 | 
		
	
		
			
			| 
				
			 | 
			
				190
			 | 
			
			
				+    if [ -d /repos/keyserver ]; then 
			 | 
		
	
		
			
			| 
				
			 | 
			
				191
			 | 
			
			
				+        mkdir $INSTALL_DIR/keyserver 
			 | 
		
	
		
			
			| 
				
			 | 
			
				192
			 | 
			
			
				+        cp -r -p /repos/keyserver/. $INSTALL_DIR/keyserver 
			 | 
		
	
		
			
			| 
				
			 | 
			
				193
			 | 
			
			
				+        cd $INSTALL_DIR/keyserver 
			 | 
		
	
		
			
			| 
				
			 | 
			
				194
			 | 
			
			
				+        git pull 
			 | 
		
	
		
			
			| 
				
			 | 
			
				195
			 | 
			
			
				+    else 
			 | 
		
	
		
			
			| 
				
			 | 
			
				196
			 | 
			
			
				+        if [ -d $INSTALL_DIR/keyserver ]; then 
			 | 
		
	
		
			
			| 
				
			 | 
			
				197
			 | 
			
			
				+            cd $INSTALL_DIR/keyserver 
			 | 
		
	
		
			
			| 
				
			 | 
			
				198
			 | 
			
			
				+            pull 
			 | 
		
	
		
			
			| 
				
			 | 
			
				199
			 | 
			
			
				+        else 
			 | 
		
	
		
			
			| 
				
			 | 
			
				200
			 | 
			
			
				+            git_clone $KEYSERVER_SKS_REPO $INSTALL_DIR/keyserver 
			 | 
		
	
		
			
			| 
				
			 | 
			
				201
			 | 
			
			
				+        fi 
			 | 
		
	
		
			
			| 
				
			 | 
			
				202
			 | 
			
			
				+    fi 
			 | 
		
	
		
			
			| 
				
			 | 
			
				203
			 | 
			
			
				+ 
			 | 
		
	
		
			
			| 
				
			 | 
			
				204
			 | 
			
			
				+    cd $INSTALL_DIR/keyserver 
			 | 
		
	
		
			
			| 
				
			 | 
			
				205
			 | 
			
			
				+    git checkout $KEYSERVER_SKS_COMMIT -b $KEYSERVER_SKS_COMMIT 
			 | 
		
	
		
			
			| 
				
			 | 
			
				206
			 | 
			
			
				+    set_completion_param "keyserver commit" "$KEYSERVER_SKS_COMMIT" 
			 | 
		
	
		
			
			| 
				
			 | 
			
				207
			 | 
			
			
				+ 
			 | 
		
	
		
			
			| 
				
			 | 
			
				208
			 | 
			
			
				+    cd /var/www/$KEYSERVER_DOMAIN_NAME 
			 | 
		
	
		
			
			| 
				
			 | 
			
				209
			 | 
			
			
				+    if [ -d /var/www/$KEYSERVER_DOMAIN_NAME/htdocs ]; then 
			 | 
		
	
		
			
			| 
				
			 | 
			
				210
			 | 
			
			
				+        rm -rf /var/www/$KEYSERVER_DOMAIN_NAME/htdocs 
			 | 
		
	
		
			
			| 
				
			 | 
			
				211
			 | 
			
			
				+    fi 
			 | 
		
	
		
			
			| 
				
			 | 
			
				212
			 | 
			
			
				+ 
			 | 
		
	
		
			
			| 
				
			 | 
			
				213
			 | 
			
			
				+    if [ -d /repos/keyserverweb ]; then 
			 | 
		
	
		
			
			| 
				
			 | 
			
				214
			 | 
			
			
				+        mkdir htdocs 
			 | 
		
	
		
			
			| 
				
			 | 
			
				215
			 | 
			
			
				+        cp -r -p /repos/keyserverweb/. htdocs 
			 | 
		
	
		
			
			| 
				
			 | 
			
				216
			 | 
			
			
				+        cd htdocs 
			 | 
		
	
		
			
			| 
				
			 | 
			
				217
			 | 
			
			
				+        git pull 
			 | 
		
	
		
			
			| 
				
			 | 
			
				218
			 | 
			
			
				+    else 
			 | 
		
	
		
			
			| 
				
			 | 
			
				219
			 | 
			
			
				+        git_clone $KEYSERVER_WEB_REPO htdocs 
			 | 
		
	
		
			
			| 
				
			 | 
			
				220
			 | 
			
			
				+    fi 
			 | 
		
	
		
			
			| 
				
			 | 
			
				221
			 | 
			
			
				+ 
			 | 
		
	
		
			
			| 
				
			 | 
			
				222
			 | 
			
			
				+    cd /var/www/$KEYSERVER_DOMAIN_NAME/htdocs 
			 | 
		
	
		
			
			| 
				
			 | 
			
				223
			 | 
			
			
				+    git checkout $KEYSERVER_WEB_COMMIT -b $KEYSERVER_WEB_COMMIT 
			 | 
		
	
		
			
			| 
				
			 | 
			
				224
			 | 
			
			
				+    set_completion_param "keyserver web commit" "$KEYSERVER_WEB_COMMIT" 
			 | 
		
	
		
			
			| 
				
			 | 
			
				225
			 | 
			
			
				+ 
			 | 
		
	
		
			
			| 
				
			 | 
			
				226
			 | 
			
			
				+    cd $INSTALL_DIR/keyserver 
			 | 
		
	
		
			
			| 
				
			 | 
			
				227
			 | 
			
			
				+    if [ ! -f Makefile.local.unused ]; then 
			 | 
		
	
		
			
			| 
				
			 | 
			
				228
			 | 
			
			
				+        echo $'Unused makefile not found' 
			 | 
		
	
		
			
			| 
				
			 | 
			
				229
			 | 
			
			
				+        exit 72398 
			 | 
		
	
		
			
			| 
				
			 | 
			
				230
			 | 
			
			
				+    fi 
			 | 
		
	
		
			
			| 
				
			 | 
			
				231
			 | 
			
			
				+    cp Makefile.local.unused Makefile.local 
			 | 
		
	
		
			
			| 
				
			 | 
			
				232
			 | 
			
			
				+    sed -i 's|LIBDB=.*|LIBDB=-ldb-5.3.1|g' Makefile.local 
			 | 
		
	
		
			
			| 
				
			 | 
			
				233
			 | 
			
			
				+ 
			 | 
		
	
		
			
			| 
				
			 | 
			
				234
			 | 
			
			
				+    make dep 
			 | 
		
	
		
			
			| 
				
			 | 
			
				235
			 | 
			
			
				+    make all 
			 | 
		
	
		
			
			| 
				
			 | 
			
				236
			 | 
			
			
				+    if [ ! "$?" = "0" ]; then 
			 | 
		
	
		
			
			| 
				
			 | 
			
				237
			 | 
			
			
				+        echo $'Unable to build sks-keyserver' 
			 | 
		
	
		
			
			| 
				
			 | 
			
				238
			 | 
			
			
				+        exit 8356328 
			 | 
		
	
		
			
			| 
				
			 | 
			
				239
			 | 
			
			
				+    fi 
			 | 
		
	
		
			
			| 
				
			 | 
			
				240
			 | 
			
			
				+    make install 
			 | 
		
	
		
			
			| 
				
			 | 
			
				241
			 | 
			
			
				+ 
			 | 
		
	
		
			
			| 
				
			 | 
			
				242
			 | 
			
			
				+    if [ ! -f /usr/local/bin/sks_build.sh ]; then 
			 | 
		
	
		
			
			| 
				
			 | 
			
				243
			 | 
			
			
				+        echo $'/usr/local/bin/sks_build.sh not found' 
			 | 
		
	
		
			
			| 
				
			 | 
			
				244
			 | 
			
			
				+        exit 238460 
			 | 
		
	
		
			
			| 
				
			 | 
			
				245
			 | 
			
			
				+    fi 
			 | 
		
	
		
			
			| 
				
			 | 
			
				246
			 | 
			
			
				+ 
			 | 
		
	
		
			
			| 
				
			 | 
			
				247
			 | 
			
			
				+    USER_EMAIL_ADDRESS=$MY_USERNAME@$HOSTNAME 
			 | 
		
	
		
			
			| 
				
			 | 
			
				248
			 | 
			
			
				+    GPG_ID=$(su -m root -c "gpg --list-keys $USER_EMAIL_ADDRESS | sed -n '2p' | sed 's/^[ \t]*//'" - $MY_USERNAME) 
			 | 
		
	
		
			
			| 
				
			 | 
			
				249
			 | 
			
			
				+    if [ ! $GPG_ID ]; then 
			 | 
		
	
		
			
			| 
				
			 | 
			
				250
			 | 
			
			
				+        echo $'No GPG ID for admin user' 
			 | 
		
	
		
			
			| 
				
			 | 
			
				251
			 | 
			
			
				+        exit 846336 
			 | 
		
	
		
			
			| 
				
			 | 
			
				252
			 | 
			
			
				+    fi 
			 | 
		
	
		
			
			| 
				
			 | 
			
				253
			 | 
			
			
				+    if [ ${#GPG_ID} -lt 5 ]; then 
			 | 
		
	
		
			
			| 
				
			 | 
			
				254
			 | 
			
			
				+        echo $'GPG ID not retrieved for admin user' 
			 | 
		
	
		
			
			| 
				
			 | 
			
				255
			 | 
			
			
				+        exit 835292 
			 | 
		
	
		
			
			| 
				
			 | 
			
				256
			 | 
			
			
				+    fi 
			 | 
		
	
		
			
			| 
				
			 | 
			
				257
			 | 
			
			
				+    if [[ "$GPG_ID" == *"error"* ]]; then 
			 | 
		
	
		
			
			| 
				
			 | 
			
				258
			 | 
			
			
				+        echo $'GPG ID not retrieved for admin user due to error' 
			 | 
		
	
		
			
			| 
				
			 | 
			
				259
			 | 
			
			
				+        exit 74825 
			 | 
		
	
		
			
			| 
				
			 | 
			
				260
			 | 
			
			
				+    fi 
			 | 
		
	
		
			
			| 
				
			 | 
			
				261
			 | 
			
			
				+ 
			 | 
		
	
		
			
			| 
				
			 | 
			
				262
			 | 
			
			
				+    sksconf_file=/var/lib/sks/sksconf 
			 | 
		
	
		
			
			| 
				
			 | 
			
				263
			 | 
			
			
				+    echo 'debuglevel: 3' > $sksconf_file 
			 | 
		
	
		
			
			| 
				
			 | 
			
				264
			 | 
			
			
				+    echo '' >> $sksconf_file 
			 | 
		
	
		
			
			| 
				
			 | 
			
				265
			 | 
			
			
				+    echo "hostname:                       $KEYSERVER_DOMAIN_NAME" >> $sksconf_file 
			 | 
		
	
		
			
			| 
				
			 | 
			
				266
			 | 
			
			
				+    echo '' >> $sksconf_file 
			 | 
		
	
		
			
			| 
				
			 | 
			
				267
			 | 
			
			
				+    echo 'hkp_address:                    127.0.0.1' >> $sksconf_file 
			 | 
		
	
		
			
			| 
				
			 | 
			
				268
			 | 
			
			
				+    echo "hkp_port:                       $KEYSERVER_PORT" >> $sksconf_file 
			 | 
		
	
		
			
			| 
				
			 | 
			
				269
			 | 
			
			
				+    echo 'recon_port:                     11370' >> $sksconf_file 
			 | 
		
	
		
			
			| 
				
			 | 
			
				270
			 | 
			
			
				+    echo '' >> $sksconf_file 
			 | 
		
	
		
			
			| 
				
			 | 
			
				271
			 | 
			
			
				+    echo "server_contact:                 $GPG_ID" >> $sksconf_file 
			 | 
		
	
		
			
			| 
				
			 | 
			
				272
			 | 
			
			
				+    echo '' >> $sksconf_file 
			 | 
		
	
		
			
			| 
				
			 | 
			
				273
			 | 
			
			
				+    echo 'initial_stat:' >> $sksconf_file 
			 | 
		
	
		
			
			| 
				
			 | 
			
				274
			 | 
			
			
				+    echo 'disable_mailsync:' >> $sksconf_file 
			 | 
		
	
		
			
			| 
				
			 | 
			
				275
			 | 
			
			
				+    echo 'membership_reload_interval:     1' >> $sksconf_file 
			 | 
		
	
		
			
			| 
				
			 | 
			
				276
			 | 
			
			
				+    echo 'stat_hour:                      12' >> $sksconf_file 
			 | 
		
	
		
			
			| 
				
			 | 
			
				277
			 | 
			
			
				+    echo '' >> $sksconf_file 
			 | 
		
	
		
			
			| 
				
			 | 
			
				278
			 | 
			
			
				+    echo 'max_matches:                    500' >> $sksconf_file 
			 | 
		
	
		
			
			| 
				
			 | 
			
				279
			 | 
			
			
				+ 
			 | 
		
	
		
			
			| 
				
			 | 
			
				280
			 | 
			
			
				+    if [ ! -d /var/lib/sks/dump ]; then 
			 | 
		
	
		
			
			| 
				
			 | 
			
				281
			 | 
			
			
				+        mkdir -p /var/lib/sks/dump 
			 | 
		
	
		
			
			| 
				
			 | 
			
				282
			 | 
			
			
				+    fi 
			 | 
		
	
		
			
			| 
				
			 | 
			
				283
			 | 
			
			
				+    cd /var/lib/sks/dump 
			 | 
		
	
		
			
			| 
				
			 | 
			
				284
			 | 
			
			
				+    echo $'Getting keyserver dump. This may take a few hours, so be patient.' 
			 | 
		
	
		
			
			| 
				
			 | 
			
				285
			 | 
			
			
				+    wget -crp -e robots=off --level=1 --cut-dirs=3 -nH \ 
			 | 
		
	
		
			
			| 
				
			 | 
			
				286
			 | 
			
			
				+         -A pgp,txt $KEYSERVER_DUMP_URL 
			 | 
		
	
		
			
			| 
				
			 | 
			
				287
			 | 
			
			
				+ 
			 | 
		
	
		
			
			| 
				
			 | 
			
				288
			 | 
			
			
				+    cd /var/lib/sks 
			 | 
		
	
		
			
			| 
				
			 | 
			
				289
			 | 
			
			
				+    echo $'Building the keyserver database from the downloaded dump' 
			 | 
		
	
		
			
			| 
				
			 | 
			
				290
			 | 
			
			
				+    echo '2' | /usr/local/bin/sks_build.sh 
			 | 
		
	
		
			
			| 
				
			 | 
			
				291
			 | 
			
			
				+ 
			 | 
		
	
		
			
			| 
				
			 | 
			
				292
			 | 
			
			
				+    KEYSERVER_ONION_HOSTNAME=$(add_onion_service keyserver 80 ${KEYSERVER_ONION_PORT}) 
			 | 
		
	
		
			
			| 
				
			 | 
			
				293
			 | 
			
			
				+ 
			 | 
		
	
		
			
			| 
				
			 | 
			
				294
			 | 
			
			
				+    echo '#!/bin/sh' > /usr/bin/keyserver-start 
			 | 
		
	
		
			
			| 
				
			 | 
			
				295
			 | 
			
			
				+    echo 'cd /var/lib/sks' >> /usr/bin/keyserver-start 
			 | 
		
	
		
			
			| 
				
			 | 
			
				296
			 | 
			
			
				+    echo 'echo -n \ sks_db' >> /usr/bin/keyserver-start 
			 | 
		
	
		
			
			| 
				
			 | 
			
				297
			 | 
			
			
				+    echo '$DAEMON db &' >> /usr/bin/keyserver-start 
			 | 
		
	
		
			
			| 
				
			 | 
			
				298
			 | 
			
			
				+    echo 'echo -n \ sks_recon' >> /usr/bin/keyserver-start 
			 | 
		
	
		
			
			| 
				
			 | 
			
				299
			 | 
			
			
				+    echo '$DAEMON recon &' >> /usr/bin/keyserver-start 
			 | 
		
	
		
			
			| 
				
			 | 
			
				300
			 | 
			
			
				+    chmod +x /usr/bin/keyserver-start 
			 | 
		
	
		
			
			| 
				
			 | 
			
				301
			 | 
			
			
				+ 
			 | 
		
	
		
			
			| 
				
			 | 
			
				302
			 | 
			
			
				+    echo '#!/bin/sh' > /usr/bin/keyserver-stop 
			 | 
		
	
		
			
			| 
				
			 | 
			
				303
			 | 
			
			
				+    echo 'killall sks' >> /usr/bin/keyserver-stop 
			 | 
		
	
		
			
			| 
				
			 | 
			
				304
			 | 
			
			
				+    echo 'sleep 5' >> /usr/bin/keyserver-stop 
			 | 
		
	
		
			
			| 
				
			 | 
			
				305
			 | 
			
			
				+    chmod +x /usr/bin/keyserver-stop 
			 | 
		
	
		
			
			| 
				
			 | 
			
				306
			 | 
			
			
				+ 
			 | 
		
	
		
			
			| 
				
			 | 
			
				307
			 | 
			
			
				+    echo '[Unit]' > /etc/systemd/system/keyserver.service 
			 | 
		
	
		
			
			| 
				
			 | 
			
				308
			 | 
			
			
				+    echo 'Description=SKS Keyserver' >> /etc/systemd/system/keyserver.service 
			 | 
		
	
		
			
			| 
				
			 | 
			
				309
			 | 
			
			
				+    echo 'After=syslog.target network.target nginx.target' >> /etc/systemd/system/keyserver.service 
			 | 
		
	
		
			
			| 
				
			 | 
			
				310
			 | 
			
			
				+    echo '' >> /etc/systemd/system/keyserver.service 
			 | 
		
	
		
			
			| 
				
			 | 
			
				311
			 | 
			
			
				+    echo '[Service]' >> /etc/systemd/system/keyserver.service 
			 | 
		
	
		
			
			| 
				
			 | 
			
				312
			 | 
			
			
				+    echo 'User=keyserver' >> /etc/systemd/system/keyserver.service 
			 | 
		
	
		
			
			| 
				
			 | 
			
				313
			 | 
			
			
				+    echo 'Group=keyserver' >> /etc/systemd/system/keyserver.service 
			 | 
		
	
		
			
			| 
				
			 | 
			
				314
			 | 
			
			
				+    echo "WorkingDirectory=/var/lib/sks" >> /etc/systemd/system/keyserver.service 
			 | 
		
	
		
			
			| 
				
			 | 
			
				315
			 | 
			
			
				+    echo "ExecStart=/usr/bin/keyserver-start" >> /etc/systemd/system/keyserver.service 
			 | 
		
	
		
			
			| 
				
			 | 
			
				316
			 | 
			
			
				+    echo "ExecStop=/usr/bin/keyserver-stop" >> /etc/systemd/system/keyserver.service 
			 | 
		
	
		
			
			| 
				
			 | 
			
				317
			 | 
			
			
				+    echo 'Restart=always' >> /etc/systemd/system/keyserver.service 
			 | 
		
	
		
			
			| 
				
			 | 
			
				318
			 | 
			
			
				+    echo 'RestartSec=10' >> /etc/systemd/system/keyserver.service 
			 | 
		
	
		
			
			| 
				
			 | 
			
				319
			 | 
			
			
				+    echo '' >> /etc/systemd/system/keyserver.service 
			 | 
		
	
		
			
			| 
				
			 | 
			
				320
			 | 
			
			
				+    echo '[Install]' >> /etc/systemd/system/keyserver.service 
			 | 
		
	
		
			
			| 
				
			 | 
			
				321
			 | 
			
			
				+    echo 'WantedBy=multi-user.target' >> /etc/systemd/system/keyserver.service 
			 | 
		
	
		
			
			| 
				
			 | 
			
				322
			 | 
			
			
				+    chmod +x /etc/systemd/system/keyserver.service 
			 | 
		
	
		
			
			| 
				
			 | 
			
				323
			 | 
			
			
				+ 
			 | 
		
	
		
			
			| 
				
			 | 
			
				324
			 | 
			
			
				+    keyserver_nginx_site=/etc/nginx/sites-available/$KEYSERVER_DOMAIN_NAME 
			 | 
		
	
		
			
			| 
				
			 | 
			
				325
			 | 
			
			
				+    if [[ $ONION_ONLY == "no" ]]; then 
			 | 
		
	
		
			
			| 
				
			 | 
			
				326
			 | 
			
			
				+        function_check nginx_http_redirect 
			 | 
		
	
		
			
			| 
				
			 | 
			
				327
			 | 
			
			
				+        nginx_http_redirect $KEYSERVER_DOMAIN_NAME 
			 | 
		
	
		
			
			| 
				
			 | 
			
				328
			 | 
			
			
				+        echo 'server {' >> $keyserver_nginx_site 
			 | 
		
	
		
			
			| 
				
			 | 
			
				329
			 | 
			
			
				+        echo '  listen 443 ssl;' >> $keyserver_nginx_site 
			 | 
		
	
		
			
			| 
				
			 | 
			
				330
			 | 
			
			
				+        echo '  listen [::]:443 ssl;' >> $keyserver_nginx_site 
			 | 
		
	
		
			
			| 
				
			 | 
			
				331
			 | 
			
			
				+        echo "  server_name $KEYSERVER_DOMAIN_NAME;" >> $keyserver_nginx_site 
			 | 
		
	
		
			
			| 
				
			 | 
			
				332
			 | 
			
			
				+        echo '' >> $keyserver_nginx_site 
			 | 
		
	
		
			
			| 
				
			 | 
			
				333
			 | 
			
			
				+        echo '  # Security' >> $keyserver_nginx_site 
			 | 
		
	
		
			
			| 
				
			 | 
			
				334
			 | 
			
			
				+        function_check nginx_ssl 
			 | 
		
	
		
			
			| 
				
			 | 
			
				335
			 | 
			
			
				+        nginx_ssl $KEYSERVER_DOMAIN_NAME 
			 | 
		
	
		
			
			| 
				
			 | 
			
				336
			 | 
			
			
				+ 
			 | 
		
	
		
			
			| 
				
			 | 
			
				337
			 | 
			
			
				+        function_check nginx_disable_sniffing 
			 | 
		
	
		
			
			| 
				
			 | 
			
				338
			 | 
			
			
				+        nginx_disable_sniffing $KEYSERVER_DOMAIN_NAME 
			 | 
		
	
		
			
			| 
				
			 | 
			
				339
			 | 
			
			
				+ 
			 | 
		
	
		
			
			| 
				
			 | 
			
				340
			 | 
			
			
				+        echo '  add_header Strict-Transport-Security max-age=15768000;' >> $keyserver_nginx_site 
			 | 
		
	
		
			
			| 
				
			 | 
			
				341
			 | 
			
			
				+        echo '' >> $keyserver_nginx_site 
			 | 
		
	
		
			
			| 
				
			 | 
			
				342
			 | 
			
			
				+        echo '  # Logs' >> $keyserver_nginx_site 
			 | 
		
	
		
			
			| 
				
			 | 
			
				343
			 | 
			
			
				+        echo '  access_log /dev/null;' >> $keyserver_nginx_site 
			 | 
		
	
		
			
			| 
				
			 | 
			
				344
			 | 
			
			
				+        echo '  error_log /dev/null;' >> $keyserver_nginx_site 
			 | 
		
	
		
			
			| 
				
			 | 
			
				345
			 | 
			
			
				+        echo '' >> $keyserver_nginx_site 
			 | 
		
	
		
			
			| 
				
			 | 
			
				346
			 | 
			
			
				+        echo '  # Root' >> $keyserver_nginx_site 
			 | 
		
	
		
			
			| 
				
			 | 
			
				347
			 | 
			
			
				+        echo "  root /var/www/$KEYSERVER_DOMAIN_NAME/htdocs;" >> $keyserver_nginx_site 
			 | 
		
	
		
			
			| 
				
			 | 
			
				348
			 | 
			
			
				+        echo '' >> $keyserver_nginx_site 
			 | 
		
	
		
			
			| 
				
			 | 
			
				349
			 | 
			
			
				+ 
			 | 
		
	
		
			
			| 
				
			 | 
			
				350
			 | 
			
			
				+        echo '  rewrite ^/stats /pks/lookup?op=stats;' >> $keyserver_nginx_site 
			 | 
		
	
		
			
			| 
				
			 | 
			
				351
			 | 
			
			
				+        echo '  rewrite ^/s/(.*) /pks/lookup?search=$1;' >> $keyserver_nginx_site 
			 | 
		
	
		
			
			| 
				
			 | 
			
				352
			 | 
			
			
				+        echo '  rewrite ^/search/(.*) /pks/lookup?search=$1;' >> $keyserver_nginx_site 
			 | 
		
	
		
			
			| 
				
			 | 
			
				353
			 | 
			
			
				+        echo '  rewrite ^/g/(.*) /pks/lookup?op=get&search=$1;' >> $keyserver_nginx_site 
			 | 
		
	
		
			
			| 
				
			 | 
			
				354
			 | 
			
			
				+        echo '  rewrite ^/get/(.*) /pks/lookup?op=get&search=$1;' >> $keyserver_nginx_site 
			 | 
		
	
		
			
			| 
				
			 | 
			
				355
			 | 
			
			
				+        echo '  rewrite ^/d/(.*) /pks/lookup?op=get&options=mr&search=$1;' >> $keyserver_nginx_site 
			 | 
		
	
		
			
			| 
				
			 | 
			
				356
			 | 
			
			
				+        echo '  rewrite ^/download/(.*) /pks/lookup?op=get&options=mr&search=$1;' >> $keyserver_nginx_site 
			 | 
		
	
		
			
			| 
				
			 | 
			
				357
			 | 
			
			
				+        echo '' >> $keyserver_nginx_site 
			 | 
		
	
		
			
			| 
				
			 | 
			
				358
			 | 
			
			
				+        echo '  location /pks {' >> $keyserver_nginx_site 
			 | 
		
	
		
			
			| 
				
			 | 
			
				359
			 | 
			
			
				+        echo "    proxy_pass         http://127.0.0.1:$KEYSERVER_PORT;" >> $keyserver_nginx_site 
			 | 
		
	
		
			
			| 
				
			 | 
			
				360
			 | 
			
			
				+        echo '    proxy_pass_header  Server;' >> $keyserver_nginx_site 
			 | 
		
	
		
			
			| 
				
			 | 
			
				361
			 | 
			
			
				+        echo "    add_header         Via \"1.1 $KEYSERVER_DOMAIN_NAME:$KEYSERVER_PORT (nginx)\";" >> $keyserver_nginx_site 
			 | 
		
	
		
			
			| 
				
			 | 
			
				362
			 | 
			
			
				+        echo '    proxy_ignore_client_abort on;' >> $keyserver_nginx_site 
			 | 
		
	
		
			
			| 
				
			 | 
			
				363
			 | 
			
			
				+        echo '    client_max_body_size 8m;' >> $keyserver_nginx_site 
			 | 
		
	
		
			
			| 
				
			 | 
			
				364
			 | 
			
			
				+        echo '  }' >> $keyserver_nginx_site 
			 | 
		
	
		
			
			| 
				
			 | 
			
				365
			 | 
			
			
				+        echo '}' >> $keyserver_nginx_site 
			 | 
		
	
		
			
			| 
				
			 | 
			
				366
			 | 
			
			
				+        echo '' >> $keyserver_nginx_site 
			 | 
		
	
		
			
			| 
				
			 | 
			
				367
			 | 
			
			
				+    else 
			 | 
		
	
		
			
			| 
				
			 | 
			
				368
			 | 
			
			
				+        echo -n '' > $keyserver_nginx_site 
			 | 
		
	
		
			
			| 
				
			 | 
			
				369
			 | 
			
			
				+    fi 
			 | 
		
	
		
			
			| 
				
			 | 
			
				370
			 | 
			
			
				+    echo 'server {' >> $keyserver_nginx_site 
			 | 
		
	
		
			
			| 
				
			 | 
			
				371
			 | 
			
			
				+    echo "    listen 127.0.0.1:$KEYSERVER_ONION_PORT default_server;" >> $keyserver_nginx_site 
			 | 
		
	
		
			
			| 
				
			 | 
			
				372
			 | 
			
			
				+    echo "    server_name $KEYSERVER_ONION_HOSTNAME;" >> $keyserver_nginx_site 
			 | 
		
	
		
			
			| 
				
			 | 
			
				373
			 | 
			
			
				+    echo '' >> $keyserver_nginx_site 
			 | 
		
	
		
			
			| 
				
			 | 
			
				374
			 | 
			
			
				+    function_check nginx_disable_sniffing 
			 | 
		
	
		
			
			| 
				
			 | 
			
				375
			 | 
			
			
				+    nginx_disable_sniffing $KEYSERVER_DOMAIN_NAME 
			 | 
		
	
		
			
			| 
				
			 | 
			
				376
			 | 
			
			
				+    echo '' >> $keyserver_nginx_site 
			 | 
		
	
		
			
			| 
				
			 | 
			
				377
			 | 
			
			
				+    echo '  # Logs' >> $keyserver_nginx_site 
			 | 
		
	
		
			
			| 
				
			 | 
			
				378
			 | 
			
			
				+    echo '  access_log /dev/null;' >> $keyserver_nginx_site 
			 | 
		
	
		
			
			| 
				
			 | 
			
				379
			 | 
			
			
				+    echo '  error_log /dev/null;' >> $keyserver_nginx_site 
			 | 
		
	
		
			
			| 
				
			 | 
			
				380
			 | 
			
			
				+    echo '' >> $keyserver_nginx_site 
			 | 
		
	
		
			
			| 
				
			 | 
			
				381
			 | 
			
			
				+    echo '  # Root' >> $keyserver_nginx_site 
			 | 
		
	
		
			
			| 
				
			 | 
			
				382
			 | 
			
			
				+    echo "  root /var/www/$KEYSERVER_DOMAIN_NAME/mail;" >> $keyserver_nginx_site 
			 | 
		
	
		
			
			| 
				
			 | 
			
				383
			 | 
			
			
				+    echo '' >> $keyserver_nginx_site 
			 | 
		
	
		
			
			| 
				
			 | 
			
				384
			 | 
			
			
				+    echo '  rewrite ^/stats /pks/lookup?op=stats;' >> $keyserver_nginx_site 
			 | 
		
	
		
			
			| 
				
			 | 
			
				385
			 | 
			
			
				+    echo '  rewrite ^/s/(.*) /pks/lookup?search=$1;' >> $keyserver_nginx_site 
			 | 
		
	
		
			
			| 
				
			 | 
			
				386
			 | 
			
			
				+    echo '  rewrite ^/search/(.*) /pks/lookup?search=$1;' >> $keyserver_nginx_site 
			 | 
		
	
		
			
			| 
				
			 | 
			
				387
			 | 
			
			
				+    echo '  rewrite ^/g/(.*) /pks/lookup?op=get&search=$1;' >> $keyserver_nginx_site 
			 | 
		
	
		
			
			| 
				
			 | 
			
				388
			 | 
			
			
				+    echo '  rewrite ^/get/(.*) /pks/lookup?op=get&search=$1;' >> $keyserver_nginx_site 
			 | 
		
	
		
			
			| 
				
			 | 
			
				389
			 | 
			
			
				+    echo '  rewrite ^/d/(.*) /pks/lookup?op=get&options=mr&search=$1;' >> $keyserver_nginx_site 
			 | 
		
	
		
			
			| 
				
			 | 
			
				390
			 | 
			
			
				+    echo '  rewrite ^/download/(.*) /pks/lookup?op=get&options=mr&search=$1;' >> $keyserver_nginx_site 
			 | 
		
	
		
			
			| 
				
			 | 
			
				391
			 | 
			
			
				+    echo '' >> $keyserver_nginx_site 
			 | 
		
	
		
			
			| 
				
			 | 
			
				392
			 | 
			
			
				+    echo '  location /pks {' >> $keyserver_nginx_site 
			 | 
		
	
		
			
			| 
				
			 | 
			
				393
			 | 
			
			
				+    echo "    proxy_pass         http://127.0.0.1:$KEYSERVER_PORT;" >> $keyserver_nginx_site 
			 | 
		
	
		
			
			| 
				
			 | 
			
				394
			 | 
			
			
				+    echo '    proxy_pass_header  Server;' >> $keyserver_nginx_site 
			 | 
		
	
		
			
			| 
				
			 | 
			
				395
			 | 
			
			
				+    echo "    add_header         Via \"1.1 $KEYSERVER_DOMAIN_NAME:$KEYSERVER_PORT (nginx)\";" >> $keyserver_nginx_site 
			 | 
		
	
		
			
			| 
				
			 | 
			
				396
			 | 
			
			
				+    echo '    proxy_ignore_client_abort on;' >> $keyserver_nginx_site 
			 | 
		
	
		
			
			| 
				
			 | 
			
				397
			 | 
			
			
				+    echo '    client_max_body_size 8m;' >> $keyserver_nginx_site 
			 | 
		
	
		
			
			| 
				
			 | 
			
				398
			 | 
			
			
				+    echo '  }' >> $keyserver_nginx_site 
			 | 
		
	
		
			
			| 
				
			 | 
			
				399
			 | 
			
			
				+    echo '}' >> $keyserver_nginx_site 
			 | 
		
	
		
			
			| 
				
			 | 
			
				400
			 | 
			
			
				+ 
			 | 
		
	
		
			
			| 
				
			 | 
			
				401
			 | 
			
			
				+    function_check create_site_certificate 
			 | 
		
	
		
			
			| 
				
			 | 
			
				402
			 | 
			
			
				+    if [ ! -f /etc/ssl/certs/${KEYSERVER_DOMAIN_NAME}.pem ]; then 
			 | 
		
	
		
			
			| 
				
			 | 
			
				403
			 | 
			
			
				+        create_site_certificate $KEYSERVER_DOMAIN_NAME 'yes' 
			 | 
		
	
		
			
			| 
				
			 | 
			
				404
			 | 
			
			
				+    fi 
			 | 
		
	
		
			
			| 
				
			 | 
			
				405
			 | 
			
			
				+ 
			 | 
		
	
		
			
			| 
				
			 | 
			
				406
			 | 
			
			
				+    if [ -f /etc/ssl/certs/${KEYSERVER_DOMAIN_NAME}.crt ]; then 
			 | 
		
	
		
			
			| 
				
			 | 
			
				407
			 | 
			
			
				+        mv /etc/ssl/certs/${KEYSERVER_DOMAIN_NAME}.crt /etc/ssl/certs/${KEYSERVER_DOMAIN_NAME}.pem 
			 | 
		
	
		
			
			| 
				
			 | 
			
				408
			 | 
			
			
				+    fi 
			 | 
		
	
		
			
			| 
				
			 | 
			
				409
			 | 
			
			
				+    if [ -f /etc/ssl/certs/${KEYSERVER_DOMAIN_NAME}.pem ]; then 
			 | 
		
	
		
			
			| 
				
			 | 
			
				410
			 | 
			
			
				+        chown root:root /etc/ssl/certs/${KEYSERVER_DOMAIN_NAME}.pem 
			 | 
		
	
		
			
			| 
				
			 | 
			
				411
			 | 
			
			
				+        sed -i "s|.crt|.pem|g" /etc/nginx/sites-available/${KEYSERVER_DOMAIN_NAME} 
			 | 
		
	
		
			
			| 
				
			 | 
			
				412
			 | 
			
			
				+    fi 
			 | 
		
	
		
			
			| 
				
			 | 
			
				413
			 | 
			
			
				+    if [ -f /etc/ssl/private/${KEYSERVER_DOMAIN_NAME}.key ]; then 
			 | 
		
	
		
			
			| 
				
			 | 
			
				414
			 | 
			
			
				+        chown root:root /etc/ssl/private/${KEYSERVER_DOMAIN_NAME}.key 
			 | 
		
	
		
			
			| 
				
			 | 
			
				415
			 | 
			
			
				+    fi 
			 | 
		
	
		
			
			| 
				
			 | 
			
				416
			 | 
			
			
				+ 
			 | 
		
	
		
			
			| 
				
			 | 
			
				417
			 | 
			
			
				+    groupadd keyserver 
			 | 
		
	
		
			
			| 
				
			 | 
			
				418
			 | 
			
			
				+    useradd -c "SKS Keyserver system account" -d /var/lib/sks -m -r -g keyserver keyserver 
			 | 
		
	
		
			
			| 
				
			 | 
			
				419
			 | 
			
			
				+    chown -R keyserver:keyserver /var/lib/sks 
			 | 
		
	
		
			
			| 
				
			 | 
			
				420
			 | 
			
			
				+    chown -R www-data:www-data /var/www/$KEYSERVER_DOMAIN_NAME/htdocs 
			 | 
		
	
		
			
			| 
				
			 | 
			
				421
			 | 
			
			
				+ 
			 | 
		
	
		
			
			| 
				
			 | 
			
				422
			 | 
			
			
				+    function_check nginx_ensite 
			 | 
		
	
		
			
			| 
				
			 | 
			
				423
			 | 
			
			
				+    nginx_ensite $KEYSERVER_DOMAIN_NAME 
			 | 
		
	
		
			
			| 
				
			 | 
			
				424
			 | 
			
			
				+ 
			 | 
		
	
		
			
			| 
				
			 | 
			
				425
			 | 
			
			
				+    systemctl enable keyserver 
			 | 
		
	
		
			
			| 
				
			 | 
			
				426
			 | 
			
			
				+    systemctl daemon-reload 
			 | 
		
	
		
			
			| 
				
			 | 
			
				427
			 | 
			
			
				+    systemctl start keyserver 
			 | 
		
	
		
			
			| 
				
			 | 
			
				428
			 | 
			
			
				+    systemctl restart nginx 
			 | 
		
	
		
			
			| 
				
			 | 
			
				429
			 | 
			
			
				+ 
			 | 
		
	
		
			
			| 
				
			 | 
			
				430
			 | 
			
			
				+    set_completion_param "keyserver domain" "$KEYSERVER_DOMAIN_NAME" 
			 | 
		
	
		
			
			| 
				
			 | 
			
				431
			 | 
			
			
				+ 
			 | 
		
	
		
			
			| 
				
			 | 
			
				432
			 | 
			
			
				+    APP_INSTALLED=1 
			 | 
		
	
		
			
			| 
				
			 | 
			
				433
			 | 
			
			
				+} 
			 | 
		
	
		
			
			| 
				
			 | 
			
				434
			 | 
			
			
				+ 
			 | 
		
	
		
			
			| 
				
			 | 
			
				435
			 | 
			
			
				+# NOTE: deliberately no exit 0 
			 |