Введение
Первая идея создания подсистемы у меня родилась во время использования 1С77. Тогда в 1С были весьма скромные возможности по созданию фоновых задач. Все что могла 1С77 штатными средствами, так это подключить обработчик ожидания в режиме пользователя. Тем временем передо мной стояли задачи регулярного выполнения: ежедневная рассылка прайсов, восстановление последовательности документов ночью. Постепенно круг выполняемых регламентных задач расширялся, а требования к расписанию их выполнения усложнялись. Так прайс с актуальными остатками теперь нужно было рассылать в одни регионы рано утром, в другие – в обед. Появились мобильные устройства, и теперь стало необходимо не только рассылать, но и принимать информацию по заказам от торговых агентов.
Все перечисленные выше задачи требовали программирования. Несмотря на разнообразие задач, их объединяет одно – это задачи, которые выполняются по расписанию.
Итак, постановка задачи стояла так: необходима подсистема выполнения обработок (алгоритмов) по расписанию. Обработки могут быть внешними и внутренними, а также можно хранить произвольный текст алгоритма (здесь и далее уже имеется в виду платформа 1С8). Подсистема регламента должна запускать обработки по расписанию как в фоновом режиме на сервере, так и в интерактивном режиме 1С Предприятия. При запуске обработки по расписанию ей передаются настройки, предварительно сохраненные средствами самой обработки или в форме настройки регламента (только для произвольного алгоритма).
Примеры задач использования подсистемы:
- · Загрузка валют
- · Обновление справочника банков
- · Обновление границы запрета редактирования в режиме пользователя
- · Подключение обработок на событие при начале работы системы: поздравление именинников, оповещение начальников кадровых служб о предстоящих днях рождения сотрудников, ограничение доступа группы сотрудников в определенные дни и часы, проведение анкетирования при входе в систему (разовые акции)
- · Снятие резервов товаров на складах
- · Формирование отчетов (например, ночью)
- · Рассылка отчетов
- · Проверка почты и загрузка информации
- · Восстановление последовательности документов
- · Ограничение работы определенного списка пользователей по времени
- · Осуществление обмена между системами (для 1С8 имеется в виду обмен без использования типовой подсистемы обмена данными)
Описание подсистемы «Управление регламентом» для 1С8.2
Подсистема предназначена для поддержки выполнения обработок по расписанию.
Настройки регламента позволяют ввести информацию о периодичности исполнения, времени, приоритете. Для каждого регламента назначается обработка и список пользователей (только для исполнения в сеансе пользователя), для которых будет задействован данный регламент.
Область применения возможностей подсистемы: формирование файлов рассылки, формирование отчетов в ночное время (когда сервер не загружен текущей обработкой запросов пользователей), выполнение алгоритмов напоминания, а также алгоритмов по событию: при начале работы, при завершении.
Работа с подсистемой
Создание регламента
Создание регламента производится через ввод элемента справочника «Регламентные обработки». Создадим для примера регламентную обработку в сеансе пользователя. Назначение регламентной обработки – обновлять границу запрета изменения данных в сеансе пользователя через каждые 15 минут. Для этого нам потребуется следующая последовательность действий:
1. Ввести новый элемент справочника Регламентные обработки
2. На элементе формы выбрать реквизит Обработка и открыть список выбора из справочника Внешние обработки
3. Добавить в справочник Внешние обработки Произвольный алгоритм. Текст произвольного алгоритма:
ПолныеПрава.УстановитьПараметрГраницыЗапретаИзмененияДанных();
4. Записать произвольный алгоритм во внешние обработки и завершить выбор
5. Указать признак «Действует в сеансе пользователя» и настроить расписание
6. В отрывшемся диалоге настройки расписания указать все дни недели, признак Периодичность и период – 900 секунд
7. Закрыть настройку расписания и сохранить регламент по кнопке ОК
Рисунок 1. Ввод регламента
Рисунок 2. Выбор регламентной обработки из внешних обработок
Рисунок 3. Ввод произвольного алгоритма
Рисунок 4. Справочник Регламенты выполнения обработок
Параметры произвольного алгоритма
Для иллюстрации использования параметров произвольного алгоритма проделаем последовательность по созданию нового регламента, описанную выше. В качестве произвольного алгоритма напишем следующий код:
Текст = Новый ЗаписьТекста("c:\test.txt");
Текст.ЗаписатьСтроку(ТекущаяДата());
Для Каждого ЭлементСписка Из Параметры Цикл
Текст.ЗаписатьСтроку(ЭлементСписка.Значение);
КонецЦикла;
Текст.Закрыть();
Далее сделаем настройку параметров. В качестве параметров выберем Список значений и зададим, к примеру, список организаций.
Для проверки работы регламента сохраним регламент. В списке регламентных обработок нажмем кнопку «Выполнить». В текстовом файле c:\test.txt должен появиться список параметров.
Тот же алгоритм мы можем применить для выполнения как в сеансе пользователя, так и фоновом задании на сервере. Результатом выполнения алгоритма будет создание файла c:\test.txt либо на компьютере пользователя, либо на сервере 1С – в зависимости от того, какое расписание было задано для выполнения регламентной обработки.
Рисунок 5. Редактирование параметров произвольного алгоритма
Настройка обработки
В примере выше, для произвольного алгоритма, было показано, как можно использовать параметры для алгоритма. Для случая использования обработок предусмотрен механизм работы с сохраненной настройкой обработки.
Общий порядок работы с сохраненной настройкой следующий. По кнопке регламента «Настроить обработку» вызывается форма обработки по-умолчанию. Реквизит «Сохраненная настройка» обработки заполняется из регламента. В интерфейсе обработки должна быть возможность сохранить настройку. После закрытия формы обработки «сохраненная настройка» сохраняется в регламенте. В дальнейшем, при регламентном выполнении обработки сохраненная настройка используется при инициализации обработки перед выполнением.
Требования к обработке для выполнения в регламенте
Для выполнения в регламенте может быть использована как внешняя обработка из справочника «Внешние обработки», так и обработка из конфигурации. Для второго случая в регламенте необходимо указать имя обработки (в реквизите ввести строку с именем обработки, например «РегламентнаяОбработка»).
В обработке должен быть реквизит «СохраненнаяНастройка» произвольного типа.
В модуле обработке должны быть объявлены экспортные процедуры:
- · СохранитьНастройку
- · ПрименитьНастройку
- · ВыполнитьОбработку
Процедура СохранитьНастройку() Экспорт
Параметры = Новый Структура;
// Сохранение реквизитов обработки
Для каждого Реквизит Из ЭтотОбъект.Метаданные().Реквизиты Цикл
//Сообщить("Имя:"+Реквизит.Имя+", значение:"+Строка(ЭтотОбъект[Реквизит.Имя]));
Параметры.Вставить(Реквизит.Имя, ЭтотОбъект[Реквизит.Имя]);
КонецЦикла;
СохраненнаяНастройка = Новый ХранилищеЗначения(Параметры);
КонецПроцедуры
Процедура ПрименитьНастройку() Экспорт
Попытка
Параметры = СохраненнаяНастройка.Получить();
// Восстановление сохраненных реквизитов обработки
Для каждого Реквизит Из ЭтотОбъект.Метаданные().Реквизиты Цикл
//Сообщить("Имя:"+Реквизит.Имя+", значение:"+Строка(ЭтотОбъект[Реквизит.Имя]));
Параметры.Свойство(Реквизит.Имя, ЭтотОбъект[Реквизит.Имя]);
КонецЦикла;
Исключение
КонецПопытки;
КонецПроцедуры
Процедура ВыполнитьОбработку() Экспорт
ЗаписьЖурналаРегистрации("РегламентнаяОбработка",
УровеньЖурналаРегистрации.Информация, , ,
"Выполнение по организации:"+Строка(Организация));
КонецПроцедуры
Редактирование расписания
Как было указано ранее для выполнения регламента можно задать расписание выполнения в сеансе пользователя или в фоновом задании на сервере 1С. Для настройки расписания в сеансе пользователя нужно нажать кнопку «Дополнительные настройки расписания…» в разделе «Работа в сеансе пользователя».
Расписание в сеансе пользователя можно настроить на период по дням недели. Обработка может вызываться периодически через заданный интервал периода выполнения или по указанному времени. Период действия расписания можно не указывать, однако дни недели указывать нужно обязательно!
Важно! Расписание в сеансе пользователя начинает действовать при входе пользователя в систему 1С. При этом, если ранее расписание было действующим, то изменение расписание вступит в силу после первого выполнения регламентной обработки. Для того чтобы измененный регламент применить сразу в сеансе пользователя, нужно по кнопке «Открыть регламентные задания» перейти в форму списка регистра сведений «Регламентные задания сеанса пользователя» и нажать «Загрузить регламент».
Для второго варианта выполнения в фоновом задании на сервере 1С расписание фонового задания начинает действовать сразу, после записи элемента справочника Регламентные обработки.
Рисунок 6. Расписание регламента в сеансе пользователя
Регламентные задания сеанса пользователя
Регламентные задания сеанса пользователя хранятся в регистре сведений «Регламентные задания». Основное назначение регистра – создание плана выполнения регламента.
Как только наступает время равное или большее времени, рассчитанного ранее в плане выполнения, происходит выполнение регламентной обработки. Далее для выполненной обработки производится новый расчет планового времени выполнения.
Таким образом, план выполнения гарантирует, что при наступлении времени выполнения, даже если текущее время оказалось позже (это может быть т.к. в сеансе пользователя выполнение последовательное и предыдущая обработка могла долго выполняться или из-за периода ожидания) все обработки будут обязательно выполнены.
Рисунок 7. Регламентные задания сеанса пользователя
Состав подсистемы
Метаданные |
Вид |
Общие модули |
УправлениеРегламентом |
Регламентные задания |
РегламентнаяОбработка |
Перечисления |
ВидыДополнительныхВнешнихОбработок (добавлен вид «Произвольный алгоритм») СобытияРегламентногоВыполнения СостоянияВыполненияРегламента |
Справочники |
ВнешниеОбработки (добавлен вид «Произвольный алгоритм») РегламентыВыполненияОбработок |
Регистры сведений |
РегламентныеЗадания |
Процедуры модуля приложения |
ПриНачалеРаботыСистемы ПриЗавершенииРаботыСистемы |