Обработка с интеграцией под различные конфигурации (Реализация паттерна Стратегия обработками в макетах)

10.02.26

Разработка - Инструментарий разработчика

После курса "Чистый код на 1С" и знакомства с паттернами GoF в контексте разработки на 1С я действительно стал замечать их в проектах, над которыми работал. Осознал, что уже использовал паттерны при разработке ещё на платформе 7.7, а уж в восьмёрке их можно встретить во многих местах. Вести разработку в конфигурации или в расширении не сложно, там для этих целей доступно множество подходящих объектов. Например, паттерн Стратегия можно реализовать на общих модулях или обработках. А как быть, если разрабатываешь внешнюю обработку? Постараюсь продемонстрировать на примере моей абстрактной обработки СозданиеЗаказов.epf. Аналогичный подход я видел в модуле 1С одного одного известного оператора ЭДО. Мой экспериментальный проект попроще, но и предназначен он для демонстрации возможности использования обработок в макетах.

Файлы

ВНИМАНИЕ: Файлы из Базы знаний - это исходный код разработки. Это примеры решения задач, шаблоны, заготовки, "строительные материалы" для учетной системы. Файлы ориентированы на специалистов 1С, которые могут разобраться в коде и оптимизировать программу для запуска в базе данных. Гарантии работоспособности нет. Возврата нет. Технической поддержки нет.

Наименование Скачано Купить файл
Обработка с интеграцией под различные конфигурации (Реализация паттерна Стратегия обработками в макетах):
.epf 33,32Kb
0 2 500 руб. Купить
Обработка с интеграцией под различные конфигурации (Реализация паттерна Стратегия обработками в макетах):
.dt 45,07Kb
0 6 200 руб. Купить

Подписка PRO — скачивайте любые файлы со скидкой до 85% из Базы знаний

Оформите подписку на компанию для решения рабочих задач

Оформить подписку и скачать решение со скидкой

На текущем месте работы я занимаюсь разработкой как раз такой внешней обработки, предназначенной для интеграции сервиса компании с различными конфигурациями клиентов. Это и типовые семейства ERP/КА2/УТ11, и их более старые версии на обычных формах УТ10/КА1.1, семейство УНФ/Розница, а также другие решения, основанные на перечисленных типовых и оригинальных тиражных решениях. Поддерживается даже работа с собственными уникальными конфигурациями (нетленки) с возможностью реализовать интеграцию самостоятельно.

 
 Под спойлером делюсь сложностями при разработке этого решения

 

Как паттерны нам могут помочь при разработке внешней обработки с интеграцией под разные конфигурации?

Вспомним паттерн Стратегия. Он позволяет для одного и того же Контекста реализовать различные Стратегии. Верно?

Давайте представим нашу внешнюю обработку Контестом (я не стал выделять Контекст в отдельную сущность для упрощения). Наша обработка знает, что хочет сделать в базе. Например, создать Заказ клиента. Но она может позволить себе не знать, что в конкретной конфигурации этот документ называется _ДемоСчетНаОплатуПокупателю. Ей это и не интересно.

Тогда интеграция с каждой конфигурацией - это Стратегия. Каждая Стратегия интеграции может реализовать создание Заказа клиента в своей конкретной конфигурации, потому что именно для этого и создана.

Мы разрабатываем внешнюю обработку, поэтому стратегии мы тоже можем реализовать на внешних обработках. Эти стратегии можно хранить в макетах двоичных данных нашей основной обработки.

Итак, познакомимся с нашей внешней обработкой СозданиеЗаказов.epf

В ней есть две формы: Форма (обычная) и ФормаУправляемая, назначенные соответственно основной и дополнительной формами.

Обработка содержит реквизиты Отладка и ПараметрыКонтекста - служебные для нашего контекста. Реквизиты Контрагенты, ДатаДокумента и СсылкаНаСозданныйЗаказ, а также табличная часть Товары - прикладные. Все они (кроме Отладки) служат для подготовки данных контекста, чтобы передать их в нужную стратегию.

 

 

Самое интересное для нас то, что в макетах ИнтеграцияКаркаснойКонфигурации, ИнтеграцияДемоБСП и ИнтеграцияЗаказыКлиентовОФ хранятся внешние обработки для интеграции с конфигурациями.

