Metadata.js для построения дешевых высоконагруженных сервисов

08.08.16

Интеграция - WEB-интеграция

В маркетинге есть понятие "голубой океан". Стратегия опирается на создание не существовавшего ранее спроса на новом рынке, где практически отсутствуют конкуренты. Вместо того, чтобы конкурировать со множеством игроков на малоприбыльных рынках ("красный океан"). В статье я расскажу об одном из инструментов, помогающем создавать и осваивать новый рынок Интернет-сервисов для бизнеса.

Что такое Metadata.js?

  • Движок ссылочной типизации для браузера и nodejs
  • Библиотека для разработки бизнес-ориентированных и учетных offline-first браузерных приложений

Если коротко, то метадата предоставляет веб-программисту высокоуровневые объекты данных, аналогичные тем, которыми пользуются программисты 1С (перечисления, справочники, документы, регистры и т.д.)

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

Еще, metadata.js можно рассматривать, как "БСП для веб", предлагающую готовые решения для:

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

Если у кого-то возник вопрос «а не очередной ли это велосипед», вынужден возразить: я достаточно ленивый человек, чтобы повторять функциональность, реализованную другими. Если бы нужную математику можно было купить, сделал бы это без долгих размышлений – это всегда дешевле и быстрее. Я старался не дублировать работу, проделанную уважаемым javascript-сообществом и по возможности использовать стандартные библиотеки. Вот список основных зависимостей:

Серверная часть

  • couchDB, NoSQL база данных с поддержкой master-master репликации
  • nginx, высокопроизводительный HTTP-сервер

Управление данными в памяти браузера

  • metadata.js, движок ссылочной типизации для браузера и Node.js
  • pouchDB, клиентская NoSQL база данных с поддержкой автономной работы и репликации с CouchDB
  • alaSQL, SQL-интерфейс к массивам javascript в памяти браузера и Node.js
  • aes, библиотека шифрования/дешифрования строк
  • xlsx, библиотека для чтения и записи XLSX / XLSM / XLSB / XLS / ODS в браузере

UI библиотеки и компоненты интерфейса

  • dhtmlx, кроссбраузерная библиотека javascript для построения современных веб и мобильных приложений
  • handsontable, компонент для отображения и редактирования табличных данных
  • daterangepicker, компонент визуализации и редактирования диапазона дат
  • filesaver.js, HTML5 реализация метода saveAs
  • moment.js, библиотека форматирования интервалов и дат
  • numbro, библиотека форматирования чисел
  • rubles.js, библиотека форматирования чисел - сумма прописью

Зачем это нужно и что даёт?

  • Масштабируемость и надёжность. Сервер средней мощности может обслуживать тысячи клиентов и эти клиенты сохранят работоспособность при перебоях связи
  • Неограниченная свобода в дизайне отзывчивого интерфейса
  • Новое качество веб-приложений, сочетающее мощь бизнес-объектов 1С с эффективностью и открытостью веб-технологий

Предыстория

Список заказов

Несколько моих клиентов заинтересовались возможностью сделать для своих дилеров личные кабинеты в браузере.
Требовалось обеспечить внутри этого кабинета работу с графическим построителем для рисования изделий (окон, витражей, офисных перегородок).

Графический редактор

Система должна рассчитать геометрию элементов, спецификацию, стоимость и отправить эту информацию в план завода.
Типичный оконный завод производит до 1000 изделий в день, сотрудничает с большим количеством дилеров (от 200 до 500).

Из задачи вытекали спецтребования:

  • Редактору геометрии требовалась интенсивная работа с данными в браузере в реальном времени – по каждому смещению мыши на сервер не набегаешься
  • Должно работать при плохой связи и в автономном режиме
  • Нужен гибкий отзывчивый интерфейс с поддержкой, в том числе, мобильных устройств
  • Нужно нулевое администрирование на клиентах
  • Хотелось сэкономить на лицензиях и серверном оборудовании

Имелся 1С-ный прототип для управления позаказным производством. В нём были подсистемы расчета спецификации, сложного ценообразования, диспетчеризации и учета - надстройка над 1С:КА 1.1. Повторить такой проект "в лоб", на языке программирования общего назначения - задача нереальная даже в теории. Решил разделить эту задачу на части:

  • Делаем платформу, которая позволит использовать структуру объектов и синтаксис ala-1С
  • Транслируем 1С-ный прототип в термины этой платформы
  • Бинго! Имеем дешевый функциональный отказоустойчивый сервис

Преемственность синтаксиса

Свойства и методы объектов metadata схожи, но не повторяют и не ограничиваются возможностями 1С.
Например, у нашей табличной части (TabularSection) есть метод НайтиСтроки (find_rows). Кроме стандартного поиска по равенству полей, добавлен синтаксический сахар:

// поиск в 1С
Результат = ТабЧасть.НайтиСтроки(Новый Структура("Поле1", Значение1));
// поиск, "как в 1С"
res = ts.find_rows({Поле1: Значение1});
// поиск на неравенство
res = ts.find_rows({Поле1: {not: Значение1}});
// поиск по списку значений
res = ts.find_rows({Поле1: {in: [Значение1, Значение2]}});
// логическое ИЛИ
res = ts.find_rows({or: [{Поле1: Поле1}, {Поле2: Поле2}]});
// поиск с произвольным условием
res = ts.find_rows({Поле1: function(v, key){if v[key] > 3 return true;}});
// поиск с условием SQL выполняется на клиенте, без обращения к серверу
res = alasql("select * from ? where `Поле1` > 3", ts._obj);

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

В offline-режиме, приложение metadata подобно локальной файловой базе 1С. Оба движка работают в этом режиме весьма шустро.
При работе с длинными списками, в metadata чуть больше свободы:

  • Можно построить сложные, составные или фасетные индексы
  • Если позволяет железо, можно работать с таблицами в памяти
  • Можно наоборот, пожертвовать производительностью в пользу экономии памяти - всё зависит от задачи

Если metadata используется, как альтернативный лёгкий клиент к серверу 1С, получаем значительное ускорение даже на типовых конфигурациях. В эксперименте использованы:

  • Один и тот же сервер – физически он расположен в Германии
  • Она и та же информационная база
  • Один и тот же канал в интернет ping ~ 90ms
  • И даже документ мы один и тот же открываем

Наш, и 1С-ный клиенты находятся в абсолютно равных условиях.
Важно: перед замерами в 1С, несколько раз открываем и закрываем формы объектов и списков, чтобы прогреть кеш 1С-ного сервера.
Итак, время открытия типового заказа покупателя в веб-клиенте 1С занимает примерно 2.5 секунды.

В metadata та же операция выполняется за 400 мс.

Теперь посмотрим сетевой трафик. В metadata json прочитанного заказа занимает порядка 7 Кб.

В 1С, только передача пакета отъела 700 мс, и этот пакет занимает 180 Кб.

Таблица объединяет данные результаты измерений:

Операция Metadata Веб клиент 1С Выигрыш
времени, раз
Выигрыш
трафика, раз
Мин. время реакции сервера 150мс 150мс - -
Загрузка и вход в программу 4сек/4Mb 20сек/6Mb 5 1,5
Открытие формы "Заказа" 400mc/8Kb 2200mc/180Kb 5 20
Открытие формы выбора справочника 300мс/0Kb 600мс/10Kb 2 >>
Поиск в динсписке кешируемых объектов 200мс/0Kb 300мс/10Kb 1,5 >>
Поиск в динсписке с обращением к серверу 300мс/10Kb 300мс/10Kb - -

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

