From OpenSCADAWiki
Jump to: navigation, search
This page is a translated version of the page Modules/SelfSystem and the translation is 62% complete.

Other languages:
English • ‎mRussian • ‎Українська
Модуль Имя Версия Лицензия Источник Языки Платформы Тип Автор Описание
SelfSystem Собственный протокол OpenSCADA 2.0 GPL2 prot_SelfSystem.so en,uk,ru,de x86,x86_64,ARM Протокол Роман Савоченко Предоставляет cобственный протокол OpenSCADA основанный на XML и интерфейсе управления OpenSCADA.

Модуль предназначен для отражения интерфейса управления OpenSCADA в сеть, с целью предоставления возможности внешним системам взаимодействовать с OpenSCADA, а также для взаимодействия между собой станций, построенных на основе OpenSCADA.

Первым опытом использования функций данного модуля стала поддержка возможности удалённой конфигурации одной OpenSCADA станции из другой, через сеть и посредством модуля конфигурации QTCfg.

1 The syntax of the protocol

The protocol is based on the "Request-Answer" method. The queries and their structure are given in the followed Table.

Structure of the request.
Requests

REQ: "SES_OPEN {user} {password}\n"
REZ OK: "REZ 0 {ses_id}\n"
REZ ERR: "REZ 1 Error authentication: wrong user or password.\n"
Request to open a session from the username user with the password. In case of success, the session ID will be received, otherwise, the code and the error message.

REQ: "SES_CLOSE {ses_id}\n"
REZ: "REZ 0\n"
Closure of the session. The result is always successful.

REQ: "REQ {ses_id} {req_size}\n{command of the control interface}"
REQ: "REQDIR {user} {password} {req_size}\n{command of the control interface}"
REZ OK: "REZ 0 {rez_size}\n{result of the command of the control interface}"
REZ ERR: "REZ 1 Error authentication: session is not valid.\n"
REZ ERR: "REZ 2 {error of the control interface}"
Basic queries — session and direct ones. Implemented by sending a standard command of the OpenSCADA Control Interface in the command of the control interface field. The result will be the response of the Control Interface result of the command of the control interface or one of the errors.

REQ: "{Error sequence}"
REZ ERR: "REZ 3 Error the command format.\n"
Any invalid request.

The protocol supports the ability of the traffic compression. Only the Control Interface data command of the control interface and result of the command of the control interface are compressed. The fact of receipt of a compressed request or response is determined by the negative value of the req_size or the rez_size response. You can define the compression options on the configuration page of the module (Fig. 1). Response of the protocol input part is forced to the compression with level -1 (that is optimal) at the compressed requests.

At.png All those parameters can be configured individually for the transport, due to the module is first one supports configuration of the external sources in additional parameters of the transports.

Рис.1. Главная вкладка страницы конфигурации параметров модуля.

On this tab, you can:

  • Familiarize the active authentication sessions.
  • Specify life time of the authentication sessions, in minutes.
  • Specify a connection limit for one user from one host.
  • Specify the compression level and lower limit. Where range of the compression level is from 0 to 9 (0 - disable the compression, -1 - optimal compression level in performance and quality) and the lower limit is a threshold for the compression using and turning its off at small requests.

2 Внутренняя структура исходящего протокола

Внутренняя структура формируется деревом XML запросов языка интерфейса управления OpenSCADA с резервированием дополнительных служебных атрибутов протокола в корневом теге:

rqDir — признак отправки сообщения минуя процедуру открытия сеанса (0-открывать сеанс, 1-отсылать сразу);
rqUser — пользователь;
rqPass — пароль;
rqAuthForce — принудительно обновить аутентификацию;
rqSeq — последовательность запроса;
conTm — принудительный таймаут подключения.

Результатом запроса также является XML дерево языка интерфейса управления OpenSCADA.