-
Notifications
You must be signed in to change notification settings - Fork 77
/
Copy pathgenerate_conf.sh
176 lines (142 loc) · 5.47 KB
/
generate_conf.sh
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
#!/bin/bash
# Generate config and secrets required to host your own outline server
set -e
shopt -s expand_aliases
if [ "$(uname)" == "Darwin" ]; then
if ! command -v gsed &> /dev/null
then
# https://unix.stackexchange.com/a/131940
echo "sed commands here are tested only with GNU sed"
echo "Installing gnu-sed"
brew install gnu-sed
else
alias sed=gsed
fi
fi
function env_add {
key=$1
val=$2
filename=$3
echo "${key}=${val}" >> $filename
}
function env_replace {
key=$1
val=$2
filename=$3
# sed -i "0,/name:/{s/${key}=.*/${key}='${val}'/}" $filename
sed "s|${key}=.*|${key}=${val}|" -i $filename
}
function env_delete {
key=$1
filename=$2
sed "/${key}/d" -i env.outline
}
function create_slack_env {
# get url from outline env
set -o allexport; source env.outline; set +o allexport
echo "=> Open https://api.slack.com/apps and Create New App"
echo "=> After creating, scroll down to 'Add features and functionality' -> 'Permissions'"
echo "=> '${URL}/auth/slack.callback'"
read -p "Copy the above to Redirect URLs. Press Enter to continue..."
echo "=> Save, go back and scroll down to 'App Credentials'"
if test -f env.slack; then
set -o allexport; source env.slack; set +o allexport
fi
read -p "Enter App ID [$SLACK_APP_ID] : " SLACK_APP_ID_INP
read -p "Enter Client ID [$SLACK_KEY] : " SLACK_KEY_INP
read -p "Enter Client Secret [$SLACK_SECRET]: " SLACK_SECRET_INP
read -p "Enter Verification Token (*not* Signing Secret) [$SLACK_VERIFICATION_TOKEN]: " SLACK_VERIFICATION_TOKEN_INP
touch env.slack
env_add SLACK_APP_ID ${SLACK_APP_ID_INP:-SLACK_APP_ID} env.slack
env_add SLACK_KEY ${SLACK_KEY_INP:-SLACK_KEY} env.slack
env_add SLACK_SECRET ${SLACK_SECRET_INP:-SLACK_SECRET} env.slack
env_add SLACK_VERIFICATION_TOKEN ${SLACK_VERIFICATION_TOKEN_INP:-SLACK_VERIFICATION_TOKEN} env.slack
}
function create_env_files {
read -p "Enter hostname [localhost]: " HOST
HOST=${HOST:-localhost}
read -p "Enter http port number [80]: " HTTP_PORT
HTTP_PORT=${HTTP_PORT:-80}
if [ $HTTP_PORT == 80 ]
then
URL="http://${HOST}"
else
URL="http://${HOST}:${HTTP_PORT}"
fi
sed "s|8888:80|${HTTP_PORT}:80|" -i docker-compose.yml
# TODO: Allow configuration of portnumber
read -p "Enter bucket name to store images [outline-bucket]: " BUCKET_NAME
BUCKET_NAME=${BUCKET_NAME:-outline-bucket}
# download latest sample env for outline
wget --quiet https://raw.githubusercontent.com/outline/outline/develop/.env.sample -O env.outline
# add new line
echo "" >> env.outline
env_replace URL $URL env.outline
env_add HOST $HOST env.outline
env_add HTTP_PORT $HTTP_PORT env.outline
SECRET_KEY=`openssl rand -hex 32`
UTILS_SECRET=`openssl rand -hex 32`
env_replace SECRET_KEY $SECRET_KEY env.outline
env_replace UTILS_SECRET $UTILS_SECRET env.outline
env_delete DATABASE_URL
env_delete DATABASE_URL_TEST
env_delete REDIS_URL
env_replace PORT 3000 env.outline
env_replace FORCE_HTTPS 'false' env.outline
# Disable SSL for PostgreSQL: https://github.com/outline/outline/issues/1501
env_add PGSSLMODE disable env.outline
# Setup datastore
sed "s|outline-bucket|${BUCKET_NAME}|" -i data/nginx/http.conf.disabled
sed "s|outline-bucket|${BUCKET_NAME}|" -i data/nginx/https.conf.disabled
MINIO_ACCESS_KEY=`openssl rand -hex 8`
MINIO_SECRET_KEY=`openssl rand -hex 32`
rm -f env.minio
env_add MINIO_ACCESS_KEY $MINIO_ACCESS_KEY env.minio
env_add MINIO_SECRET_KEY $MINIO_SECRET_KEY env.minio
env_add MINIO_BROWSER off env.minio
env_replace AWS_ACCESS_KEY_ID $MINIO_ACCESS_KEY env.outline
env_replace AWS_SECRET_ACCESS_KEY $MINIO_SECRET_KEY env.outline
env_replace AWS_S3_UPLOAD_BUCKET_NAME $BUCKET_NAME env.outline
env_replace AWS_S3_UPLOAD_BUCKET_URL $URL env.outline
}
function generate_starter_https_conf {
echo "Generating HTTPS configuration"
# https://letsencrypt.org/docs/certificates-for-localhost/
openssl req -x509 -out data/certs/public.crt -keyout data/certs/private.key \
-newkey rsa:2048 -nodes -sha256 \
-subj '/CN=localhost' -extensions EXT -config <( \
printf "[dn]\nCN=localhost\n[req]\ndistinguished_name = dn\n[EXT]\nsubjectAltName=DNS:localhost\nkeyUsage=digitalSignature\nextendedKeyUsage=serverAuth")
pushd data/nginx
rm -f default.conf
ln -s https.conf.disabled default.conf
popd
set -o allexport; source env.outline; set +o allexport
read -p "Enter https port number [443]: " HTTPS_PORT
HTTPS_PORT=${HTTPS_PORT:-443}
if [ $HTTPS_PORT == 443 ]
then
URL="https://${HOST}"
else
URL="https://${HOST}:${HTTPS_PORT}"
fi
sed "s|4443:443|${HTTPS_PORT}:443|" -i docker-compose.yml
env_replace FORCE_HTTPS 'true' env.outline
env_add HTTPS_PORT $HTTPS_PORT env.outline
env_replace URL $URL env.outline
env_replace AWS_S3_UPLOAD_BUCKET_URL $URL env.outline
}
function delete_data {
read -p "Do you want to delete your database and images [no]: " DELETE_DB
DELETE_DB=${DELETE_DB:-no};
if [ $DELETE_DB == "yes" ]
then
echo "deleting database and images"
rm -rfv data/pgdata data/minio_root
fi
}
function init_data_dirs {
# get url from outline env
set -o allexport; source env.outline; set +o allexport
mkdir -p data/minio_root/${AWS_S3_UPLOAD_BUCKET_NAME} data/pgdata
}
$*