-
Notifications
You must be signed in to change notification settings - Fork 7
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Added automatic creation of predefined elements #144
Changes from 5 commits
c844ddb
7f7a9ac
5e7dae0
4568496
79be5dc
8bee7e3
f3f1205
73a3029
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -19,6 +19,71 @@ | |
КонецПроцедуры | ||
``` | ||
|
||
## Уникальность предопределенных элементов | ||
|
||
Для обеспечения целостности данных и управления предопределёнными значениями реализован механизм контроля изменений. Он основан на вычислении хеша с использованием алгоритма **MD5**, учёте пометки на удаление, ручных изменений и проверке уникальности идентификаторов. | ||
|
||
### Основные этапы проверки | ||
1. **Первоначальная проверка уникальности идентификаторов:** | ||
- На этапе инициализации идентификаторы всех элементов проверяются на уникальность. | ||
- Если обнаружены коллизии (дублирующиеся идентификаторы), будет выдано сообщение об ошибке, и такие элементы будут пропущены. | ||
2. **Хеш и состояние элемента:** | ||
- Хеш вычисляется для каждого элемента и сохраняется в регистре **состояний предопределённых элементов**. | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Нужно написать на основании каких данных формируется хэш - что там не учитываются изменяемые реквизиты There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. |
||
- **Ключи хеша:** | ||
- ИдентификаторНастройки | ||
- Наименование | ||
- Родитель (если включена иерархия) | ||
- ЭтоГруппа (если включена иерархия групп и элементов) | ||
- Изменяемые реквизиты при расчете не учитываются | ||
- Остальные ключи опционально, зависят от типа объекта метаданных (см. [область Структуры колонок таблиц](../src/cf/CommonModules/пбп_ПредопределенныеЗначенияПереопределяемый/Ext/Module.bsl#247-343) и [исключаемые поля для расчета хеша](../src/cf/CommonModules/пбп_ПредопределенныеЗначенияПереопределяемый/Ext/Module.bsl#345-381)) | ||
- Если элемент изменяется в пользовательском режиме, устанавливается флаг **ручное изменение:** | ||
- Такой элемент исключается из проверки хеша при последующих обновлениях. | ||
3. **Обработка элементов с пометкой на удаление:** | ||
- Если элемент помечен на удаление и его хеш отличается от нового: | ||
- Значения элемента обновляются данными из кода. | ||
- Пометка на удаление снимается автоматически. | ||
- Если элемент не помечен на удаление и его хеш отличается от нового: | ||
- Формируется уведомление о конфликте для дальнейшего разрешения. | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Нужно описать пример конфликта и его решения There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. |
||
|
||
**Пример решения конфликтов при создании/обновлении предопределенных элементов** | ||
|
||
![image](images/ФормаРазрешенияКонфликтов.png) | ||
|
||
Виды ошибок: | ||
- Коллизии идентификаторов | ||
- Эта ошибка не решается в пользовательском режиме, для ее устранения необходимо перейти в общий модуль ``пбп_ПредопределенныеЗначенияПереопределяемый`` и исправить конфликтующие элементы. | ||
- Расхождение элемента с кодом | ||
- Для элемента установлен флаг обновления: Элемент будет обновлен данными из программного кода, а также обновится хеш элемента в регистре сведений **``пбп_СостоянияПредопределенныхЭлементов``**. | ||
- Для элемента не установлен флаг обновления: Элемент не будет обновлен. В записи регистра сведений **``пбп_СостоянияПредопределенныхЭлементов``** будет установлен флаг **``Ручное изменение``**, указывающий на то, что элемент был изменен вручную и не подлежит автоматическому обновлению в будущем. | ||
|
||
**Примечание** - Флаг ``Заменить элементом из кода`` активен только для элементов с видом ошибки ``Расхождение элемента с кодом`` | ||
|
||
## Автоматическое создание новых элементов | ||
|
||
Для автоматизации процесса заполнения предопределенных элементов необходимо модифицировать/добавить в расширение общий модуль **``ОбщегоНазначенияПереопределяемый``**. В процедуре **``ПриДобавленииСерверныхОповещений``** требуется добавить новое серверное оповещение. | ||
|
||
**Пример кода для подключения через расширение** | ||
|
||
```BSL | ||
&После("ПриДобавленииСерверныхОповещений") | ||
Процедура пбп_ПриДобавленииСерверныхОповещений(Оповещения) | ||
|
||
// Создаем новое серверное оповещение для предопределённых значений | ||
Оповещение = СерверныеОповещения.НовоеСерверноеОповещение("пбп_ПредопределенныеЗначения"); | ||
|
||
// Указываем модуль для получения и отправки сообщений | ||
Оповещение.ИмяМодуляОтправки = ""; // В данном случае используется рег. задание для отправки | ||
Оповещение.ИмяМодуляПолучения = "пбп_ПредопределенныеЗначенияСлужебныйКлиент"; | ||
|
||
// Настраиваем периодичность проверки (в секундах) | ||
Оповещение.ПериодПроверки = 300; | ||
|
||
// Добавляем новое оповещение в список оповещений | ||
Оповещения.Вставить(Оповещение.Имя, Оповещение); | ||
|
||
КонецПроцедуры | ||
``` | ||
|
||
## Добавление новых элементов | ||
|
||
В модуле **пбп_ПредопределенныеЗначенияПереопределяемый** значения добавляются через метод **Добавить()** коллекции **Результат**, которая представляет собой таблицу предопределённых значений. Каждая новая запись в этой таблице может быть настроена как группа путём установки свойства ЭтоГруппа в значение Истина. | ||
|
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -14,6 +14,8 @@ | |
ОбработатьКонфликтныеЭлементы(АдресТаблицы); | ||
КонецЕсли; | ||
|
||
УстановитьУсловноеОформление(); | ||
|
||
КонецПроцедуры | ||
|
||
&НаКлиенте | ||
|
@@ -76,13 +78,14 @@ | |
ДобавляемыеРеквизиты = Новый Структура; | ||
Для Каждого Колонка Из Таблица.Колонки Цикл | ||
Если ИсключаемыеПоля.Свойство(Колонка.Имя) | ||
Или СтрНачинаетсяС(Колонка.Имя, "Служеб_") Тогда | ||
Или СтрНачинаетсяС(Колонка.Имя, "Служебный_") Тогда | ||
Продолжить; | ||
КонецЕсли; | ||
ДобавляемыеРеквизиты.Вставить(ПрефиксКод + Колонка.Имя, Колонка.ТипЗначения); | ||
ДобавляемыеРеквизиты.Вставить(ПрефиксБаза + Колонка.Имя, Колонка.ТипЗначения); | ||
Поля.Добавить(Колонка.Имя, Колонка.Имя); | ||
КонецЦикла; | ||
|
||
пбп_РаботаСФормами.СоздатьРеквизитыТаблицы(ЭтотОбъект, "ТаблицаКонфликтов", ДобавляемыеРеквизиты); | ||
|
||
ШиринаКолонки = 5; | ||
|
@@ -121,7 +124,7 @@ | |
|
||
МенеджерОбъекта = пбп_ОбщегоНазначенияСлужебный.МенеджерОбъектаПоПолномуИмени(ИмяФормыВладельца); | ||
|
||
СписокПредопределенных = Таблица.ВыгрузитьКолонку("Служеб_ПредопределенныйЭлемент"); | ||
СписокПредопределенных = Таблица.ВыгрузитьКолонку("Служебный_ПредопределенныйЭлемент"); | ||
|
||
Запрос = Новый Запрос; | ||
Запрос.Текст = | ||
|
@@ -150,8 +153,14 @@ | |
нСтрока[ПрефиксКод + КлючЗначение.Ключ] = КлючЗначение.Значение; | ||
КонецЦикла; | ||
|
||
Если Строка.Служебный_КоллизииИдентификаторов Тогда | ||
нСтрока.Ошибка = Перечисления.пбп_ВидыОшибокПредопределенныхЭлементов.КоллизииИдентификаторов; | ||
Иначе | ||
нСтрока.Ошибка = Перечисления.пбп_ВидыОшибокПредопределенныхЭлементов.РасхождениеЭлементаСКодом; | ||
КонецЕсли; | ||
|
||
Выборка.Сбросить(); | ||
Если Выборка.НайтиСледующий(Строка.Служеб_ПредопределенныйЭлемент, "Ссылка") Тогда | ||
Если Выборка.НайтиСледующий(Строка.Служебный_ПредопределенныйЭлемент, "Ссылка") Тогда | ||
ЗаполнитьЗначенияСвойств(БазоваяСтруктура, Выборка); | ||
Для Каждого КлючЗначение Из БазоваяСтруктура Цикл | ||
нСтрока[ПрефиксБаза + КлючЗначение.Ключ] = КлючЗначение.Значение; | ||
|
@@ -181,13 +190,23 @@ | |
Таблица.Индексы.Добавить(ИдентификаторНастройки); | ||
Для Каждого Строка Из ТаблицаКонфликтов Цикл | ||
Стр = Таблица.Найти(Строка[ПрефиксКод + ИдентификаторНастройки], ИдентификаторНастройки); | ||
|
||
Если Строка.Ошибка = Перечисления.пбп_ВидыОшибокПредопределенныхЭлементов.КоллизииИдентификаторов Тогда | ||
Таблица.Удалить(Стр); | ||
Продолжить; | ||
КонецЕсли; | ||
|
||
Если Строка.ЗаменитьЭлементомИзКода Тогда | ||
Стр.Служеб_ОбновитьЭлемент = Истина; | ||
Стр.Служебный_ОбновитьЭлемент = Истина; | ||
Иначе | ||
Стр.Служеб_УстановитьФлагРучноеИзменение = Истина; | ||
Стр.Служебный_УстановитьФлагРучноеИзменение = Истина; | ||
КонецЕсли; | ||
КонецЦикла; | ||
|
||
Если Не ЗначениеЗаполнено(Таблица) Тогда | ||
Возврат; | ||
КонецЕсли; | ||
|
||
Менеджер = пбп_ОбщегоНазначенияСлужебный.МенеджерОбъектаПоПолномуИмени(ИмяФормыВладельца); | ||
ДопПараметры = пбп_ПредопределенныеЗначения.ДопПараметрыОбработкиПредопределенныхЭлементов( | ||
Таблица, Менеджер); | ||
|
@@ -199,17 +218,40 @@ | |
Процедура ЗаполнитьОтметки(ЗначениеОтметки) | ||
Модифицированность = Истина; | ||
Для Каждого Строка Из ТаблицаКонфликтов Цикл | ||
Если Строка.Ошибка = | ||
ПредопределенноеЗначение("Перечисление.пбп_ВидыОшибокПредопределенныхЭлементов.КоллизииИдентификаторов") Тогда | ||
Продолжить; | ||
КонецЕсли; | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Исправьте сравнение значения ошибки В строках 221-224 используется сравнение: Если Строка.Ошибка =
ПредопределенноеЗначение("Перечисление.пбп_ВидыОшибокПредопределенныхЭлементов.КоллизииИдентификаторов") Тогда Использование Примените следующий дифф для исправления: - Если Строка.Ошибка =
- ПредопределенноеЗначение("Перечисление.пбп_ВидыОшибокПредопределенныхЭлементов.КоллизииИдентификаторов") Тогда
+ Если Строка.Ошибка = Перечисления.пбп_ВидыОшибокПредопределенныхЭлементов.КоллизииИдентификаторов Тогда There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. @denisushakov, спасибо за пояснение. Вы правы, на клиенте нельзя напрямую обратиться к значению перечисления, поэтому использование функции ✏️ Learnings added
|
||
Строка.ЗаменитьЭлементомИзКода = ЗначениеОтметки; | ||
КонецЦикла; | ||
КонецПроцедуры | ||
|
||
&НаСервере | ||
Процедура УстановитьУсловноеОформление() | ||
|
||
УсловноеОформление.Элементы.Очистить(); | ||
|
||
Элемент = УсловноеОформление.Элементы.Добавить(); | ||
|
||
ПолеЭлемента = Элемент.Поля.Элементы.Добавить(); | ||
ПолеЭлемента.Поле = Новый ПолеКомпоновкиДанных(Элементы.ТаблицаКонфликтовЗаменитьЭлементомИзКода.Имя); | ||
|
||
ОтборЭлемента = Элемент.Отбор.Элементы.Добавить(Тип("ЭлементОтбораКомпоновкиДанных")); | ||
ОтборЭлемента.ЛевоеЗначение = Новый ПолеКомпоновкиДанных("ТаблицаКонфликтов.Ошибка"); | ||
ОтборЭлемента.ВидСравнения = ВидСравненияКомпоновкиДанных.Равно; | ||
ОтборЭлемента.ПравоеЗначение = Перечисления.пбп_ВидыОшибокПредопределенныхЭлементов.КоллизииИдентификаторов; | ||
|
||
Элемент.Оформление.УстановитьЗначениеПараметра("ТолькоПросмотр", Истина); | ||
|
||
КонецПроцедуры | ||
|
||
#Область СообщенияОСобытии | ||
|
||
&НаСервере | ||
Процедура СообщитьОбОтсутствииЭлемента(Идентификатор) | ||
|
||
ТекстСообщения = НСтр("ru = 'Элемент '%1' отсутствуют в базе!'; | ||
|en = 'The element '%1' is missing from the database!'"); | ||
ТекстСообщения = НСтр("ru = 'Элемент ''%1'' отсутствует в базе!'; | ||
|en = 'The element ''%1'' is missing from the database!'"); | ||
ТекстСообщения = пбп_СтроковыеФункцииСлужебныйКлиентСервер.ПодставитьПараметрыВСтроку( | ||
ТекстСообщения, | ||
Идентификатор); | ||
|
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Кстати а это в оповещениях учтено? Или только если нужно разрешить конфликт?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.