Browse Source

Add Rocket.Chat

dennisro 6 years ago
parent
commit
679f55bc4d

+ 30 - 0
data/services/rocketchat/containers.sh

@@ -0,0 +1,30 @@
+rocketchat_db_dockerbunker() {
+	docker run -d \
+		--name=${FUNCNAME[0]//_/-} \
+		--restart=always \
+		--network dockerbunker-${SERVICE_NAME} --net-alias=db \
+		-v ${SERVICE_NAME}-db-vol-1:${volumes[${SERVICE_NAME}-db-vol-1]} \
+		-v ${SERVICE_NAME}-db-vol-1:${volumes[${SERVICE_NAME}-db-vol-2]} \
+	${IMAGES[db]} mongod --smallfiles >/dev/null
+}
+
+rocketchat_service_dockerbunker() {
+	docker run -d \
+		--name=${FUNCNAME[0]//_/-} \
+		--restart=always \
+		--network dockerbunker-${SERVICE_NAME} \
+		--env-file="${SERVICE_ENV}" \
+	${IMAGES[service]} >/dev/null
+}
+
+rocketchat_hubot_dockerbunker() {
+	docker run -d \
+		--name=${FUNCNAME[0]//_/-} \
+		--restart=always \
+		--network dockerbunker-${SERVICE_NAME} \
+		--env-file="${SERVICE_ENV}" \
+	${IMAGES[hubot]} >/dev/null
+}
+
+
+

+ 57 - 0
data/services/rocketchat/nginx/rocketchat.conf

@@ -0,0 +1,57 @@
+map $http_upgrade $connection_upgrade {
+    default upgrade;
+    ''      close;
+}
+
+upstream rocketchat {
+ server rocketchat-service-dockerbunker:3000;
+}
+
+server {
+    listen 80;
+	server_name ${SERVICE_DOMAIN};
+    return 301 https://$host$request_uri;
+	add_header X-Content-Type-Options "nosniff" always;
+	add_header X-XSS-Protection "1; mode=block" always;
+	add_header X-Frame-Options "DENY" always;
+	add_header Referrer-Policy "strict-origin" always;
+	add_header Strict-Transport-Security "max-age=31536000; includeSubDomains";
+	server_tokens off;
+}
+
+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 X-Content-Type-Options "nosniff" always;
+	add_header X-XSS-Protection "1; mode=block" always;
+	add_header X-Frame-Options "DENY" always;
+	add_header Referrer-Policy "strict-origin" always;
+	add_header Strict-Transport-Security "max-age=31536000; includeSubDomains";
+	server_tokens off;
+
+	include /etc/nginx/includes/gzip.conf;
+
+location / {
+        proxy_pass http://rocketchat/;
+			proxy_http_version 1.1;
+			proxy_set_header Upgrade $http_upgrade;
+			proxy_set_header Connection "upgrade";
+			proxy_set_header Host $http_host;
+			proxy_set_header X-Real-IP $remote_addr;
+			proxy_set_header X-Forward-For $proxy_add_x_forwarded_for;
+			proxy_set_header X-Forward-Proto http;
+			proxy_set_header X-Nginx-Proxy true;
+			proxy_redirect off;
+    }
+
+	location ~ /.well-known {
+        allow all;
+		root /var/www/html;
+	}
+}
+
+

+ 92 - 0
data/services/rocketchat/rocketchat.sh

@@ -0,0 +1,92 @@
+#!/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="Rocket.Chat"
+SERVICE_NAME="$(echo -e "${PROPER_NAME,,}" | tr -cd '[:alnum:]')"
+PROMPT_SSL=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}-hubot-dockerbunker" "${SERVICE_NAME}-db-dockerbunker" )
+declare -a add_to_network=( "${SERVICE_NAME}-service-dockerbunker" )
+declare -A IMAGES=( [service]="rocketchat/rocket.chat:latest" [hubot]="rocketchat/hubot-rocketchat:latest" [db]="mongo" )
+declare -A volumes=( [${SERVICE_NAME}-db-vol-1]="/data/db" [${SERVICE_NAME}-db-vol-2]="/dump" )
+declare -a networks=( "dockerbunker-${SERVICE_NAME}" )
+
+[[ -z $1 ]] && options_menu
+
+configure() {
+	pre_configure_routine
+	
+	echo -e "# \e[4mRocket.Chat Settings\e[0m"
+
+	set_domain
+	
+	echo ""	
+	
+	unset BOT_NAME
+	if [ "${BOT_NAME}" ]; then
+		read -p "Rocket.Chat Bot Display Name: " -ei "${BOT_NAME}" BOT_NAME
+	else
+		read -p "Rocket.Chat Bot Display Name: " -ei "Botty MacBotface" BOT_NAME
+	fi
+	
+	echo ""
+
+	unset ROCKETCHAT_USER
+	if [ "$ROCKETCHAT_USER" ]; then
+		read -p "Rocket.Chat Bot Username: " -ei "$ROCKETCHAT_USER" ROCKETCHAT_USER
+	else
+		read -p "Rocket.Chat Bot Username: " -ei "" ROCKETCHAT_USER
+	fi
+	
+	echo ""
+
+	unset ROCKETCHAT_PASSWORD
+	while [[ "${#ROCKETCHAT_PASSWORD}" -le 6 || "$ROCKETCHAT_PASSWORD" != *[A-Z]* || "$ROCKETCHAT_PASSWORD" != *[a-z]* || "$ROCKETCHAT_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 Bot Password:") " -ei "" ROCKETCHAT_PASSWORD
+			stty "$stty_orig"
+			echo ""
+		VALIDATE=1
+	done
+	unset VALIDATE
+	echo ""
+	cat <<-EOF >> "${SERVICE_ENV}"
+	PROPER_NAME=${PROPER_NAME}
+	SERVICE_NAME=${SERVICE_NAME}
+	SSL_CHOICE=${SSL_CHOICE}
+	LE_EMAIL=${LE_EMAIL}
+
+	SERVICE_DOMAIN=${SERVICE_DOMAIN}
+
+    MONGO_URL=mongodb://db:27017/rocketchat
+	ROOT_URL=https://${SERVICE_DOMAIN}
+	Accounts_UseDNSDomainCheck=True
+	ROCKETCHAT_URL=rocketchat-service-dockerbunker:3000
+	
+	ROCKETCHAT_ROOM=GENERAL
+	ROCKETCHAT_USER=${ROCKETCHAT_USER}
+	BOT_NAME="${BOT_NAME}"
+	ROCKETCHAT_PASSWORD=${ROCKETCHAT_PASSWORD}
+	EXTERNAL_SCRIPTS=hubot-help,hubot-seen,hubot-links,hubot-greetings
+	
+	EOF
+	
+	post_configure_routine
+}
+
+if [[ $1 == "letsencrypt" ]];then
+	$1 $*
+else
+	$1
+fi

+ 1 - 0
dockerbunker.sh

@@ -42,6 +42,7 @@ declare -a ALL_SERVICES=( \
 	"Open Project" \
 	"Padlock Cloud" \
 	"Piwik" \
+	"Rocket.Chat" \
 	"Seafile Pro" \
 	"Searx" \
 	"Send" \