Создание и публикация веб-сервисов

Публикация и работа созданных в Loginom веб-сервисов доступна при наличии установленного компонента Loginom Integrator.

Реализация методов сервиса

Взаимодействие с веб-сервисом осуществляется при помощи его методов. Каждый метод веб-сервиса имеет определенный идентификатор и выполняет сопоставленное этому идентификатору действие. Как правило, (но не обязательно) метод принимает входные данные и возвращает ответ. Действие, выполняемое методом, в Loginom реализуется публикуемым узлом Сценария, а структура входных данных и ответа определяется входными и выходными портами этого узла. В качестве идентификатора метода используется строка, состоящая из имени узла и имени пакета, в котором узел содержится.

Чаще всего в качестве такого узла выступает Подмодель, поскольку в ней пользователь имеет возможность реализовать произвольную логику и задать структуру входных и выходных данных, создавая и настраивая ее порты. Но в общем случае таким узлом может быть любой узел Сценария, имеющий настройки, описанные в пункте Настройка публикуемых узлов. В случае, если таких узлов в пакете несколько и публикуется несколько пакетов, то для каждого из таких узлов создается соответствующий ему метод SOAP-сервиса и операция REST-сервиса. В случае с REST-сервисом для каждого из публикуемых пакетов создается конечная точка REST-сервиса.

Настройка публикуемых узлов

Публикуемый в качестве метода веб-сервиса узел должен иметь следующие настройки:

  • задан модификатор доступа Опубликованный;
  • в окне выбора модификатора доступа задано уникальное в пределах пакета имя узла;
  • узел должен быть видимым из корня сценария, т.е. в случае, если узел является вложенным (в подмодель или иерархию подмоделей), то у всех подмоделей, в которых он содержится, должен быть установлен модификатор доступа Открытый;
  • во входных и выходных портах заданы поля/переменные, определяющие структуру запроса и ответа метода веб-сервиса.

Важно: при использовании автосинхронизации полей возможны ситуации, когда поля/переменные в портах определены механизмом автосинхронизации из структуры данных, подаваемых в порт. Если при включенной автосинхронизации удалить связь порта с источником данных, то ранее созданные из данных поля/переменные будут удалены из порта механизмом автосинхронизации как временные, актуальные только для конкретных данных. При публикации такого узла поля/переменные в портах не будут заданы, соответственно структуры запроса/ответа сервиса не будут определены.

В связи с этим порты публикуемых узлов необходимо настроить одним из способов:

  • Отключить автосинхронизацию полей и при необходимости задать нужные поля/переменные (рекомендуется).
  • Если механизмом автосинхронизации уже созданы необходимые поля/переменные из подаваемых в порт данных, то необходимо отредактировать любой из параметров (Имя, Метку, Назначение и т.д.) всех необходимых полей/переменных. Измененные поля выделяются в мастере настройки порта жирным шрифтом и фиксируются как постоянные, ожидаемые портом.
  • Очистить список и создать все необходимые поля/переменные вручную.

Параметр Назначение входного поля влияет на свойство его обязательности в запросе к сервису. Поля с Назначением Не задано или Непригодное публикуются как необязательные (в WSDL SOAP-сервиса имеют атрибут minOccurs="0", а в схеме запроса REST-сервиса не входят в состав required-узлов). Поля с другими значениями параметра являются обязательными в запросе. В ответе сервиса все поля публикуются как обязательные.

Публикация

После того, как необходимые для публикации узлы сценария настроены, необходимо произвести публикацию пакета.

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

Для публикации пакета требуется перейти в редактирование веб-сервиса. После открытия навигации существует два способа:

  • Перейти во вкладку Веб-сервисы и нажать на кнопку Добавить;
  • Правой кнопкой мыши нажать на публикуемый пакет и выбрать Опубликовать.

Обращение к созданному сервису

WSDL опубликованного SOAP-сервиса можно получить по ссылке:

http://<Server>/<App>/soap?wsdl, где <Server> — хост Loginom Integrator, <App> — имя приложения Loginom Integrator (задается при инсталляции Loginom Integrator, при установке по умолчанию <App> = lgi).

Пример: http://localhost/lgi/soap?wsdl

Информацию о конечных точках, операциях, URL, структуре REST-запросов и ответов можно получить по ссылке:

http://<Server>/<App>/rest/help, где <Server> — хост Loginom Integrator, <App> — имя приложения Loginom Integrator (задается при инсталляции Loginom Integrator, при установке по умолчанию <App> = lgi).

Пример: http://localhost/lgi/rest/help

Для обращения к опубликованным сервисам из сценария Loginom используются компоненты SOAP-запрос и REST-запрос.

Loginom Integrator поддерживает OpenAPI и опционально включает Swagger UI. Для тестирования API можно выполнять запросы на странице http://<Server>/<App>/openapi/index.html.

Пример: http://localhost/lgi/openapi/index.html

Совместимость веб-сервисов Loginom с Deductor

В продуктах прошлого поколения (Deductor) публикация веб-сервисов осуществлялась DIS (Deductor Integration Server), а обращение к веб-сервисам DIS из сценариев Deductor осуществлялось при помощи узла WEB-сервис. Чтобы использовать этот узел для обращения к веб-сервисам Loginom, при публикации пакетов должна применятся настройка Использовать пространство имен Loginom Integrator. Кроме того, в конфигурации Loginom Integrator должно быть указано непустое значение атрибута urlPathPrefix.

Примечание: применение настройки Использовать пространство имен Loginom Integrator при публикации нескольких пакетов накладывает ограничение на именование публикуемых узлов. Имена, задаваемые при выборе модификатора доступа, должны быть уникальны в рамках всего набора публикуемых пакетов.

Веб-сервисы Loginom имеют следующую особенность: XML ответов и запросов веб-сервисов в своей структуре могут иметь элемент <PortName> (элемент содержит имя порта), отсутствующий в веб-сервисах DIS. Для устранения этого различия в публикуемых подмоделях Loginom в имени порта должно указываться <Не задано>.

Примечание: опция <Не задано> при именовании порта доступна в случае, если этот порт единственный входной или выходной. В этом случае для формирования произвольной структуры запроса/ответа в качестве портов Подмодели удобно использовать порты типа Дерево данных с возможностью задать структуру данных XSD-схемой, т.е. использовать тот же механизм, что и в Deductor Integration Server.