|  | @@ -39,289 +39,206 @@ MY_BLOG_TITLE="My Blog"
 | 
	
		
			
			| 39 | 39 |  MY_BLOG_SUBTITLE="Another ${PROJECT_NAME} Blog"
 | 
	
		
			
			| 40 | 40 |  
 | 
	
		
			
			| 41 | 41 |  function reconfigure_blog {
 | 
	
		
			
			| 42 |  | -	echo -n ''
 | 
	
		
			
			|  | 42 | +    echo -n ''
 | 
	
		
			
			| 43 | 43 |  }
 | 
	
		
			
			| 44 | 44 |  
 | 
	
		
			
			| 45 | 45 |  function upgrade_blog {
 | 
	
		
			
			| 46 |  | -	if ! grep -Fxq "install_blog" $COMPLETION_FILE; then
 | 
	
		
			
			| 47 |  | -		return
 | 
	
		
			
			| 48 |  | -	fi
 | 
	
		
			
			| 49 |  | -	function_check set_repo_commit
 | 
	
		
			
			| 50 |  | -	set_repo_commit /var/www/$FULLBLOG_DOMAIN_NAME/htdocs "Blog commit" "$FULLBLOG_COMMIT" $FULLBLOG_REPO
 | 
	
		
			
			| 51 |  | -
 | 
	
		
			
			| 52 |  | -	# update blog avatar
 | 
	
		
			
			| 53 |  | -	${PROJECT_NAME}-blog
 | 
	
		
			
			|  | 46 | +    if ! grep -Fxq "install_blog" $COMPLETION_FILE; then
 | 
	
		
			
			|  | 47 | +	return
 | 
	
		
			
			|  | 48 | +    fi
 | 
	
		
			
			|  | 49 | +    function_check set_repo_commit
 | 
	
		
			
			|  | 50 | +    set_repo_commit /var/www/$FULLBLOG_DOMAIN_NAME/htdocs "Blog commit" "$FULLBLOG_COMMIT" $FULLBLOG_REPO
 | 
	
		
			
			|  | 51 | +
 | 
	
		
			
			|  | 52 | +    # update blog avatar
 | 
	
		
			
			|  | 53 | +    ${PROJECT_NAME}-blog
 | 
	
		
			
			| 54 | 54 |  }
 | 
	
		
			
			| 55 | 55 |  
 | 
	
		
			
			| 56 | 56 |  function backup_local_blog {
 | 
	
		
			
			| 57 |  | -	FULLBLOG_DOMAIN_NAME='blog'
 | 
	
		
			
			| 58 |  | -	if grep -q "Blog domain" $COMPLETION_FILE; then
 | 
	
		
			
			| 59 |  | -		FULLBLOG_DOMAIN_NAME=$(cat $COMPLETION_FILE | grep "Blog domain" | awk -F ':' '{print $2}')
 | 
	
		
			
			| 60 |  | -	fi
 | 
	
		
			
			|  | 57 | +    FULLBLOG_DOMAIN_NAME='blog'
 | 
	
		
			
			|  | 58 | +    if grep -q "Blog domain" $COMPLETION_FILE; then
 | 
	
		
			
			|  | 59 | +	FULLBLOG_DOMAIN_NAME=$(cat $COMPLETION_FILE | grep "Blog domain" | awk -F ':' '{print $2}')
 | 
	
		
			
			|  | 60 | +    fi
 | 
	
		
			
			| 61 | 61 |  
 | 
	
		
			
			| 62 |  | -	source_directory=/var/www/${FULLBLOG_DOMAIN_NAME}/htdocs
 | 
	
		
			
			| 63 |  | -	if [ -d $source_directory ]; then
 | 
	
		
			
			| 64 |  | -		dest_directory=blog
 | 
	
		
			
			| 65 |  | -		echo $"Backing up $source_directory to $dest_directory"
 | 
	
		
			
			|  | 62 | +    source_directory=/var/www/${FULLBLOG_DOMAIN_NAME}/htdocs
 | 
	
		
			
			|  | 63 | +    if [ -d $source_directory ]; then
 | 
	
		
			
			|  | 64 | +	dest_directory=blog
 | 
	
		
			
			|  | 65 | +	echo $"Backing up $source_directory to $dest_directory"
 | 
	
		
			
			| 66 | 66 |  
 | 
	
		
			
			| 67 |  | -		function_check suspend_site
 | 
	
		
			
			| 68 |  | -		suspend_site ${FULLBLOG_DOMAIN_NAME}
 | 
	
		
			
			|  | 67 | +	function_check suspend_site
 | 
	
		
			
			|  | 68 | +	suspend_site ${FULLBLOG_DOMAIN_NAME}
 | 
	
		
			
			| 69 | 69 |  
 | 
	
		
			
			| 70 |  | -		function_check backup_directory_to_usb
 | 
	
		
			
			| 71 |  | -		backup_directory_to_usb $source_directory $dest_directory
 | 
	
		
			
			|  | 70 | +	function_check backup_directory_to_usb
 | 
	
		
			
			|  | 71 | +	backup_directory_to_usb $source_directory $dest_directory
 | 
	
		
			
			| 72 | 72 |  
 | 
	
		
			
			| 73 |  | -		function_check restart_site
 | 
	
		
			
			| 74 |  | -		restart_site
 | 
	
		
			
			|  | 73 | +	function_check restart_site
 | 
	
		
			
			|  | 74 | +	restart_site
 | 
	
		
			
			| 75 | 75 |  
 | 
	
		
			
			| 76 |  | -		echo $"Backup to $dest_directory complete"
 | 
	
		
			
			| 77 |  | -	fi
 | 
	
		
			
			|  | 76 | +	echo $"Backup to $dest_directory complete"
 | 
	
		
			
			|  | 77 | +    fi
 | 
	
		
			
			| 78 | 78 |  }
 | 
	
		
			
			| 79 | 79 |  
 | 
	
		
			
			| 80 | 80 |  function restore_local_blog {
 | 
	
		
			
			| 81 |  | -	FULLBLOG_DOMAIN_NAME='blog'
 | 
	
		
			
			| 82 |  | -	if grep -q "Blog domain" $COMPLETION_FILE; then
 | 
	
		
			
			| 83 |  | -		FULLBLOG_DOMAIN_NAME=$(cat $COMPLETION_FILE | grep "Blog domain" | awk -F ':' '{print $2}')
 | 
	
		
			
			|  | 81 | +    FULLBLOG_DOMAIN_NAME='blog'
 | 
	
		
			
			|  | 82 | +    if grep -q "Blog domain" $COMPLETION_FILE; then
 | 
	
		
			
			|  | 83 | +	FULLBLOG_DOMAIN_NAME=$(cat $COMPLETION_FILE | grep "Blog domain" | awk -F ':' '{print $2}')
 | 
	
		
			
			|  | 84 | +    fi
 | 
	
		
			
			|  | 85 | +    if [ $FULLBLOG_DOMAIN_NAME ]; then
 | 
	
		
			
			|  | 86 | +	echo $"Restoring blog installation"
 | 
	
		
			
			|  | 87 | +	temp_restore_dir=/root/tempblog
 | 
	
		
			
			|  | 88 | +	restore_directory_from_usb $temp_restore_dir blog
 | 
	
		
			
			|  | 89 | +	rm -rf /var/www/${FULLBLOG_DOMAIN_NAME}/htdocs
 | 
	
		
			
			|  | 90 | +	cp -r $temp_restore_dir/var/www/${FULLBLOG_DOMAIN_NAME}/htdocs /var/www/${FULLBLOG_DOMAIN_NAME}/
 | 
	
		
			
			|  | 91 | +	if [ ! "$?" = "0" ]; then
 | 
	
		
			
			|  | 92 | +	    set_user_permissions
 | 
	
		
			
			|  | 93 | +	    backup_unmount_drive
 | 
	
		
			
			|  | 94 | +	    exit 593
 | 
	
		
			
			| 84 | 95 |  	fi
 | 
	
		
			
			| 85 |  | -	if [ $FULLBLOG_DOMAIN_NAME ]; then
 | 
	
		
			
			| 86 |  | -		echo $"Restoring blog installation"
 | 
	
		
			
			| 87 |  | -		temp_restore_dir=/root/tempblog
 | 
	
		
			
			| 88 |  | -		restore_directory_from_usb $temp_restore_dir blog
 | 
	
		
			
			| 89 |  | -		rm -rf /var/www/${FULLBLOG_DOMAIN_NAME}/htdocs
 | 
	
		
			
			| 90 |  | -		cp -r $temp_restore_dir/var/www/${FULLBLOG_DOMAIN_NAME}/htdocs /var/www/${FULLBLOG_DOMAIN_NAME}/
 | 
	
		
			
			| 91 |  | -		if [ ! "$?" = "0" ]; then
 | 
	
		
			
			| 92 |  | -			set_user_permissions
 | 
	
		
			
			| 93 |  | -			backup_unmount_drive
 | 
	
		
			
			| 94 |  | -			exit 593
 | 
	
		
			
			| 95 |  | -		fi
 | 
	
		
			
			| 96 |  | -		rm -rf $temp_restore_dir
 | 
	
		
			
			| 97 |  | -		if [ ! -d /var/www/${FULLBLOG_DOMAIN_NAME}/htdocs/content ]; then
 | 
	
		
			
			| 98 |  | -			echo $"No content directory found after restoring blog"
 | 
	
		
			
			| 99 |  | -			set_user_permissions
 | 
	
		
			
			| 100 |  | -			backup_unmount_drive
 | 
	
		
			
			| 101 |  | -			exit 287
 | 
	
		
			
			| 102 |  | -		fi
 | 
	
		
			
			| 103 |  | -		chown -R www-data:www-data /var/www/${FULLBLOG_DOMAIN_NAME}/htdocs
 | 
	
		
			
			| 104 |  | -		# Ensure that the bundled SSL cert is being used
 | 
	
		
			
			| 105 |  | -		if [ -f /etc/ssl/certs/${FULLBLOG_DOMAIN_NAME}.bundle.crt ]; then
 | 
	
		
			
			| 106 |  | -			sed -i "s|${FULLBLOG_DOMAIN_NAME}.crt|${FULLBLOG_DOMAIN_NAME}.bundle.crt|g" /etc/nginx/sites-available/${FULLBLOG_DOMAIN_NAME}
 | 
	
		
			
			| 107 |  | -		fi
 | 
	
		
			
			| 108 |  | -		for d in /home/*/ ; do
 | 
	
		
			
			| 109 |  | -			USERNAME=$(echo "$d" | awk -F '/' '{print $3}')
 | 
	
		
			
			| 110 |  | -			if [[ $USERNAME != "git" && $USERNAME != "mirrors" && $USERNAME != "sync" ]]; then
 | 
	
		
			
			| 111 |  | -				if [ -d /var/www/${FULLBLOG_DOMAIN_NAME}/htdocs/content/$USERNAME/blog/uncategorized/post ]; then
 | 
	
		
			
			| 112 |  | -					mv /var/www/${FULLBLOG_DOMAIN_NAME}/htdocs/content/$USERNAME/blog/*.md /var/www/${FULLBLOG_DOMAIN_NAME}/htdocs/content/$USERNAME/blog/uncategorized/post
 | 
	
		
			
			| 113 |  | -				fi
 | 
	
		
			
			| 114 |  | -			fi
 | 
	
		
			
			| 115 |  | -		done
 | 
	
		
			
			| 116 |  | -		if [ -d /etc/letsencrypt/live/${FULLBLOG_DOMAIN_NAME} ]; then
 | 
	
		
			
			| 117 |  | -			ln -s /etc/letsencrypt/live/${FULLBLOG_DOMAIN_NAME}/privkey.pem /etc/ssl/private/${FULLBLOG_DOMAIN_NAME}.key
 | 
	
		
			
			| 118 |  | -			ln -s /etc/letsencrypt/live/${FULLBLOG_DOMAIN_NAME}/fullchain.pem /etc/ssl/certs/${FULLBLOG_DOMAIN_NAME}.pem
 | 
	
		
			
			|  | 96 | +	rm -rf $temp_restore_dir
 | 
	
		
			
			|  | 97 | +	if [ ! -d /var/www/${FULLBLOG_DOMAIN_NAME}/htdocs/content ]; then
 | 
	
		
			
			|  | 98 | +	    echo $"No content directory found after restoring blog"
 | 
	
		
			
			|  | 99 | +	    set_user_permissions
 | 
	
		
			
			|  | 100 | +	    backup_unmount_drive
 | 
	
		
			
			|  | 101 | +	    exit 287
 | 
	
		
			
			|  | 102 | +	fi
 | 
	
		
			
			|  | 103 | +	chown -R www-data:www-data /var/www/${FULLBLOG_DOMAIN_NAME}/htdocs
 | 
	
		
			
			|  | 104 | +	# Ensure that the bundled SSL cert is being used
 | 
	
		
			
			|  | 105 | +	if [ -f /etc/ssl/certs/${FULLBLOG_DOMAIN_NAME}.bundle.crt ]; then
 | 
	
		
			
			|  | 106 | +	    sed -i "s|${FULLBLOG_DOMAIN_NAME}.crt|${FULLBLOG_DOMAIN_NAME}.bundle.crt|g" /etc/nginx/sites-available/${FULLBLOG_DOMAIN_NAME}
 | 
	
		
			
			|  | 107 | +	fi
 | 
	
		
			
			|  | 108 | +	for d in /home/*/ ; do
 | 
	
		
			
			|  | 109 | +	    USERNAME=$(echo "$d" | awk -F '/' '{print $3}')
 | 
	
		
			
			|  | 110 | +	    if [[ $USERNAME != "git" && $USERNAME != "mirrors" && $USERNAME != "sync" ]]; then
 | 
	
		
			
			|  | 111 | +		if [ -d /var/www/${FULLBLOG_DOMAIN_NAME}/htdocs/content/$USERNAME/blog/uncategorized/post ]; then
 | 
	
		
			
			|  | 112 | +		    mv /var/www/${FULLBLOG_DOMAIN_NAME}/htdocs/content/$USERNAME/blog/*.md /var/www/${FULLBLOG_DOMAIN_NAME}/htdocs/content/$USERNAME/blog/uncategorized/post
 | 
	
		
			
			| 119 | 113 |  		fi
 | 
	
		
			
			|  | 114 | +	    fi
 | 
	
		
			
			|  | 115 | +	done
 | 
	
		
			
			|  | 116 | +	if [ -d /etc/letsencrypt/live/${FULLBLOG_DOMAIN_NAME} ]; then
 | 
	
		
			
			|  | 117 | +	    ln -s /etc/letsencrypt/live/${FULLBLOG_DOMAIN_NAME}/privkey.pem /etc/ssl/private/${FULLBLOG_DOMAIN_NAME}.key
 | 
	
		
			
			|  | 118 | +	    ln -s /etc/letsencrypt/live/${FULLBLOG_DOMAIN_NAME}/fullchain.pem /etc/ssl/certs/${FULLBLOG_DOMAIN_NAME}.pem
 | 
	
		
			
			| 120 | 119 |  	fi
 | 
	
		
			
			|  | 120 | +    fi
 | 
	
		
			
			| 121 | 121 |  }
 | 
	
		
			
			| 122 | 122 |  
 | 
	
		
			
			| 123 | 123 |  function backup_remote_blog {
 | 
	
		
			
			| 124 |  | -	if grep -q "Blog domain" $COMPLETION_FILE; then
 | 
	
		
			
			| 125 |  | -		FULLBLOG_DOMAIN_NAME=$(cat $COMPLETION_FILE | grep "Blog domain" | awk -F ':' '{print $2}')
 | 
	
		
			
			| 126 |  | -		temp_backup_dir=/var/www/${FULLBLOG_DOMAIN_NAME}/htdocs
 | 
	
		
			
			| 127 |  | -		if [ -d $temp_backup_dir ]; then
 | 
	
		
			
			| 128 |  | -			echo $"Backing up blog"
 | 
	
		
			
			| 129 |  | -			backup_directory_to_friend $temp_backup_dir blog
 | 
	
		
			
			| 130 |  | -			echo $"Backup of blog complete"
 | 
	
		
			
			| 131 |  | -		else
 | 
	
		
			
			| 132 |  | -			echo $"Blog domain specified but not found in $temp_backup_dir"
 | 
	
		
			
			| 133 |  | -			exit 2578
 | 
	
		
			
			| 134 |  | -		fi
 | 
	
		
			
			|  | 124 | +    if grep -q "Blog domain" $COMPLETION_FILE; then
 | 
	
		
			
			|  | 125 | +	FULLBLOG_DOMAIN_NAME=$(cat $COMPLETION_FILE | grep "Blog domain" | awk -F ':' '{print $2}')
 | 
	
		
			
			|  | 126 | +	temp_backup_dir=/var/www/${FULLBLOG_DOMAIN_NAME}/htdocs
 | 
	
		
			
			|  | 127 | +	if [ -d $temp_backup_dir ]; then
 | 
	
		
			
			|  | 128 | +	    echo $"Backing up blog"
 | 
	
		
			
			|  | 129 | +	    backup_directory_to_friend $temp_backup_dir blog
 | 
	
		
			
			|  | 130 | +	    echo $"Backup of blog complete"
 | 
	
		
			
			|  | 131 | +	else
 | 
	
		
			
			|  | 132 | +	    echo $"Blog domain specified but not found in $temp_backup_dir"
 | 
	
		
			
			|  | 133 | +	    exit 2578
 | 
	
		
			
			| 135 | 134 |  	fi
 | 
	
		
			
			|  | 135 | +    fi
 | 
	
		
			
			| 136 | 136 |  }
 | 
	
		
			
			| 137 | 137 |  
 | 
	
		
			
			| 138 | 138 |  function restore_remote_blog {
 | 
	
		
			
			| 139 |  | -	if [ -d $SERVER_DIRECTORY/backup/blog ]; then
 | 
	
		
			
			| 140 |  | -		FULLBLOG_DOMAIN_NAME=$(cat $COMPLETION_FILE | grep "Blog domain" | awk -F ':' '{print $2}')
 | 
	
		
			
			| 141 |  | -		echo $"Restoring blog installation $FULLBLOG_DOMAIN_NAME"
 | 
	
		
			
			| 142 |  | -		temp_restore_dir=/root/tempblog
 | 
	
		
			
			| 143 |  | -		mkdir $temp_restore_dir
 | 
	
		
			
			| 144 |  | -		function_check restore_directory_from_friend
 | 
	
		
			
			| 145 |  | -		restore_directory_from_friend $temp_restore_dir blog
 | 
	
		
			
			| 146 |  | -		rm -rf /var/www/${FULLBLOG_DOMAIN_NAME}/htdocs
 | 
	
		
			
			| 147 |  | -		cp -r $temp_restore_dir/var/www/${FULLBLOG_DOMAIN_NAME}/htdocs /var/www/${FULLBLOG_DOMAIN_NAME}/
 | 
	
		
			
			| 148 |  | -		if [ ! "$?" = "0" ]; then
 | 
	
		
			
			| 149 |  | -			exit 593
 | 
	
		
			
			| 150 |  | -		fi
 | 
	
		
			
			| 151 |  | -		rm -rf $temp_restore_dir
 | 
	
		
			
			| 152 |  | -		if [ ! -d /var/www/${FULLBLOG_DOMAIN_NAME}/htdocs/content ]; then
 | 
	
		
			
			| 153 |  | -			echo $"No content directory found after restoring blog"
 | 
	
		
			
			| 154 |  | -			exit 287
 | 
	
		
			
			| 155 |  | -		fi
 | 
	
		
			
			| 156 |  | -		# Ensure that the bundled SSL cert is being used
 | 
	
		
			
			| 157 |  | -		if [ -f /etc/ssl/certs/${FULLBLOG_DOMAIN_NAME}.bundle.crt ]; then
 | 
	
		
			
			| 158 |  | -			sed -i "s|${FULLBLOG_DOMAIN_NAME}.crt|${FULLBLOG_DOMAIN_NAME}.bundle.crt|g" /etc/nginx/sites-available/${FULLBLOG_DOMAIN_NAME}
 | 
	
		
			
			| 159 |  | -		fi
 | 
	
		
			
			| 160 |  | -		for d in /home/*/ ; do
 | 
	
		
			
			| 161 |  | -			USERNAME=$(echo "$d" | awk -F '/' '{print $3}')
 | 
	
		
			
			| 162 |  | -			if [[ $USERNAME != "git" && $USERNAME != "mirrors" && $USERNAME != "sync" ]]; then
 | 
	
		
			
			| 163 |  | -				if [ -d /var/www/${FULLBLOG_DOMAIN_NAME}/htdocs/content/$USERNAME/blog/uncategorized/post ]; then
 | 
	
		
			
			| 164 |  | -					mv /var/www/${FULLBLOG_DOMAIN_NAME}/htdocs/content/$USERNAME/blog/*.md /var/www/${FULLBLOG_DOMAIN_NAME}/htdocs/content/$USERNAME/blog/uncategorized/post
 | 
	
		
			
			| 165 |  | -				fi
 | 
	
		
			
			| 166 |  | -			fi
 | 
	
		
			
			| 167 |  | -		done
 | 
	
		
			
			| 168 |  | -		if [ -d /etc/letsencrypt/live/${FULLBLOG_DOMAIN_NAME} ]; then
 | 
	
		
			
			| 169 |  | -			ln -s /etc/letsencrypt/live/${FULLBLOG_DOMAIN_NAME}/privkey.pem /etc/ssl/private/${FULLBLOG_DOMAIN_NAME}.key
 | 
	
		
			
			| 170 |  | -			ln -s /etc/letsencrypt/live/${FULLBLOG_DOMAIN_NAME}/fullchain.pem /etc/ssl/certs/${FULLBLOG_DOMAIN_NAME}.pem
 | 
	
		
			
			|  | 139 | +    if [ -d $SERVER_DIRECTORY/backup/blog ]; then
 | 
	
		
			
			|  | 140 | +	FULLBLOG_DOMAIN_NAME=$(cat $COMPLETION_FILE | grep "Blog domain" | awk -F ':' '{print $2}')
 | 
	
		
			
			|  | 141 | +	echo $"Restoring blog installation $FULLBLOG_DOMAIN_NAME"
 | 
	
		
			
			|  | 142 | +	temp_restore_dir=/root/tempblog
 | 
	
		
			
			|  | 143 | +	mkdir $temp_restore_dir
 | 
	
		
			
			|  | 144 | +	function_check restore_directory_from_friend
 | 
	
		
			
			|  | 145 | +	restore_directory_from_friend $temp_restore_dir blog
 | 
	
		
			
			|  | 146 | +	rm -rf /var/www/${FULLBLOG_DOMAIN_NAME}/htdocs
 | 
	
		
			
			|  | 147 | +	cp -r $temp_restore_dir/var/www/${FULLBLOG_DOMAIN_NAME}/htdocs /var/www/${FULLBLOG_DOMAIN_NAME}/
 | 
	
		
			
			|  | 148 | +	if [ ! "$?" = "0" ]; then
 | 
	
		
			
			|  | 149 | +	    exit 593
 | 
	
		
			
			|  | 150 | +	fi
 | 
	
		
			
			|  | 151 | +	rm -rf $temp_restore_dir
 | 
	
		
			
			|  | 152 | +	if [ ! -d /var/www/${FULLBLOG_DOMAIN_NAME}/htdocs/content ]; then
 | 
	
		
			
			|  | 153 | +	    echo $"No content directory found after restoring blog"
 | 
	
		
			
			|  | 154 | +	    exit 287
 | 
	
		
			
			|  | 155 | +	fi
 | 
	
		
			
			|  | 156 | +	# Ensure that the bundled SSL cert is being used
 | 
	
		
			
			|  | 157 | +	if [ -f /etc/ssl/certs/${FULLBLOG_DOMAIN_NAME}.bundle.crt ]; then
 | 
	
		
			
			|  | 158 | +	    sed -i "s|${FULLBLOG_DOMAIN_NAME}.crt|${FULLBLOG_DOMAIN_NAME}.bundle.crt|g" /etc/nginx/sites-available/${FULLBLOG_DOMAIN_NAME}
 | 
	
		
			
			|  | 159 | +	fi
 | 
	
		
			
			|  | 160 | +	for d in /home/*/ ; do
 | 
	
		
			
			|  | 161 | +	    USERNAME=$(echo "$d" | awk -F '/' '{print $3}')
 | 
	
		
			
			|  | 162 | +	    if [[ $USERNAME != "git" && $USERNAME != "mirrors" && $USERNAME != "sync" ]]; then
 | 
	
		
			
			|  | 163 | +		if [ -d /var/www/${FULLBLOG_DOMAIN_NAME}/htdocs/content/$USERNAME/blog/uncategorized/post ]; then
 | 
	
		
			
			|  | 164 | +		    mv /var/www/${FULLBLOG_DOMAIN_NAME}/htdocs/content/$USERNAME/blog/*.md /var/www/${FULLBLOG_DOMAIN_NAME}/htdocs/content/$USERNAME/blog/uncategorized/post
 | 
	
		
			
			| 171 | 165 |  		fi
 | 
	
		
			
			| 172 |  | -		echo $"Restore of blog complete"
 | 
	
		
			
			|  | 166 | +	    fi
 | 
	
		
			
			|  | 167 | +	done
 | 
	
		
			
			|  | 168 | +	if [ -d /etc/letsencrypt/live/${FULLBLOG_DOMAIN_NAME} ]; then
 | 
	
		
			
			|  | 169 | +	    ln -s /etc/letsencrypt/live/${FULLBLOG_DOMAIN_NAME}/privkey.pem /etc/ssl/private/${FULLBLOG_DOMAIN_NAME}.key
 | 
	
		
			
			|  | 170 | +	    ln -s /etc/letsencrypt/live/${FULLBLOG_DOMAIN_NAME}/fullchain.pem /etc/ssl/certs/${FULLBLOG_DOMAIN_NAME}.pem
 | 
	
		
			
			| 173 | 171 |  	fi
 | 
	
		
			
			|  | 172 | +	echo $"Restore of blog complete"
 | 
	
		
			
			|  | 173 | +    fi
 | 
	
		
			
			| 174 | 174 |  }
 | 
	
		
			
			| 175 | 175 |  
 | 
	
		
			
			| 176 | 176 |  function remove_blog {
 | 
	
		
			
			| 177 |  | -	if ! grep -Fxq "install_blog" $COMPLETION_FILE; then
 | 
	
		
			
			| 178 |  | -		return
 | 
	
		
			
			| 179 |  | -	fi
 | 
	
		
			
			| 180 |  | -	if [ ! -d /var/www/$FULLBLOG_DOMAIN_NAME ]; then
 | 
	
		
			
			| 181 |  | -		rm -rf /var/www/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			| 182 |  | -	fi
 | 
	
		
			
			| 183 |  | -	nginx_dissite $FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			| 184 |  | -	if [ ! -f /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME ]; then
 | 
	
		
			
			| 185 |  | -		rm -rf /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			|  | 177 | +    if ! grep -Fxq "install_blog" $COMPLETION_FILE; then
 | 
	
		
			
			|  | 178 | +	return
 | 
	
		
			
			|  | 179 | +    fi
 | 
	
		
			
			|  | 180 | +    if [ ! -d /var/www/$FULLBLOG_DOMAIN_NAME ]; then
 | 
	
		
			
			|  | 181 | +	rm -rf /var/www/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			|  | 182 | +    fi
 | 
	
		
			
			|  | 183 | +    nginx_dissite $FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			|  | 184 | +    if [ ! -f /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME ]; then
 | 
	
		
			
			|  | 185 | +	rm -rf /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			|  | 186 | +    fi
 | 
	
		
			
			|  | 187 | +    if [ $FULLBLOG_CODE ]; then
 | 
	
		
			
			|  | 188 | +	if [ -f /usr/bin/dynamicdns ]; then
 | 
	
		
			
			|  | 189 | +	    sed -i "/$FULLBLOG_DOMAIN_NAME/d" /usr/bin/dynamicdns
 | 
	
		
			
			|  | 190 | +	    sed -i "/$FULLBLOG_CODE/d" /usr/bin/dynamicdns
 | 
	
		
			
			| 186 | 191 |  	fi
 | 
	
		
			
			| 187 |  | -	if [ $FULLBLOG_CODE ]; then
 | 
	
		
			
			| 188 |  | -		if [ -f /usr/bin/dynamicdns ]; then
 | 
	
		
			
			| 189 |  | -			sed -i "/$FULLBLOG_DOMAIN_NAME/d" /usr/bin/dynamicdns
 | 
	
		
			
			| 190 |  | -			sed -i "/$FULLBLOG_CODE/d" /usr/bin/dynamicdns
 | 
	
		
			
			| 191 |  | -		fi
 | 
	
		
			
			| 192 |  | -	fi
 | 
	
		
			
			| 193 |  | -	function_check remove_onion_service
 | 
	
		
			
			| 194 |  | -	remove_onion_service blog ${FULLBLOG_ONION_PORT}
 | 
	
		
			
			| 195 |  | -	sed -i '/install_blog/d' $COMPLETION_FILE
 | 
	
		
			
			| 196 |  | -	sed -i '/Blog .*/d' $COMPLETION_FILE
 | 
	
		
			
			|  | 192 | +    fi
 | 
	
		
			
			|  | 193 | +    function_check remove_onion_service
 | 
	
		
			
			|  | 194 | +    remove_onion_service blog ${FULLBLOG_ONION_PORT}
 | 
	
		
			
			|  | 195 | +    sed -i '/install_blog/d' $COMPLETION_FILE
 | 
	
		
			
			|  | 196 | +    sed -i '/Blog .*/d' $COMPLETION_FILE
 | 
	
		
			
			| 197 | 197 |  }
 | 
	
		
			
			| 198 | 198 |  
 | 
	
		
			
			| 199 | 199 |  function get_blog_admin_password {
 | 
	
		
			
			| 200 |  | -	if [ -f /home/$MY_USERNAME/README ]; then
 | 
	
		
			
			| 201 |  | -		if grep -q "Your blog password is" /home/$MY_USERNAME/README; then
 | 
	
		
			
			| 202 |  | -			FULLBLOG_ADMIN_PASSWORD=$(cat /home/$MY_USERNAME/README | grep "Your blog password is" | awk -F ':' '{print $2}' | sed 's/^ *//')
 | 
	
		
			
			| 203 |  | -		fi
 | 
	
		
			
			|  | 200 | +    if [ -f /home/$MY_USERNAME/README ]; then
 | 
	
		
			
			|  | 201 | +	if grep -q "Your blog password is" /home/$MY_USERNAME/README; then
 | 
	
		
			
			|  | 202 | +	    FULLBLOG_ADMIN_PASSWORD=$(cat /home/$MY_USERNAME/README | grep "Your blog password is" | awk -F ':' '{print $2}' | sed 's/^ *//')
 | 
	
		
			
			| 204 | 203 |  	fi
 | 
	
		
			
			|  | 204 | +    fi
 | 
	
		
			
			| 205 | 205 |  }
 | 
	
		
			
			| 206 | 206 |  
 | 
	
		
			
			| 207 | 207 |  function install_blog {
 | 
	
		
			
			| 208 |  | -	if [ ! $FULLBLOG_DOMAIN_NAME ]; then
 | 
	
		
			
			| 209 |  | -		echo $'The blog domain name was not specified'
 | 
	
		
			
			| 210 |  | -		exit 5062
 | 
	
		
			
			| 211 |  | -	fi
 | 
	
		
			
			| 212 |  | -
 | 
	
		
			
			| 213 |  | -	if grep -Fxq "install_blog" $COMPLETION_FILE; then
 | 
	
		
			
			| 214 |  | -		return
 | 
	
		
			
			| 215 |  | -	fi
 | 
	
		
			
			| 216 |  | -
 | 
	
		
			
			| 217 |  | -	# for the avatar changing command
 | 
	
		
			
			| 218 |  | -	apt-get -y install imagemagick
 | 
	
		
			
			| 219 |  | -
 | 
	
		
			
			| 220 |  | -	if [ ! -d /var/www/$FULLBLOG_DOMAIN_NAME ]; then
 | 
	
		
			
			| 221 |  | -		mkdir /var/www/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			| 222 |  | -	fi
 | 
	
		
			
			| 223 |  | -
 | 
	
		
			
			| 224 |  | -	cd /var/www/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			| 225 |  | -	git_clone $FULLBLOG_REPO htdocs
 | 
	
		
			
			| 226 |  | -	cd htdocs
 | 
	
		
			
			| 227 |  | -	git checkout $FULLBLOG_COMMIT -b $FULLBLOG_COMMIT
 | 
	
		
			
			| 228 |  | -	if ! grep -q "Blog commit" $COMPLETION_FILE; then
 | 
	
		
			
			| 229 |  | -		echo "Blog commit:$FULLBLOG_COMMIT" >> $COMPLETION_FILE
 | 
	
		
			
			| 230 |  | -	else
 | 
	
		
			
			| 231 |  | -		sed -i "s/Blog commit.*/Blog commit:$FULLBLOG_COMMIT/g" $COMPLETION_FILE
 | 
	
		
			
			| 232 |  | -	fi
 | 
	
		
			
			| 233 |  | -	cd /var/www/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			| 234 |  | -
 | 
	
		
			
			| 235 |  | -	chown -R www-data:www-data /var/www/$FULLBLOG_DOMAIN_NAME/htdocs
 | 
	
		
			
			| 236 |  | -
 | 
	
		
			
			| 237 |  | -	if [[ $ONION_ONLY == "no" ]]; then
 | 
	
		
			
			| 238 |  | -		function_check nginx_http_redirect
 | 
	
		
			
			| 239 |  | -		nginx_http_redirect $FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			| 240 |  | -		echo 'server {' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			| 241 |  | -		echo '    listen 443 ssl;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			| 242 |  | -		echo "    root /var/www/$FULLBLOG_DOMAIN_NAME/htdocs;" >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			| 243 |  | -		echo "    server_name $FULLBLOG_DOMAIN_NAME;" >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			| 244 |  | -		echo '    access_log off;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			| 245 |  | -		echo "    error_log /var/log/nginx/${FULLBLOG_DOMAIN_NAME}_error_ssl.log $WEBSERVER_LOG_LEVEL;" >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			| 246 |  | -		echo '    index index.php;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			| 247 |  | -		echo '    charset utf-8;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			| 248 |  | -		echo '    proxy_read_timeout 86400s;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			| 249 |  | -		function_check nginx_limits
 | 
	
		
			
			| 250 |  | -		nginx_limits $FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			| 251 |  | -		function_check nginx_ssl
 | 
	
		
			
			| 252 |  | -		nginx_ssl $FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			| 253 |  | -		function_check nginx_disable_sniffing
 | 
	
		
			
			| 254 |  | -		nginx_disable_sniffing $FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			| 255 |  | -		echo '    add_header Strict-Transport-Security "max-age=0;";' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			| 256 |  | -		echo '' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			| 257 |  | -		echo '    # rewrite to front controller as default rule' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			| 258 |  | -		echo '    location / {' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			| 259 |  | -		echo '        rewrite ^/(.*) /index.php?q=$uri&$args last;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			| 260 |  | -		echo '    }' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			| 261 |  | -		echo '' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			| 262 |  | -		echo "    # make sure webfinger and other well known services aren't blocked" >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			| 263 |  | -		echo '    # by denying dot files and rewrite request to the front controller' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			| 264 |  | -		echo '    location ^~ /.well-known/ {' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			| 265 |  | -		echo '        allow all;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			| 266 |  | -		echo '    }' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			| 267 |  | -		echo '' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			| 268 |  | -		echo '    # statically serve these file types when possible' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			| 269 |  | -		echo '    # otherwise fall back to front controller' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			| 270 |  | -		echo '    # allow browser to cache them' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			| 271 |  | -		echo '    # added .htm for advanced source code editor library' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			| 272 |  | -		echo '    location ~* \.(jpg|jpeg|gif|png|ico|css|js|htm|html|ttf|woff|svg)$ {' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			| 273 |  | -		echo '        expires 30d;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			| 274 |  | -		echo '        try_files $uri /index.php?q=$uri&$args;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			| 275 |  | -		echo '    }' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			| 276 |  | -		echo '' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			| 277 |  | -		echo '    # block these file types' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			| 278 |  | -		echo '    location ~* \.(tpl|md|tgz|log|out)$ {' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			| 279 |  | -		echo '        deny all;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			| 280 |  | -		echo '    }' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			| 281 |  | -		echo '' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			| 282 |  | -		echo '    # pass the PHP scripts to FastCGI server listening on 127.0.0.1:9000' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			| 283 |  | -		echo '    # or a unix socket' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			| 284 |  | -		echo '    location ~* \.php$ {' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			| 285 |  | -		echo '        # Zero-day exploit defense.' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			| 286 |  | -		echo '        # http://forum.nginx.org/read.php?2,88845,page=3' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			| 287 |  | -		echo "        # Won't work properly (404 error) if the file is not stored on this" >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			| 288 |  | -		echo "        # server, which is entirely possible with php-fpm/php-fcgi." >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			| 289 |  | -		echo "        # Comment the 'try_files' line out if you set up php-fpm/php-fcgi on" >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			| 290 |  | -		echo "        # another machine. And then cross your fingers that you won't get hacked." >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			| 291 |  | -		echo '        try_files $uri $uri/ /index.php;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			| 292 |  | -		echo '        # NOTE: You should have "cgi.fix_pathinfo = 0;" in php.ini' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			| 293 |  | -		echo '        fastcgi_split_path_info ^(.+\.php)(/.+)$;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			| 294 |  | -		echo '        # With php5-cgi alone:' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			| 295 |  | -		echo '        # fastcgi_pass 127.0.0.1:9000;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			| 296 |  | -		echo '        # With php5-fpm:' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			| 297 |  | -		echo '        fastcgi_pass unix:/var/run/php5-fpm.sock;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			| 298 |  | -		echo '        include fastcgi_params;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			| 299 |  | -		echo '        fastcgi_index index.php;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			| 300 |  | -		echo '        fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			| 301 |  | -		echo '    }' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			| 302 |  | -		echo '' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			| 303 |  | -		echo '    # deny access to all dot files' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			| 304 |  | -		echo '    location ~ /\. {' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			| 305 |  | -		echo '        deny all;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			| 306 |  | -		echo '    }' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			| 307 |  | -		echo '' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			| 308 |  | -		echo '    #deny access to store' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			| 309 |  | -		echo '    location ~ /store {' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			| 310 |  | -		echo '        deny all;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			| 311 |  | -		echo '    }' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			| 312 |  | -		echo '    location ~ /(data|conf|bin|inc)/ {' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			| 313 |  | -		echo '      deny all;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			| 314 |  | -		echo '    }' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			| 315 |  | -		echo '    location ~ /\.ht {' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			| 316 |  | -		echo '      deny  all;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			| 317 |  | -		echo '    }' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			| 318 |  | -		echo '}' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			| 319 |  | -		echo '' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			| 320 |  | -	else
 | 
	
		
			
			| 321 |  | -		echo -n '' > /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			| 322 |  | -	fi
 | 
	
		
			
			|  | 208 | +    if [ ! $FULLBLOG_DOMAIN_NAME ]; then
 | 
	
		
			
			|  | 209 | +	echo $'The blog domain name was not specified'
 | 
	
		
			
			|  | 210 | +	exit 5062
 | 
	
		
			
			|  | 211 | +    fi
 | 
	
		
			
			|  | 212 | +
 | 
	
		
			
			|  | 213 | +    if grep -Fxq "install_blog" $COMPLETION_FILE; then
 | 
	
		
			
			|  | 214 | +	return
 | 
	
		
			
			|  | 215 | +    fi
 | 
	
		
			
			|  | 216 | +
 | 
	
		
			
			|  | 217 | +    # for the avatar changing command
 | 
	
		
			
			|  | 218 | +    apt-get -y install imagemagick
 | 
	
		
			
			|  | 219 | +
 | 
	
		
			
			|  | 220 | +    if [ ! -d /var/www/$FULLBLOG_DOMAIN_NAME ]; then
 | 
	
		
			
			|  | 221 | +	mkdir /var/www/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			|  | 222 | +    fi
 | 
	
		
			
			|  | 223 | +
 | 
	
		
			
			|  | 224 | +    cd /var/www/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			|  | 225 | +    git_clone $FULLBLOG_REPO htdocs
 | 
	
		
			
			|  | 226 | +    cd htdocs
 | 
	
		
			
			|  | 227 | +    git checkout $FULLBLOG_COMMIT -b $FULLBLOG_COMMIT
 | 
	
		
			
			|  | 228 | +    if ! grep -q "Blog commit" $COMPLETION_FILE; then
 | 
	
		
			
			|  | 229 | +	echo "Blog commit:$FULLBLOG_COMMIT" >> $COMPLETION_FILE
 | 
	
		
			
			|  | 230 | +    else
 | 
	
		
			
			|  | 231 | +	sed -i "s/Blog commit.*/Blog commit:$FULLBLOG_COMMIT/g" $COMPLETION_FILE
 | 
	
		
			
			|  | 232 | +    fi
 | 
	
		
			
			|  | 233 | +    cd /var/www/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			|  | 234 | +
 | 
	
		
			
			|  | 235 | +    chown -R www-data:www-data /var/www/$FULLBLOG_DOMAIN_NAME/htdocs
 | 
	
		
			
			|  | 236 | +
 | 
	
		
			
			|  | 237 | +    if [[ $ONION_ONLY == "no" ]]; then
 | 
	
		
			
			|  | 238 | +	function_check nginx_http_redirect
 | 
	
		
			
			|  | 239 | +	nginx_http_redirect $FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			| 323 | 240 |  	echo 'server {' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			| 324 |  | -	echo "    listen 127.0.0.1:${FULLBLOG_ONION_PORT} default_server;" >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			|  | 241 | +	echo '    listen 443 ssl;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			| 325 | 242 |  	echo "    root /var/www/$FULLBLOG_DOMAIN_NAME/htdocs;" >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			| 326 | 243 |  	echo "    server_name $FULLBLOG_DOMAIN_NAME;" >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			| 327 | 244 |  	echo '    access_log off;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
 | 
	
	
		
			
			|  | @@ -331,6 +248,8 @@ function install_blog {
 | 
	
		
			
			| 331 | 248 |  	echo '    proxy_read_timeout 86400s;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			| 332 | 249 |  	function_check nginx_limits
 | 
	
		
			
			| 333 | 250 |  	nginx_limits $FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			|  | 251 | +	function_check nginx_ssl
 | 
	
		
			
			|  | 252 | +	nginx_ssl $FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			| 334 | 253 |  	function_check nginx_disable_sniffing
 | 
	
		
			
			| 335 | 254 |  	nginx_disable_sniffing $FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			| 336 | 255 |  	echo '    add_header Strict-Transport-Security "max-age=0;";' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
 | 
	
	
		
			
			|  | @@ -397,95 +316,176 @@ function install_blog {
 | 
	
		
			
			| 397 | 316 |  	echo '      deny  all;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			| 398 | 317 |  	echo '    }' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			| 399 | 318 |  	echo '}' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			| 400 |  | -
 | 
	
		
			
			| 401 |  | -	function_check create_site_certificate
 | 
	
		
			
			| 402 |  | -	create_site_certificate $FULLBLOG_DOMAIN_NAME 'yes'
 | 
	
		
			
			| 403 |  | -
 | 
	
		
			
			| 404 |  | -	function_check configure_php
 | 
	
		
			
			| 405 |  | -	configure_php
 | 
	
		
			
			| 406 |  | -
 | 
	
		
			
			| 407 |  | -	# blog settings
 | 
	
		
			
			| 408 |  | -	cp /var/www/$FULLBLOG_DOMAIN_NAME/htdocs/config/config.ini.example /var/www/$FULLBLOG_DOMAIN_NAME/htdocs/config/config.ini
 | 
	
		
			
			| 409 |  | -	sed -i "s|site.url.*|site.url = '/'|g" /var/www/$FULLBLOG_DOMAIN_NAME/htdocs/config/config.ini
 | 
	
		
			
			| 410 |  | -	sed -i "s|blog.title.*|blog.title = '$MY_BLOG_TITLE'|g" /var/www/$FULLBLOG_DOMAIN_NAME/htdocs/config/config.ini
 | 
	
		
			
			| 411 |  | -	sed -i "s|blog.tagline.*|blog.tagline = '$MY_BLOG_SUBTITLE'|g" /var/www/$FULLBLOG_DOMAIN_NAME/htdocs/config/config.ini
 | 
	
		
			
			| 412 |  | -	sed -i 's|timezone.*|timezone = "Europe/London"|g' /var/www/$FULLBLOG_DOMAIN_NAME/htdocs/config/config.ini
 | 
	
		
			
			| 413 |  | -	sed -i "s|Your name|$MY_NAME|g" /var/www/$FULLBLOG_DOMAIN_NAME/htdocs/config/config.ini
 | 
	
		
			
			| 414 |  | -
 | 
	
		
			
			| 415 |  | -	# set social networks
 | 
	
		
			
			| 416 |  | -	if grep -q "social.hubzilla" /var/www/$FULLBLOG_DOMAIN_NAME/htdocs/config/config.ini; then
 | 
	
		
			
			| 417 |  | -		sed -i "s|;social.hubzilla|social.hubzilla|g" /var/www/$FULLBLOG_DOMAIN_NAME/htdocs/config/config.ini
 | 
	
		
			
			| 418 |  | -		sed -i "s|social.hubzilla.*|social.hubzilla = \"$HUBZILLA_DOMAIN_NAME\"|g" /var/www/$FULLBLOG_DOMAIN_NAME/htdocs/config/config.ini
 | 
	
		
			
			| 419 |  | -	fi
 | 
	
		
			
			| 420 |  | -	if grep -q "social.gnusocial" /var/www/$FULLBLOG_DOMAIN_NAME/htdocs/config/config.ini; then
 | 
	
		
			
			| 421 |  | -		sed -i "s|;social.gnusocial|social.gnusocial|g" /var/www/$FULLBLOG_DOMAIN_NAME/htdocs/config/config.ini
 | 
	
		
			
			| 422 |  | -		sed -i "s|social.gnusocial.*|social.gnusocial = \"$MICROBLOG_DOMAIN_NAME\"|g" /var/www/$FULLBLOG_DOMAIN_NAME/htdocs/config/config.ini
 | 
	
		
			
			| 423 |  | -	fi
 | 
	
		
			
			| 424 |  | -
 | 
	
		
			
			| 425 |  | -	# clear proprietary social network strings
 | 
	
		
			
			| 426 |  | -	sed -i 's|social.facebook.*|social.facebook = ""|g' /var/www/$FULLBLOG_DOMAIN_NAME/htdocs/config/config.ini
 | 
	
		
			
			| 427 |  | -	sed -i 's|social.twitter.*|social.twitter = ""|g' /var/www/$FULLBLOG_DOMAIN_NAME/htdocs/config/config.ini
 | 
	
		
			
			| 428 |  | -	sed -i 's|social.google.*|social.google = ""|g' /var/www/$FULLBLOG_DOMAIN_NAME/htdocs/config/config.ini
 | 
	
		
			
			| 429 |  | -
 | 
	
		
			
			| 430 |  | -	# create a user password
 | 
	
		
			
			| 431 |  | -	function_check get_blog_admin_password
 | 
	
		
			
			| 432 |  | -	get_blog_admin_password
 | 
	
		
			
			| 433 |  | -	if [ ! $FULLBLOG_ADMIN_PASSWORD ]; then
 | 
	
		
			
			| 434 |  | -		if [ -f $IMAGE_PASSWORD_FILE ]; then
 | 
	
		
			
			| 435 |  | -			FULLBLOG_ADMIN_PASSWORD="$(printf `cat $IMAGE_PASSWORD_FILE`)"
 | 
	
		
			
			| 436 |  | -		else
 | 
	
		
			
			| 437 |  | -			FULLBLOG_ADMIN_PASSWORD="$(create_password ${MINIMUM_PASSWORD_LENGTH})"
 | 
	
		
			
			| 438 |  | -		fi
 | 
	
		
			
			| 439 |  | -		echo '' >> /home/$MY_USERNAME/README
 | 
	
		
			
			| 440 |  | -		echo '' >> /home/$MY_USERNAME/README
 | 
	
		
			
			| 441 |  | -		echo $'HTMLy Blog' >> /home/$MY_USERNAME/README
 | 
	
		
			
			| 442 |  | -		echo '==========' >> /home/$MY_USERNAME/README
 | 
	
		
			
			| 443 |  | -		echo $"Your blog username: $MY_USERNAME" >> /home/$MY_USERNAME/README
 | 
	
		
			
			| 444 |  | -		echo $"Your blog password is: $FULLBLOG_ADMIN_PASSWORD" >> /home/$MY_USERNAME/README
 | 
	
		
			
			| 445 |  | -		if [[ $ONION_ONLY == 'no' ]]; then
 | 
	
		
			
			| 446 |  | -			echo $"Log into your blog at https://$FULLBLOG_DOMAIN_NAME/login" >> /home/$MY_USERNAME/README
 | 
	
		
			
			| 447 |  | -		fi
 | 
	
		
			
			| 448 |  | -		chown $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/README
 | 
	
		
			
			| 449 |  | -		chmod 600 /home/$MY_USERNAME/README
 | 
	
		
			
			| 450 |  | -	fi
 | 
	
		
			
			| 451 |  | -
 | 
	
		
			
			| 452 |  | -	# create a user
 | 
	
		
			
			| 453 |  | -	FULLBLOG_ADMIN_PASSWORD_HASH=$(${PROJECT_NAME}-sec --bloghash "$FULLBLOG_ADMIN_PASSWORD")
 | 
	
		
			
			| 454 |  | -	if [ ${#FULLBLOG_ADMIN_PASSWORD_HASH} -lt 8 ]; then
 | 
	
		
			
			| 455 |  | -		echo $'Blog admin password could not be hashed'
 | 
	
		
			
			| 456 |  | -		exit 625728
 | 
	
		
			
			| 457 |  | -	fi
 | 
	
		
			
			| 458 |  | -	echo ';Password' > /var/www/$FULLBLOG_DOMAIN_NAME/htdocs/config/users/$MY_USERNAME.ini
 | 
	
		
			
			| 459 |  | -	echo "password = $FULLBLOG_ADMIN_PASSWORD_HASH" >> /var/www/$FULLBLOG_DOMAIN_NAME/htdocs/config/users/$MY_USERNAME.ini
 | 
	
		
			
			| 460 |  | -	echo 'encryption = password_hash' >> /var/www/$FULLBLOG_DOMAIN_NAME/htdocs/config/users/$MY_USERNAME.ini
 | 
	
		
			
			| 461 |  | -	echo ';Role' >> /var/www/$FULLBLOG_DOMAIN_NAME/htdocs/config/users/$MY_USERNAME.ini
 | 
	
		
			
			| 462 |  | -	echo 'role = admin' >> /var/www/$FULLBLOG_DOMAIN_NAME/htdocs/config/users/$MY_USERNAME.ini
 | 
	
		
			
			| 463 |  | -
 | 
	
		
			
			| 464 |  | -	function_check nginx_ensite
 | 
	
		
			
			| 465 |  | -	nginx_ensite $FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			| 466 |  | -
 | 
	
		
			
			| 467 |  | -	FULLBLOG_ONION_HOSTNAME=$(add_onion_service blog 80 ${FULLBLOG_ONION_PORT})
 | 
	
		
			
			| 468 |  | -
 | 
	
		
			
			| 469 |  | -	systemctl restart php5-fpm
 | 
	
		
			
			| 470 |  | -	systemctl restart nginx
 | 
	
		
			
			| 471 |  | -
 | 
	
		
			
			| 472 |  | -	if ! grep -q "Blog onion domain" /home/$MY_USERNAME/README; then
 | 
	
		
			
			| 473 |  | -		echo $"Blog onion domain: ${FULLBLOG_ONION_HOSTNAME}" >> /home/$MY_USERNAME/README
 | 
	
		
			
			| 474 |  | -		echo $"Log into your blog at https://${FULLBLOG_ONION_HOSTNAME}/login" >> /home/$MY_USERNAME/README
 | 
	
		
			
			| 475 |  | -		echo '' >> /home/$MY_USERNAME/README
 | 
	
		
			
			| 476 |  | -		chown $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/README
 | 
	
		
			
			| 477 |  | -		chmod 600 /home/$MY_USERNAME/README
 | 
	
		
			
			|  | 319 | +	echo '' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			|  | 320 | +    else
 | 
	
		
			
			|  | 321 | +	echo -n '' > /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			|  | 322 | +    fi
 | 
	
		
			
			|  | 323 | +    echo 'server {' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			|  | 324 | +    echo "    listen 127.0.0.1:${FULLBLOG_ONION_PORT} default_server;" >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			|  | 325 | +    echo "    root /var/www/$FULLBLOG_DOMAIN_NAME/htdocs;" >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			|  | 326 | +    echo "    server_name $FULLBLOG_DOMAIN_NAME;" >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			|  | 327 | +    echo '    access_log off;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			|  | 328 | +    echo "    error_log /var/log/nginx/${FULLBLOG_DOMAIN_NAME}_error_ssl.log $WEBSERVER_LOG_LEVEL;" >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			|  | 329 | +    echo '    index index.php;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			|  | 330 | +    echo '    charset utf-8;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			|  | 331 | +    echo '    proxy_read_timeout 86400s;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			|  | 332 | +    function_check nginx_limits
 | 
	
		
			
			|  | 333 | +    nginx_limits $FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			|  | 334 | +    function_check nginx_disable_sniffing
 | 
	
		
			
			|  | 335 | +    nginx_disable_sniffing $FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			|  | 336 | +    echo '    add_header Strict-Transport-Security "max-age=0;";' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			|  | 337 | +    echo '' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			|  | 338 | +    echo '    # rewrite to front controller as default rule' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			|  | 339 | +    echo '    location / {' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			|  | 340 | +    echo '        rewrite ^/(.*) /index.php?q=$uri&$args last;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			|  | 341 | +    echo '    }' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			|  | 342 | +    echo '' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			|  | 343 | +    echo "    # make sure webfinger and other well known services aren't blocked" >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			|  | 344 | +    echo '    # by denying dot files and rewrite request to the front controller' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			|  | 345 | +    echo '    location ^~ /.well-known/ {' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			|  | 346 | +    echo '        allow all;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			|  | 347 | +    echo '    }' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			|  | 348 | +    echo '' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			|  | 349 | +    echo '    # statically serve these file types when possible' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			|  | 350 | +    echo '    # otherwise fall back to front controller' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			|  | 351 | +    echo '    # allow browser to cache them' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			|  | 352 | +    echo '    # added .htm for advanced source code editor library' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			|  | 353 | +    echo '    location ~* \.(jpg|jpeg|gif|png|ico|css|js|htm|html|ttf|woff|svg)$ {' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			|  | 354 | +    echo '        expires 30d;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			|  | 355 | +    echo '        try_files $uri /index.php?q=$uri&$args;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			|  | 356 | +    echo '    }' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			|  | 357 | +    echo '' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			|  | 358 | +    echo '    # block these file types' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			|  | 359 | +    echo '    location ~* \.(tpl|md|tgz|log|out)$ {' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			|  | 360 | +    echo '        deny all;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			|  | 361 | +    echo '    }' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			|  | 362 | +    echo '' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			|  | 363 | +    echo '    # pass the PHP scripts to FastCGI server listening on 127.0.0.1:9000' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			|  | 364 | +    echo '    # or a unix socket' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			|  | 365 | +    echo '    location ~* \.php$ {' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			|  | 366 | +    echo '        # Zero-day exploit defense.' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			|  | 367 | +    echo '        # http://forum.nginx.org/read.php?2,88845,page=3' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			|  | 368 | +    echo "        # Won't work properly (404 error) if the file is not stored on this" >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			|  | 369 | +    echo "        # server, which is entirely possible with php-fpm/php-fcgi." >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			|  | 370 | +    echo "        # Comment the 'try_files' line out if you set up php-fpm/php-fcgi on" >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			|  | 371 | +    echo "        # another machine. And then cross your fingers that you won't get hacked." >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			|  | 372 | +    echo '        try_files $uri $uri/ /index.php;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			|  | 373 | +    echo '        # NOTE: You should have "cgi.fix_pathinfo = 0;" in php.ini' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			|  | 374 | +    echo '        fastcgi_split_path_info ^(.+\.php)(/.+)$;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			|  | 375 | +    echo '        # With php5-cgi alone:' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			|  | 376 | +    echo '        # fastcgi_pass 127.0.0.1:9000;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			|  | 377 | +    echo '        # With php5-fpm:' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			|  | 378 | +    echo '        fastcgi_pass unix:/var/run/php5-fpm.sock;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			|  | 379 | +    echo '        include fastcgi_params;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			|  | 380 | +    echo '        fastcgi_index index.php;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			|  | 381 | +    echo '        fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			|  | 382 | +    echo '    }' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			|  | 383 | +    echo '' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			|  | 384 | +    echo '    # deny access to all dot files' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			|  | 385 | +    echo '    location ~ /\. {' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			|  | 386 | +    echo '        deny all;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			|  | 387 | +    echo '    }' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			|  | 388 | +    echo '' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			|  | 389 | +    echo '    #deny access to store' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			|  | 390 | +    echo '    location ~ /store {' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			|  | 391 | +    echo '        deny all;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			|  | 392 | +    echo '    }' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			|  | 393 | +    echo '    location ~ /(data|conf|bin|inc)/ {' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			|  | 394 | +    echo '      deny all;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			|  | 395 | +    echo '    }' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			|  | 396 | +    echo '    location ~ /\.ht {' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			|  | 397 | +    echo '      deny  all;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			|  | 398 | +    echo '    }' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			|  | 399 | +    echo '}' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			|  | 400 | +
 | 
	
		
			
			|  | 401 | +    function_check create_site_certificate
 | 
	
		
			
			|  | 402 | +    create_site_certificate $FULLBLOG_DOMAIN_NAME 'yes'
 | 
	
		
			
			|  | 403 | +
 | 
	
		
			
			|  | 404 | +    function_check configure_php
 | 
	
		
			
			|  | 405 | +    configure_php
 | 
	
		
			
			|  | 406 | +
 | 
	
		
			
			|  | 407 | +    # blog settings
 | 
	
		
			
			|  | 408 | +    cp /var/www/$FULLBLOG_DOMAIN_NAME/htdocs/config/config.ini.example /var/www/$FULLBLOG_DOMAIN_NAME/htdocs/config/config.ini
 | 
	
		
			
			|  | 409 | +    sed -i "s|site.url.*|site.url = '/'|g" /var/www/$FULLBLOG_DOMAIN_NAME/htdocs/config/config.ini
 | 
	
		
			
			|  | 410 | +    sed -i "s|blog.title.*|blog.title = '$MY_BLOG_TITLE'|g" /var/www/$FULLBLOG_DOMAIN_NAME/htdocs/config/config.ini
 | 
	
		
			
			|  | 411 | +    sed -i "s|blog.tagline.*|blog.tagline = '$MY_BLOG_SUBTITLE'|g" /var/www/$FULLBLOG_DOMAIN_NAME/htdocs/config/config.ini
 | 
	
		
			
			|  | 412 | +    sed -i 's|timezone.*|timezone = "Europe/London"|g' /var/www/$FULLBLOG_DOMAIN_NAME/htdocs/config/config.ini
 | 
	
		
			
			|  | 413 | +    sed -i "s|Your name|$MY_NAME|g" /var/www/$FULLBLOG_DOMAIN_NAME/htdocs/config/config.ini
 | 
	
		
			
			|  | 414 | +
 | 
	
		
			
			|  | 415 | +    # set social networks
 | 
	
		
			
			|  | 416 | +    if grep -q "social.hubzilla" /var/www/$FULLBLOG_DOMAIN_NAME/htdocs/config/config.ini; then
 | 
	
		
			
			|  | 417 | +	sed -i "s|;social.hubzilla|social.hubzilla|g" /var/www/$FULLBLOG_DOMAIN_NAME/htdocs/config/config.ini
 | 
	
		
			
			|  | 418 | +	sed -i "s|social.hubzilla.*|social.hubzilla = \"$HUBZILLA_DOMAIN_NAME\"|g" /var/www/$FULLBLOG_DOMAIN_NAME/htdocs/config/config.ini
 | 
	
		
			
			|  | 419 | +    fi
 | 
	
		
			
			|  | 420 | +    if grep -q "social.gnusocial" /var/www/$FULLBLOG_DOMAIN_NAME/htdocs/config/config.ini; then
 | 
	
		
			
			|  | 421 | +	sed -i "s|;social.gnusocial|social.gnusocial|g" /var/www/$FULLBLOG_DOMAIN_NAME/htdocs/config/config.ini
 | 
	
		
			
			|  | 422 | +	sed -i "s|social.gnusocial.*|social.gnusocial = \"$MICROBLOG_DOMAIN_NAME\"|g" /var/www/$FULLBLOG_DOMAIN_NAME/htdocs/config/config.ini
 | 
	
		
			
			|  | 423 | +    fi
 | 
	
		
			
			|  | 424 | +
 | 
	
		
			
			|  | 425 | +    # clear proprietary social network strings
 | 
	
		
			
			|  | 426 | +    sed -i 's|social.facebook.*|social.facebook = ""|g' /var/www/$FULLBLOG_DOMAIN_NAME/htdocs/config/config.ini
 | 
	
		
			
			|  | 427 | +    sed -i 's|social.twitter.*|social.twitter = ""|g' /var/www/$FULLBLOG_DOMAIN_NAME/htdocs/config/config.ini
 | 
	
		
			
			|  | 428 | +    sed -i 's|social.google.*|social.google = ""|g' /var/www/$FULLBLOG_DOMAIN_NAME/htdocs/config/config.ini
 | 
	
		
			
			|  | 429 | +
 | 
	
		
			
			|  | 430 | +    # create a user password
 | 
	
		
			
			|  | 431 | +    function_check get_blog_admin_password
 | 
	
		
			
			|  | 432 | +    get_blog_admin_password
 | 
	
		
			
			|  | 433 | +    if [ ! $FULLBLOG_ADMIN_PASSWORD ]; then
 | 
	
		
			
			|  | 434 | +	if [ -f $IMAGE_PASSWORD_FILE ]; then
 | 
	
		
			
			|  | 435 | +	    FULLBLOG_ADMIN_PASSWORD="$(printf `cat $IMAGE_PASSWORD_FILE`)"
 | 
	
		
			
			|  | 436 | +	else
 | 
	
		
			
			|  | 437 | +	    FULLBLOG_ADMIN_PASSWORD="$(create_password ${MINIMUM_PASSWORD_LENGTH})"
 | 
	
		
			
			| 478 | 438 |  	fi
 | 
	
		
			
			| 479 |  | -	echo "Blog onion domain:${FULLBLOG_ONION_HOSTNAME}" >> $COMPLETION_FILE
 | 
	
		
			
			| 480 |  | -
 | 
	
		
			
			| 481 |  | -	function_check add_ddns_domain
 | 
	
		
			
			| 482 |  | -	add_ddns_domain $FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			| 483 |  | -
 | 
	
		
			
			| 484 |  | -	if ! grep -q "Blog domain:" $COMPLETION_FILE; then
 | 
	
		
			
			| 485 |  | -		echo "Blog domain:$FULLBLOG_DOMAIN_NAME" >> $COMPLETION_FILE
 | 
	
		
			
			|  | 439 | +	echo '' >> /home/$MY_USERNAME/README
 | 
	
		
			
			|  | 440 | +	echo '' >> /home/$MY_USERNAME/README
 | 
	
		
			
			|  | 441 | +	echo $'HTMLy Blog' >> /home/$MY_USERNAME/README
 | 
	
		
			
			|  | 442 | +	echo '==========' >> /home/$MY_USERNAME/README
 | 
	
		
			
			|  | 443 | +	echo $"Your blog username: $MY_USERNAME" >> /home/$MY_USERNAME/README
 | 
	
		
			
			|  | 444 | +	echo $"Your blog password is: $FULLBLOG_ADMIN_PASSWORD" >> /home/$MY_USERNAME/README
 | 
	
		
			
			|  | 445 | +	if [[ $ONION_ONLY == 'no' ]]; then
 | 
	
		
			
			|  | 446 | +	    echo $"Log into your blog at https://$FULLBLOG_DOMAIN_NAME/login" >> /home/$MY_USERNAME/README
 | 
	
		
			
			| 486 | 447 |  	fi
 | 
	
		
			
			| 487 |  | -
 | 
	
		
			
			| 488 |  | -	echo 'install_blog' >> $COMPLETION_FILE
 | 
	
		
			
			|  | 448 | +	chown $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/README
 | 
	
		
			
			|  | 449 | +	chmod 600 /home/$MY_USERNAME/README
 | 
	
		
			
			|  | 450 | +    fi
 | 
	
		
			
			|  | 451 | +
 | 
	
		
			
			|  | 452 | +    # create a user
 | 
	
		
			
			|  | 453 | +    FULLBLOG_ADMIN_PASSWORD_HASH=$(${PROJECT_NAME}-sec --bloghash "$FULLBLOG_ADMIN_PASSWORD")
 | 
	
		
			
			|  | 454 | +    if [ ${#FULLBLOG_ADMIN_PASSWORD_HASH} -lt 8 ]; then
 | 
	
		
			
			|  | 455 | +	echo $'Blog admin password could not be hashed'
 | 
	
		
			
			|  | 456 | +	exit 625728
 | 
	
		
			
			|  | 457 | +    fi
 | 
	
		
			
			|  | 458 | +    echo ';Password' > /var/www/$FULLBLOG_DOMAIN_NAME/htdocs/config/users/$MY_USERNAME.ini
 | 
	
		
			
			|  | 459 | +    echo "password = $FULLBLOG_ADMIN_PASSWORD_HASH" >> /var/www/$FULLBLOG_DOMAIN_NAME/htdocs/config/users/$MY_USERNAME.ini
 | 
	
		
			
			|  | 460 | +    echo 'encryption = password_hash' >> /var/www/$FULLBLOG_DOMAIN_NAME/htdocs/config/users/$MY_USERNAME.ini
 | 
	
		
			
			|  | 461 | +    echo ';Role' >> /var/www/$FULLBLOG_DOMAIN_NAME/htdocs/config/users/$MY_USERNAME.ini
 | 
	
		
			
			|  | 462 | +    echo 'role = admin' >> /var/www/$FULLBLOG_DOMAIN_NAME/htdocs/config/users/$MY_USERNAME.ini
 | 
	
		
			
			|  | 463 | +
 | 
	
		
			
			|  | 464 | +    function_check nginx_ensite
 | 
	
		
			
			|  | 465 | +    nginx_ensite $FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			|  | 466 | +
 | 
	
		
			
			|  | 467 | +    FULLBLOG_ONION_HOSTNAME=$(add_onion_service blog 80 ${FULLBLOG_ONION_PORT})
 | 
	
		
			
			|  | 468 | +
 | 
	
		
			
			|  | 469 | +    systemctl restart php5-fpm
 | 
	
		
			
			|  | 470 | +    systemctl restart nginx
 | 
	
		
			
			|  | 471 | +
 | 
	
		
			
			|  | 472 | +    if ! grep -q "Blog onion domain" /home/$MY_USERNAME/README; then
 | 
	
		
			
			|  | 473 | +	echo $"Blog onion domain: ${FULLBLOG_ONION_HOSTNAME}" >> /home/$MY_USERNAME/README
 | 
	
		
			
			|  | 474 | +	echo $"Log into your blog at https://${FULLBLOG_ONION_HOSTNAME}/login" >> /home/$MY_USERNAME/README
 | 
	
		
			
			|  | 475 | +	echo '' >> /home/$MY_USERNAME/README
 | 
	
		
			
			|  | 476 | +	chown $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/README
 | 
	
		
			
			|  | 477 | +	chmod 600 /home/$MY_USERNAME/README
 | 
	
		
			
			|  | 478 | +    fi
 | 
	
		
			
			|  | 479 | +    echo "Blog onion domain:${FULLBLOG_ONION_HOSTNAME}" >> $COMPLETION_FILE
 | 
	
		
			
			|  | 480 | +
 | 
	
		
			
			|  | 481 | +    function_check add_ddns_domain
 | 
	
		
			
			|  | 482 | +    add_ddns_domain $FULLBLOG_DOMAIN_NAME
 | 
	
		
			
			|  | 483 | +
 | 
	
		
			
			|  | 484 | +    if ! grep -q "Blog domain:" $COMPLETION_FILE; then
 | 
	
		
			
			|  | 485 | +	echo "Blog domain:$FULLBLOG_DOMAIN_NAME" >> $COMPLETION_FILE
 | 
	
		
			
			|  | 486 | +    fi
 | 
	
		
			
			|  | 487 | +
 | 
	
		
			
			|  | 488 | +    echo 'install_blog' >> $COMPLETION_FILE
 | 
	
		
			
			| 489 | 489 |  }
 | 
	
		
			
			| 490 | 490 |  
 | 
	
		
			
			| 491 | 491 |  # NOTE: deliberately no exit 0
 |