В табличном макете МанифестОбъектов хранится описание для всех макетов обработки. Он очень важен. С его помощью обработка определяет какую стратегию использовать и из какого макета её взять.

 

Логика работы форм простая.

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

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

 
 Создание заказа из обработки

 

Посмотрим как происходит обращение к нашим стратегиям.

При открытии обработки в событиях ПриСозданииНаСервере() в управляемых или ПередОткрытием() в обычных формах выполняется подготовка контекста обработки: восстанавливаются сохраненные настройки (значение флага Отладка) и инициализируются параметры контекста. Помните про реквизит ПараметрыКонтекста? Как раз в нем мы запоминаем АдресМодуляИнтеграции, подключенного как внешняя обработка из макета или сохраненного в одном каталоге с главной обработкой.

 

Первое обращение к модулю интеграции (нашей стратегии)

Тут же вызывается первый метод нашей стратегии для получения типов данных. Наша основная обработка не знает в каком справочнике конфигурации хранятся Контрагенты и Номенклатура. Как и не имеет ни малейшего понятия о виде документа. Поэтому реквизит обработки Контрагент и реквизит ТЧ Номенклатура имеют тип СправочникСсылка, а реквизит обработки СсылкаНаСозданныйЗаказ - ДокументСсылка.

 
 Инициализация

Точные типы данных нам и сообщает наша Стратегия. При этом она имеет доступ к Контексту через переменную своего модуля ГлавныйКонтекст, в котором хранится объект нашей основной обработки.

А значит, может напрямую изменять реквизит обработки ПараметрыКонтекста(тип Структура), в частности, заполнив его свойство ТипыДанныхДляРеквизитов.

 
 Определение типов данных из модуля интеграции

После инициализации параметров контекста в событии формы ПриОткрытии() устанавливаются соответствующие ограничения типов для элементов формы.

 
 Применение типов полученных из интеграции для реквизитов формы

 

Второе обращение к стратегии

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

 
 Цепочка вызовов для создания заказа в базе данных

 

Как это добро отлаживать и дорабатывать?

Главное, что нужно - это заранее включить Отладку в обработке и выгрузить обработки из макетов.

 
 В Конфигураторе ничего особенного настраивать не нужно.
 
 В EDT я использовал следующую организацию проекта.

 

Как добавить новый модуль интеграции для ещё одной конфигурации?

 
 Легко
 

 

Какие выгоды мы получаем от такой реализации?

  • Теперь мы не нарушаем стандарт #std669.
  • Легко дорабатывать и отлаживать интеграции.
  • Просто добавить интеграцию с новой конфигурацией.
  • Можно вести параллельную разработку разных интеграций (с использованием различных систем контроля версий).
  • При необходимости модули интеграции (Стратегии) можно использовать в другой обработке (Контексте). Например, обработка для загрузки заказов из внешней системы, которая работает в регламентном задании.
  • Для каждого модуля интеграции можно написать отдельные юнит-тесты.
  • Если основная обработка должна поставляться без исходных кодов или с обфускацией, то модули интеграции можно оставить открытыми для доработки и даже добавлять новые под конкретную конфигурацию.
  • Проще перейти на разработку в EDT, но и в Конфигураторе разрабатывать удобней.
  • Использование EDT открывает дополнительные возможности в виде проверки на лету, строгой типизации и доступа к 1С:Напарник.

 

 
 Известные проблемы и их решение

 

Проект и все обработки, а также выгрузку базы крутейшейтестовой конфигурации ЗаказыКлиентовОбычныеФормы можно скачать на GitHub.

 
 Скриншот ветки master репозитория проекта на GitHub

Если данная статья будет вам полезна и захочется меня поддержать, можете сделать это скачиванием файлов.

Проверено на следующих конфигурациях и релизах:

  • 1С:Библиотека стандартных подсистем, редакция 3.1, релизы 3.1.11.309

Вступайте в нашу телеграмм-группу Инфостарт

Обработки Интеграции Внешняя обработка в макете Стандарты Паттерны Стратегия EDT Конфигуратор GIT

См. также

