Инструмент для создания веб приложений на основе 1С REST сервиса

Обзор платформы-конструктора для создания веб-приложений, использующих в качестве источника базы данных 1С

1С, начиная с версии 8.3.5, поддерживает возможность получения данных от платформы  с помощью «коробочного HTTP REST сервиса, реализующего спецификацию стандарта доступа к данным OData (подробнее – здесь).

HTTP REST открывает широкие возможности разработки приложений на различных платформах, используя в качестве источника данных 1С. Здесь можно посмотреть хороший пример описания общих подходов к разработке такого приложения на стеке стандартных веб технологий.

Компанией RWAD Technologies создан инструмент FastWebAppConstructor (FWAC), позволяющий выполнять разработку таких приложений в режиме «конструктора».


FWAC — это универсальный инструмент для быстрой разработки современных веб приложений, использующих в качестве источника данных существующие веб сервисы (посредством использования спецификации доступа к данным OData) либо локальные хранилища.

 

Описание процесса создания приложения

Процесс создания веб приложения на основе 1С REST сервиса средствами FWAC включает в себя:


Создание модели данныхСоздание модели данных

Модель данных создается с помощью операции анализа метаданных 1С REST сервиса. Описание метаданных доступно по следующей маске маршрута: http://[host]/[1C_db_name]/odata/standard.odata/$metadata. В результате  анализа метаданных в импортируемой модели данных учитываются:

—          Таблицы (справочники);

—          Определение первичных ключей таблиц.

—          Связи таблиц (внешние ключи);

—          Типы данных полей;

—          Ограничения обязательности заполнения полей и другие ограничения.

В процессе импорта схемы данных из метаданных OData сервиса возможно выбрать целевые таблицы и поля.

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


Создание запросов (views)

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

Процесс построения запроса  состоит из следующих операций:

1. Определение набора сущностей (справочников), используемых в запросе

Определение набора сущностей (справочников), используемых в запросе

 

2. Определение полей для включения в запрос

Выбор полей запроса

 

3. Формирование условий для фильтрации данных

Определение фильтра запросов

 

Ключевой особенностью FWAC в части работы с запросами является поддержка данного функционала применительно к 1C REST сервису. «Из коробки» 1С REST не реализует параметр $expand запроса к веб сервису (с помощью данного параметра осуществляется встраивание связанных сущностей  в ответ веб сервиса, реализующему спецификацию OData).

FWAC имеет встроенный механизм связывания данных «на клиентской стороне», что позволяет использовать запросы даже в случае, если данный функционал не в полной мере поддержан со стороны сервера.

Таким образом, FWAC значительно расширяет контекст применения функциональных возможностей «коробочного» 1С REST сервиса.

 

Формирование структуры навигационного меню

Управление структурой меню

Создание иерархической структуры навигационного меню осуществляется буквально в несколько кликов. Уровень вложенности узлов меню не ограничен.

Имеется возможность использования font-awesome иконок для пунктов меню.

FWAC также предоставляет возможность определения стиля оформления создаваемого приложения с помощью UI тем bootswatch.

 

Сборка приложения

Сборка приложения

Продукт реализует следующие варианты сборки создаваемого приложения:

1. Локально запускаемое веб приложение. Функционирует с помощью встроенного в сборку приложения локального веб сервера (требует .NET v.4).

2. «Desktop» приложение, исполненное в среде Node WebKit. Подробнее о NodeWebKit можно узнать на сайте проекта.

3. Публикация на локальный веб сервер Microsoft IIS. В перспективе планируется реализовать автоматическое формирование Deploy пакетов приложения для публикации на удаленных серверах и поддержка других популярных веб серверов.


 Получение конечного результата

1. Предтставление со списком записей

Внешний вид созданного приложения

 2. Представление создания (редактирования) записи

Создание (редактирование) записи

Пример созданного FWAC приложения можно посмотреть здесь.

 

Таким образом, FWAC представляет из себя инструмент, позволяющий ценой минимальных трудозатрат создать современное веб приложение, использующее в качестве источника данных 1С REST сервис.

 

Среди ключевых преимуществ FWAC можно выделить:

–        Скорость разработки

В сравнении с традиционными способами проектирования и разработки веб приложений использование FWAC позволит многократно сократить временные издержки и трудозатраты;

–        Расширяемость

Создаваемые средствами FWAC приложения можно кастомизировать и расширять, используя стек стандартных и широко распространенных технологий (HTML, CSS, JS, AngularJS);

–        Аутентификация

