Explorar el Código

Add Fathom Analytics

Dennis Rodewyk hace 5 años
padre
commit
0b7d14b7a4

+ 34 - 0
data/services/fathomanalytics/containers.sh

@@ -0,0 +1,34 @@
+fathomanalytics_db_dockerbunker() {
+	docker run -d \
+		--name=${FUNCNAME[0]//_/-} \
+		--restart=always \
+		--network dockerbunker-${SERVICE_NAME} --net-alias=db \
+		--env-file="${SERVICE_ENV}" \
+		--env MYSQL_ROOT_PASSWORD=${MYSQL_ROOT_PASSWORD} \
+		--env MYSQL_DATABASE=${MYSQL_DATABASE} \
+		--env MYSQL_USER=${MYSQL_USER} \
+		--env MYSQL_PASSWORD=${MYSQL_PASSWORD} \
+		-v ${SERVICE_NAME}-db-vol-1:${volumes[${SERVICE_NAME}-db-vol-1]} \
+		-v "${SERVICES_DIR}"/${SERVICE_NAME}/mysql/:/etc/mysql/conf.d/:ro \
+		--health-cmd="mysqladmin ping --host localhost --silent" --health-interval=10s --health-retries=5 --health-timeout=30s \
+	${IMAGES[db]} >/dev/null
+
+	wait_for_db
+}
+
+fathomanalytics_service_dockerbunker() {
+	docker run -d \
+		--name=${FUNCNAME[0]//_/-} \
+		--restart=always \
+		--network dockerbunker-${SERVICE_NAME} \
+		--env-file "${SERVICE_ENV}" \
+		--env FATHOM_SERVER_ADDR=":8080" \
+		--env FATHOM_DEBUG=false \
+		--env FATHOM_DATABASE_DRIVER="mysql" \
+		--env FATHOM_DATABASE_NAME="fathomanalytics" \
+		--env FATHOM_DATABASE_USER="fathomanalytics" \
+		--env FATHOM_DATABASE_PASSWORD="${MYSQL_PASSWORD}" \
+		--env FATHOM_DATABASE_HOST="db:3306" \
+		--env FATHOM_SECRET="${FATHOM_SECRET}" \
+	${IMAGES[service]} >/dev/null
+}

+ 120 - 0
data/services/fathomanalytics/fathomanalytics.sh

@@ -0,0 +1,120 @@
+#!/usr/bin/env bash
+
+while true;do ls | grep -q dockerbunker.sh;if [[ $? == 0 ]];then BASE_DIR=$PWD;break;else cd ../;fi;done
+
+PROPER_NAME="Fathom Analytics"
+SERVICE_NAME="$(echo -e "${PROPER_NAME,,}" | tr -d '[:space:]')"
+PROMPT_SSL=1
+safe_to_keep_volumes_when_reconfiguring=1
+
+declare -a environment=( "data/env/dockerbunker.env" "data/include/init.sh" )
+
+for env in "${environment[@]}";do
+	[[ -f "${BASE_DIR}"/$env ]] && source "${BASE_DIR}"/$env
+done
+
+declare -A WEB_SERVICES
+declare -a containers=( "${SERVICE_NAME}-service-dockerbunker" "${SERVICE_NAME}-db-dockerbunker")
+declare -a add_to_network=( "${SERVICE_NAME}-service-dockerbunker" )
+declare -a networks=( "dockerbunker-${SERVICE_NAME}" )
+declare -A volumes=( [${SERVICE_NAME}-db-vol-1]="/var/lib/mysql" )
+declare -A IMAGES=( [db]="mariadb:10.2" [service]="usefathom/fathom" )
+
+[[ -z $1 ]] && options_menu
+
+configure() {
+	pre_configure_routine
+
+	echo -e "# \e[4mFathom Analytics Settings\e[0m"
+
+	set_domain
+
+	if [ "${FATHOM_ADMIN_EMAIL}" ]; then
+	  read -p "Admin E-Mail: " -ei "${FATHOM_ADMIN_EMAIL}" FATHOM_ADMIN_EMAIL
+	else
+	  read -p "Admin E-Mail: " FATHOM_ADMIN_EMAIL
+	fi
+	
+	unset FATHOM_ADMIN_PASSWORD
+	while [[ "${#FATHOM_ADMIN_PASSWORD}" -le 6 || "${FATHOM_ADMIN_PASSWORD}" != *[A-Z]* || "${FATHOM_ADMIN_PASSWORD}" != *[a-z]* || "${FATHOM_ADMIN_PASSWORD}" != *[0-9]* ]];do
+		if [ ${VALIDATE} ];then
+			echo -e "\n\e[31m  Password does not meet requirements\e[0m"
+		fi
+			stty_orig="$(stty -g)"
+			stty -echo
+	  		read -p " $(printf "\n   \e[4mPassword requirements\e[0m\n   Minimum Length 6,Uppercase, Lowercase, Integer\n\n   Enter Password:") " -ei "" FATHOM_ADMIN_PASSWORD
+			stty "${stty_orig}"
+			echo ""
+		VALIDATE=1
+	done
+	unset VALIDATE
+	echo ""
+
+	echo ""
+
+	# avoid tr illegal byte sequence in macOS when generating random strings
+	if [[ $OSTYPE =~ "darwin" ]];then
+		if [[ $LC_ALL ]];then
+			oldLC_ALL=$LC_ALL
+			export LC_ALL=C
+		else
+			export LC_ALL=C
+		fi
+	fi
+	cat <<-EOF >> "${SERVICE_ENV}"
+	PROPER_NAME="${PROPER_NAME}"
+	SERVICE_NAME=${SERVICE_NAME}
+	SSL_CHOICE=${SSL_CHOICE}
+	LE_EMAIL=${LE_EMAIL}
+
+	# ------------------------------
+	# General Settings
+	# ------------------------------
+	
+	FATHOM_ADMIN_EMAIL=${FATHOM_ADMIN_EMAIL}
+	FATHOM_ADMIN_PASSWORD=${FATHOM_ADMIN_PASSWORD}
+	
+	SERVICE_DOMAIN=${SERVICE_DOMAIN}
+	FATHOM_SECRET=$(tr -dc 'a-zA-Z0-9' < /dev/urandom | head -c 64)
+
+	# ------------------------------
+	# SQL database configuration
+	# ------------------------------
+
+	MYSQL_DATABASE=fathomanalytics
+	MYSQL_USER=fathomanalytics
+	
+	# Please use long, random alphanumeric strings (A-Za-z0-9)
+	MYSQL_PASSWORD=$(tr -dc 'a-zA-Z0-9' < /dev/urandom | head -c 28)
+	MYSQL_ROOT_PASSWORD=$(tr -dc 'a-zA-Z0-9' < /dev/urandom | head -c 28)
+	
+	## ------------------------------
+	SERVICE_SPECIFIC_MX=${SERVICE_SPECIFIC_MX}
+	EOF
+	if [[ $OSTYPE =~ "darwin" ]];then
+		[[ $oldLC_ALL ]] && export LC_ALL=$oldLC_ALL || unset LC_ALL
+	fi
+
+	post_configure_routine
+}
+
+setup() {
+	initial_setup_routine
+
+	SUBSTITUTE=( "\${SERVICE_DOMAIN}" )
+	basic_nginx
+
+	docker_run_all
+
+	post_setup_routine
+	
+	echo -en "\n\e[1mCreating Admin user\e[0m"
+	docker exec -t fathomanalytics-service-dockerbunker bash -c "./fathom user add --email=${FATHOM_ADMIN_EMAIL} --password=${FATHOM_ADMIN_PASSWORD}" >/dev/null
+	exit_response
+}
+
+if [[ $1 == "letsencrypt" ]];then
+	$1 $*
+else
+	$1
+fi

+ 54 - 0
data/services/fathomanalytics/nginx/fathomanalytics.conf

@@ -0,0 +1,54 @@
+##
+# You should look at the following URL's in order to grasp a solid understanding
+# of Nginx configuration files in order to fully unleash the power of Nginx.
+# http://wiki.nginx.org/Pitfalls
+# http://wiki.nginx.org/QuickStart
+# http://wiki.nginx.org/Configuration
+#
+# Generally, you will want to move this file somewhere, and start with a clean
+# file but keep this around for reference. Or just disable in sites-enabled.
+#
+# Please see /usr/share/doc/nginx-doc/examples/ for more detailed examples.
+##
+
+# Default server configuration
+#
+upstream fathomanalytics {
+ server fathomanalytics-service-dockerbunker:8080;
+}
+
+server {
+    listen 80;
+	server_name ${SERVICE_DOMAIN};
+    return 301 https://$host$request_uri;
+}
+
+server {
+    listen 443 ssl;
+	server_name ${SERVICE_DOMAIN};
+	ssl_certificate /etc/nginx/ssl/${SERVICE_DOMAIN}/cert.pem;
+	ssl_certificate_key /etc/nginx/ssl/${SERVICE_DOMAIN}/key.pem;
+	include /etc/nginx/includes/ssl.conf;
+
+    add_header Strict-Transport-Security "max-age=15768000; includeSubDomains";
+	add_header X-Frame-Options DENY;
+	add_header X-Content-Type-Options nosniff;
+
+	include /etc/nginx/includes/gzip.conf;
+
+    location / {
+        proxy_pass http://fathomanalytics/;
+		proxy_set_header  Host              $http_host;   # required for docker client's sake
+		proxy_set_header  X-Real-IP         $remote_addr; # pass on real client's IP
+		proxy_set_header  X-Forwarded-For   $proxy_add_x_forwarded_for;
+		proxy_set_header  X-Forwarded-Proto $scheme;
+		proxy_read_timeout                  900;
+    }
+
+	location ~ /.well-known {
+        allow all;
+		root /var/www/html;
+	}
+}
+
+

+ 1 - 0
included_services

@@ -4,6 +4,7 @@ Cryptpad
 CS50 IDE
 Dillinger
 Drone CI
+Fathom Analytics
 Firefly III
 Firefox Sync
 Ghost