Я не критикую платформу 1С. Технологии веб-клиента 1С и легкого клиента отличаются очень сильно.
Наш лёгкий клиент не предназначен для замены традиционного веб-клиента в тех задачах, с которыми платформа 1С справляется хорошо.
Конкурировать с 1С на её поле - глупо и бесперспективно. Зато, с metadata.js можно сделать бизнесу выгодное предложение в тех областях, куда 1С вообще не заглядывает. Появляется возможность добавить в дешевые веб-приложения такие функции, которые ранее были доступными только в тяжелых учетных системах.

Совмещаем сильные стороны 1С и современного web для решения бизнес-задач

Есть встречное движение:

  • 1С в глобальную сеть
  • Традиционный web – в область задач автоматизации бизнеса

Чтобы лучше понять это движение и интересы участников, рассмотрим наиболее сильные и слабые стороны 1С и веб-технологий:

  • Веб-технологии содержат фантастические по изяществу и выразительности инструменты, но, к сожалению, там нет необходимого для бизнес-задач уровня абстракции. Посмотрите на сайты платежных систем, заказа билетов на самолет, поезд, личные кабинеты операторов сотовой связи – функциональность скудная, так как в языке, на котором думают постановщик и разработчик, нет слов для описания решаемой задачи.
  • Платформа 1С - это очень мощный инструмент для построения учетных систем, но он сильно отстал от современного веб. Дело в том, что в 2008-2009 годах, когда проектировалась архитектура управляемого приложения,  Javascript был другим. В браузерах не было автономной работы, в языке отсутствовали инструменты для управления свойствами объектов. В результате тонкий и веб-клиент 1С умеют лишь показывать данные и принимать ввод пользователя. В конце нулевых годов, такому подходу, наверное альтернативы не было. Но сегодня, когда любой телефон содержит несколько вычислительных ядер и несколько гигабайт ОЗУ, использование только серверного рендеринга и отказ от данных на клиенте – это непозволительная роскошь.
  • В metadata.js
    • Задействованы возможности современных браузеров
    • Реализован уровень абстракции, доступный ранее только в платформе 1С
    • Часть вычислительной работы и хранение коротких списков - справочников и перечислений перенесена на клиента.
      Это позволило значительно улучшить производительность, снизить нагрузку на сервер, повысить скорость и качество разработки

Инструменты metadata.js могут украсить жизнь как разработчикам 1С, так и веб-программистам. Но и те, и другие пока не проявляют интереса к нашей математике.
Рассчитывают отсидеться на освоенных технологиях. Конкуренция пока небольшая, «пирога» всем хватает.

Есть устоявшиеся стереотипы:

  • Для работы браузера нужно подключение к Интернет
  • Настольная программа работает быстро, а браузерная - тормозит
  • 1С-ный синтаксис есть только внутри 1С
  • Система на 1000 пользователей - это очень дорого
  • Из браузера трудно достучаться до COM и USB портов и прочего внешнего оборудования
  • Автономное веб-приложение - это очень сложно

Metadata.js пытается эти стереотипы пошатнуть.

  • Браузер прекрасно работает offline
  • Нативному приложению, чтобы приблизиться к качеству веб-интерфейса, сначала нужно реализовать внутри себя браузер
  • Синтаксис, подобный 1С-ному, теперь доступен в javascript
  • Система на 1000 пользователей - это реально дешево
  • Из javascript легко управлять COM, USB и сетевыми устройствами
  • Автономное веб-приложение - это очень просто

Пользуйтесь и зарабатывайте на внедрениях.

*****************

Данная статья написана по итогам доклада, прочитанного на конференции INFOSTART EVENT 2015 CONNECTION 15-17 октября 2015 года.

Приглашаем вас на новую конференцию INFOSTART EVENT 2019 INCEPTION.

См. также

Интеграция Альфа Авто 5 / Альфа Авто 6 и AUTOCRM / Инфотек

Сайты и интернет-магазины WEB-интеграция Платформа 1С v8.3 Конфигурации 1cv8 1С:Управление торговлей 11 Автомобили, автосервисы Россия Управленческий учет Платные (руб)

Интеграционный модуль обмена между конфигурацией Альфа Авто 5 и Альфа Авто 6 и порталом AUTOCRM. Данный модуль универсален. Позволяет работать с несколькими обменами AUTOCRM разных брендов в одной информационной базе в ручном и автоматическом режиме. Без существенных изменений типовой конфигурации. Проверено с брендами: Интеграция 1С и GEELY Интеграция 1С и HAVAL Интеграция 1С и KIA Интеграция 1С и FORD Интеграция 1С и LADA ГАРАНТИЯ 100% ВНЕДРЕНИЯ!

36000 руб.

03.08.2020    15657    9    17    

9

Модуль для обмена "1С:Предприятие 8. УАТ. ПРОФ" с FortMonitor

WEB-интеграция 8.3.8 Конфигурации 1cv8 Автомобили, автосервисы Беларусь Украина Россия Казахстан Управленческий учет Платные (руб)

Расширение предназначено для конфигурации "1С:Предприятие 8. Управление Автотранспортом. ПРОФ". Функционал модуля: 1. Заполнение регистров сведений по подсистеме "Мониторинг", а именно: события по мониторингу, координаты по мониторингу, пробег и расход по мониторингу, текущее местоположение ТС по мониторингу 2. Заполнение путевого листа: пробег по мониторингу, время выезда/заезда, табличная часть ГСМ, места стоянок по геозонам. 3. Отчеты по данным загруженным в регистры сведений. 4. Предусмотрена автоматическая загрузка данных в фоновом режиме (условия работы данной загрузке читайте в описании товара) Модуль работает без включенной константы по настройкам мониторинга. Модуль формы предоставляется с открытым кодом, общий модуль защищен. Любой заинтересованный пользователь, имеет возможность скачать демо-версию расширения.

22656 руб.

25.05.2021    12809    30    8    

10

Интеграция 1С — Битрикс24. Обмен задачами

Сайты и интернет-магазины Интеграция WEB-интеграция Платформа 1С v8.3 Конфигурации 1cv8 Управленческий учет Платные (руб)

Интеграция 1С и Битрикс24. Разработка имеет двухстороннюю синхронизацию 1С и Битрикс24 задачами. Решение позволяет создавать пользователя в 1С из Битрикс24 и наоборот. Данная разработка технически подходит под все основные конфигурации линейки продуктов 1С:Предприятие 8.3 (8.3.18.1289). При приобретении предоставляется 1 месяц бесплатных обновлений разработки. Доступна демо-версия продукта с подключением Вашего Битрикс24

5040 руб.

04.05.2021    17425    6    15    

13

[Расширение] БОР-Навигатор.Культура

Зарплата Бюджетный учет WEB-интеграция Обмен с ГосИС Платформа 1С v8.3 Сложные периодические расчеты 1С:Зарплата и кадры государственного учреждения 3 Государственные, бюджетные структуры Россия Бюджетный учет Платные (руб)

Расширение конфигурации, включающее в себя объекты, необходимые для подготовки и сдачи отчета "Штатная численность" системы "БОР-Навигатор.Культура" в программе "1С:Зарплата и кадры государственного учреждения", редакция 3.1.

8400 руб.

01.02.2019    25687    9    0    

7

Интеграция с сервисом vetmanager

