Adding configuration abilities to matrix.sh
This commit is contained in:
4
seqs/matrix.cfg.example
Normal file
4
seqs/matrix.cfg.example
Normal file
@@ -0,0 +1,4 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
MATRIX_HOME="/opt/synapse"
|
||||||
|
MATRIX_DOMAIN="matrix.example.com"
|
@@ -2,12 +2,12 @@
|
|||||||
|
|
||||||
toolName=synapse
|
toolName=synapse
|
||||||
toolDeps="build-essential python3-dev libffi-dev python3-pip python3-setuptools postgresql libssl-dev virtualenv libjpeg-dev libxslt1-dev libpq5 libpq-dev"
|
toolDeps="build-essential python3-dev libffi-dev python3-pip python3-setuptools postgresql libssl-dev virtualenv libjpeg-dev libxslt1-dev libpq5 libpq-dev"
|
||||||
toolDir="/opt/synapse"
|
|
||||||
toolConfig="${toolDir}/homeserver.yaml"
|
|
||||||
toolUser="synapse"
|
toolUser="synapse"
|
||||||
toolGroup="synapse"
|
toolGroup="synapse"
|
||||||
toolDomain="matrix.winklerfamilie.eu"
|
|
||||||
toolUrl="https://$toolDomain"
|
# Filled by configuration
|
||||||
|
toolConfig=
|
||||||
|
toolUrl=
|
||||||
|
|
||||||
# Needed for different steps
|
# Needed for different steps
|
||||||
postgresDb=""
|
postgresDb=""
|
||||||
@@ -18,18 +18,20 @@ postgresPass=""
|
|||||||
# (when called from a different directory)
|
# (when called from a different directory)
|
||||||
WDIR="$( cd "$( dirname "${BASH_SOURCE[0]}" )" >>/dev/null 2>&1 && pwd )"
|
WDIR="$( cd "$( dirname "${BASH_SOURCE[0]}" )" >>/dev/null 2>&1 && pwd )"
|
||||||
CONFIG=0
|
CONFIG=0
|
||||||
#CONFIG_FILE_NAME="${toolName}.cfg"
|
CONFIG_FILE_NAME="matrix.cfg"
|
||||||
#CONFIG_FILE_TEMPLATE="$WDIR/${CONFIG_FILE_NAME}.example"
|
CONFIG_FILE_TEMPLATE="$WDIR/${CONFIG_FILE_NAME}.example"
|
||||||
|
|
||||||
#step_config() {
|
step_config() {
|
||||||
## e.g. to source a config file manually:
|
initSeqConfig "$CONFIG_FILE_NAME" "$CONFIG_FILE_TEMPLATE"
|
||||||
#. "$CONFIG_FILE"
|
if [ $? -eq 0 ] ; then
|
||||||
## or to use sequencer api:
|
CONFIG=1
|
||||||
#initSeqConfig "$CONFIG_FILE_NAME" "$CONFIG_FILE_TEMPLATE"
|
toolConfig="${MATRIX_HOME}/homeserver.yaml"
|
||||||
#if [ $? -eq 0 ] ; then
|
toolUrl="https://$MATRIX_DOMAIN"
|
||||||
# CONFIG=1
|
localHome="$MATRIX_HOME"
|
||||||
#fi
|
echo " $toolName home: $MATRIX_HOME"
|
||||||
#}
|
echo " $toolName domain: $MATRIX_DOMAIN"
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
step_1_info() { echo "Installing $toolName dependencies"; }
|
step_1_info() { echo "Installing $toolName dependencies"; }
|
||||||
step_1_alias() { ALIAS="install"; }
|
step_1_alias() { ALIAS="install"; }
|
||||||
@@ -62,29 +64,29 @@ step_2() {
|
|||||||
step_3_info() { echo "Create $toolName user and group"; }
|
step_3_info() { echo "Create $toolName user and group"; }
|
||||||
step_3() {
|
step_3() {
|
||||||
exe addgroup "$toolGroup"
|
exe addgroup "$toolGroup"
|
||||||
exe adduser --system --home ${toolDir}/ --no-create-home --disabled-password --shell /bin/nologin --ingroup "$toolGroup" "$toolUser"
|
exe adduser --system --home ${MATRIX_HOME}/ --no-create-home --disabled-password --shell /bin/nologin --ingroup "$toolGroup" "$toolUser"
|
||||||
}
|
}
|
||||||
|
|
||||||
step_4_info() { echo "Install $toolName"; }
|
step_4_info() { echo "Install $toolName"; }
|
||||||
step_4() {
|
step_4() {
|
||||||
exe mkdir -p "$toolDir"
|
exe mkdir -p "$MATRIX_HOME"
|
||||||
exe virtualenv -p python3 "${toolDir}/env"
|
exe virtualenv -p python3 "${MATRIX_HOME}/env"
|
||||||
exe cd "$toolDir"
|
exe cd "$MATRIX_HOME"
|
||||||
exe source "${toolDir}/env/bin/activate"
|
exe source "${MATRIX_HOME}/env/bin/activate"
|
||||||
exe pip install --upgrade pip
|
exe pip install --upgrade pip
|
||||||
exe pip install --upgrade setuptools
|
exe pip install --upgrade setuptools
|
||||||
exe pip install matrix-synapse[postgres]
|
exe pip install matrix-synapse[postgres]
|
||||||
|
|
||||||
# Create default configuration
|
# Create default configuration
|
||||||
exe python3 -m synapse.app.homeserver --server-name "$toolDomain" --config-path homeserver.yaml --generate-config --report-stats=no
|
exe python3 -m synapse.app.homeserver --server-name "$MATRIX_DOMAIN" --config-path homeserver.yaml --generate-config --report-stats=no
|
||||||
exe deactivate
|
exe deactivate
|
||||||
|
|
||||||
# Create media directories
|
# Create media directories
|
||||||
exe mkdir -p ${toolDir}/media_store ${toolDir}/uploads
|
exe mkdir -p ${MATRIX_HOME}/media_store ${MATRIX_HOME}/uploads
|
||||||
exe chmod 770 "${toolDir}/media_store" "${toolDir}/uploads"
|
exe chmod 770 "${MATRIX_HOME}/media_store" "${MATRIX_HOME}/uploads"
|
||||||
# Allow matrix to write its logs in /opt/synapse
|
# Allow matrix to write its logs in /opt/synapse
|
||||||
exe chmod 755 "${toolDir}"
|
exe chmod 755 "${MATRIX_HOME}"
|
||||||
exe chown ${toolUser}:${toolGroup} "${toolDir}" "${toolDir}/media_store" "${toolDir}/uploads"
|
exe chown ${toolUser}:${toolGroup} "${MATRIX_HOME}" "${MATRIX_HOME}/media_store" "${MATRIX_HOME}/uploads"
|
||||||
}
|
}
|
||||||
|
|
||||||
step_5_info() { echo "Configure $toolName"; }
|
step_5_info() { echo "Configure $toolName"; }
|
||||||
@@ -94,10 +96,12 @@ step_5() {
|
|||||||
|
|
||||||
step_6_info() { echo "Create $toolName systemd service"; }
|
step_6_info() { echo "Create $toolName systemd service"; }
|
||||||
step_6() {
|
step_6() {
|
||||||
addConf -c "$toolService" "$toolServiceLoc"
|
# eval needed to expand sourced configuration variables
|
||||||
|
local localService=`eval "echo \"$toolService\""`
|
||||||
|
addConf -c "$localService" "$toolServiceLoc"
|
||||||
exe systemctl daemon-reload
|
exe systemctl daemon-reload
|
||||||
exe systemctl enable matrix-synapse.service
|
exe systemctl enable matrix-synapse.service
|
||||||
exe service matrix-synapse.service start
|
exe service matrix-synapse start
|
||||||
}
|
}
|
||||||
toolServiceLoc="/etc/systemd/system/matrix-synapse.service"
|
toolServiceLoc="/etc/systemd/system/matrix-synapse.service"
|
||||||
toolService="[Unit]
|
toolService="[Unit]
|
||||||
@@ -106,12 +110,12 @@ After=network.target postgresql.service
|
|||||||
|
|
||||||
[Service]
|
[Service]
|
||||||
Type=forking
|
Type=forking
|
||||||
WorkingDirectory=${toolDir}/
|
WorkingDirectory=\${MATRIX_HOME}/
|
||||||
ExecStart=${toolDir}/env/bin/synctl start
|
ExecStart=\${MATRIX_HOME}/env/bin/synctl start
|
||||||
ExecStop=${toolDir}/env/bin/synctl stop
|
ExecStop=\${MATRIX_HOME}/env/bin/synctl stop
|
||||||
ExecReload=${toolDir}/env/bin/synctl restart
|
ExecReload=\${MATRIX_HOME}/env/bin/synctl restart
|
||||||
User=${toolUser}
|
User=\${toolUser}
|
||||||
Group=${toolGroup}
|
Group=\${toolGroup}
|
||||||
Restart=always
|
Restart=always
|
||||||
StandardOutput=syslog
|
StandardOutput=syslog
|
||||||
StandardError=syslog
|
StandardError=syslog
|
||||||
@@ -120,11 +124,11 @@ SyslogIdentifier=synapse
|
|||||||
[Install]
|
[Install]
|
||||||
WantedBy=multi-user.target"
|
WantedBy=multi-user.target"
|
||||||
|
|
||||||
step_10_info() { echo "Upgrade $toolName installation at $toolDir"; }
|
step_10_info() { echo "Upgrade $toolName installation at $MATRIX_HOME"; }
|
||||||
step_10_alias() { ALIAS="upgrade"; }
|
step_10_alias() { ALIAS="upgrade"; }
|
||||||
step_10() {
|
step_10() {
|
||||||
echo " [I] Upgrading $toolName"
|
echo " [I] Upgrading $toolName"
|
||||||
exe source "${toolDir}/env/bin/activate"
|
exe source "${MATRIX_HOME}/env/bin/activate"
|
||||||
exe pip install --upgrade pip
|
exe pip install --upgrade pip
|
||||||
exe pip install --upgrade matrix-synapse
|
exe pip install --upgrade matrix-synapse
|
||||||
saveReturn $?
|
saveReturn $?
|
||||||
@@ -158,7 +162,7 @@ step_14() {
|
|||||||
step_16_info() { echo "Create new user"; }
|
step_16_info() { echo "Create new user"; }
|
||||||
step_16_alias() { ALIAS="newuser"; }
|
step_16_alias() { ALIAS="newuser"; }
|
||||||
step_16() {
|
step_16() {
|
||||||
exe /opt/synapse/env/bin/register_new_matrix_user -c "$toolDir/homeserver.yaml" $toolUrl
|
exe /opt/synapse/env/bin/register_new_matrix_user -c "$MATRIX_HOME/homeserver.yaml" $toolUrl
|
||||||
}
|
}
|
||||||
|
|
||||||
step_18_info() { echo "Drop postgres database for $toolName"; }
|
step_18_info() { echo "Drop postgres database for $toolName"; }
|
||||||
|
Reference in New Issue
Block a user