Updates after first successful installation
This commit is contained in:
@@ -1,11 +1,13 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
toolName=synapse
|
toolName=synapse
|
||||||
toolDeps="build-essential python3-dev libffi-dev python3-pip python3-setuptools postgresql libssl-dev virtualenv libjpeg-dev libxslt1-dev libpq5"
|
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"
|
toolDir="/opt/synapse"
|
||||||
toolConfig="${toolDir}/homeserver.yaml"
|
toolConfig="${toolDir}/homeserver.yaml"
|
||||||
toolUser="synapse"
|
toolUser="synapse"
|
||||||
toolGroup="synapse"
|
toolGroup="synapse"
|
||||||
|
toolDomain="matrix.winklerfamilie.eu"
|
||||||
|
toolUrl="https://$toolDomain"
|
||||||
|
|
||||||
# Needed for different steps
|
# Needed for different steps
|
||||||
postgresDb=""
|
postgresDb=""
|
||||||
@@ -52,13 +54,19 @@ step_2() {
|
|||||||
readDatabaseInfos
|
readDatabaseInfos
|
||||||
|
|
||||||
exe cd ~postgres
|
exe cd ~postgres
|
||||||
exe sudo -u postgres psql -c "CREATE USER ${postgresUser} WITH ENCRYPTED password '${postgresPass}';"
|
exe su -c "psql -c \"CREATE USER ${postgresUser} WITH ENCRYPTED password '${postgresPass}';\"" - postgres
|
||||||
exe sudo -u postgres psql -c "CREATE DATABASE ${postgresDb} ENCODING "UTF8" LC_COLLATE='C' LC_CTYPE='C' template=template0 OWNER ${postgresUser};"
|
exe su -c "psql -c \"CREATE DATABASE ${postgresDb} ENCODING \"UTF8\" LC_COLLATE='C' LC_CTYPE='C' template=template0 OWNER ${postgresUser};\"" - postgres
|
||||||
exe sudo -u postgres psql -c "GRANT ALL PRIVILEGES ON DATABASE \"${postgresDb}\" to ${postgresUser};"
|
exe su -c "psql -c \"GRANT ALL PRIVILEGES ON DATABASE \"${postgresDb}\" to ${postgresUser};\"" - postgres
|
||||||
}
|
}
|
||||||
|
|
||||||
step_3_info() { echo "Install $toolName"; }
|
step_3_info() { echo "Create $toolName user and group"; }
|
||||||
step_3() {
|
step_3() {
|
||||||
|
exe addgroup "$toolGroup"
|
||||||
|
exe adduser --system --home ${toolDir}/ --no-create-home --disabled-password --shell /bin/nologin --ingroup "$toolGroup" "$toolUser"
|
||||||
|
}
|
||||||
|
|
||||||
|
step_4_info() { echo "Install $toolName"; }
|
||||||
|
step_4() {
|
||||||
exe mkdir -p "$toolDir"
|
exe mkdir -p "$toolDir"
|
||||||
exe virtualenv -p python3 "${toolDir}/env"
|
exe virtualenv -p python3 "${toolDir}/env"
|
||||||
exe cd "$toolDir"
|
exe cd "$toolDir"
|
||||||
@@ -68,32 +76,33 @@ step_3() {
|
|||||||
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 matrix.mydomain.com --config-path homeserver.yaml --generate-config --report-stats=no
|
exe python3 -m synapse.app.homeserver --server-name "$toolDomain" --config-path homeserver.yaml --generate-config --report-stats=no
|
||||||
exe deactivate
|
exe deactivate
|
||||||
|
|
||||||
# Create media directories
|
# Create media directories
|
||||||
exe mkdir ${toolDir}/media_store ${toolDir}/uploads
|
exe mkdir -p ${toolDir}/media_store ${toolDir}/uploads
|
||||||
exe chmod 770 "${toolDir}/media_store" "${toolDir}/uploads"
|
exe chmod 770 "${toolDir}/media_store" "${toolDir}/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 "${toolDir}"
|
||||||
exe chown ${toolUser}:${toolGroup} "${toolDir}" "${toolDir}/media_store" "${toolDir}/uploads"
|
exe chown ${toolUser}:${toolGroup} "${toolDir}" "${toolDir}/media_store" "${toolDir}/uploads"
|
||||||
}
|
}
|
||||||
|
|
||||||
step_4_info() { echo "Configure $toolName"; }
|
step_5_info() { echo "Configure $toolName"; }
|
||||||
step_4() {
|
step_5() {
|
||||||
exe vi "$toolConfig"
|
exe vi "$toolConfig"
|
||||||
}
|
}
|
||||||
|
|
||||||
step_5_info() { echo "Create $toolName systemd service"; }
|
step_6_info() { echo "Create $toolName systemd service"; }
|
||||||
step_5() {
|
step_6() {
|
||||||
exe addgroup "$toolGroup"
|
|
||||||
exe adduser --system --home ${toolDir}/ --no-create-home --disabled-password --shell /bin/nologin --ingroup "$toolGroup" "$toolUser"
|
|
||||||
addConf -c "$toolService" "$toolServiceLoc"
|
addConf -c "$toolService" "$toolServiceLoc"
|
||||||
|
exe systemctl daemon-reload
|
||||||
|
exe systemctl enable matrix-synapse.service
|
||||||
|
exe service matrix-synapse.service start
|
||||||
}
|
}
|
||||||
toolServiceLoc="/etc/systemd/system/system/matrix-synapse.service"
|
toolServiceLoc="/etc/systemd/system/matrix-synapse.service"
|
||||||
toolService="[Unit]
|
toolService="[Unit]
|
||||||
Description=Matrix Synapse service
|
Description=Matrix Synapse service
|
||||||
After=network.target
|
After=network.target postgresql.service
|
||||||
|
|
||||||
[Service]
|
[Service]
|
||||||
Type=forking
|
Type=forking
|
||||||
@@ -111,6 +120,21 @@ SyslogIdentifier=synapse
|
|||||||
[Install]
|
[Install]
|
||||||
WantedBy=multi-user.target"
|
WantedBy=multi-user.target"
|
||||||
|
|
||||||
|
step_15_info() { echo "Create new user"; }
|
||||||
|
step_15_alias() { ALIAS="newuser"; }
|
||||||
|
step_15() {
|
||||||
|
exe /opt/synapse/env/bin/register_new_matrix_user -c "$toolDir/homeserver.yaml" $toolUrl
|
||||||
|
}
|
||||||
|
|
||||||
|
step_18_info() { echo "Drop postgres database for $toolName"; }
|
||||||
|
step_18_alias() { ALIAS="dropdb"; }
|
||||||
|
step_18() {
|
||||||
|
readDatabaseInfos
|
||||||
|
|
||||||
|
exe cd ~postgres
|
||||||
|
exe su -c "psql -c \"DROP DATABASE ${postgresDb};\"" - postgres
|
||||||
|
}
|
||||||
|
|
||||||
step_20_info() { echo "Backup postgres database"; }
|
step_20_info() { echo "Backup postgres database"; }
|
||||||
step_20_alias() { ALIAS="backupdb"; }
|
step_20_alias() { ALIAS="backupdb"; }
|
||||||
step_20() {
|
step_20() {
|
||||||
@@ -138,9 +162,9 @@ step_22() {
|
|||||||
echo " pg_restore -h localhost -p 5432 -U synapse -d new_db -v \"10.70.0.61.backup\""
|
echo " pg_restore -h localhost -p 5432 -U synapse -d new_db -v \"10.70.0.61.backup\""
|
||||||
echo
|
echo
|
||||||
echo "Available postgresql databases:"
|
echo "Available postgresql databases:"
|
||||||
exe cd ~postgres && sudo -u postgres psql -c '\l'
|
exe cd ~postgres && su -c "psql -c '\l'" - postgres
|
||||||
echo "Available postgresql user:"
|
echo "Available postgresql user:"
|
||||||
exe cd ~postgres && sudo -u postgres psql -c '\du'
|
exe cd ~postgres && su -c "psql -c '\du'" - postgres
|
||||||
}
|
}
|
||||||
|
|
||||||
# Read postgres database information dbname/user/pass if empty
|
# Read postgres database information dbname/user/pass if empty
|
||||||
|
Reference in New Issue
Block a user