WEB-интеграция Платформа 1С v8.3 Бухгалтерский учет 1С:Бухгалтерия 3.0 Бытовые услуги, сервис Платные (руб)

Внешняя обработка разрабатывалась для загрузки документов из Ветменеджер в 1С: Бухгалтерия 3.0

12000 руб.

02.02.2021    16258    41    49    

22
Комментарии
В избранное Подписаться на ответы Сортировка: Древо развёрнутое
Свернуть все
1. Steelvan 302 08.08.16 10:28 Сейчас в теме
Что бы оно автономно работало, надо локально устанавливать apach или что-то подобное ?
2. unpete 577 08.08.16 10:36 Сейчас в теме
(1) Steelvan,
Что бы оно автономно работало, надо локально устанавливать apach или что-то подобное
Клиенту для автономной работы ничего устанавливать не надо.
Конфигурация сервера зависит от задачи. Если нужно совсем автономное рабочее место (например, учет личных финансов), работать может вообще без сервера - по аналогии с локальной файловой 1С.
3. Steelvan 302 08.08.16 11:02 Сейчас в теме
куда браузер будет локально обращаться ? По какому адресу ?
4. Steelvan 302 08.08.16 11:03 Сейчас в теме
Без сервера ? Подключение сразу к файлу 1CD ?
5. unpete 577 08.08.16 11:15 Сейчас в теме
(4) Steelvan,
Подключение сразу к файлу 1CD
При чем здесь 1CD? Metadata это не надстройка над 1С, а самостоятельный движок данных, который умеет бесшовно интегрироваться с 1С, если этого требует прикладная задача.
куда браузер будет локально обращаться ? По какому адресу ?
За данными, браузер у нас не "обращается адресу" а читает и пишет их в indexedDB
6. CheBurator 3119 08.08.16 12:28 Сейчас в теме
осталось расписать что такое nodejs
7. unpete 577 08.08.16 12:58 Сейчас в теме
(6) CheBurator,
осталось расписать что такое nodejs
Это вопрос, сарказм или предложение?
Через неделю планирую опубликовать статью "Helloworld на metadata.js" с пошаговыми инструкциями и примерами кода. Надеюсь, статья ответит на базовые вопросы.
Lostar; for_questions; vovan_victory; TreeDogNight; z86; dlebedev8; ZLENKO; pablo_escobar; Alien_job; Makushimo; akR00b; EliasShy; +12 Ответить
8. v3rter 08.08.16 13:37 Сейчас в теме
Гуглим:

http://www.oknosoft.ru/metadata/codex/#obj=0100&ref=&frm=&view=content
Штатно, решения на metadata.js работают по протоколу https. При использовании нешифрованного http, становятся недоступны функции serviceWorkers, но в остальной части, приложение остается работоспособным. В codex предприняты специальные усилия, чтобы примеры работали даже по протоколу file. Скопируйте и разархивируйте файлы https://github.com/oknosoft/metadata.js/archive/master.zip в любую папку на локальном компьютере и откройте файл index.html из корневого каталога.


Примеры https://github.com/oknosoft/metadata.js/tree/master/examples/unf

Особенности: http://www.oknosoft.ru/metadata/
Для некоммерческих Open Source проектов доступна лицензия AGPL-3.0
Коммерческая лицензия на разработчика стоит €300 и позволяет использовать и распространять ПО в любом количестве неконкурирующих продуктов, без ограничений на количество копий


10. unpete 577 08.08.16 14:20 Сейчас в теме
(8) v3rter,
Штатно, решения на metadata.js работают по протоколу https
Имеется в виду транспорт для синхронизации с сервером. Понятно, что в автономном режиме https не используется, т.к. сервер недоступен
Посмотреть примеры полезно, но они для движка версии v0.9 - конец 2015 года. Полноценная автономная работа появилась в v0.10 - март 2016. Актуальная версия v0.11.
Для некоммерческих Open Source проектов доступна лицензия AGPL-3.0
Если ваш проект с открытым кодом - покупать лицензии не требуется.
Для коммерческих проектов нужны наши лицензии плюс лицензии задействованных библиотек: dhtmlx и handsontable
Важно: все лицензии на разработчика. Их можно использовать для неограниченного числа автоматизируемых рабочих мест на неограниченном количестве серверов.
9. igo1 266 08.08.16 14:15 Сейчас в теме
Не очень понятно, но зерно интереса есть.
11. MishaD 14 08.08.16 19:29 Сейчас в теме
Посмотрел Демо на https://jsfiddle.net . Слева структура метаданных, справа отображение. А между ними огромный пустой кусок. Причем если потянуть разделитель влево, то метаданные скрываются, а пустого места меньше не становится. Сверху предположительно есть кнопочки, но их не видно. Использую Яндекс браузер.
Прикрепленные файлы:
12. unpete 577 08.08.16 19:58 Сейчас в теме
(11) MishaD, Фрейм jsfiddle, действительно, портит разметку. Пример там опубликован, чтобы показать лаконичность клиентского кода. Его там всего 10-20 строчек.
Если открыть то же самое без jsfiddle-обёртки, разметка нормальная.
13. пользователь 08.08.16 20:06
(0)
Еще год назад примерно смотрел ваш продукт Metadata.js, интересная реализация, даже для экспериментов делал у себя некоторые доработки. Но вопрос - какая лицензия? На каких условиях распространяется продукт?

Этот вопрос меня останавливал использовать его в продакшене у клиентов.
15. capitan 2461 08.08.16 21:57 Сейчас в теме
(13) YPermitin,
18000 рублей
Но!
в состав Metadata.js входит dhtmlx цена на который для проектов больше 1 - от 1000 у.е.
К тому же в лицензии написано :Распространение ПО в составе продуктов, являющихся конкурентами metadata.js, или обладающих схожей с функциональностью - запрещено
То есть вместе с 1С ее нельзя использовать.
Solovyeff; +1 Ответить
26. unpete 577 09.08.16 09:19 Сейчас в теме
(15) capitan,
входит dhtmlx цена на который для проектов больше 1 - от 1000 у.е.

  • В коммерческую лицензию метадата не входят лицензии dhtmlx и handsontable
  • metadata умеет работать на сервере или в браузере без визуализации. В этом случае, dhtmlx и handsontable не нужны. Вы можете манипулировать объектами данных с помощью metadata, а показывать их пользователю с помощью своего кода
  • для opensource проектов работает agpl, по которой ничего покупать не надо


31. capitan 2461 09.08.16 12:22 Сейчас в теме
(26)
В коммерческую лицензию метадата не входят лицензии dhtmlx и handsontable
metadata умеет работать на сервере или в браузере без визуализации. В этом случае, dhtmlx и handsontable не нужны.

Если я буду работать на сервере без визуализации, я просто из 1С впишу/прочитаю данные в БД.
Это будет по крайней мере безопаснее, нежели использовать такую прослойку как у вас. И абсолютно точно не съест лицензий, кроме серверной.
А отобразит их веб программист с помощью своего кода.
Народ то возбуждается как раз на отображение в виде аля 1С, а оно стоит как серверная лицензия 1С.
для opensource проектов работает agpl, по которой ничего покупать не надо