Создаваемые с помощью FWAC приложения поддерживают аутентификацию пользователей на уровне источника данных;

–        Работа с запросами

FWAC предоставляет возможность построения запросов.

–        Автопубликация

С помощью FWAC возможно выполнить автоматическую публикацию созданного веб приложения на сервер;

–        Современный UI

FWAC позволяет создавать приложения с удобным UI. В основе создаваемого интерфейса лежит библиотека Bootstrap. Также имеется возможность изменения стиля создаваемого приложения в два клика.

 

Технические требования:

— MS Windows 7 и выше;

— .Net Framework 4.5 и выше (в состав дистрибутива включен патч .NET 4.5.2).

Продукт работает с платформой 1С с релиза 8.3.5 (необходима поддержка публикации стандартного 1С Rest веб сервиса).

 

Предлагаем Вам принять участие в бета-тестировании продукта.

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

Код FWAC является частично закрытым.

Для установки продукта необходимо скачать дистрибутив, прикрепленный к настоящей публикации, и следовать порядку действий, заложенному в процесс установки.

22 Comments

  1. unpete
    • Если используется только стандартный rest, как организован и ввод ссылочных типов и фильтрация по подстроке? Насколько мне известно, odata-вский substring() вместе с like %% в 1С-ной реализации не поддержаны
    • Где описание API почитать? Какие классы и с какими методами доступны front-end разработчику?
    • Где живое демо с примерами подключения к типовым конфигурациям? Желательно, чтобы печать и присоединенные файлы в демках были доступны.
    • Как обстоят дела с автономной работой и асинхронной репликацией?
    Reply
  2. Tahallus

    Что-то гугл не знает такой компании как «RWAD Technologies»

    Reply
  3. ptolemey

    ПРОШУ пощения — отвечал с другой машины — был залогинен под другой учеткой((((

    Пост не удаляется больше.

    (1) unpete,

    >> Если используется только стандартный rest, как организован и ввод ссылочных типов и фильтрация по подстроке? Насколько мне известно, odata-вский substring() вместе с like %% в 1С-ной реализации не поддержаны

    Построение проекций (то, что в согласно спецификации OData реализуется с помощью параметра $expand) — реализовано с помощью последовательности XHR запросов, начиная от корневой сущности и далее по цепочке внешних ключей. При построении результата «запроса» список уже запрошенных сущностей кэшируется. Время жизни кэша — до завершения построения всей проекции.

    По фильтрации — здесь Вы абсолютно верно заметили — пока коробочный REST не умеет 🙂

    НО 1C уже работает в этом направлении — тут анонс расширения функциональности — http://v8.1c.ru/o7/201508odata/index.htm

    >> где описание API почитать? Какие классы и с какими методами доступны front-end разработчику?

    Оно есть на официальном сайте компании (и продукта соответственно).

    Однако, сразу акцентирую Ваше внимание на том, что «ядро» клиентской стороны предоставляет API на AngularJS. Такой выбор был сделан в силу его лидирующих позиций в области комплексных фронт стеков. Обсуждаемы варианты сборки приложения под другие платформы, например Ember. Pure JS пока не рассматривался.

    >> Где живое демо с примерами подключения к типовым конфигурациям? Желательно, чтобы печать и присоединенные файлы в демках были доступны.

    Про непосредственно ссылку — ответ аналогичен предыдущему пункту. По остальной части вопроса — сейчас продукт с стадии бэты и возможны расширения функциональности в отношении в том числе данных вопросов (печать и присоединенные файлы). Однако, сразу отмечу, что механизм работы с файлами в принципе был реализован с помощью «перемещения» в виде Base64.

    Проект будет активно дорабатываться с учетом фидбэка во время и по завершении бэты.

    >> Как обстоят дела с автономной работой и асинхронной репликацией?

    Пока такие режимы не предусмотрены непосредственно.

    НО есть возможность сборки создаваемого приложения с «локальным» поставщиком данных на базе PouchDB. Над ним сделана весомая по объёму внутренней логики обертка.

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

    Reply
  4. dmzubr

    (2) Tahallus,

    Уместное замечание. 🙂

    Сайт стартовал вместе с проектом в текущем месяце. Поэтому пока соответствующие позиции занимает в результатах работы поисковиков.

    Reply
  5. Sh_Vladimir

    Добрый день! А возможно получить какие-то готовые примеры для оценки возможности применения технологии на текущей стадии развития? Заранее спасибо!

    Reply
  6. dmzubr

    (5) Sh_Vladimir,

    Ответил в ЛС

    Reply
  7. Жолтокнижниг

    (0) 1с кажется не поддерживает параметр skip и тд,

    Reply
  8. dmzubr

    (7) Жолтокнижниг,

    Именно так.

    1С поддержку $skip пока только собирается реализовать. Подробнее есть инфа тут — http://v8.1c.ru/o7/201508odata/index.htm

    В то же время, с учетом уже второго по счету комментария на счет «отклонений» от спецификации, добавлю, что у нас имеется также http сервис для 1С, уже сейчас реализующий следующие параметры:

    • $expand
    • $top
    • $skip
    • $filter — в части substring.

    Были также добавлены некоторые «свои». Например, булевый параметр $fillnavproperties. При передаче в сервис для данного параметра значения true — будут сразу заполнены текстовыми значениями все поля внешних ключей целевой таблицы. Если точнее, то не все поля, а поля, перечисленные в части $select запроса.

    Данный сервис используется только для выполнения GET операций.

    Естественно применять этот сервис можно и вне контекста применения продукта, рассмотренного в публикации.

    Не стали включать детали в текущую публикацию, чтобы было чем поделиться еще 🙂

    Касательно его применения именно в контексте статьи — благодаря использованию данного сервиса в приложении, создаваемом с помощью FWAC — полнофункционально реализуется режим server-side pagination.

    На стороне клиента вшит query builder, который на основании имеющейся информации о схеме модели данных, формирует текст запроса к сервису.

    Общая «сигнатура» сервиса соответствует спецификации OData за исключением всего одного знака-разделителя.

    Если же использовать стандартный OData — то pagination и поиск будут выполняться на клиентской стороне.

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

    Reply
  9. unpete

    (8) Преамбула:

    • Есть фреймворк с открытым исходным кодом под GPL, называется UI5, разработан и сопровождается небезызвестной фирмой SAP. Позиционируют его ровно для тех же задач, что и ваш FWAC. Никаких новых подходов к веб-разработке этот UI5, как и десяток других REST-клиентов не предлагает. Сервер там рассматривается, как сервер, а клиент предназначен для отображения данных и обработки ввода пользователя
    • Есть metadata.js, где разработчику в javascript предлагаются ровно те классы данных, которыми он привык манипулировать внутри 1С, а именно: справочники, документы и регистры. С полноценным SQL на клиенте, с динамическим обновлением конфигурации, с реактивным обновлением данных, автоформами и событиями объектов

    Вопросы:

    • Пользователь FWAC — кто он? веб-разработчик или бывший 1С-ник или кто-то третий
    • Каковы отличия-преимущества FWAC по сравнению с двумя описанными выше инструментами

    Reply
  10. dmzubr
    Reply
  11. unpete

    (10) Спасибо, а зачем мобильный клиент 1с, если есть браузер с поддержкой оффлайн?

    Reply
  12. dmzubr

    (11) unpete,

    Заказчику проекта порой потребно иметь обязательно полноценное устанавливаемое мобильное приложение, чтобы можно было в Маркете разместить. Чаще всего мотивы в таком случае носят «имиджевый» характер.

    Как результат — функциональностью даже порой готовы пожертвовать.

    Reply
  13. Key-Zed

    Файл лицензии fwac не найден как получить лицензию. Сайт не доступен

    Reply
  14. dmzubr

    (13) Key-Zed,

    ответил в ЛС

    Reply
  15. nems

    (14)

    тот же вопрос по лицензии

    Reply
  16. dmzubr

    (15) nems,

    ответил в ЛС

    Reply
  17. WellMaster

    С наступающим!

    Аналогично, где можно получить лицензию?

    Reply
  18. dmzubr

    (17) WellMaster, ответил в ЛС

    Reply
  19. UJF

    конструктор не получает список сущностей из опубликокованной со стандартным интерфейсом ODATA типовой УТ.

    Reply
  20. dmzubr

    (19) UJF, ответил в ЛС

    Reply
  21. miksomov

    Добрый день, Дмитрий.

    Скажите проект еще существует и поддерживается или закрылся?

    И можно ли сюда задавать вопросы?

    Reply
  22. dmzubr

    (21) miksomov, проект существует, но он в стадии бета-версии и остался на данный момент. В ближайшее время планов по его реинкарнации нет.

    Вопросы думаю лучше в ЛС. Спасибо за проявленный к продукту интерес.

    Reply

Leave a Comment

Ваш адрес email не будет опубликован. Обязательные поля помечены *