-
Kernel
-
Plugins
-
Release Notes
Kernel
Plugins
Release Notes
The program has the following types of Web-interface:
For calling of the running system use URL: http://<host>:<port>; where:
<host> - IP address of the server;
<port> - port, by default is 9088.
Configuration process has to be started from user interface. After creation database has only one superuser admin with password admin.
Change them after the first log in. The user with ID=1 is a special one, permissions are ignored for him. |
The interface is available by suffix /user.
Основные элементы обычного интерфейса пользователя.
1 - кнопка вызова меню;
2 - панель запущенных оснасток;
3 - буфер открытых объектов;
4 - пример запущенной оснастки.
Меню иерархическое, позволяет запускать оснастки и выполнять различные действия в системе. Пункты меню могут быть скрыты, если соответствующие права запрещены пользователю.
Приложение для манипулирования данными Оснастка может быть запущена только в одном экземпляре, похожа на программу в операционной системе.
Блок данных, например процессы. Все в объекты закрываемые результате перехода на другие объекты либо оснастки помещаются в буфер на первую позицию (поведение по-умолчанию, но может быть изменено). Ёмкость буфера ограничена, при его переполнении нижние объекты удаляются. Явно закрытые крестом объекты в буфер не попадают. Для обновления карточки открытого объекта необходимо кликнуть мышью по наименованию объекта.
Назначение буфера сходно с буфером обмена операционной системы: на находящиеся в нём объекты можно ссылаться в различных редакторах. Кроме того, буфер позволяет осуществить быстрый переход на объекты, с которыми пользователь работал последнее время.
При наведении и удержании мыши на некоторых элементах интерфейса отображается всплывающая подсказка, предоставляющая дополнительные сведения.
Отображает название текущей открытой оснастки либо объекта. Может содержать ссылку на раздел документации с симоволом вопроса. Клик по названию в строке заголовка обновляет открытый объект или вкладку.
В правом верхнем углу перед ссылкой на профиль отображаются настроенные для выведения счётчики процессов. Клик по счётчику открывает соответствующую очередь процессов и сохранённый фильтр. Таким образом можно всегда видеть перед глазами важнейшие числа.
Далее отображается суммарное число необработанных сообщений и непрочитанных новостей. При изменении их количества число начинает мигать. Клик по пункту выпадающего меню переводит соответсвенно в оснастку новостей либо сообщений.
В правом верхнем углу отображается имя текущего пользователя. При нажатии на него открывается меню, ведущее в профиль.
В профиле пользователь имеет возможность изменить логин с паролем, параметры своего аккаунта. В нижней части редактора - специфичные для данного пользователя нюансы поведения интерфейса, которые можно изменить.
Значения по-умолчанию опций интерфейса доступны для изменения в конфигурации. Для этого в с помощью инспектора кода (FireBug, встроенное средство браузера, либо просмотр исходного кода фрагмента) узнать имя hidden поля параметра и значений. Например, для свойства "Порядок объектов в буфере" это будет:
<input name="iface_buffer_behavior" value="2" type="hidden">
...
<li selected="selected" value="1">Подсветка строки / клик</li>
<li value="0">Кнопка со звёздочкой</li>
Заменой нижнего подчёркивания на точки получается имя значения по-умолчанию данной опции для конфигурации. В данном случае, установка:
iface.buffer.behavior=2
Включит для всех пользователей редактирование с помощью отдельной кнопки со звёздочкой как поведение по-умолчанию.
The interface is available by suffix /usermob.
В текущей версии мобильный интерфейс пользователя предоставляет доступ к мобильной очереди процессов. В отличие от обычной она сильно ограничена функциональностью:
фильтрация и сортировка жёстко заданы;
значения колонок со ссылками (открытие контрагент, пользователя) отображаются простым текстом, как при выводе очереди на печать;
нет постраничного деления, предполагается, что фильтр ограничивает весь необходимый набор процессов для исполнителя.
Для того, чтобы очередь процессов была считалась мобильной, в конфигурации её должно быть указано:
showIn=usermob
Для всех фильтров должны быть определены жёстко значения, например:
filter.{@inc:cnt}.type=openClose filter.{@cnt}.values=open filter.{@inc:cnt}.type=executors filter.{@cnt}.values=current sort.combo.count=3 sort.mode.2.column.id=2 sort.mode.2.title=Создан обр. sort.mode.2.desc=1 sort.mode.3.column.id=6 sort.mode.3.title=Статус
Создание процесса в очереди возможно только мастером, для всех разрешённые к созданию типы процессов должны быть указаны в переменной конфигурации очереди createAllowedProcessList примерно следующим образом:
createAllowedProcessList=72:Подключение;74:Подключение1
В данном примере 72 и 74 - коды процессов, для каждого создаваемого типа будет отображена своя кнопка.
Открытие процесса происходит нажатием в любое место строки таблицы. При открытии процессе также вызывается мастер. Но не создания а редактирования. Пример открытого процесса со следующей конфигурацией мастера:
wizard.step.1.title=Статус wizard.step.1.class=SetStatusStep wizard.step.2.title=Описание wizard.step.2.class=SetDescriptionStep
The interface is available by suffix /user.
Configuration sample of NGINX for accessing it from outside network.
Beside of some kernel functionality, described below, this interface is also used by following plugins:
Default <OPEN_URL> for accessing the open interface is /open that can be changed in configuration. It is recommended to make separated included configuration for configuring open interface.
# changed root <OPEN_URL> #url.open=https://demo.bgerp.org/open
For enabling showing user specific information by URL <OPEN_URL>/profile/<USER_ID>:
create user parameter with type list and value 1=Yes, ID of that is <ENABLE_PARAM_ID>;
add the following records in configuration.
user.open.enable.paramId=<ENABLE_PARAM_ID> user.open.show.paramIds=<PARAM_IDS>
Where:
<PARAM_IDS> - comma-separated user parameter IDs to be shown, parameter type file is not supported
For enabling showing process information by URL <OPEN_URL>/process/<PROCESS_ID> define in configuration:
process.open.typeIds=<TYPE_IDS> process.open.show.paramIds=<PARAM_IDS> process.open.show.message.tagIds=<MESSAGE_TAG_IDS> # optionally JEXL expression for handling access secrets #process.open.secret.expression=<SECRET_EXPRESSION>
Where:
<TYPE_IDS> - comma-separated process type IDs to be shown;
<PARAM_IDS> - comma-separated process parameter IDs to be shown, parameter type file is not supported;
<MESSAGE_TAG_IDS> - comma-separated message tag IDs to be shown, * - show all tags;
<SECRET_EXPRESSION> - JEXL expression for secret handling, e.g using plugin secret.
For enabling showing process queue by URL <OPEN_URL>/process/queue/<OPEN_NAME> define in configuration of the queue:
openUrl=<OPEN_NAME> media.html.open.columns=<COLUMN_IDS>
Where:
<COLUMN_IDS> - comma-separated list of queue columns.
For localization of the Open Interface add HTTP request parameter lang=<LANG>, where <LANG> - shortcut of the wanted language.
Числовые коды объекты, они же идентификаторы, необходимы для однозначного определения различных объектов данных в системе. Например, параметров, статусов и т.п. Генерируются при создании и не меняются в течении всего срока жизни объекта. Поэтому, в отличии от наименований, пригодны для использования в конфигурациях. Код объекта обычно выводится в таблице справочника, либо при открытии редактора объекта и сопровождается меткой ID. На скриншоте ниже приведены различные объекты и их коды.
Также в конфигурациях могут потребоваться коды объектов внешних систем, например, BGBilling (получение кодов описано в разделе "Горячие клавиши").
Очень большое количество редко меняющихся настроек поведения системы вынесено в конфигурации. Конфигурация - это текстовый блок, состоящих из записей вида: <ключ>=<значение>. На одной строке может быть только одна такая запись, символ # в начале строки означает комментарий.
Конфигурации вводятся либо в текстовых .properties - файлах (опции подключения к БД, базовые настройки), либо в редакторах конфигурации, сохраняясь в базе данных.
В значениях параметров конфигурации возможна подстановка ранее указанных значений с помощью подстановок {@имя параметра}. Рассмотрим пример подстановки.
# определение значения howYou=how you # использование подстановки some.kind.of.config.record=Thats {@howYou} should use macro!
При такой конфигурации при взятии значения some.kind.of.config.record получаем в результате строку "Thats how you should use macro!". Подставляемое значение должно быть обязательно определено ранее подстановки.
После разбора конфигурация используется системой как набор пар ключ - значение, в котором порядок не определён. При необходимости указания порядка в ключе вводятся дополнительные числовые индексы.
Например:
object.1.id=1 object.1.title=Title1 object.2.id=2 object.2.title=Title2
При большом количестве подобных записей ведение индекса может быть затруднительным, особенно при необходимости изменения номеров записей. В этом случе индекс можно вынести в отдельную переменную, увеличивая его с помощью макроса inc. Далее приведена идентичная конфигурация, индексы в которой выведены в переменную.
object.{@inc:cnt}.id=1 object.{@cnt}.title=Title1 object.{@inc:cnt}.id=2 object.{@cnt}.title=Title2
Помимо присвоения параметр конфигурации можно приклеивать к уже существующему под таким ключём значению. Для этого используется оператор += Например:
key=1 key+=,2 key+=,3
В этом случе под ключом key будет храниться строка "1,2,3".
Склеивание помогает разбить длинную строку конфигурации на несколько более читаемых. Например:
# дата рожд., с.-н. пасп., д.в. пасп., кем выд. пасп, адрес проп., тел. гор, тел. сот, адрес(а) усл., перс. данные bgbilling:creator.importParameters=73,74,75,76,77,78,14,12,115 # ИНН, КПП, ФИО руководителя, полное название, должность рук.-ля, E-Mail(ы) bgbilling:creator.importParameters+=,248,249, 252, 428, 429, 15
Также оно полезно при объединении нескольких конфигураций, позволяя создать общую объединённую переменную.
Ещё один способ разбития на несколько строк значения конфигурации. Используется, например, в JEXL скриптах.
value=<<END Line1 Line2 END
Значение value будет Line1Line2. Переносы строк не участвуют в склеивании. Вместо END можно использовать любую строку.
This tool may is available in Log menu and allows collecting session logs, which may be requested by developers.
Once enabled the tool is collecting logs starting from DEBUG level for the current user session only, that allows easier observe possible problems.
The log is refreshed any time when it opened back.