Приведите пожалуйста пример opensource проекта на 1С.
Кстати. Прошел год с вашего доклада и насколько я вижу на всех значимых форумах по 1С вы тогда отписались.
Есть Success Stories успешных внедрений?
Дилеры оконных заводов не в счет, им то я понимаю в добровольно/приказном порядке систему внедрили.
depresnjak; 33lab; Solovyeff; +3 Ответить
33. unpete 577 09.08.16 12:49 Сейчас в теме
(31) capitan,
просто из 1С впишу/прочитаю данные в БД
Если вы предпочитаете вместо документов, регистров и справочников оперировать сырыми записями БД, metadata в этом, конечно, не поможет.
Программист в metadata не использует XHR и не работает с DOM. Он пишет обработчики событий "при создании", "при изменении реквизита", "перед записью" и т.д. в модулях объектов и менеджеров
Народ то возбуждается как раз на отображение в виде аля 1С
Давайте не будем фантазировать, от чего возбуждается народ и предоставим возможность использовать в работе те инструменты, которые он сочтет удобными для своих задач.
В заголовке написано: "Движок ссылочной типизации" - ни слова про "отображение"
Метадата умеет рисовать интерфейс, но в этом она не оригинальна. Есть сотни библиотек про рисование интерфейсов.
Зато, библиотек про оффлайн/онлайн данные с методами и свойствами, как в 1с, я в интернете не нашел.
40. unpete 577 10.08.16 10:12 Сейчас в теме
(31) capitan,
Success Stories успешных внедрений?
https://www.npmjs.com/ устроит? Обрабатывает 500 млн. запросов в сутки, до 10 тыс. запросов в секунду. Каталог 380 тыс. записей. Наверняка, вы и сами использовали npm в работе. На сервере они используют примерно ту же математику, что и в metadata. Или эта story недостаточно success?
96. KAV2 156 03.08.18 07:24 Сейчас в теме
(26) На Гитхаб указано что исходники Metadata.js распространяются под лицензией MIT, это означает что можно копировать изменять и использовать в коммерческих проектах (со ссылкой на автора) совершенно бесплатно без каких-либо ограничений, верно?
97. unpete 577 03.08.18 07:35 Сейчас в теме
28. unpete 577 09.08.16 10:03 Сейчас в теме
(13) YPermitin,
Но вопрос - какая лицензия? На каких условиях распространяется продукт?

Приложения на metadata.js умеют работать в разных режимах:
  • Распределенная система - в этом режиме, CouchDB реализует шину данных, к которой подключены веб-клиенты и одна или несколько ИБ 1С. Базы могут быть разной структуры и располагаться в разных датацентрах. Репликация с 1С выполняется в фоновых заданиях
  • Клиент-серверный режим без 1С - в этом режиме, используем ту же шину данных, но 1С к ней не подключена рантайм. Обмен с 1С может выполняться отдельными обработками
  • Локальный однопользовательский режим без 1С - отдельный компьютер или мобильное устройство без доступа к сети. Обмен с внешним миром через дискету или флешку
  • Лёгкий клиент 1С - должны быть опубликованы http-сервисы 1С. Веб-приложение обращается напрямую к серверу 1С. В этом (и только в этом) режиме, требуются клиентские лицензии 1С по числу одновременно выполняющихся запросов. Не путать с количеством клиентов, в браузерах которых открыто веб-приложение. Технически, лицензии не нужны. Сервер 1С из пула лицензий при работе http-сессии ничего не откусывает. Юридически, в разных документах у 1С на этот счет разные толкования. Я вёл переписку с отделом лицензирования 1С. Внятного официального ответа так и не получил. Думаю, если возникла потребность именно в лёгком клиенте, проще эти 1С-ные лицензии просто купить. Не такая уж это большая сумма на фоне общей стоимости проекта
Теперь, про лицензии на разработчика:
  • AGPLv3 - имеете право ничего никому не платить, но обязаны предоставить по первому требованию исходные тексты всего вашего проекта, плюс, обязаны упомянуть в титрах все использованные библиотеки. Проект может быть коммерческим, Вы можете брать деньги за лицензии и сопровождение. Главное, соблюсти два условия: открытый код + упоминания авторов
  • Коммерческая лицензия - наша лицензия стоит 18 тыс. руб. на разработчика и позволяет выпускать и тиражировать прикладные решения с закрытым кодом. Решения не должны конкурировать с самим движком metadata. Например, будет незаконно переименовать метадату в ala1c, изменить стили оформления и выдавать за свою разработку. Кроме нашей коммерческой лицензии, потребуются коммерческие лицензии всех остальных, задействованных в вашем проекте библиотек (их состав зависит от вашего проекта)
32. пользователь 09.08.16 12:28
(28) спасибо за развернутый ответ.

Думаю продукт стоит внимания.
Не знаю как у других, но для решения моих задач его использовать можно даже с учетом лицензирования по AGPL.

Если правильно понимаю, то pull-request'ы на GitHub разрешены и приветствуются? =)
34. unpete 577 09.08.16 12:51 Сейчас в теме
(32) YPermitin, Конечно, приветствуются с благодарностью.
14. capitan 2461 08.08.16 21:47 Сейчас в теме
Есть много проектов, которым я неистово аплодирую за их оригинальность..
Но противопоставлять себя грандам... да еще на сайте сообщества 1С :)
Сколько не занижай приору, ламборджини из нее не выйдет.
Кроме метаданных, под капотом 1С достаточно серьезные решения.
Команда программистов, постановщиков задач и т.п.
И до вас и после будут проекты пытающиеся оперировать бизнес-объектами.
Тырить логику конфигурации у 1С дело не хитрое.
Собственно в этом и все совмещение вашей платформы и 1С ?
24. unpete 577 09.08.16 09:10 Сейчас в теме
(14) capitan,
противопоставлять себя грандам
В чем противопоставление?
Я в каждом абзаце подчеркиваю, что если некая задача хорошо решается в 1С, не надо тратить время на метадату.
Я не предлагаю заменить метадатой настольную 1С. Напротив, предлагаю распространить подходы 1С в большой веб и мобильные приложения.
Там реально непаханое поле и сообщество 1С могло бы эффективно на этом поле поиграть.
Тырить логику конфигурации у 1С
Такую предъяву неплохо бы обосновать. Что именно я стырил?
Собственно в этом и все совмещение вашей платформы и 1С
Бесшовная интеграция - одна из, но не единственная и не главная функция 1С.
Если бы Вы дали себе труд посмотреть в исходники, Вам бы тоже очень понравилось, как эта интеграция устроена изнутри
70. Designer1C 445 18.10.17 16:00 Сейчас в теме
(14)При всей команде программистов, постановщиков задач и других фирма 1С не в состоянии перекрыть открывающиеся при внедрении конфигураций задачи.
Например в 2005 - 2010 годах при повальном переходе с 1С:7.7 на конфигурации 1С:8 отсутствовала возможность качественного переноса данных.
В тот период пользовались регулярным спросом программы по переносу данных в УПП , ЗУП ,БП, УТ из ТиС, Комплексной, ЗиК, Бух-7.7
Да, прошло время и 1С наконец-то сделали свои рабочие версии переносов данных
При этом несколько лет им было просто не до этого.
А работать надо.
16. Solovyeff 09.08.16 00:10 Сейчас в теме
Задумка очень интересная, давно присматриваюсь к JS (особенно Node.JS), но если capitan прав с суммарной стоимостью лицензии, то продукт совсем не дешев и вместе с разработкой для заказчика выйдет в очень круглую сумму, что в нынешнее время резко сужает круг заинтересованных лиц, опять же, вряд ли этот фактор может поспособствовать "голубому океану":).
P.S. Интересно было бы услышать комментарии автора насчет лицензии и конечно побольше примеров работы с metadata.js
30. unpete 577 09.08.16 10:25 Сейчас в теме
(16) Solovyeff,
продукт совсем не дешев
Там 2 человекогода работы - примерно 4000 человекочасов. Вы какую цену порекоменудете?
побольше примеров
спасибо, учту
35. Solovyeff 09.08.16 14:23 Сейчас в теме
(30)
Там 2 человекогода работы - примерно 4000 человекочасов. Вы какую цену порекомендуете?

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

