Установка Dashboard

Для установки Dashboard требуется скопировать его файлы в целевую папку. Для этого нужно выполнить команду:

sudo cp -r ~/Загрузки/TerraLink.xDEPro/Printforms.Dashboard /opt/TerraLink.xDEPro/Printforms/Printforms.Dashboard

Настройка подключения к Printforms API

Для работы Dashboard понадобится подключение к Printforms API.

Для настройки подключения нужно скопировать демонстрационный конфигурационный файл в конфигурационный файл, который будет использоваться Dashboard:

sudo cp /opt/TerraLink.xDEPro/Printforms/Printforms.Dashboard/appsettings.json.demo /opt/TerraLink.xDEPro/Printforms/Printforms.Dashboard/appsettings.json

Далее нужно открыть конфигурационный файл в текстовом редакторе:

sudo nano /opt/TerraLink.xDEPro/Printforms/Printforms.Dashboard/appsettings.json

найти поле ApiConnectAddress и задать IP-адрес и порт для подключения к Printforms API через Nginx:

{
    // ...
    "RestApiConnectionSettings": {
        "ApiConnectAddress": "http://192.168.11.128:6130"
    },
    // ...
}

Затем нужно сохранить файл (Ctrl+O) и выйти из редактора (Ctrl+X).

Настройка доступа к Dashboard через Nginx

Для настройки доступа к Dashboard через Nginx требуется создать файл с конфигурацией сайта в текстовом редакторе:

sudo nano /etc/nginx/sites-available/xde-printforms-dashboard

и скопировать в него содержимое:

server {
        # виртуальный сервер настраивается на порт по умолчанию для этого HTTP-приложения + 100
        listen        6133;

        # в примере доступ к этому HTTP-приложению возможен только по IP-адресу
        server_name   192.168.11.128;
        location / {
                # порт по умолчанию для этого HTTP-приложения - 6033
                proxy_pass         http://127.0.0.1:6033;
                proxy_http_version 1.1;
                proxy_set_header   Upgrade $http_upgrade;
                proxy_set_header   Connection keep-alive;
                proxy_set_header   Host $host:$server_port;
                proxy_cache_bypass $http_upgrade;
                proxy_set_header   X-Forwarded-For $proxy_add_x_forwarded_for;
                proxy_set_header   X-Forwarded-Proto $scheme;
        }
}

Затем нужно сохранить файл (Ctrl+O) и выйти из редактора (Ctrl+X).

Примечание

Для доступа по IP-адресу значение параметра server_name должно быть равно фактическому IP-адресу машины, на которую устанавливается Dashboard. Здесь указан пример IP-адреса.

Теперь нужно создать ссылку на конфигурационный файл сайта в папке /etc/nginx/sites-enabled/ и перезапустить Nginx:

sudo ln -s /etc/nginx/sites-available/xde-printforms-dashboard /etc/nginx/sites-enabled/
sudo systemctl restart nginx

Предупреждение

Не используйте HTTP-подключение к Nginx в продуктивной среде. Это может привести к несанкционированному доступу к данным, в том числе к содержимому документов и паролям. Используйте HTTPS-подключение.

Автоматический запуск Dashboard

Для автоматического запуска Dashboard нужно в текстовом редакторе создать файл конфигурации сервиса:

sudo nano /etc/systemd/system/xde-printforms-dashboard.service

и скопировать в него содержимое:

[Unit]
Description=TerraLink xDEPro Printforms Dashboard

[Service]
WorkingDirectory=/opt/TerraLink.xDEPro/Printforms/Printforms.Dashboard
# доступ извне будет возможен только через Nginx
ExecStart=/opt/dotnet/dotnet /opt/TerraLink.xDEPro/Printforms/Printforms.Dashboard/TerraLink.xDEPro.Printforms.Dashboard.Host.dll --urls http://127.0.0.1:6033
Restart=always
RestartSec=10
KillSignal=SIGINT
SyslogIdentifier=xde-printforms-dashboard
User=xdeadmin
Environment=ASPNETCORE_ENVIRONMENT=Production
Environment=DOTNET_PRINT_TELEMETRY_MESSAGE=false

[Install]
WantedBy=multi-user.target

Затем нужно сохранить файл (Ctrl+O) и выйти из редактора (Ctrl+X).

Теперь нужно включить и запустить сервис:

sudo systemctl enable xde-printforms-dashboard.service
sudo systemctl start xde-printforms-dashboard

Проверка доступности Dashboard

Для проверки доступности Dashboard нужно открыть браузер на машине, отличной от той, на которую производится установка. В адресной строке браузера указать настроенный адрес и порт:

http://192.168.11.128:6133

В ответ в браузере должна открыться страница авторизации Dashboard.