2018-07-27 16:08:14 +03:00
|
|
|
#!/bin/bash
|
2018-09-25 20:45:08 +03:00
|
|
|
set -e
|
|
|
|
|
2018-07-16 19:10:33 +03:00
|
|
|
# config
|
2018-09-18 17:51:50 +03:00
|
|
|
SYNAPSE_BRANCH=develop
|
2018-07-16 19:10:33 +03:00
|
|
|
INSTALLATION_NAME=consent
|
|
|
|
SERVER_DIR=installations/$INSTALLATION_NAME
|
|
|
|
CONFIG_TEMPLATE=consent
|
2018-08-07 19:28:18 +03:00
|
|
|
PORT=5005
|
2018-07-16 19:10:33 +03:00
|
|
|
# set current directory to script directory
|
2018-09-25 20:45:08 +03:00
|
|
|
BASE_DIR=$(cd $(dirname $0) && pwd)
|
2018-07-27 15:00:01 +03:00
|
|
|
|
2018-07-27 16:08:14 +03:00
|
|
|
if [ -d $BASE_DIR/$SERVER_DIR ]; then
|
2018-08-14 13:53:16 +03:00
|
|
|
echo "synapse is already installed"
|
|
|
|
exit
|
2018-07-27 15:00:01 +03:00
|
|
|
fi
|
|
|
|
|
2018-07-27 15:10:19 +03:00
|
|
|
cd $BASE_DIR
|
2019-06-24 13:51:05 +03:00
|
|
|
mkdir -p $SERVER_DIR
|
2018-07-27 15:10:19 +03:00
|
|
|
cd $SERVER_DIR
|
2019-03-29 13:25:21 +03:00
|
|
|
virtualenv -p python3 env
|
2018-07-16 19:10:33 +03:00
|
|
|
source env/bin/activate
|
2018-09-25 20:45:08 +03:00
|
|
|
|
|
|
|
# Having been bitten by pip SSL fail too many times, I don't trust the existing pip
|
|
|
|
# to be able to --upgrade itself, so grab a new one fresh from source.
|
|
|
|
curl https://bootstrap.pypa.io/get-pip.py -o get-pip.py
|
|
|
|
python get-pip.py
|
|
|
|
|
2018-07-16 19:10:33 +03:00
|
|
|
pip install --upgrade setuptools
|
2019-06-24 13:51:05 +03:00
|
|
|
pip install https://codeload.github.com/matrix-org/synapse/zip/$SYNAPSE_BRANCH
|
2018-07-16 19:10:33 +03:00
|
|
|
# apply configuration
|
2019-06-24 13:51:05 +03:00
|
|
|
pushd env/bin/
|
2018-07-16 19:10:33 +03:00
|
|
|
cp -r $BASE_DIR/config-templates/$CONFIG_TEMPLATE/. ./
|
2018-09-25 20:45:08 +03:00
|
|
|
|
|
|
|
# Hashes used instead of slashes because we'll get a value back from $(pwd) that'll be
|
|
|
|
# full of un-escapable slashes.
|
2019-04-03 16:46:55 +03:00
|
|
|
# Use .bak suffix as using no suffix doesn't work macOS.
|
|
|
|
sed -i.bak "s#{{SYNAPSE_ROOT}}#$(pwd)/#g" homeserver.yaml
|
|
|
|
sed -i.bak "s#{{SYNAPSE_PORT}}#${PORT}#g" homeserver.yaml
|
|
|
|
sed -i.bak "s#{{FORM_SECRET}}#$(uuidgen)#g" homeserver.yaml
|
|
|
|
sed -i.bak "s#{{REGISTRATION_SHARED_SECRET}}#$(uuidgen)#g" homeserver.yaml
|
|
|
|
sed -i.bak "s#{{MACAROON_SECRET_KEY}}#$(uuidgen)#g" homeserver.yaml
|
|
|
|
rm *.bak
|
2019-06-24 13:51:05 +03:00
|
|
|
|
|
|
|
popd
|
2019-06-24 13:51:51 +03:00
|
|
|
# generate signing keys for signing_key_path
|
|
|
|
python -m synapse.app.homeserver --generate-keys --config-dir env/bin/ -c env/bin/homeserver.yaml
|