====== MATTERMOST ====== Présentation d'installation d'un serveur Mattermost sur //debian// 9.\\ Dans cette présentation, nous allons configurer un site https://equipe.sleto.net.\\ Nous utiliserons les variables //DBNAME//, //DBUSER// et //DBPASSWD// respectivement pour le nom, l'utilisateur et le mot de passe de base de données.\\ ===== Dépendances ===== Utilise un [[Serveur web sécurisé (Nginx / Let's Encrypt)]].\\ Nécessite également les outils : sudo apt-get install -y postgresql postgresql-contrib supervisor git Vous devrez également ajouter le domaine __equipe.sleto.net__ dans le [[Serveur DNS (bind9)]] ===== Base de données ===== Nous allons créé une base de donnée PostgreSQL: sudo -u postgres psql -c "CREATE USER $DBUSER;" sudo -u postgres psql -c "ALTER USER $DBUSER PASSWORD '$DBPASSWD';" sudo -u postgres psql -c "CREATE DATABASE $DBNAME OWNER $DBUSER;" ===== Pré-configuration ===== Création d'un utilisateur __mattermost__: adduser --system --home /opt/mattermost --shell /bin/bash --disabled-password --quiet mattermost install -d -m 755 -o $DBUSER /opt/mattermost adduser mattermost www-data ===== Installation ===== Pour installer l'outil: rm -rf /opt/mattermost cd /tmp curl https://releases.mattermost.com/7.5.1/mattermost-7.5.1-linux-amd64.tar.gz -o mattermost.tar.gz tar -xvzf mattermost.tar.gz mv mattermost /opt rm mattermost.tar.gz mkdir /opt/mattermost/data chown -R mattermost:www-data /opt/mattermost chmod -R g+w /opt/mattermost ===== Configuration ===== Configuration: Modifier, dans le fichier ///opt/mattermost/config/config.json// , les champs suivants: { "SqlSettings": { "DriverName": "postgre", "DataSource": "postgres://:@127.0.0.1:5432/?sslmode=disable&connect_timeout=10" }, "ServiceSettings": { "SiteURL": "https://equipe.sleto.net", "ListenAddress": ":", "EnableLocalMode": true }, "TeamSettings": { "SiteName": "Équipe", "CustomDescriptionText": "Communication d'équipe par Sleto via Mattermost", "EnableCustomBrand": true, "CustomBrandText": "Cet outil est un service de messagerie instantanée libre, sécurisée et collaborative, proposé par Sleto.", "MaxChannelsPerTeam": 100, "MaxUsersPerTeam": 30, "EnableUserCreation": false }, "SupportSettings": { "SupportEmail": "", "TermsOfServiceLink": "https://www.sleto.net/mentions-legales", "PrivacyPolicyLink": "https://www.sleto.net/mentions-legales", "AboutLink": "https://www.sleto.net/equipe" }, "PasswordSettings": { "MinimumLength": 6, "Number": false }, "PluginSettings": { "Enable": false }, "LocalizationSettings": { "AvailableLocales": "fr,en", "DefaultClientLocale": "fr", "DefaultServerLocale": "fr" }, "EmailSettings": { "SMTPServer": "localhost", "SMTPPort": "25", "SMTPUsername": "", "SMTPPassword": "" } } Créer le fichier de gestion de service ///etc/systemd/system/mattermost.service//: [Unit] Description=Mattermost After=network.target After=postgresql.service Requires=postgresql.service [Service] Type=notify ExecStart=/opt/mattermost/bin/mattermost TimeoutStartSec=3600 Restart=always RestartSec=10 WorkingDirectory=/opt/mattermost User=mattermost Group=www-data LimitNOFILE=49152 [Install] WantedBy=postgresql.service Et l'instruction: systemctl daemon-reload systemctl start mattermost.service systemctl enable mattermost.service ===== Configuration web ===== Créer un fichier ///opt/etherpad/nginx-equipe//: upstream mmbackend { server 127.0.0.1:8065; keepalive 32; } proxy_cache_path /var/cache/nginx levels=1:2 keys_zone=mattermost_cache:10m max_size=3g inactive=120m use_temp_path=off; server { listen 80; server_name equipe.sleto.net; return 301 https://$host$request_uri; } server { listen 443 ssl; server_name equipe.sleto.net; access_log /var/log/nginx/equipe.sleto.net.access.log; error_log /var/log/nginx/equipe.sleto.net.error.log; include /opt/ssl/equipe.sleto.net.conf; location ~ /api/v[0-9]+/(users/)?websocket$ { proxy_set_header Upgrade $http_upgrade; proxy_set_header Connection \"upgrade\"; client_max_body_size 50M; proxy_set_header Host $http_host; proxy_set_header X-Real-IP $remote_addr; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; proxy_set_header X-Forwarded-Proto $scheme; proxy_set_header X-Frame-Options SAMEORIGIN; proxy_buffers 256 16k; proxy_buffer_size 16k; client_body_timeout 60; send_timeout 300; lingering_timeout 5; proxy_connect_timeout 90; proxy_send_timeout 300; proxy_read_timeout 90s; proxy_pass http://mmbackend; } location / { client_max_body_size 50M; proxy_set_header Connection \"\"; proxy_set_header Host $http_host; proxy_set_header X-Real-IP $remote_addr; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; proxy_set_header X-Forwarded-Proto $scheme; proxy_set_header X-Frame-Options SAMEORIGIN; proxy_buffers 256 16k; proxy_buffer_size 16k; proxy_read_timeout 600s; proxy_cache mattermost_cache; proxy_cache_revalidate on; proxy_cache_min_uses 2; proxy_cache_use_stale timeout; proxy_cache_lock on; proxy_http_version 1.1; proxy_pass http://mmbackend; } } Notons que ///opt/ssl/equipe.sleto.net.conf// contiendra les informations relatives aux clefs privé et public HTTPS/SSL (voir [[Serveur web sécurisé (Nginx / Let's Encrypt)]]). Activer la configuration web par: ln -sf /opt/$DBUSER/nginx-equipe /etc/nginx/sites-enabled ===== Rechargement ===== Pour rafraîchir les services nginx service nginx restart