Около года назад мы выпустили открытую и бесплатную платформу для разработки бизнес-приложений lsFusion. В первую очередь, мы ориентировались на разработчиков, которые могут на ней быстро и легко создавать различные информационные системы. Тем не менее, разработка “с нуля” системы управления, даже небольшим бизнесом, остается достаточно трудоемким процессом.
По этой причине мы решили создать базовое решение с названием MyCompany, которое реализует основные бизнес-процессы малого бизнеса. Оно полностью бесплатно, выпускается под Apache лицензией, и ее исходники находятся на Github. Решение легко устанавливается и поддерживает российское законодательство.
В качестве системы управления базой данных используется PostgreSQL. На сервере решение устанавливается и запускается как Java приложение, состоящее из сервера приложений и веб-приложения под управлением Apache Tomcat. В качестве GUI может использоваться как веб-интерфейс, так и десктоп-клиент, запускающийся через Java Web Start.
Функционал
Демо-версию с заполненными данными можно посмотреть по адресу https://demo.lsfusion.org/mycompany-ru. Авторизация по указанной ссылке отключена.
В качестве основы была взята логика, заложенная в известном в мире решении — Odoo. К сожалению, далеко не все подходы, реализованные в нем, хорошо подходят для использования в российских реалиях. Поэтому часть процессов пришлось изменить в соответствии с собственным опытом и другими популярными приложениями. Несмотря на это, логика «MyCompany» гораздо ближе к мировым стандартам, чем к логике 1С. Также в ней имеется локализация на английский язык (с возможностью добавления любого другого языка).
На данный момент в решении отсутствует реализация регламентной отчетности (бухгалтерского учета) и расчета заработной платы. В этой нише на территории РФ исторически сильны позиции решений на платформе 1С, а бухгалтера — это очень консервативные пользователи. По этой причине на первом этапе предполагается выгрузка необходимых данных в систему бухгалтерского учета, а непосредственно решение используется для ведения управленческого учета.
«MyCompany» имеет модульную архитектуру и состоит из семи крупных блоков:
Обработка большинства документов в системе построено по принципу прохождения статусов. По достижению определенных статусов изменяются соответствующие данные в учете, а также могут добавляться дополнительные колонки и действия.
Справочники (Master Data)
В систему заложены основные справочники, необходимые для работы с контрагентами и номенклатурой товаров.
Контрагенты делятся на два вида: юридические и физические лица. Любой человек может быть привязан к организации, в которой он работает. Поддерживаются ведение нескольких собственных компаний.
В качестве номенклатуры могут выступать как товары, так и услуги. Они могут быть привязаны к категориям, которые образуют дерево динамической глубины. Для каждой категории можно задать, какие атрибуты могут и должны быть заданы для всей номенклатуры, входящей в нее. Также можно указать каким образом формировать общее наименование на основе значений атрибутов. Для любой номенклатуры можно задать ее разновидности.
Есть возможность автоматически загружать данные юридических лиц через API, предоставляемый DaData.
Склад (Inventory)
В этом блоке реализована логика складского учета с расчетом остатков по местам хранения. Места хранения могут иметь иерархическую структуру. Сотрудникам компании можно предоставлять доступ только к отдельным местам хранения.
Поддерживается расчет себестоимости остатков по фиксированной и средней себестоимости, а также по методу FIFO. Способ расчета можно выбирать разным в зависимости от категории товаров.
Основными пользователями этого модуля являются работники склада, которые оперируют исключительно количественными характеристиками.
Поддерживаются четыре основных вида документов :
- Приемка. Регистрирует приемку товара на склад. Поддерживает логику ожидаемого и принятого количества, а также статусы процесса приемки и размещения.
- Отгрузка. Отражает расход со склада и перемещение между складами. Кроме того, на определенном статусе резервирует товар на складе.
- Списание. Отражает списание товара со склада.
- Инвентаризация. Регистрирует обнаружение или потерю товара на складе. Инвентаризация может проводится целиком по месту хранения, выбранной категории или определенным товарам.
Реализован поштучный учет и интеграция с Честным знаком в части получения контрольных марок, передачи и получения документов в/из ГИС МТ.
Расчеты (Invoicing)
Этот блок реализует логику регистрации входящих и исходящих накладных и платежей. Поддерживается логика связи входящих и исходящих документов для расчета долгов по документу и контрагентам. Реализована возможность разнесения стоимости услуг на себестоимость товаров различными способами.
Поддерживаются четыре основных вида документов :
- Поступление. Регистрирует входящую накладную или акт выполненных работ на товары или услуги. На основании этого документа может автоматически или вручную создаваться документ приемки на склад.
- Реализация. Регистрирует исходящую накладную или акт выполненных работ на товары или услуги. На основании этого документа может автоматически или вручную создаваться документ отгрузки со склада.
- Входящие платежи. Отражает поступление денежных средств в кассу или на расчетный счет.
- Исходящие платежи. Отражает расход денежных средств из кассы или с расчетного счета.
Реализованы печатные формы УПД, ТОРГ-12 и ТОРГ-13.
Закупки (Purchase)
В блоке реализована логика заказов товара и услуг у поставщика. Поддерживается возможность регистрации прайс-листов поставщиков с последующей автоматической подстановкой цен в заказ.
Заказ проходит несколько статусов, в ходе которых он может автоматически отправляться поставщику по электронной почте. Подтвержденный заказ автоматически создает планируемое поступление товара, которое затем обрабатывается кладовщиком. После того, как товар принят, бухгалтером создается документ поступления на основе принятого количества.
Продажи (Sales)
В этом блоке реализован функционал регистрации заказов покупателей и формирования продажных цен.
Реализована возможность задавать несколько видов цен, которые затем привязываются к покупателям или типам заказов. Цены для каждого из видов задаются при помощи документов прайс-листов с различными периодами действий. Поддерживается формирование печатных форм прайс-листов и ценников.
Для различных видов цен можно задать скидки, которые будут автоматически или вручную рассчитываться при формировании заказов или документов реализации (в том числе и в POS).
Заказ покупателя также проходит несколько статусов с возможностью отправки покупателю подтверждения заказа. При этом автоматически создается документ на отгрузку товара, который в дальнейшем исполняется работником склада. Затем бухгалтер может создать документ реализации товара на основе отгруженного количества.
Розничная торговля (Retail)
В этом блоке реализован функционал по розничной торговле товарами и услугами.
Основным элементом пакета является форма POS, при помощи которой осуществляется розничная продажа и возврат товаров. Поддерживается возможность открытия и закрытия смен, внесения и изъятия денег. Реализована интеграция с фискальным регистратором АТОЛ через веб-сервер.
К системе можно подключать несколько касс, настроенных, как для одного, так и для разных мест продаж.
Все чеки проводятся как документы реализации, автоматически отражая все изменения в учете. Чеки можно создавать на основе заказов клиентов.
Производство (Manufacturing)
Этот блок реализует возможность учитывать производство продукции и списания сырья по ней с расчетом себестоимости.
Производство и списание сырья производится на основе производственных заказов. С их помощью можно регистрировать как производство, так и разборку (разукомплектацию) готовых изделий. Реализован автоматический расчет количества продукции, отходов и сырья на основе введенных спецификаций. Поддерживается создание спецификаций с учетом их “вложенности” друг в друга. Реализована возможность автоматического создания производственных заказов на основе заказов на продажу.
Установка
Для установки решения потребуется сервер под управлением операционной системы Linux или Windows с подключением к Интернет.
На нем должно быть минимум 2 гигабайта оперативной памяти, должен быть открыт порт 8080 для работы веб-клиента и порт 7652 для работы десктоп-клиента.
Linux
Рассмотрим установку MyCompany на примере команд для сервера под управлением CentOS 7, выполняемых с правами суперпользователя root.
Установить платформу lsFusion:
root@centos7: localectl set-locale LANG=ru_RU.UTF-8
root@centos7: source <(curl -s https://download.lsfusion.org/yum/install-lsfusion4)
Установить конфигурацию MyCompany:
root@centos7: yum install -y wget
root@centos7: wget http://download.lsfusion.org/solutions/mycompany-1.0.jar -O /var/lib/lsfusion/mycompany.jar
root@centos7: echo "logics.topModule = MyCompanyRu" >> /etc/lsfusion4-server/settings.properties
Перезапустить службу сервера lsFusion:
root@centos7: systemctl stop lsfusion4-server
root@centos7: systemctl start lsfusion4-server
Процесс запуска сервера приложений можно контролировать в логе /var/log/lsfusion4-server/start.log.
Windows
Скачать и запустить установщик сервера и клиента по ссылке: 64-битная ОС, 32-битная ОС.
Оставить все параметры по умолчанию. Если необходимо, то задать пароли.
Скачать последнюю версию MyCompany по ссылке и сохранить их в папку lib сервера. (по умолчанию — C:\Program Files\lsFusion 4\Server\lib)
Перезапустить службу сервера lsFusion.
Миграция данных
В решении существует простой механизм загрузки начальных данных через файлы в формате Excel. Для импорта справочников и других объектов достаточно зайти в Администрирование / Миграция. Для каждого вида справочника есть отдельная кнопка, которая формирует шаблон в формате XLSX, из которого затем можно загрузить данные из старой системы.
Доработка
Доработка логики работы решения осуществляется путем внесения изменений в исходный код на внутреннем языке платформы lsFusion. На рабочем сервере это можно сделать добавлением новых модулей путем копирования файлов в папку /var/lib/lsfusion.
Для быстрой и удобной разработки рекомендуется установить локально дистрибутив, который содержит в себе IntelliJ IDEA Community Edition вместе с предустановленным плагином, а также клиентское приложение в виде веб-сервера. При инсталляции устанавливать серверную часть не обязательно, так как нужные библиотеки будут автоматически загружены при помощи Maven. Затем в IDEA нужно запустить Get from Version Control / Github и ввести github.com/lsfusion-solutions/mycompany.git. После этого необходимо настроить запуск сервера через Edit configurations / + / lsFusion Server. После любых изменений, сделанных в исходный код, нужно перезапускать сервер приложений.
Для того, чтобы собрать jar-файл с учетом сделанных изменений, необходимо настроить сборку artifacts. Собранный artifact нужно скопировать в папку /var/lib/lsfusion вместо исходного jar-файла решения MyCompany.
Есть вариант подключать базовое решение MyCompany через Maven. Преимущество такого подхода заключается в том, что при обновлении версии базового решения, не будет необходимости делать слияние “пересекающихся” изменений исходного кода. Недостатком же является невозможность вносить изменения в исходный код базового решения.
Для подключения решения MyCompany через Maven нужно прописать в pom.xml следующие параметры:
<repositories> |
Для большей прозрачности доработок и исключения необходимости слияния кода рекомендуется новую функциональность добавлять в отдельные модули.
Пример:
Предположим, необходимо добавить в логику приложения возможность задавать кредитный лимит для покупателя.
Сначала создаем новый модуль DebtLimit:
MODULE DebtLimit; |
Затем заходим в пользовательский интерфейс под администратором и наводим мышкой на заголовок поля с долгом покупателя:
Видим, что вычисляемое свойство, которое рассчитывает долг, объявлено в модуле DebtPartner и называется debt с единственным параметром Контрагент(Partner). В новом модуле подключаем этот модуль, чтобы можно было обращаться к его свойствам:
REQUIRE DebtPartner; |
Создадим для контрагента новое свойство Кредитный лимит, в которое пользователь сможет вводить значение и помещаем его на форму редактирования контрагента partner в контейнер headerRight:
debtLimit 'Кредитный лимит' = DATA NUMERIC[14,2] (Partner); |
Наконец, добавляем ограничение, которое будет проверять, что долг в любой момент времени не должен превышать кредитный лимит по этому покупателю:
CONSTRAINT debt(Partner p) > debtLimit(p) MESSAGE 'По покупателю превышен кредитный лимит'; |
Осталось подключить этот модуль к проекту. Создадим новый модуль RogaIKopyta и пропишем его в файле settings.properties:
logics.topModule = RogaIKopyta |
При запуске сервера приложений будут подключены только те модули, от которых зависит (в том числе рекурсивно) модуль RogaIKopyta. Соответственно, к нему подключаем созданный нами модуль и MyCompanyRu из базового решения, в котором подключены все основные модули, а также российская локализация:
MODULE RogaIKopyta; |
Чтобы установить эти изменения на боевой сервер нужно либо собрать artifact, как описано выше, либо просто скопировать два файла с модулями RogaIKopyta и DebtLimit в папку /var/lib/lsfusion. Также надо не забыть поменять logics.topModule на рабочем сервере. После изменений нужно перезапустить службу сервера приложений.
Поддержка и развитие
Разработкой решения MyCompany занимается белорусская компания ЛюксСофт. Она существует более 20 лет и является лидером на рынке автоматизации крупной розничной торговли в Беларуси. Пять из восьми крупнейших розничных сетей Беларуси используют ее решение lsFusion ERP для автоматизации своей основной деятельности.
Благодаря использованию Java-технологий можно легко подключать различные готовые библиотеки для всевозможных интеграций с внешними системами и других низкоуровневых действий. Удобство разработки обеспечивается за счет использования одной из лучших IDE в мире — IntelliJ IDEA (Community Edition).
Основной целью разработки решения MyCompany является поддержка open source движения и популяризация платформы lsFusion. Финансирование решения идет за счет продаж и поддержки коммерческих систем на базе платформы в Беларуси.
На момент написания статьи были реализованы основные функции, необходимые на наш взгляд для минимального жизнеспособного продукта. Дальнейшая разработка будет осуществляться на основе потребностей пользователей. Пожелания по доработке решения можно создавать в виде Issues на Github. Также любые вопросы по решению можно задать в нашем Slack-канале.
Мы готовы реализовывать доработки и оказывать поддержку в том числе и на коммерческой основе. При этом мы будем всячески поддерживать желающих делать это собственными силами или оказывать услуги третьим лицам. Лицензия решения Apache и LGPL лицензия самой платформы даже позволяют разрабатывать и продавать на их основе решение под собственной торговой маркой.
Модульная архитектура дает возможность создавать отдельно подключаемые открытые и коммерческие модули, которые будут расширять основную функциональность решения. При помощи Maven можно создавать и подключать отдельные библиотеки с определенной логикой, а затем собирать из них готовое решение.
По нашему опыту разработка на lsFusion требует значительно меньше усилий и квалификации, чем разработка на той же платформе 1С. В ней не требуется писать вручную запросы, управлять клиент-серверным взаимодействием и многими другими техническими аспектами. Любой 1С-программист сможет очень быстро освоить разработку на платформе и оказывать услуги по поддержке решения MyCompany. В то же время, в нашей компании есть много людей, которые не имели никакого опыта разработки на чем-либо, и без проблем научились программировать на платформе lsFusion. Большинство продвинутых пользователей Excel, которые умеют строить в нем сложные формулы, а также SQL-программисты, смогут легко освоить базовые механизмы платформы для самостоятельной доработки решения MyCompany.
Бизнес, в свою очередь, сможет сэкономить на различных лицензиях (1С, Windows, Microsoft SQL Server), получив при этом быстрое и современное решение.
Заключение
Основные преимущества MyCompany перед аналогами на российском рынке:
- Бесплатность и открытость. Никаких лицензионных условий, подписок, ограничений по пользователям, платежей, HASP-ключей и прочих неудобств.
- Скорость и удобство работы. В отличие от решений на базе 1С, веб-интерфейс работает настолько быстро, что прекрасно работает даже в мобильном браузере. В документы можно добавлять десятки тысяч записей, и это не будет вызывать значительных замедлений при работе. В абсолютно каждую таблицу на любой форме встроено множество возможностей по аналитике и навигации.
- Расширяемость. Дорабатывать функционал можно простым добавлением в папку текстовых файлов на лаконичном высокоуровневом языке lsFusion, программировать на котором могут даже продвинутые бизнес-пользователи или любой разработчик 1С.
vsh797
Верно ли я понял, что все таблицы в веб-версии выводятся графическими элементами? Заголовков нет. Ссылки есть, но текста не содержат. Даже не знаю, для чего они. В общем для работы со скринридером все довольно печально.
lemur-galago Автор
На самом деле, таблицы в веб-версии выводятся именно как таблицы. Никаких графических элементов ни в заголовках, ни в ячейках таблиц нет (ну, за исключением случаев когда туда нужно поместить именно картинку, например, как изображение товара). Заголовки в таблицах есть, текст в заголовках написан.
Наверное это какая-то особенность скринридера?! Мы проверим как веб-версия работает со скринридерами и постараемся исправиться.
vsh797
Видимо "Сводная таблица" выводится картинкой. По кнопке "Таблица" переключается на тег. Но вообще очень сложно разобраться, что реально там происходит. Видимо js слушатели реагируют на фокус скринридера и страница постоянно скачет.
Скринридер стандартный для windows — nvda.
Про заголовки я имел ввиду h1… h6. По-хорошему они должны отделять разные части страницы друг от друга. Так же, как и ul, например. Именно между ними, как правило, и осуществляется навигация с помощью скринридера. Например, заголовок с названием вашей статьи на этой странице — h1.
Veidt
Нет, сводная таблица рендерится очень похоже на обычную таблицу, то есть tr/td'ками (хоть и coffeescript'ом, а таблица на самом деле GWT). Рендереры ячеек и там и там используются одинаковые.
Но как это все конечно скринридером воспринимается надо изучать.
Заголовки h* для бизнес-приложений это немного странная вещь, так как в бизнес-приложениях в основном используется более сложный flex / table layout'инг, и как в этом случае использовать эти теги конечно загадка.
vsh797
Если таблица выведена тегами, то скринридер ее так и озвучит. Если же перейти по ссылке демо-версии, то таблиц не обнаруживается, зато есть графический элемент с данными.
2020 — 132020 — 152020 — 172020 — 192020 — 222020 — 242020 — 262020 — 282020 — 302020 — 352020 — 372020 — 402020 — 462020 — 502020 — 522021 — 12021 — 32021 — 52021 — 530200400600800 graphic
anonymous
А RaspberryPi 4 c 4G ОЗУ потянет эту систему? вывод через экран с тачскрин сделать и всякие штрихридеры через юсб подключить. Чтобы создать раб место кассира в маленьком магазе.
Или Ваша система не для этого?
lemur-galago Автор
Серверная часть вряд ли сможет нормально работать на таком железе, а вот для клиента, как минимум, есть варианты. Самый простой — из браузера открывать веб-интерфейс, адаптированный для мобильных устройств. Можно пойти и более сложным путем — используя любую подходящую технологию, сделать для мобильного устройства клиентскую часть, которая будет посредством REST API общаться с серверной частью.
В целом, варианты есть — все зависит от решаемой задачи.
anonymous
Хорошо — вынесем сервер в облако, закроем впн-ом. Клиента на малинке организовать получится? Ну или планшет на андроиде? или тсд на андроиде? — китайцы такие делают.
lemur-galago Автор
Клиент на мобильном устройстве — это не проблема. У нас в портфеле есть решения и с ТСД, и с адаптированными формами под смартфоны, и кейсы работы на планшетах.
Вы, например, можете попробовать зайти на демо MyCompany со смартфона и у вас автоматически откроются формы, адаптированные для таких устройств. Вы можете открыть эту же страницу с планшета, зайти в раздел «Розничная торговля» и попробовать форму POS — работа с планшета здесь вполне комфортна. Опять же, платформа позволяет очень легко добавить необходимые именно вам формы, в том числе и адаптированные для экранов мобильных устройств.
caballero
zippy.com.ua потянет на RPI
fosihas
Это в первую очередь: работа конечного пользователя. Простая установка, обновление и работа, без привлечения третьих лиц.
Начало хорошее и есть к чему стремится.
CrushBy
Тут только надо учитывать, что все-таки есть разница в подходах и решениях между коммерческими (как 1С) и open-source проектами.
Но я бы не сказал, что вот это прямо про 1С, учитывая что при простом обновлении платформы с 8.3.17 до 8.3.18 могут возникнуть проблемы:
vrnvorona
Если при обновлении минорной версии возникают проблемы, то версионирование неверное или баг какой-то конкретный имхо.
CrushBy
Добро пожаловать в мир 1С.
В современном мире (например, PostgreSQL или Java) уже второе число — это только баг-фиксы. А у 1С третья цифра — это добавление новых фич (причем существенных).
AndreySu
Проработав более 10 лет назад, в разработчиках ERP систем, Microsoft, SAP.
Наблюдаю удивительную приемственность 10 — 20 летней давности в UX.
CrushBy
Не стоит смешивать B2C и B2B интерфейсы. В первом случае, удобство и красота для пользователя стоит на первом месте. Во втором случае, на первых местах находятся эффективность выполнения сотрудником своих функций, гибкость бизнес-процессов, цена и так далее. Удобство и красота где-то дальше. Да, это плохо, но, к сожалению, такова жизнь, так как лица принимающие решения, как правило, не будут работать непосредственно с программой.
AndreySu
Да, но объем располагаемой информации одновременно на всём экране утомит любой мозг. Я не говорю о крайности про B2C, но и B2B подобный интерфейсы тоже крайность, видимо не хотят искать в B2B компромисс в UX. Конечно проще всего тянуть нашлёпывание ипутбоксов на формы со времен Borland Delphi X.0
CrushBy
А Вы видели когда-нибудь интерфейс биржевого брокера? Там тоже нужно делать одну кнопку, как у Apple?
Дело в том, что нагруженный интерфейс зачастую является более удобным, когда пользователю для принятия решения не нужно ничего жать, чтобы увидеть информацию, которая нужна эпизодически. Достаточно просто перевести взгляд.
Кроме того, чем сложнее интерфейс с точки зрения поведения, тем сложнее его код. Соответственно, тем выше стоимость его доработки, вероятность ошибки и так далее.
В общем, не все так однозначно. Видимо не просто так SAP, Axapta, 1С и прочие бизнес-приложения имеют такие интерфейсы. Возможно это наименьшее из зол.
AndreySu
Честно говоря последние несколько лет работаю, делая интерфес биржевого брокера для CFD и CE. И да, могу с уверенностью сказать что видел и делаем с UX сейчас.
CrushBy
И как там? На формах одна большая кнопка с одним болшьим текстовым полем? Или все-таки много разных относительно небольших элементов, каждый из которых отображает отдельную необходимую для принятия решения информацию?
AndreySu
Второе.
Но в описанной в статье системе второе х 10
happy-cat
Добрый день!
Есть несколько вопросов:
Спасибо
PS бегло посмотрел систему но на мои вопросы ответов не нашел
lemur-galago Автор
1. В настоящий момент вы можете вести базу физических и юридических лиц с информацией об их адресах, контактах, договорах, местоположении и т.д. Кроме того, в планах есть добавление базового функционала CRM — логики потенциальных сделок.
2-3 Вообще говоря, система MyCompany ориентирована, в первую очередь, на работу с товарами и в большей степени она подходит организациям, занимающимся оптовой и розничной торговлей. Несмотря на это, базовый функционал работы с услугами в MyCompany присутствует. Он, по меньшей мере, позволяет работать с услугами начиная от заказов и заканчиваю учетом задолженностей. Следует понимать, что это только базовый функционал, не учитывающий никаких отраслевых специфик.
Если говорить о возможности добавления такого функционала, то да — такая задача, учитывая модульность системы и открытый исходный код, представляется не запредельно сложной.
XVlady5
Очень не хватило отдельной части как проверить получившийся результат. Куда и как писать автотесты на автоматизируемые процессы. Я понимаю, что это потянет на отдельную статью, но хочется видеть мнение разработчиков платформы на этот вопрос.
Veidt
Тут есть вот какая особенность. Надо понимать, что lsFusion очень высокодекларативная платформа (думаю, что на порядок превышающая все существующие). Соответственно, в ней максимально описывается именно ЧТО надо получить, а не КАК это надо получить. А значит непонятно, что значит тестировать «получившийся результат», потому как, как говорится, «программа работает так, как она написана». Еще более непонятно как тестировать пользовательский интерфейс (и что в нем тестировать).
Впрочем допускаю, что какие-то сценарии тестирования все же могут быть (все же действия и события привносят определенную императивность, пусть и в пропорции 20 на 80), но для их проверки в любом случае придется запускать сервер. Поэтому я бы это видел как прописывание в действие выполняемое на старте сервера:
Соответственно дальше на сервере сборки / тестирования запускаем старт сервера в test mode и проверяем, что он прошел успешно (по логу можно понять что именно упало). Правда пока готовой инфраструктуры под это нет, но она скорее всего сведется к каким-то стандартным действиям, которые не сложно написать самому.
Naf2000
Sql тоже декларативный. Но зачастую запросы содержат ошибки
Veidt
Ну, во-первых, SQL все же менее декларативный, работает на более низком уровне абстракции (таблиц, а не функций), и, в том числе поэтому, имеют большую accidental complexity (скажем типы join'ов, возможность соединения не по всем ключевым полям и т.п.). Как следствие имеет существенно большую вероятность ошибок.
Плюс (и что наверное главное) в SQL нет инкрементальности (реактивности) из коробки (только в очень частных случаях), а именно ее обеспечение в современных бизнес-приложениях это чуть ли не 90% всей императивной логики. В lsFusion такой проблемы нет.
Впрочем, опять-таки, не отрицаю, что все же, в весьма редких случаях, некоторые сценарии тестирования могут быть необходимы, и я выше контурно описал, как это все может выглядеть на практике.
alex0x001
А есть ли примеры интеграции Вашей платформы с 1C? Через HTTP/Web сервисы, ODATA, AMQP и.т.д. В любом случае для отчетности (в России) будет использоваться 1с бухгалтерия/ЗУП, (да и у многих процессы также завязаны на ERP/УНФ)… В принципе примерно понятно как реализовать, но хотелось бы реальных use case.
lemur-galago Автор
Конечно у нас есть достаточное число кейсов интеграции с другими системами. Среди этих систем есть, конечно же, и решения на базе 1С. Для интеграции мы используем различные технологии — механизмы и способы обмена зависят от требований каждого конкретного проекта.
Что касается именно myCompany, то в самых ближайших планах у нас добавление базового механизма обмена в формате 1C:EnterpriseData. Это должно позволить достаточно просто интегрироваться с большинством типовых решений 1С.