Преглед на файлове

Another matrix implementation

Bob Mottram преди 8 години
родител
ревизия
d5913b32e1
променени са 1 файла, в които са добавени 394 реда и са изтрити 0 реда
  1. 394
    0
      src/freedombone-app-matrix

+ 394
- 0
src/freedombone-app-matrix Целия файл

@@ -0,0 +1,394 @@
1
+#!/bin/bash
2
+#
3
+# .---.                  .              .
4
+# |                      |              |
5
+# |--- .--. .-.  .-.  .-.|  .-. .--.--. |.-.  .-. .--.  .-.
6
+# |    |   (.-' (.-' (   | (   )|  |  | |   )(   )|  | (.-'
7
+# '    '     --'  --'  -' -  -' '  '   -' -'   -' '   -  --'
8
+#
9
+#                    Freedom in the Cloud
10
+#
11
+# matrix server
12
+#
13
+# https://raw.githubusercontent.com/silvio/docker-matrix
14
+#
15
+# License
16
+# =======
17
+#
18
+# Copyright (C) 2016 Bob Mottram <bob@freedombone.net>
19
+#
20
+# This program is free software: you can redistribute it and/or modify
21
+# it under the terms of the GNU Affero General Public License as published by
22
+# the Free Software Foundation, either version 3 of the License, or
23
+# (at your option) any later version.
24
+#
25
+# This program is distributed in the hope that it will be useful,
26
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
27
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
28
+# GNU Affero General Public License for more details.
29
+#
30
+# You should have received a copy of the GNU Affero General Public License
31
+# along with this program.  If not, see <http://www.gnu.org/licenses/>.
32
+
33
+VARIANTS=''
34
+
35
+IN_DEFAULT_INSTALL=0
36
+SHOW_ON_ABOUT=1
37
+
38
+MATRIX_DATA_DIR='/var/lib/matrix'
39
+MATRIX_TURN_PORT=3478
40
+MATRIX_PORT=8448
41
+MATRIX_REPO="https://github.com/matrix-org/synapse"
42
+MATRIX_COMMIT='f5a4001bb116c468cc5e8e0ae04a1c570e2cb171'
43
+
44
+matrix_variables=(ONION_ONLY
45
+                  MY_USERNAME
46
+                  MATRIX_PASSWORD
47
+                  DEFAULT_DOMAIN_NAME)
48
+
49
+function matrix_generate_turn_key {
50
+    local turnkey="${1}"
51
+    local filepath="${2}"
52
+
53
+    echo "lt-cred-mech" > "${filepath}"
54
+    echo "use-auth-secret" >> "${filepath}"
55
+    echo "static-auth-secret=${turnkey}" >> "${filepath}"
56
+    echo "realm=turn.${DEFAULT_DOMAIN_NAME}" >> "${filepath}"
57
+    echo "cert=${MATRIX_DATA_DIR}/${DEFAULT_DOMAIN_NAME}.tls.crt" >> "${filepath}"
58
+    echo "pkey=${MATRIX_DATA_DIR}/${DEFAULT_DOMAIN_NAME}.tls.key" >> "${filepath}"
59
+}
60
+
61
+function matrix_generate_synapse_file {
62
+    local filepath="${1}"
63
+
64
+    cd /etc/matrix
65
+    python -m synapse.app.homeserver \
66
+           --config-path "${filepath}" \
67
+           --generate-config \
68
+           --report-stats ${REPORT_STATS} \
69
+           --server-name ${DEFAULT_DOMAIN_NAME}
70
+}
71
+
72
+function matrix_configure_homeserver_yaml {
73
+    local turnkey="${1}"
74
+    local filepath="${2}"
75
+
76
+    local ymltemp="$(mktemp)"
77
+
78
+    awk -v TURNURIES="turn_uris: [\"turn:${DEFAULT_DOMAIN_NAME}:${MATRIX_TURN_PORT}?transport=udp\", \"turn:${DEFAULT_DOMAIN_NAME}:${MATRIX_TURN_PORT}?transport=tcp\"]" \
79
+        -v TURNSHAREDSECRET="turn_shared_secret: \"${turnkey}\"" \
80
+        -v PIDFILE="pid_file: ${MATRIX_DATA_DIR}/homeserver.pid" \
81
+        -v DATABASE="database: \"${MATRIX_DATA_DIR}/homeserver.db\"" \
82
+        -v LOGFILE="log_file: \"${MATRIX_DATA_DIR}/homeserver.log\"" \
83
+        -v MEDIASTORE="media_store_path: \"${MATRIX_DATA_DIR}/media_store\"" \
84
+        '{
85
+        sub(/turn_shared_secret: "YOUR_SHARED_SECRET"/, TURNSHAREDSECRET);
86
+        sub(/turn_uris: \[\]/, TURNURIES);
87
+        sub(/pid_file: \/homeserver.pid/, PIDFILE);
88
+        sub(${MATRIX_DATA_DIR}base: "\/homeserver.db"/, DATABASE);
89
+        sub(/log_file: "\/homeserver.log"/, LOGFILE);
90
+        sub(/media_store_path: "\/media_store"/, MEDIASTORE);
91
+        print;
92
+        }' "${filepath}" > "${ymltemp}"
93
+
94
+    mv ${ymltemp} "${filepath}"
95
+}
96
+
97
+function matrix_start {
98
+    if [ -f ${MATRIX_DATA_DIR}/turnserver.conf ]; then
99
+        echo "-=> start turn"
100
+        /usr/bin/turnserver --daemon -c ${MATRIX_DATA_DIR}/turnserver.conf
101
+    fi
102
+
103
+    echo "-=> start riot.im client"
104
+    (
105
+        if [ -f ${MATRIX_DATA_DIR}/vector.im.conf ] || [ -f ${MATRIX_DATA_DIR}/riot.im.conf ] ; then
106
+            echo "The riot web client is now handled via silvio/matrix-riot-docker"
107
+        fi
108
+    )
109
+
110
+    echo "-=> start matrix"
111
+    python -m synapse.app.homeserver --config-path ${MATRIX_DATA_DIR}/homeserver.yaml
112
+}
113
+
114
+function matrix_stop {
115
+    echo "-=> stop matrix"
116
+    echo "-=> via docker stop ..."
117
+}
118
+
119
+
120
+function matrix_diff {
121
+    echo "-=> Diff between local configfile and a fresh generated config file"
122
+    echo "-=>      some values are different in technical point of view, like"
123
+    echo "-=>      autogenerated secret keys etc..."
124
+
125
+    DIFFPARAMS="${DIFFPARAMS:-Naur}"
126
+    DEFAULT_DOMAIN_NAME="${DEFAULT_DOMAIN_NAME:-demo_server_name}"
127
+    REPORT_STATS="${REPORT_STATS:-no_or_yes}"
128
+    export DEFAULT_DOMAIN_NAME REPORT_STATS
129
+
130
+    matrix_generate_synapse_file /tmp/homeserver.synapse.yaml
131
+    diff -${DIFFPARAMS} /tmp/homeserver.synapse.yaml ${MATRIX_DATA_DIR}/homeserver.yaml
132
+    rm /tmp/homeserver.synapse.yaml
133
+}
134
+
135
+function matrix_generate {
136
+    breakup="0"
137
+    [[ -z "${DEFAULT_DOMAIN_NAME}" ]] && echo "STOP! environment variable DEFAULT_DOMAIN_NAME must be set" && breakup="1"
138
+    [[ -z "${REPORT_STATS}" ]] && echo "STOP! environment variable REPORT_STATS must be set to 'no' or 'yes'" && breakup="1"
139
+    [[ "${breakup}" == "1" ]] && exit 1
140
+
141
+    [[ "${REPORT_STATS}" != "yes" ]] && [[ "${REPORT_STATS}" != "no" ]] && \
142
+        echo "STOP! REPORT_STATS needs to be 'no' or 'yes'" && breakup="1"
143
+
144
+    echo "-=> generate turn config"
145
+    turnkey=$(pwgen -s 64 1)
146
+    matrix_generate_turn_key $turnkey ${MATRIX_DATA_DIR}/turnserver.conf
147
+
148
+    echo "-=> generate synapse config"
149
+    matrix_generate_synapse_file ${MATRIX_DATA_DIR}/homeserver.tmp
150
+
151
+    echo "-=> configure some settings in homeserver.yaml"
152
+    matrix_configure_homeserver_yaml $turnkey ${MATRIX_DATA_DIR}/homeserver.tmp
153
+
154
+    mv ${MATRIX_DATA_DIR}/homeserver.tmp ${MATRIX_DATA_DIR}/homeserver.yaml
155
+}
156
+
157
+function remove_user_matrix {
158
+    remove_username="$1"
159
+
160
+    ${PROJECT_NAME}-pass -u $remove_username --rmapp matrix
161
+
162
+    # TODO
163
+}
164
+
165
+function add_user_matrix {
166
+    new_username="$1"
167
+    new_user_password="$2"
168
+
169
+    ${PROJECT_NAME}-pass -u $new_username -a matrix -p "$new_user_password"
170
+
171
+    cd /etc/matrix
172
+    register_new_matrix_user -c ${MATRIX_DATA_DIR}/homeserver.yaml https://localhost:${MATRIX_PORT} -u "${new_username}" -p "${new_user_password}" -a
173
+    echo '0'
174
+}
175
+
176
+function install_interactive_matrix {
177
+    echo -n ''
178
+    APP_INSTALLED=1
179
+}
180
+
181
+function change_password_matrix {
182
+    curr_username="$1"
183
+    new_user_password="$2"
184
+
185
+    #${PROJECT_NAME}-pass -u "$curr_username" -a matrix -p "$new_user_password"
186
+}
187
+
188
+function reconfigure_matrix {
189
+    echo -n ''
190
+}
191
+
192
+function upgrade_matrix {
193
+    function_check set_repo_commit
194
+    set_repo_commit /etc/matrix "matrix commit" "$MATRIX_COMMIT" $MATRIX_REPO
195
+
196
+    pip install --upgrade --process-dependency-links .
197
+    chown -R matrix:matrix /etc/matrix
198
+    chown -R matrix:matrix /var/lib/matrix
199
+}
200
+
201
+function backup_local_matrix {
202
+    source_directory=/etc/matrix
203
+    if [ -d $source_directory ]; then
204
+        systemctl stop matrix
205
+        function_check backup_directory_to_usb
206
+        backup_directory_to_usb $source_directory matrix
207
+        source_directory=/var/lib/matrix
208
+        if [ -d $source_directory ]; then
209
+            backup_directory_to_usb $source_directory matrixdata
210
+        fi
211
+        systemctl start matrix
212
+    fi
213
+}
214
+
215
+function restore_local_matrix {
216
+    if [ -d /etc/matrix ]; then
217
+        systemctl stop matrix
218
+
219
+        temp_restore_dir=/root/tempmatrix
220
+        function_check restore_directory_from_usb
221
+        restore_directory_from_usb $temp_restore_dir matrix
222
+        cp -r $temp_restore_dir/etc/matrix/* /etc/matrix
223
+        if [ ! "$?" = "0" ]; then
224
+            function_check backup_unmount_drive
225
+            backup_unmount_drive
226
+            exit 3783
227
+        fi
228
+        rm -rf $temp_restore_dir
229
+        chown -R matrix:matrix /etc/matrix
230
+
231
+        temp_restore_dir=/root/tempmatrixdata
232
+        restore_directory_from_usb $temp_restore_dir matrixdata
233
+        cp -r $temp_restore_dir/var/lib/matrix/* /var/lib/matrix
234
+        if [ ! "$?" = "0" ]; then
235
+            function_check backup_unmount_drive
236
+            backup_unmount_drive
237
+            exit 78352
238
+        fi
239
+        rm -rf $temp_restore_dir
240
+        chown -R matrix:matrix /var/lib/matrix
241
+
242
+        systemctl start matrix
243
+    fi
244
+}
245
+
246
+function backup_remote_matrix {
247
+    source_directory=/etc/matrix
248
+    if [ -d $source_directory ]; then
249
+        systemctl stop matrix
250
+        function_check backup_directory_to_friend
251
+        backup_directory_to_friend $source_directory matrix
252
+        source_directory=/var/lib/matrix
253
+        if [ -d $source_directory ]; then
254
+            backup_directory_to_friend $source_directory matrixdata
255
+        fi
256
+        systemctl start matrix
257
+    fi
258
+}
259
+
260
+function restore_remote_synapse {
261
+    if [ -d /etc/matrix ]; then
262
+        systemctl stop matrix
263
+
264
+        temp_restore_dir=/root/tempmatrix
265
+        function_check restore_directory_from_friend
266
+        restore_directory_from_friend $temp_restore_dir matrix
267
+        cp -r $temp_restore_dir/etc/matrix/* /etc/matrix
268
+        if [ ! "$?" = "0" ]; then
269
+            exit 38935
270
+        fi
271
+        rm -rf $temp_restore_dir
272
+        chown -R matrix:matrix /etc/matrix
273
+
274
+        temp_restore_dir=/root/tempmatrixdata
275
+        restore_directory_from_friend $temp_restore_dir matrixdata
276
+        cp -r $temp_restore_dir/var/lib/matrix/* /var/lib/matrix
277
+        if [ ! "$?" = "0" ]; then
278
+            exit 60923
279
+        fi
280
+        rm -rf $temp_restore_dir
281
+        chown -R matrix:matrix /var/lib/matrix
282
+
283
+        systemctl start matrix
284
+    fi
285
+}
286
+
287
+function remove_matrix {
288
+    firewall_remove ${MATRIX_PORT}
289
+    firewall_remove ${MATRIX_TURN_PORT}
290
+    systemctl stop matrix
291
+    systemcrl disable matrix
292
+    if [ -f /etc/systemd/system/matrix.service ]; then
293
+        rm /etc/systemd/system/matrix.service
294
+    fi
295
+    apt-get -y remove --purge coturn
296
+    cd /etc/matrix
297
+    pip uninstall .
298
+    rm -rf $MATRIX_DATA_DIR
299
+    rm -rf /etc/matrix
300
+    deluser matrix
301
+    delgroup matrix
302
+    remove_onion_service matrix ${MATRIX_PORT}
303
+
304
+    remove_completion_param install_matrix
305
+    sed -i '/matrix/d' $COMPLETION_FILE
306
+}
307
+
308
+function install_matrix {
309
+    if [[ ${ONION_ONLY} == 'no' ]]; then
310
+        # obtain a cert for the default domain
311
+        if [[ "$(cert_exists ${DEFAULT_DOMAIN_NAME} pem)" == "0" ]]; then
312
+            echo $'Obtaining certificate for the main domain'
313
+            create_site_certificate ${DEFAULT_DOMAIN_NAME} 'yes'
314
+        fi
315
+    fi
316
+
317
+    REBUILD=1
318
+    export DEBIAN_FRONTEND=noninteractive
319
+    apt-get -yq install coreutils coturn \
320
+            curl file gcc git libevent-2.0-5 \
321
+            libevent-dev libffi-dev libffi6 \
322
+            libgnutls28-dev libjpeg62-turbo \
323
+            libjpeg62-turbo-dev libldap-2.4-2 \
324
+            libldap2-dev libsasl2-dev \
325
+            libsqlite3-dev libssl-dev \
326
+            libssl1.0.0 libtool libxml2 \
327
+            libxml2-dev libxslt1-dev libxslt1.1 \
328
+            make pwgen python python-dev \
329
+            python-pip python-psycopg2 \
330
+            python-virtualenv sqlite unzip \
331
+            zlib1g zlib1g-dev
332
+
333
+    pip install --upgrade pip
334
+    pip install --upgrade python-ldap
335
+    pip install --upgrade lxml
336
+
337
+    if [ ! -d /etc/matrix ]; then
338
+        function_check git_clone
339
+        git_clone $MATRIX_REPO /etc/matrix
340
+        if [ ! -d /etc/matrix ]; then
341
+            echo $'Unable to clone matrix repo'
342
+            exit 6724683
343
+        fi
344
+    fi
345
+
346
+    cd /etc/matrix
347
+    git checkout $MATRIX_COMMIT -b $MATRIX_COMMIT
348
+    set_completion_param "matrix commit" "$MATRIX_COMMIT"
349
+    pip install --upgrade --process-dependency-links .
350
+    if [ ! "$?" = "0" ]; then
351
+        exit 782542
352
+    fi
353
+
354
+    groupadd matrix
355
+    useradd -c "Matrix system account" -d /var/lib/matrix -m -r -g matrix matrix
356
+
357
+    chown -R matrix:matrix /etc/matrix
358
+    chown -R matrix:matrix /var/lib/matrix
359
+
360
+    echo '[Unit]' > /etc/systemd/system/matrix.service
361
+    echo 'Description=Matrix federated messaging' >> /etc/systemd/system/matrix.service
362
+    echo '' >> /etc/systemd/system/matrix.service
363
+    echo '[Service]' >> /etc/systemd/system/matrix.service
364
+    echo 'Type=simple' >> /etc/systemd/system/matrix.service
365
+    echo 'User=matrix' >> /etc/systemd/system/matrix.service
366
+    echo "WorkingDirectory=/etc/matrix" >> /etc/systemd/system/matrix.service
367
+    echo "ExecStart=/usr/bin/turnserver --daemon -c ${MATRIX_DATA_DIR}/turnserver.conf" >> /etc/systemd/system/matrix.service
368
+    echo "ExecStart=/usr/bin/python -m synapse.app.homeserver --config-path ${MATRIX_DATA_DIR}/homeserver.yaml" >> /etc/systemd/system/matrix.service
369
+    echo 'Restart=always' >> /etc/systemd/system/matrix.service
370
+    echo 'RestartSec=10' >> /etc/systemd/system/matrix.service
371
+    echo '' >> /etc/systemd/system/matrix.service
372
+    echo '[Install]' >> /etc/systemd/system/matrix.service
373
+    echo 'WantedBy=multi-user.target' >> /etc/systemd/system/matrix.service
374
+    systemctl enable matrix
375
+    systemctl daemon-reload
376
+    systemctl start matrix
377
+
378
+    update_default_domain
379
+
380
+    firewall_add matrix ${MATRIX_PORT}
381
+    firewall_add matrix-turn ${MATRIX_TURN_PORT}
382
+
383
+    MATRIX_ONION_HOSTNAME=$(add_onion_service matrix ${MATRIX_PORT} ${MATRIX_PORT})
384
+    if [ ! ${MATRIX_PASSWORD} ]; then
385
+        if [ -f ${IMAGE_PASSWORD_FILE} ]; then
386
+            MATRIX_PASSWORD="$(printf `cat $IMAGE_PASSWORD_FILE`)"
387
+        else
388
+            MATRIX_PASSWORD="$(create_password ${MINIMUM_PASSWORD_LENGTH})"
389
+        fi
390
+    fi
391
+
392
+    add_user_matrix "${MY_USERNAME}" "${MATRIX_PASSWORD}"
393
+    APP_INSTALLED=1
394
+}