Rocket.Chat бесплатный корпоративный мессенджер, который прост в обслуживании и удобен в использовании.

Для установки нам потребуется сервер на Ubuntu. Я использую vdsina (по моей ссылке скидка 10%)

Заказываем сервер, получаем данные для авторизации, входим по ssh и обновляем сервер apt update && apt upgrade && reboot

Переподключаемся и устанавливаем пакет snap apt-get install snapd

Затем сам сервер из пакета snap install rocketchat-server

Переходим на сервер по адресу с указанием порта http://IP_Address:3000

Проходим все настройки и сервер готов. Остается только прикрутить https через настройку обратного проксирования

Устанавливаем apt install nginx

Правим nano /etc/nginx/sites-enabled/default

# Upstreams
upstream backend {
server 127.0.0.1:3000;
}

server {
listen 443;
server_name chat.1Side.ru;
error_log /var/log/nginx/rocketchat.access.log;
ssl on;
ssl_certificate /etc/nginx/certificate.crt;
ssl_certificate_key /etc/nginx/certificate.key;
ssl_protocols TLSv1 TLSv1.1 TLSv1.2; # don’t use SSLv3 ref: POODLE
client_max_body_size 2000M;
location / {
proxy_pass http://127.0.0.1:3000/;
proxy_http_version 1.1;
proxy_set_header Upgrade $http_upgrade;
proxy_set_header Connection «upgrade»;
proxy_set_header Host $http_host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forward-For $proxy_add_x_forwarded_for;
proxy_set_header X-Forward-Proto http;
proxy_set_header X-Nginx-Proxy true;
proxy_redirect off;
}
}

Прописываем SSL ключи в /etc/nginx/certificate.{crt;key}

Либо поставим бесплатный через Let’s Encrypt

Настройка авторизации LDAP Active Directory

Переходим в настройку https://chat.1Side.ru/admin/LDAP

Указываем:

  • Хост: IP адрес
  • Порт: 389
  • Шифрование: Без шифрования
  • Base DN: DC=1Side,DC=local
  • User DN: Rocket.Chat@1Side.local
  • Пароль: Пароль пользователя Rocket.Chat
  • Карта пользовательских данных: {«#{cn} #{telephoneNumber} #{l}»:»name», «mail»:»email»}
  • Фильтр Группы Пользователей: (&(sAMAccontName=#{username})(memberOf=CN=#{groupName},OU=1side_adm,OU=1side_users,DC=1Side,DC=local))

Чтобы пользователи могли авторизоваться, нужно указывать в профиле AD почту, номер телефона, город. Эти данные разбираются в параметре Карта пользовательских данных

Из практики город лучше указывать отдел или иное деление, например: IT Воронеж, 1C Казань, Бухгалтерия Смоленск