P.S. Я однозначно не за халяву, сам программист., но очень любопытно узнать как человек/компания собирается создавать рынок, с таким отношением и стратегией)) Часто у вас потенциальные клиенты спрашивают сколько ваш труд стоит человекочасов и как они счастливые готовы за это платить? Опять же, 18 000 это копейки, я про "скрытые" лицензии. Насчет безопасности само собой вопрос открытый.. Но все равно, задумка хорошая и однозначно стоит наблюдать за эволюцией, кто знает может будет Angular в мире 1C)
36. unpete 577 09.08.16 15:56 Сейчас в теме
(35) Solovyeff,
может будет Angular в мире 1C
Аналогии не понял. Angular - он про манипуляции с DOM. Metadata - про ссылочные данные на клиенте, обработку событий объектов данных и прозрачную их синхронизацию с сервером и другими клиентами. Вроде, совсем разные задачи.
37. unpete 577 09.08.16 15:59 Сейчас в теме
(35) Solovyeff,
Насчет безопасности само собой вопрос открытый
А что не так с безопасностью? Для транспорта используем только шифрованный https. Или Вы какую-то другую безопасность имеете в виду?
38. unpete 577 09.08.16 19:11 Сейчас в теме
(35) Solovyeff,
1С знаете сколько человекочасов потратило на свой продукт
Про часы не знаю, но сравним для примера метод Итог() в 1С и нашей табличной части.
Цитата из синтакс-помощника:
Итог (Total)
Синтаксис:
Итог(<Колонка>)
Параметры:
<Колонка> (обязательный)
Тип: Число; Строка.
Индекс либо имя колонки, по которой подсчитывается итог.
Возвращаемое значение:
Тип: Число; Неопределено.
Описание:
Суммирует значения всех строк в указанной колонке.

Цитата из API metadata:
aggregate ( [dimensions] [resources] [aggr] [ret_array] ) Number | Array
Вычисляет агрегатную функцию по табличной части
Не изменяет исходный объект. Если пропущен аргумент aggr - вычисляет сумму.
Стандартные агрегаторы: SUM, COUNT, MIN, MAX, FIRST, LAST, AVG, AGGR, ARRAY, REDUCE
AGGR - позволяет задать собственный агрегатор (функцию) для нестандартного расчета итогов
Параметры:
[dimensions] Array | String optional - список измерений
[resources] Array | String optional - список ресурсов
[aggr] String optional - агрегатная функция
[ret_array] Boolran optional - указывает возвращать массив значений
Возвращает:
Number | Array:
Значение агрегатной фукнции или массив значений
17. goldencity178 8 09.08.16 06:03 Сейчас в теме
В яндекс браузере дофига корявостей с отображением страниц, С гугла его содрали быстро, но не доработали с полем HTML поэтому скорее всего и есть глюк самого яндекс браузера.
18. goldencity178 8 09.08.16 06:05 Сейчас в теме
подходит скорее для групп объединенных компаний и холдингов, инвесторов и даже крупных Российских банков
29. unpete 577 09.08.16 10:10 Сейчас в теме
(18) goldencity178,
холдингов, инвесторов и даже крупных Российских банков
Представители СБ РФ вели со мной переговоры про фронт на metadata, но потом соскочили - якобы их служба безопасности не одобрила
42. dlebedev8 10.08.16 13:40 Сейчас в теме
(29) ай-яй-яй, как нехорошо вы поступаете, что разглашаете тайну коммерческих переговоров. Правильно они сделали, что соскочили.
43. unpete 577 10.08.16 15:44 Сейчас в теме
(42) dlebedev8,
Правильно они сделали, что соскочили
Правильно для кого? Для акционеров, которые получат меньше прибыли, для работников, которые остались без эффективных рабочих мест или для клиентов, которые будут дольше стоять в очереди?
47. capitan 2461 10.08.16 18:07 Сейчас в теме
(43)
Правильно для кого?

Для клиентов, деньги которых они хранят.
В курсе сколько access incident у сбера в день ?
У меня есть по Kiwi данные например.
И сколько их у вас, если такая статистика ведется.
19. goldencity178 8 09.08.16 06:18 Сейчас в теме
"К тому же в лицензии написано :Распространение ПО в составе продуктов, являющихся конкурентами metadata.js, или обладающих схожей с функциональностью - запрещено
То есть вместе с 1С ее нельзя использовать. "
Распространение - это продажа и реализация, а не эксплуатация. Использовать можно так как в предложении : "Распространение ПО в составе продуктов, являющихся конкурентами metadata.js, или обладающих схожей с функциональностью - запрещено" - здесь идет запрет о совместной продаже и с юридической точки зрения запрет совместного распространения и запрет эксплуатации - НЕ ОДНО И ТОЖЕ
20. goldencity178 8 09.08.16 06:29 Сейчас в теме
Продавать на сайте или в интернет магазине можно как различные и отличающиеся друг от друга продукты и в коммерческом предложении прописывать как рекомендуемый для совместной работы продукт. но в одном программном продукте не распространять, как и прописано в лицензии.
В 1С Сделайте документ "Коммерческое предложение" состоящее из 2 различных частей.
1. Товары и услуги.
2. Рекомендуемые дополнения.

в 1 прописывается основной комплекс предлагаемых товаров и работ, оказываемых услуг, а во второй сделаете рекомендуемые для совместной работы, которые заказчик может в дальнейшем приобрести. В таком порядке условия соглашения никак не нарушаются и согласно пункту такому-то о :
"Распространение ПО в составе продуктов, являющихся конкурентами metadata.js, или обладающих схожей с функциональностью - запрещено" условия полностью соблюдаете. юридически это граммотно и более целесообразно. 1С выступал бы не как продукт в составе основного комплекта ПО, являющихся конкурентами metadata.js, или обладающих схожей с функциональностью, а лишь как рекомендуемое дополнение.

Ситуация довольно примитивная, но позволяет обойти условия не нарушая при этом таковые вышеизложенные условия лицензии.
21. goldencity178 8 09.08.16 06:36 Сейчас в теме
Если у вас есть в движке сайта возможность добавлять к продаваемым сопутки, сделайте их как рекомендуемые, условия "Распространение ПО в составе продуктов, являющихся конкурентами metadata.js, или обладающих схожей с функциональностью - запрещено" вы не нарушаете, если в языковом файле движка магазина вместо сопутки написать рекомендую дополнение, то это хороший вариант. все условия соблюдены и юридически довольно граммотно.

Юристы верят бумажкам и доказательствам, а не словам
22. ardn 620 09.08.16 08:15 Сейчас в теме
metadata.js можно оформить в виде приложения для смартфонов (android)?
23. unpete 577 09.08.16 08:58 Сейчас в теме
(22) ardn, Конечно.
Если по каким-то причинам не устраивает исполнение программы внутри браузера, приложение можно скомпилировать с помощью cordovaв нативное для ios и android, а с помощью electron - в нативное для windows, linux и osx
25. ardn 620 09.08.16 09:11 Сейчас в теме
Отлично
На гитхабе актуальные примеры? Хочу освоить ваш движок.
27. unpete 577 09.08.16 09:21 Сейчас в теме
(25) ardn,
На гитхабе актуальные примеры