Инструментарий разработчика Чистка данных Свертка базы Инструменты администратора БД Системный администратор Программист Руководитель проекта 1С:Предприятие 8 1С:ERP Управление предприятием 2 1С:Бухгалтерия 3.0 1С:Управление торговлей 11 1С:Комплексная автоматизация 2.х 1С:Управление нашей фирмой 3.0 Россия Платные (руб)

Инструмент представляет собой обработку для проведения свёртки или обрезки баз данных. Работает на ЛЮБЫХ конфигурациях (УТ, БП, ERP, УНФ, КА и т.д.). Поддерживаются серверные и файловые базы, управляемые и обычные формы. Может выполнять свертку одновременно в несколько потоков. А так же автоматически, без непосредственного участия пользователя. Решение в Реестре отечественного ПО

24900 руб.

20.08.2024    59053    314    157    

285

Инструментарий разработчика Роли и права Запросы СКД Программист Руководитель проекта 1С:Предприятие 8 Платные (руб)

Инструменты для разработчиков 1С 8.3: Infostart Toolkit. Автоматизация и ускорение разработки на управляемых формах. Легкость работы с 1С.

16500 руб.

02.09.2020    242703    1324    419    

1118

Инструментарий разработчика Нейросети Платные (руб)

Первые попытки разработки на 1С с использованием больших языковых моделей (LLM) могут разочаровать. LLMки сильно галлюцинируют, потому что не знают устройства конфигураций 1С, не знают нюансов синтаксиса. Но если дать им подсказки с помощью MCP, то результат получается кардинально лучше. Далее в публикации: MCP для поиска по метаданым 1С, справке синтакс-помошника и проверки синтаксиса.

15250 руб.

25.08.2025    38816    78    19    

91

Пакетная печать Печатные формы Инструментарий разработчика Программист 1С:Предприятие 8 1С:Зарплата и кадры бюджетного учреждения 1С:ERP Управление предприятием 2 1С:Управление торговлей 11 1С:Библиотека стандартных подсистем Платные (руб)

Расширение для создания и редактирования печатных форм в системе 1С:Предприятие 8.3. Благодаря конструктору можно значительно снизить затраты времени на разработку печатных форм, повысить качество и прозрачность разработки, а также навести порядок в многообразии корпоративных печатных форм.

22570 руб.

06.10.2023    34690    87    35    

112

Инструментарий разработчика Программист 1С:Предприятие 8 Платные (руб)

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

9500 руб.

17.05.2024    48618    167    63    

204

Инструменты администратора БД Инструментарий разработчика Роли и права Программист 1С:Предприятие 8 1C:Бухгалтерия Россия Платные (руб)

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

17000 руб.

10.11.2023    23362    84    42    

98

Разработка Инструментарий разработчика Работа с интерфейсом Адаптация типовых решений Нейросети 1C:Бухгалтерия 1C:ERP 1С:ЗУП 1С:КА 1С:УНФ 1С:УТ 1С:Розница 1С:ДО 1С:ERP Управление предприятием 2 Платные (руб)

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

36600 руб.

28.08.2025    5743    2    2    

5
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. ixijixi 2101 10.02.26 12:43 Сейчас в теме
Плюс поставил, но как по мне - слишком заморочено. Трудновато разрабатывать, отлаживать, поддерживать, безопасный режим опять же будет мешать.
2. Antoska 16 10.02.26 12:55 Сейчас в теме
(1) Спасибо. Согласен, что это не совсем просто. К сожалению платформа не позволяет добавлять модули во внешнюю обработку, как для конфигурации или расширения. Для того и выпустил статью, чтобы показать как это можно сделать на обработках в макетах.
Про безопасный режим в статье есть информация под спойлером:
В модуле обработки нельзя использовать конструкторы некоторых объектов в безопасном режиме (5.5.4.3. Безопасный режим работы Руководства разработчика). Например, нельзя использовать Новый Файл(). Решить эту проблему можно, переписав код без использования этого объекта либо отключив безопасный режим. Отключить его можно в настройках пользователя или для всей платформы. В конфигурациях на базе БСП есть ещё возможность отключить безопасный режим или настроить нужные разрешения при добавлении обработки в Дополнительные отчеты и обработки. Подробнее в документации.
Для отправки сообщения требуется регистрация/авторизация