Примеры драматически старые. В ближайшие недели запланирована публикация новых примеров + статья с пошаговыми инструкциями для быстрого старта
KRJ; peterg; z86; chek.e.l@mail.ru; ardn; +5 Ответить
56. unpete 577 11.08.16 13:35 Сейчас в теме
(27)
Примеры драматически старые
Опубликовано новое описание Hello world на metadata.js
TreeDogNight; ardn; +2 Ответить
39. detec 136 10.08.16 09:42 Сейчас в теме
Идея хорошая, примеры выглядят прилично. Думаю, это может взлететь на зарубежных рынках.
41. capitan 2461 10.08.16 12:48 Сейчас в теме
На сервере они используют примерно ту же математику, что и в metadata

Угу.
Я распечатываю список контрагентов и в газпроме распечатывают список контрагентов.
Значит я работаю в газпроме.
На вашей системе кроме вас кто то еще создал коммерческие решения или год пиару прошел зря ?
44. FSerg 66 10.08.16 16:15 Сейчас в теме
Больше года назад перед конференцией инфостарта - я смотрел ваш продукт.
Я не понимаю, почему так много скептических комментариев или придирок к цене.
Классный высоко-технологичный проект!
И есть множество задач, когда нужно дать пользователю простой интерфейс со связью с 1С и в идеале чтобы просто в браузере работало на чем угодно.
45. unpete 577 10.08.16 16:23 Сейчас в теме
(44) FSerg,
в идеале чтобы просто в браузере работало на чем угодно
Завтра опубликую статью с пошаговой инструкцией helloworld с автономной работой в браузере.
Пишу этот ответ, чтобы подстегнуть работы по демо-примеру. Заставить себя работать трудно, но обещание придется исполнять
почему так много скептических комментариев
Мне это тоже интересно. И еще, хочется инженерной критики по существу. Например, "у тебя здесь утечки памяти" или "тут лишний цикл" или "это разыменование можно сделать проще и красивее"
46. capitan 2461 10.08.16 18:00 Сейчас в теме
И есть множество задач, когда нужно дать пользователю простой интерфейс со связью с 1С и в идеале чтобы просто в браузере работало на чем угодно.

Где эти задачи ?
Вы отделяйте мух от котлет.
Есть веб программисты, они привыкли к своим языкам программирования и своей среде исполнения.
Есть программисты 1С у них свой язык программирования и своя среда исполнения.
Стыковка происходит элементарным обменом, формат стандартизован.
А вы почему то считаете, что сайты должен делать 1С ник ?
Это так же непросто, там есть свои тонкости, не говоря уже об элементарной безопасности.
Этот проект никто не ломает потому лишь, что на нем никто не работает.
Это если говорить о "простой интерфейс со связью с 1С"
А если говорить о проекте как об учетной системе, то уверяю вас их сотни и большая часть тоже имеет встроенный конфигуратор.
Откройте любой каталог ПО
И все они стыкуются или будут стыковаться с 1С. И многие из них хотели бы здесь рассказать какие они классные.
48. unpete 577 10.08.16 18:27 Сейчас в теме
(46) capitan,
уверяю вас их сотни
Приведите, пожалуйста одну ссылку на систему, где есть автономная работа в браузере и ссылочная типизация.
Я с удовольствием сверну работы по метадата и приму участие в развитии более грамотного движка.
49. unpete 577 10.08.16 18:40 Сейчас в теме
(46) capitan,
Есть веб программисты, они привыкли к своим языкам программирования и своей среде исполнения
Вы сути моего предложения не услышали. У веб-программистов не получается сделать ни одного приличного сайта по двум причинам:
  • Они не понимают и не хотят понимать бизнес-процессов учета и управления
  • Они каждый раз изобретают велосипед на языке низкого уровня вместо того, чтобы воспользоваться такими бизнес-объектами, как документ и регистр
Вы исходите из предположения, что сложившиеся подходы к веб-разработке - удовлетворительны.
Что вебщики рисуют нормальные интернет-магазины и личные кабинеты.
Я утверждаю, что сегодняшние веб-решения изнутри - это Ад и Израиль.
Почитайте исходники хоть вордпресса, хоть битрикса, или, например, opencart.
Читать предлагаю недалеко от туалета - вас обязательно вырвет.
LexBond; djl; jONES1979; +3 Ответить
58. Steelvan 302 12.08.16 08:16 Сейчас в теме
(49)

Это Ад и Америка.
Американцы хуже евреев.

Интересно, как сейчас возбудятся те, кто там ни разу не бывал, но кто верит в сказочки что там рай :)
И заплачут, что я наступаю на их сказочные фантазии ;)
59. unpete 577 12.08.16 09:36 Сейчас в теме
(58) Steelvan, Выражение Ад и Израиль возникло еще во времена Иисуса и означает "просто ад"
60. unpete 577 12.08.16 09:44 Сейчас в теме
(58)(58) Steelvan, Мне кается, для обсуждения рассовых и политических вопросов есть специальные интернет-ресурсы. Зачем это на Инфостарте?
61. genayo 12.08.16 10:32 Сейчас в теме
(60) Не обращайте внимания, это местный дурачёк.
dour-dead; +1 Ответить
50. FSerg 66 10.08.16 21:45 Сейчас в теме
(46) capitan,

Где эти задачи?

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

Вы отделяйте мух от котлет.
Есть веб программисты, они привыкли к своим языкам программирования и своей среде исполнения.
Есть программисты 1С у них свой язык программирования и своя среда исполнения.

В том то и дело, что с каждым днем эта грань стирается! Есть крутые 1C-инженеры, которые знают/изучают Python, JavaScript, Docker и вот это вот все и есть посредственные, которых не интересует ничего дальше границ 1С.

Стыковка происходит элементарным обменом, формат стандартизован.

Обмен и реалтайм работа - сильно разная работа.

А вы почему то считаете, что сайты должен делать 1С ник?

ИМХО, речь в публикации вообще не о сайтах. Речь о решении, которое предлагает классный способ дать удобные web-интерфейсы к 1C.

Это так же непросто, там есть свои тонкости, не говоря уже об элементарной безопасности.

Ок, если страшно, начните использовать это в интранете, т.е. там где вы полностью контролируете инфраструктуру и периметр.
itriot11; +1 Ответить
51. unpete 577 11.08.16 08:57 Сейчас в теме
(50) FSerg,
Купите лицензий по числу партнеров?

Стоимость лицензий, конечно, имеет значение, но позиционирование у меня другое:
  • Metadata жрёт в 20 раз меньше трафика. Это инженерный факт. Оспаривать его бессмысленно. Как следствие, работает при плохой связи и даже в автономном режиме
  • У нас намного проще и надежнее серверная инфраструктура. Для обслуживания 1000 клиентов, CouchDB использует меньше ОЗУ и процессорного времени
  • Metadata предоставляет веб-программисту высокоуровневые объекты данных, прямого аналога которым просто нет в других фреймворках
Напомню лозунг: "если ваша задача хорошо решается в стандартной 1С - не надо тратить время на метадату"
52. unpete 577 11.08.16 09:16 Сейчас в теме
(46) capitan,
Где эти задачи ?
Таких задач, действительно, много.

Например, рабочее место контролера ОТК, где требуется регистрировать готовность изделия + наличие и характер дефектов. Обычные ТСД и сканер не годятся, т.к. дефекты надо привязать к элементу изделия. Решено использовать смартфон + bluetooth сканер. При сканировании этикетки, выводим на экран смартфона чертёж изделия с возможностью выделить любые элементы и указать в контекстном меню маршрут исправления.

Еще, есть цеховая безбумажка, где для отображения данных использованы бытовые телевизоры. Метадата прекрасно справляется с задачей, работая внутри встроенного в телевизор браузера.
Понятно, что этой реализации, предшествовали безуспешные попытки сделать то же самое в веб-клиенте 1С. Возможно, проблема в моей низкой квалификации, а может быть и в чем-то другом.
53. dlebedev8 11.08.16 10:10 Сейчас в теме
(52) да много есть разных задач, глупо об этом спорить. Кому надо, сами свяжутся и договорятся. Остальные будут и дальше критиковать и искать недостатки.

Не могли бы вы пояснить по лицензированию AGPL? Что именно вы причисляете к проекту, исходники которого должны быть открыты? Например, если делать личный кабинет дилера к конфигурации 1С: Управление торговлей (10 или 11)?
54. unpete 577 11.08.16 10:38 Сейчас в теме
(53) dlebedev8,
пояснить по лицензированию AGPL
Вот текст с сайта gnu.org на русском языке: https://www.gnu.org/licenses/why-affero-gpl.html
55. unpete 577 11.08.16 10:44 Сейчас в теме
(53) dlebedev8,
Например, если делать личный кабинет дилера
IMHO, будет достаточно открыть код клиентского приложения + код design-документов CouchDB
57. unpete 577 11.08.16 15:45 Сейчас в теме
(53) dlebedev8,
личный кабинет дилера к конфигурации 1С
По заказам онлайн/оффлайн для типовых УТ, КА, УПП, ERP - можем поработать совместно.
У меня есть заготовка https://github.com/oknosoft/order-online и живой демо-пример https://light.oknosoft.ru/orders/
Личные кабинены - это самое типовое и самое понятное назначение метадаты.
Еще, напрашиваются проекты "Розница" и "Мобильное рабочее место торгового представителя". По ним, так же, готов предложить совместную работу.
62. kodermax 12.08.16 11:14 Сейчас в теме
Идеи этого продукта мне очень понравились, сейчас идёт активное внедрение его в процесс заявок на закупку.
Технологии используемые в Metadata.js(NodeJs, CouchDB,...) это просто сказка, наконец-то современные технологии добрались до 1с)
Единственное, требуется активное сообщество для этого продукта, которое выстроит современную архитектуру, будет писать тесты, исправлять ошибки оперативно и добавлять красоту и новые функции.
TreeDogNight; unpete; +2 Ответить
63. user637563_alex 10.11.16 14:13 Сейчас в теме
Очень интересная работа! Желаю вам успехов!
Подскажите, для чего используется AlaSQL на стороне клиента? Ведь есть уже PouchDB..
64. unpete 577 10.11.16 14:53 Сейчас в теме
(63) user637563_alex,
для чего используется AlaSQL
AlaSQL выполняет две функции:
  • Хранение структурированных данных в озу браузера (быстрый синхронный кеш)
  • SQL интерфейс к этим данным
PouchDB отвечает за:
  • Хранение данных в indexeddb
  • Синхронизацию этих данных с CouchDB
65. ipoloskov 162 10.11.16 15:06 Сейчас в теме
66. PerlAmutor 129 21.07.17 06:37 Сейчас в теме
Скажу честно, очень устал от COM в 1С... Вроде как и кроссплатформенное уже все, но нет приходится мучаться в прямом смысле этого слова.
Почему за столько лет так и не создали обычную .dll'ку/.so для подключения к базам 1С? Зачем нужен "зоопарк" всех версий 1С и COMобъектов в системе, когда нормальные программисты все реализуют на уровне версий протоколов в одной компоненте, дорабатывая её с каждой новой версии и оставляя обратную совместимость. Даже мелкие утилиты размером в несколько десятков килобайт имеют встроенные https серверы (а иногда и целый ворох серверов) для возможности использования API, а 1С обязательно нужно использовать внешний Web сервер, с отдельным установленным плагином к этому типу сервера, чтобы хоть как-то задействовать тот же OData. Использование ActiveX InternetExplorer'a и разгребание косяков связанных с разными версиями браузера меня тоже убивает. Движки браузеров типа WebKit или Chromium внедряют в свои приложения уже со школьной скамьи... Это я пишу после недельной безуспешной попытки собрать win32ole на node.js в Windows 10/Windows7, чтобы хоть как-то их подружить. В итоге всё свелось к подключению через прекомпилированный "edge" для Node.js 6 версии, т.к. в 8 версии edge не собирается точно также. На выходе имеем плагин edge, который на языке JavaScript, передает коде на язык C#, который создает подключение к COM объекту 1С, чтобы использовать его на языке 1С... Это похоже на удаление зуба через задний проход.
ifilll; dmpas; YPermitin; +3 Ответить
67. unpete 577 21.07.17 10:20 Сейчас в теме
(66) Всё это очень мило, но не имеет отношения к теме статьи. Metadata нужна не для подключения к базе 1с, а для разработки на javascript с использованием 1с-подобных объектов. 1с в нашем сценарии используется только для прототипирования метаданных.
1c-intelligence; torbeev; +2 Ответить
68. sag33 18.10.17 08:40 Сейчас в теме
Да, идея хорошая!....Но учитывая, что 90% "оконных" дилеров не могут найти смысловой и правовой разницы между "поставкой товара" и "доставкой товара", то продвинутые решения для личным кабинетам не смогут быть реализованы на 100%...просто уровень знаний на стороны конечного пользователя (дилера) крайне низкий!
69. unpete 577 18.10.17 11:17 Сейчас в теме
(68) Да наплевать мне на дилеров. Я работаю с заводами, у которого этих дилеров от 300 (у больших - 600). Даю заводу инструмент, а с правовыми смыслами путь они сами разбираются.
71. dumsik 34 28.10.17 05:12 Сейчас в теме
Евгений, web приложение написанное с помощью metadata.js поддерживает адаптивный интерфейс или это уже нужно допиливать? Я имею ввиду разные размеры экранов мобильных устройств.
72. unpete 577 30.10.17 10:37 Сейчас в теме
(71)
адаптивный интерфейс
В версии v0.12 разметка статическая. Визуальная часть v2.0 опирается на material-ui - там с адаптивная разметка поддержана из коробки.
73. dumsik 34 16.11.17 16:07 Сейчас в теме
(72) запутался с номерами версий на github v.2.0 это как я понял v0.12.232 ?
74. unpete 577 17.11.17 09:53 Сейчас в теме
(73) v2 - это набор пакетов, расположенный в https://github.com/oknosoft/metadata.js/tree/master/packages и публикуемый в npm с помощью Lerna
75. dumsik 34 20.11.17 15:12 Сейчас в теме
(74) мало что понял :( буду разбираться. Евгений, скажите для программиста 1с который про web разработку знает только очень поверхностно порог вхождения в metadata.js большой?
76. unpete 577 20.11.17 18:09 Сейчас в теме
(75) С освоением метадаты не будет проблем в двух случаях:
1. Имеете негативный опыт разработки на традиционных веб-технологиях. Если за плечами есть внедренная самописная crm, cms или как минимум - интернет-магазин, вам будет проще воспринять наши идеи. Вы очень быстро увидите, что метадата позволяет экономить тысячи строчек кода и сотни часов вашего времени. С точки зрения веб, метадата - очень высокоуровневый инструмент.
2. Есть реальная задача, где требуется высокая доступность данных и которую не получается решить на 1С из-за ограничений платформы. Открыв метадату, вы будете опьянены безграничной свободой, по сравнению с 1С, метадата - очень низкоуровневый инструмент.
77. genayo 09.12.17 07:56 Сейчас в теме
Как вы планируете развивать продукт с учетом http://www.cnews.ru/news/top/2017-12-08_prilozheniya_dlya_chrome_prekratili_sushchestvovanie ? Или вы не этот вид приложения используете?
78. unpete 577 09.12.17 12:14 Сейчас в теме
(77) ChromeApp - это всего лишь способ поделиться ссылкой на вебприложение. Изменения в политике Google в отношении Web Store никак не отразятся на нашем проекте.
79. genayo 09.12.17 14:04 Сейчас в теме
В этой новости также вроде как говорится, что "Ранее установленные Chrome Apps все еще работают, однако браузер Chrome потеряет необходимую для этого функциональность уже в первом квартале 2018", это тоже никак не повлияет?
80. unpete 577 09.12.17 18:50 Сейчас в теме
(79)
потеряет необходимую для этого функциональность уже в первом квартале 2018
Это про другое, мы используем только то, что есть в стандарте EcmaScript и не привязаны к Chrome. Мы просто рекомендуем использовать Chrome, т.к. в нём стандарты ES поддержаны лучше, чем в других браузерах.
При желании, вы можете запустить приложение на метадате вообще не в браузере, а на любом устройстве с поддержкой js.
81. johnnyshut23 71 09.12.17 22:33 Сейчас в теме
Спасибо большое, полезно!
82. trdm 22.05.18 15:28 Сейчас в теме
для построения дешевых высоконагруженных сервисов

вместе эти 2 слова способны убить любого менеджера по продажам.
83. unpete 577 22.05.18 19:57 Сейчас в теме
(82)
убить любого менеджера по продажам
Так я, вроде, для программистов, а не для менеджеров работаю
84. 2ncom 82 06.07.18 22:20 Сейчас в теме
Очень интересно! Спасибо!
85. meteorit 41 19.07.18 14:32 Сейчас в теме
Евгений, добрый день!
Демо-пример "Hello, world" смоделировали, дошли до авторизации, авторизация под пользователем "Гость" прошла, но при переходе в список "Перемещение денег" выдает ошибку (скрин). Заранее спасибо за помощь!
Прикрепленные файлы:
86. unpete 577 19.07.18 19:44 Сейчас в теме
(85) Последние 4 года показали, что идея популяризации метадаты была ошибкой. Партнёров, разделяющих мои ценности не нашлось, а задачу, сделать из нашей библиотеки инструмент для народа, мне в одиночку не решить. Сожалею, что отнял у вас время.
87. CheBurator 3119 19.07.18 20:03 Сейчас в теме
(86) НАРОДУ - нужен не инструмент, а готовые решения. Или инструмент "из коробки", по запуску которого из коробки получится готовое решение.
создавать еще один инструмент в довесок или как альтернативу или к уже существующей технологии - это интересно только для чистых программеров. В нашей (1Сной) области - чистым программеров предложенный инструмент - не интересен потому, что "чистые" 1С-программеры влияния на бизнес-процессы и выстраивание архитектуры - не имеют (нагружать себя лишним инструментарием, неприменяемым в области зарабатывания денег это или непродуктивно или только хобби). А бизнес-программисты 1С - им этот дополнительный инструмент вообще побоку. им хватает головняка и с платформой, и с конфами, и с бизнес-вопросами.

Итого: невнятное позиционирование для ШИРОКИХ масс не дало результата.
Как-то так я себе представляю.
88. yogaga 19.07.18 20:18 Сейчас в теме
(86) Да ладно, "делай что должно, и будь что будет"
89. meteorit 41 19.07.18 21:21 Сейчас в теме
(86) Спасибо за ваш ответ! Т е демо-пример не рабочий, получается?
Как я понимаю, IndexedDB нужна только для оффлайн-режима работы в браузере, может быть ее можно как-то отключить тогда и запустить только онлайн?
90. yogaga 19.07.18 21:38 Сейчас в теме
(89) Вы бы на гитхаб метадаты сходили, чтоли...
93. meteorit 41 20.07.18 13:23 Сейчас в теме
(90) Мы как раз оттуда пришли и делали установку последней сборки:
https://github.com/oknosoft/metadata.js/tree/develop/packages
94. пользователь 20.07.18 13:55
Сообщение было скрыто модератором.
...
95. yogaga 22.07.18 08:39 Сейчас в теме
(93) Хммм... я же отвечал на это сообщение...
91. unpete 577 19.07.18 23:12 Сейчас в теме
Позиционирование было очень внятным. Я искал людей, желающих вложиться в разработку правильных инструментов. Почему возникло мнение, что я что-то кому-то предлагаю - не понятно.
Итог, в целом - хороший. Голубой океан никуда не делся. Внешних и внутренних проектов хватит на пять жизней. Внедрённые на метадате решения подтвердили высокую эффективность выбранных технологий.
1С хвастается проектами на 1000 пользователей и считает это highload. Сейчас, мы работаем над проектом с плановой нагрузкой в миллион подключений и нет сомнений, что проект будет успешно реализован.
92. CheBurator 3119 19.07.18 23:44 Сейчас в теме
(91) это хорошо, держите в курсе, интересно
98. alexey.kutya 301 14.11.18 13:44 Сейчас в теме
Евгений, а смотрели в сторону openui5? Попытка SAP создать свой opensource framework для web. Интересный опыт. Есть статья с дискуссией о будущем этого проекта Статья. Это конечно не совсем то, что вы сделали, но есть и что-то общее.

По поводу веб-клиента 1С полностью согласен. Неуклюжий, тормозной, морально устаревший. Также удручает способ реализации асинхронных методов 1С.

Выводы: такие opensource проекты, как react, angular, node и пр. находятся на острие web developments и поддерживаются всемирным сообществом. Будут появляться новые. Попытки создать фрэймворки заточенные под конкретные задачи всегда будут иметь очень узкое локальное применение и всегда будут иметь риски морального устаревания и субъективного подхода. В результате можно пойти не той дорогой. Такие гиганты как SAP имеют право на ошибку. Отдельным энтузиастам сложнее в этом плане.

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

P.S. Это лично мое субъективное мнение, никак не претендующее на истину.
P.P.S. И да, проблема пользовательского интерфейса существует, и пока нет решения. Каждый пытается решать по своему. Понятно, что надо смотреть в сторону web технологии, как наиболее универсальной в данный момент. SAP в этом плане пошел дальше 1С, но и сравнивать их возможности некорректно.
P.P.P.S. Вам респект за такой подвиг и желание создавать продвинутые решения. Возможно еще не время для широкого принятия этой идеи. Корпоративный сектор очень консервативен в своих решениях.
Steelvan; +1 Ответить
99. unpete 577 14.11.18 16:41 Сейчас в теме
(98) я общего не вижу. Метадата - про распределенные ссылочно-типизировпнные данные. У нас есть немного UI, но качество визуальной подсистемы - так себе.
Оставьте свое сообщение