ОБЛАСТЬ ТЕХНИКИ
Настоящее техническое решение относится к области информационных технологий, в частности, к способу и системе проверки целостности и достоверности первичных электронных данных.
УРОВЕНЬ ТЕХНИКИ
Из патента US7299408B1 (МПК G06F17/00, опубл. 2007-11-20) известно решение, описывающее валидацию электронных документов (ЭД). Известное решение включает прием ЭД, содержащего часть основных данных и часть для просмотра, причем часть основных данных может анализироваться отдельно от части просмотра, а часть просмотра включает в себя форматирование представления, по меньшей мере, для одного дисплея, соответствующего основной части данных; извлечение набора правил валидации, соответствующих ЭД, причем набор правил валидации включает в себя правила сравнения для определения, соответствует ли первое отображение, обеспеченное частью просмотра, основной части данных для первого набора значений; применение набора правил валидации к первому ЭД; определение того, что ЭД является действительным, на основе определения того, что первый дисплей по существу соответствует основной части данных для первого набора значений, при этом определение того, соответствует ли первый дисплей по существу основной части данных, включает в себя доступ к множеству связующих элементов в ЭД, в котором отдельные из множества связывающих элементов соответственно связывают первый атрибут и второй атрибут, причем первый атрибут соответствует значению основных данных для конкретного информационного поля в части основных данных, а второй атрибут соответствует данным вида значение для конкретного информационного поля в части просмотра и определение того, что первое отображение по существу соответствует основной части данных, где значение основных данных равно значению данных просмотра; и вывод результатов проверки ЭД для отражения определения того, что ЭД является действительным.
Недостатком данного технического решения является то, что оно не основывается на микросервисной архитектуре, что приводит к сложностям при доработках связанных с внесением изменений.
В указанном выше решении также отсутствует возможность управления валидацией без редактирования файлов, содержащих правила проверок, что снижает эффективность метода, поскольку требует гораздо больше трудозатрат и времени команды разработчиков.
Дополнительным недостатком является то, что решение описывает возможность осуществления способа преимущественно на заранее определенных форматах электронного документа, тем самым сокращая возможности его реализации.
Кроме того, данное решение предполагает визуализацию результатов валидации на экраны, как один из этапов проведения проверки, тем самым не реализовано достаточное автоматизированное проведение проверок, что значительно увеличивает время проведения валидации.
Из уровня техники известно решение, описывающее способ исправления ЭД при его создании (наполнении структуры) и редактировании (US7657832B1, МПК G06F17/00, опубл. 2010-02-02). При этом способ содержит: выявление ошибки проверки в структуре ЭД XML, причем ошибка проверки является аспектом структуры ЭД XML, который не соответствует правилам определения типа документа XML или схеме XML, причем правила связаны с ЭД XML, причем ошибка валидации имеет особый вид, при этом идентификация ошибки валидации включает построение детерминированной конечной автоматизации из модели контента, определенной в определение типа документа ЭД XML, и определение ошибки валидации с использованием детерминированного конечного автомата; выбор шаблона предложения из множества шаблонов предложений в соответствии с конкретным видом ошибки проверки и использование выбранного шаблона предложения для предложения пользователю предложенных исправлений, которые предварительно определены в шаблоне для конкретного вида ошибки проверки, выбранного шаблона предложения включая логику, необходимую для изменения структуры ЭД XML в соответствии с правилами определения типа документа XML или схемы XML, при этом изменение структуры ЭД XML включает в себя переназначение элемента в структуре ЭД XML и перемещение элемента из текущего местоположение в новом месте в структуре ЭД XML; получение ввода, выбирающего одно из предложенных исправлений; и использование логики в выбранном шаблоне предложения для применения коррекции, выбранной входными данными, к электронному документу XML.
Из описания данного решения не следует, что оно реализовано на микросервисной архитектуре, компоненты, входящие в состав данного решения, свидетельствуют об использовании монолитного подхода. Следовательно, недостатком данного технического решения является то, что такое решение будет недостаточно гибким к изменениям и трудно масштабируемым при работе в высоконагруженной корпоративной среде.
Также в данном решении, как и в указанном выше решении, отсутствует возможность управления валидацией без редактирования файлов, содержащих правила проверок, что снижает эффективность метода, поскольку требует гораздо больше трудозатрат и времени команды разработчиков.
Дополнительным недостатком является то, что решение описывает возможность осуществления способа исправления ЭД преимущественно на заранее определенных форматах ЭД, тем самым сокращаются возможности его реализации.
Преимуществами заявленного решения по отношению к известным из уровня техники является то, что заявленное решение реализовано в парадигме микросервисной архитектуры; наличие в нем механизма управления валидацией документа без редактирования файлов содержащих правила валидации; в заявленном решении также отсутствует акцент на формат поставляемого ЭД на вход; не обязывает располагать в документе часть данных для представления; и валидация документа выполняется автоматически без участия пользователя.
СУЩНОСТЬ ИЗОБРЕТЕНИЯ
Технической проблемой, на решение которой направлено заявленное техническое решение, является создание компьютерно-реализуемого способа и системы валидации сложных структур данных в комплексной микросервисной архитектуре. Дополнительные варианты реализации настоящего изобретения представлены в зависимых пунктах изобретения.
Техническим результатом, достигающимся при решении вышеуказанной технической проблемы, является то, что использование способа валидации сложных структур данных в комплексной микросервисной архитектуре с визуальным отображением результатов способствует своевременному раннему обнаружению непригодных (неконсистентных) для дальнейшей обработки данных и ЭД, вносимых/загружаемых в систему дистанционного банковского обслуживания. При этом снижение уровня неконсистентных данных повышает качество обработки информации и увеличивает отказоустойчивость систем дистанционного банковского обслуживания клиентов.
Дополнительным результатом является повышение эффективности управления системами дистанционного банковского обслуживания за счет возможности выполнять настройки бизнес-контролей и задавать правила валидации для каждого отдельного ЭД и каждого его поля (атрибута).
Дополнительным техническим результатом является автоматическая валидация ЭД без участия пользователей.
Заявленные результаты достигаются за счет осуществления компьютерно-реализуемого способа валидации сложных структур данных в комплексной микросервисной архитектуре, содержащего этапы, на которых:
получают сложную структуру данных (СД);
извлекают метаинформацию, соответствующую типу полученной СД из библиотеки метаинформации;
согласно метаинформации извлекают из библиотеки набор правил валидации, соответствующих полученной СД;
применяют набор правил валидации к СД для проверки целостности и достоверности первичных данных;
выявляют, по меньшей мере, одну ошибку проверки СД, причем ошибка проверки является аспектом структуры СД, которая не соответствует правилам валидации;
при этом выявленная, по меньшей мере, одна ошибка валидации включает построение детерминированной конечной автоматизации из модели контента;
выбирают шаблон из множества шаблонов предложений в соответствии с выявленным конкретным видом ошибки проверки и используют выбранный шаблон предложения;
исправляют по меньшей мере одну ошибку в соответствии с правилами валидации;
выводят результат проверки СД для отражения определения того, что СД является действительной.
В частном варианте выбирают шаблон из множества шаблонов в соответствии с выявленным конкретным видом ошибки проверки и используют выбранный шаблон.
В другом частном варианте шаблон реализован в виде списка программ.
В другом частном варианте определение структуры СД включает в себя определение отсутствующего, постороннего, неуместного или несоответствующего структурного аспекта СД.
В другом частном варианте набор правил валидации дополнительно включает в себя ссылочные правила идентификатора для изучения значений, которые назначены полям в основной части данных, и определения, имеют ли значения, соответствующим полям, ожидаемые критерии.
Заявленный результат также достигается за счет системы валидации сложных структур данных в комплексной микросервисной архитектуре для реализации способа, и содержащей:
по крайней мере, одно пользовательское устройство, необходимое для загрузки или формирования СД; имеющее связь, по крайней мере, с одним микросервисом системы дистанционного обслуживания, содержащий модули для хранения и применения правил валидации; по крайней мере, один прикладной микросервис, содержащий модули для хранения и применения правил валидации и хранения и выбора соответствующей типу СД метаинформации; по крайней мере, один микросервис контролей, содержащий модули для управления правилами валидации и хранения матриц проверок; микросервис управления параметрами микросервиса контролей.
ОПИСАНИЕ ЧЕРТЕЖЕЙ
Реализация изобретения будет описана в дальнейшем в соответствии с прилагаемыми чертежами, которые представлены для пояснения сути изобретения и никоим образом не ограничивают область изобретения. К заявке прилагаются следующие чертежи:
Фиг. 1 иллюстрирует пример общей системы валидации сложных структур данных в комплексной микросервисной архитектуре;
Фиг. 2 иллюстрирует основные этапы реализации заявленного способа, в том числе этапов разработки компонентов системы.
ДЕТАЛЬНОЕ ОПИСАНИЕ ИЗОБРЕТЕНИЯ
В приведенном ниже подробном описании реализации изобретения приведены многочисленные детали реализации, призванные обеспечить отчетливое понимание настоящего изобретения. Однако, квалифицированному в предметной области специалисту, будет очевидно каким образом можно использовать настоящее изобретение, как с данными деталями реализации, так и без них. В других случаях хорошо известные методы, процедуры и компоненты не были описаны подробно, чтобы не затруднять понимание особенностей настоящего изобретения.
Кроме того, из приведенного изложения будет ясно, что изобретение не ограничивается приведенной реализацией. Многочисленные возможные модификации, изменения, вариации и замены, сохраняющие суть и форму настоящего изобретения, будут очевидными для квалифицированных в предметной области специалистов.
С целью своевременной проверки данных и ЭД, получаемых от пользователей системой дистанционного банковского обслуживания (ДБО), для их своевременной обработки предложен способ валидации сложных структур данных в комплексной микросервисной архитектуре с визуальным отображением результатов.
Под сложными структурами данных принято считать данные в упорядоченном виде. Для реализации предложенного способа предлагается применить бизнес-контроли, то есть применить специальные правила обработки информации. При этом для каждого вида проверки применяется отдельный бизнес-контроль, а способы проведения или условия проведения конкретной проверки содержатся в метаинформации, из которой следует регламент проведения проверки и другая основная информация об объекте.
Заявленный способ представляет из себя унифицированный механизм, позволяющий реализовывать сервисы, отвечающие высоким уровнем проверки целостности и достоверности первичных данных сложных структур данных, например, ЭД; и дает возможность гибко управлять бизнес-контролями для каждого ЭД внутри системы ДБО.
Также заявленный способ может быть применен в любых других системах, в которых пользователи могут загружать данные, документы, изображения и от своевременной валидации загружаемой информации пользователем зависит успешность функционирования такой системы и качества оказания соответствующих услуг.
Отличительной технической особенностью заявленного способа является декомпозиция процесса проверки, или контроля данных на независимые части, где,
• Первая часть - это данные;
• Вторая часть - это метаинформация, содержащая управляющую информацию о том, какие данные, где, когда и по каким правилам проверять (контролировать);
• Третья часть - это программный код, реализующий логику проверки данных.
Также отличительной особенностью способа является то, что проверка может проводиться в два этапа за счет использования правил Front-end и Back-end архитектур в компоновке системы, причем проведение проверок проводится, как и на Front-end контуре, так и на Back-end, таким образом, понижается нагрузка на модули Back-end архитектуры, что в свою очередь повышает отказоустойчивость предложенной системы валидации сложных структур данных
Заявленная система валидации сложных структур данных в комплексной микросервисной архитектуре для реализации заявленного способа, основана на микросервисной архитектуре и компоненты, входящие в ее состав, функционально разделены на управляющую (конфигурационную) и исполняемую части.
Управляющая часть отвечает за настройку и определение условий срабатывания контролей, согласно метаинформации.
Исполняемая часть отвечает за реализацию проверок как на стороне сервера (Back-end), так и на стороне браузера пользователя (Front-end), в соответствии с определенными правилами проведения проверки каждого бизнес-контроля.
На Фиг. 1 представлен общий вид основных компонентов системы, управляющая часть выражена в микросервисе контролей (104), а исполняющая часть выражена в прикладном микросервисе (103). При этом технически возможно реализовать функции прикладного микросервиса и в компоненте (102), а также увеличить количество модулей для увеличения мощностей системы.
1) Компонент «101» - пользователь, который посредством браузера/мобильного приложения может вносить информацию, загружать данные и электронные документы в систему дистанционного обслуживания или формировать электронные документы самостоятельно. Таким пользователем может быть клиент, обслуживаемый в системе дистанционного обслуживания.
2) Компонент «102» - микросервис (или его фронтальная часть), расположенный в контуре front-end, который снабжен одним или несколькими программными модулями, функция которых заключается в хранении и применении наборов правил проведения проверок и правил (инструкций) для функционирования микросервиса. Компонент 102 взаимодействует с компонентом 103 посредством представления REST API для получения метаинформации бизнес-контролей, предусмотренных для выполнения валидации на front-end контуре.
3) Компонент «103» - микросервис, расположенный в контуре Back-end, который в свою очередь снабжен одним или несколькими программными сервисами, функция которых заключается в хранении и применении наборов базовых правил проведения проверок и правил (инструкций) микросервиса; базой данных, в которой хранится библиотека метаинформации бизнес-контролей, специфичных для каждого типа электронного документа (предусмотренных для обработки в системе дистанционного обслуживания); одним или несколькими программными сервисами для взаимодействия с библиотекой бизнес-контролей; модулем API микросервиса контролей.
Прикладной микросервис выполняет исполняющую часть заявленного способа.
4) Компонент «104» - микросервис, выполняющий функцию управления бизнес-контролями и применением правил, предоставляет REST API для управления метаинформацией контролей для конкретных типов ЭД. Микросервис снабжен несколькими модулями: базой данных, в которой хранятся настройки для управления проведением проверок, назовем это библиотекой бизнес-контролей; одним или несколькими модулями, функция которых заключается в управлении процедурой проверки электронного документа; модулем взаимодействия с библиотекой бизнес-контролей.
5) Компонент «105» - админ консоль - микросервис, который предоставляет внутреннему пользователю управлять параметрами микросервиса контролей по типам ЭД, предоставляет REST API для доступа к настройкам контролей.
Все правила реализуются единообразно и группируются в зависимости от типа ЭД и переносятся в систему. При этом общие контроли формируют отдельную библиотеку и могут быть применены для валидации как ЭД, так и прочих структур данных. Такой модульный подход позволяет организовать разработку и развертывание контролей, реализованных в разных функциональных стримах, независимо, и минимизировать их влияние друг на друга.
В реализации выделяются следующие элементы:
1. Библиотека управления метаданными реализует функциональность по созданию, конфигурированию и исполнению контролей. Предоставляет доступ к структурам данных в PostgreSQL в которых хранятся настройки контролей.
2. Back-end реализация (правило) предназначена для исполнения контролей на стороне сервера. Реализуется в виде набора Java-классов.
3. Front-end реализация (правило) предназначена для исполнения на стороне браузера пользователя. Реализуется в виде набора JavaScript- функций.
4. Микросервис предоставляет REST API для доступа к настройкам контролей.
Реализация на «Back-end» контуре - предназначена для исполнения контролей на стороне сервера (серверов). Реализация «Front-end» контуре - предназначена для исполнения на стороне фронтальной части в браузере/мобильном приложении пользователя и предполагается для выполнения элементарных проверок, например, таких как:
- Проверка поля на непустоту;
- Проверка поля на длину;
- Проверка поля на корректность введенных символов;
- Проверка значения поля;
- Номер документа не состоит из одних нулей.
Бизнес-контроль состоит из следующих частей:
Проверка - это метаданные проверки, содержащие управляющую информацию о контроле. Они позволяют настраивать условия работы контроля.
Правило - исполняемая логика проверки. Каждое правило имеет уникальный идентификатор - ruleId.
Описание бизнес - контролей формируется заранее для каждого типа электронного документа заранее.
Это примерный перечень элементарных проверок, которым не ограничивается заявленное решение и, который может изменяться. Признак элементарности того или иного бизнес-контроля устанавливается в библиотеке бизнес-контролей.
В описании присутствуют дополнительно две роли - это разработчик и внутренний пользователь. Разработчик создает компоненты системы, внутренний пользователь выполняет функции администрирования работы системы и способа.
Как представлено на Фиг. 2, для реализации компьютерно-реализуемого способа валидации сложных структур данных в комплексной микросервисной архитектуре и разработки компонентов системы сперва необходимо сформировать библиотеки с перечнем бизнес-контролей и инструкцией по управлению бизнес-контролями включая:
• доменную модель и физическую структуру данных для хранения бизнес-контролей;
• сервисы для управления и использования бизнес-контролей;
• набор общих правил для конфигурирования бизнес-контролей.
Это самый первичный этап, который реализуется разработчиком системы и отображен на этапе «201».
Далее разработчик создает (202) модули, за счет которых возможно управлять бизнес-контролями, в том числе создавать и (или) удалять и (или) изменять бизнес-контроли, таким образом, разрабатывается логика функционирования прикладного микросервиса (103). Для управления бизнес-контролями разработчик реализует микросервис контролей (104), в рамках которого предоставляется API для взаимодействия с микросервисом админ консоль (105), функция которого заключается в управлении бизнес-контролями над ЭД пользователям (как правило, внутренним пользователям) системы.
Затем внутренний пользователь системы может приступать к управлению бизнес-контролями - этап «203». Это значит то, что теперь внутренний пользователь системы дистанционного обслуживания клиентов может настраивать бизнес-контроли, формировать перечни бизнес-контролей к виду электронного документа или другим образом вносить изменения в базу данных микросервиса контролей (104) - библиотеку бизнес-контролей. После того, как бизнес-контроли сформированы внутренним пользователем и в части логики исполнения контролей были добавлены в микросервис контролей (104), то метаинформация бизнес-контролей переносится (204) в исполняющую часть способа в прикладной микросервис (103) и сохраняется в библиотеке метаинформации.
Далее уже внешний пользователь системы, например, клиент, может создавать или загружать ЭД (205), а система будет осуществлять автоматическую процедуру валидации ЭД со сложной структурой данных (206).
Ниже в таблице 1 приведены обязательные параметры для метаданных контроля в заявленном способе.
Таблица 1
Возможность изменения данного параметра предусмотрена только для элементарных контролей
Возможно задавать как общую принадлежность всем Клиентам Банка, так и конкретным Клиентам/группам Клиентов. При этом настройка по конкретным Клиентам имеет приоритет над общей настройкой.
При разработке контроля заложена соответствующая логика (алгоритм), реализующая данный механизм, а также определена возможность в целом использования данного механизма в контроле
Для задания условий изменяемых параметров предусмотрена возможность использования регулярных выражений (например, для контроля на допустимые символы для числового поля условие проверки может выглядеть как [0-9]).
Данный параметр формируется динамически. На основании выполнения логики проверки (параметр 14) возвращается ключ (идентификатор) сообщения об ошибке, по которому на UI определяется текст сообщения (хранится в файле локализационных ресурсов) на языке, установленном для пользовательского интерфейса (локально).
В таблице 2 приведена примерная библиотека выполняемых контролей.
Данная библиотека может быть дополнена, могут быть изменены требования к реализации выполняемых контролей, непосредственно сама реализация контролей, а также параметры выполнения того или иного контроля.
Таблица 2
2. Через GUI должна быть предоставлена возможность указывать, к какому атрибуту документа должен быть применен контроль
3. Остальные параметры должны быть настраиваемы (в рамках концепции контролей).
NotEmptyRule
2. Через GUI должна быть предоставлена возможность настройки следующих параметров:
1. указывать, к какому атрибуту документа должен быть применен контроль;
2. максимальное количество символов для поля (в случае применения на front-end возможно физически запретить ввод больше числа символов);
1. минимальное количество символов для поля.
2. Остальные параметры должны быть настраиваемы (в рамках концепции контролей).
"Длина поля <FieldName> не должна быть меньше Y символов" (в случае ввода меньшего числа символов)
2. max - максимальное количество символов для поля
2. Через GUI должна быть предоставлена возможность настройки следующих параметров:
1. указывать, к какому атрибуту документа должен быть применен контроль;
2. указывать допустимые либо запрещенные символы (в виде регулярного выражения);
3. Остальные параметры должны быть настраиваемы (в рамках концепции контролей).
2. Через GUI должна быть предоставлена возможность настройки следующих параметров:
1. указывать, к какому атрибуту документа должен быть применен контроль;
2. максимальное значение для поля;
3. минимальное значение для поля.
3. Остальные параметры должны быть настраиваемы (в рамках концепции контролей).
"Значение поля <FieldName> не должна быть меньше Y" (в случае меньшего значения)
2. max - максимальное значение поля
2. Через GUI должна быть предоставлена возможность настройки следующих параметров:
1. указывать, к какому атрибуту (дата) документа должен быть применен контроль;
2. указывать, с каким атрибутом (дата) будет происходить сравнение;
3. указывать, какую логическую операцию (например, FieldName > FieldName2);
2. Сложный контроль - должен использовать следующую логику:
1. длина поля ИНН = 10, 12, 5 символов или 1 символ со значением "0")
3. Остальные параметры должны быть настраиваемы (в рамках концепции контролей).
2. Сложный контроль - должен использовать следующую логику:
а. Допустимое число дней опережения;
b. Допустимое число дней просрочки;
3. Остальные параметры должны быть настраиваемы (в рамках концепции контролей).
2. maxDays - допустимое число дней опережения
2. Через GUI должна быть предоставлена возможность указывать, к какому атрибуту документа должен быть применен контроль
2. Через GUI должна быть предоставлена возможность указывать, к какому атрибуту документа должен быть применен контроль
2. idField - наименование поля, являющегося первичным ключем в справочнике
1. checkedFields - наименнования полей справочника для сравнения
Все правила реализуются единообразно в виде Spring бинов, которые группируются в зависимости от типа ЭД и добавляются в систему в виде jar-файлов. При этом общие контроли формируют отдельную библиотеку и могут быть применены для валидации как ЭД. Такой модульный подход позволяет организовать разработку и развертывание контролей, реализованных в разных функциональных стримах, независимо, и минимизировать их влияние друг на друга.
При этом метаданные:
- Предназначены для хранения информации о доступных контролях, их реализациях и ассоциируемых с ними ЭД;
- Частично конфигурируются посредством административной консоли;
- Хранение данных осуществляется в виде структуры данных, позволяющей настраивать применимость контролей для любого типа ЭД в разрезе каналов доступа, организаций, филиалов банка и этапов жизненного цикла ЭД.
Back-end реализация:
- Каждый контроль реализуется в виде отдельного java-класса по общему шаблону;
- Контроли активируется в рамках переходов по жизненному циклу документа;
- В исполняемый модуль (jar) для каждого EP включаются все java-классы, реализующие контроли, ассоциируемые с типом ЭД для которого сконфигурирован данный EP;
- Список сконфигурированных контролей для каждого этапа жизненного цикла ЭД формируется непосредственно перед выполнением EP на основании обращения к метаданным.
Front-end реализация (только элементарные контроли) может быть настроена таким образом, чтобы применяться к отдельным типам электронных документов:
- Контроли реализуются в виде разделяемой javascript-библиотеки по общему шаблону;
- Список сконфигурированных контролей формируется и передается на front-end в процессе отрисовки конкретной экранной формы (REST-запрос к метаданным в back-end);
- Для каждого контроля передаются следующие данные:
- название javascript-функции, реализующей контроль;
- атрибут ЭД к которому применяется контроль;
- значения параметров, используемых javascript-функцией в процессе выполнения проверки.
- Выполнение контролей активируется соответствующим событием (например, нажатие кнопки "сохранить").
Таким образом, проведение процедуры, в ходе которых проводится проверка ЭД, имеющего сложную структуру данных, может происходить в несколько этапов - сначала может быть применены бизнес-контроли и валидация документа в контуре Front-end, затем применяются бизнес-контроли и валидация из контура Back-end.
Такое разделение позволяет не применять полностью все бизнес-контроли к документам, например, заполненным пользователем вручную в заранее обозначенные системой области, к которым достаточно применить бизнес-контроли по общему шаблону. Таким образом, пользователю сразу сообщают о наличии ошибки или, наоборот, о том, что данные введены верно.
Подробнее процедура проведения валидации разъясняется на приведенном ниже примере.
Пользователю системы дистанционного обслуживания необходимо создать документ, при этом параметры типа документа заранее в системе установлены. Посредством мобильного приложения или браузера Пользователь загружает документ в систему дистанционного обслуживания, который содержит атрибут "Дата создания".
При открытии экранной формы для создания документа в исполняющей части способа выполняется загрузка из управляющей части бизнес-контролей, сконфигурированных, к применению, например, в пользовательском интерфейсе, для данного типа документа. Если в управляющей части системы для данного типа документа к атрибуту "Дата создания" установлен бизнес-контроль, логика которого заключается в том, что дата создания не должна быть меньше текущей, то при переходе к следующему атрибуту или завершении процесса ввода выполняется процедура валидации, в которой сверяют значение атрибута документа с логикой бизнес-контроля.
При этом в управляющей части установлено, что атрибут "Дата создания" относится к категории элементарных контролей, то проведение валидации доступно на контуре Front-end. Применение бизнес-контролей и валидация документа на фронтальной части является опциональной возможностью потому, что документ может быть не только создан вручную, но и импортирован через загрузку файла или через интеграционный слой от внешних АС по сети.
Поэтому если значение не проходит бизнес-контроль, т.е. выявляется несоответствие логики то элемент экранной формы, предназначенный для атрибута, выделяется любым доступным способом, и сопровождается описанием причины не прохождения с подсказкой согласно описательной части данного бизнес-контроля (207).
В случае если значение соответствует успешному прохождению бизнес-контроля, документ сохраняется в средствах хранения, в соответствующей структуре данных предназначенной для хранения данного типа документа для его последующей обработки в системе дистанционного обслуживания, а пользователю сообщается (207) статус валидации документа «Успешно».
Если в управляющей части установлено, что атрибут "Дата создания" не относится к категории элементарных контролей, то выполняется основная процедура валидации реализованная на контуре Back-end, и тогда валидация документа выполняется следующим образом:
1. По ключевым атрибутам документа (в примере таким ключевым атрибутом является идентификатор типа документа) осуществляется поиск по матрице бизнес-контролей актуального набора бизнес-контролей для данного типа документа.
2. Определив актуальный набор контролей (в примере ограничились одним бизнес-контролем для документа - это контроль атрибута "Дата создания", в реальной жизни их может быть сколько угодно много), выполняется последовательная проверка соответствия значений атрибутов документа правилам, сконфигурированным для найденных контролей.
При этом для каждого контроля выполняется следующая последовательность действий:
a. Получить значения атрибутов документа используемых в логике контроля;
b. Применить логику контроля к полученным значениям с учетом параметров контроля;
c. Если в результате применения логики контроля обнаружено несоответствие, создается запись с информацией о выявленном несоответствии.
3. По результату применения всех контролей формируется итоговый список обнаруженных несоответствий.
4. Данный список сохраняется в средствах хранения и возвращается как результат обработки документа.
5. Для пользователя данный список отображается в инспекторе ошибок. Пользователь может ознакомиться с перечнем выявленных несоответствий, отображаемых на экране его пользовательского устройства.
При идентификации несоответствия со списком элементов экранной формы, предназначенных для атрибута, то загруженный элемент или поле его ввода выделяется некоторым образом и сопровождается описанием причины не прохождения с подсказкой согласно описательной части данного бизнес-контроля. Таким образом, внешний пользователь узнает причину ошибки и устраняет несоответствие.
Если несоответствий не обнаружено, то документ из состояния черновик переходит в состояние, которое позволяет его дальнейшую обработку согласно бизнес-процессу.
Таким образом, заявленное решение позволяет осуществить автоматическую валидацию сложных структур данных в комплексной микросервисной архитектуре с визуальным отображением результатов, своевременно обнаруживать непригодные (неконсистентные) для дальнейшей обработки данные и ЭД, вносимые/загружаемые в систему банковского обслуживания. Дополнительно позволяет повысить эффективность управления системами банковского обслуживания за счет возможности выполнять настройки бизнес-контролей и задавать правила валидации для каждого отдельного ЭД и каждого его поля (атрибута), а также распределить нагрузку на исполняющие модули, что в свою очередь повышает отказоустойчивость предложенной системы валидации сложных структур данных в комплексной микросервисной архитектуре.
В настоящих материалах заявки было представлено предпочтительное раскрытие осуществление заявленного технического решения, которое не должно использоваться как ограничивающее иные, частные воплощения его реализации, которые не выходят за рамки испрашиваемого объема правовой охраны и являются очевидными для специалистов в соответствующей области техники.
название | год | авторы | номер документа |
---|---|---|---|
ПРОГРАММНО-АППАРАТНЫЙ КОМПЛЕКС 5BOX | 2022 |
|
RU2807033C1 |
СИСТЕМА И СПОСОБ УПРАВЛЕНИЯ ИНЖЕНЕРНЫМИ ДАННЫМИ | 2022 |
|
RU2787261C1 |
СПОСОБ И СИСТЕМА ДЛЯ УПРАВЛЕНИЯ БИЗНЕС-ПРОЦЕССОМ ПРЕДПРИЯТИЯ | 2003 |
|
RU2308084C2 |
ОБЛАЧНАЯ ИНТЕЛЛЕКТУАЛЬНАЯ ПЛАТФОРМА ПРИНЯТИЯ РЕШЕНИЙ ДЛЯ ЦЕЛЕЙ УПРАВЛЕНИЯ УМНЫМ ГОРОДОМ | 2021 |
|
RU2790038C1 |
МОДЕЛЬ ДАННЫХ ДЛЯ ОБЪЕКТНО-РЕЛЯЦИОННЫХ ДАННЫХ | 2006 |
|
RU2421798C2 |
СПОСОБ И СИСТЕМА АВТОМАТИЧЕСКОГО ПРИНЯТИЯ ПРАВОВОГО РЕШЕНИЯ | 2019 |
|
RU2732071C1 |
СИНХРОНИЗАЦИЯ В РЕАЛЬНОМ ВРЕМЕНИ ДАННЫХ XML МЕЖДУ ПРИЛОЖЕНИЯМИ | 2006 |
|
RU2439680C2 |
ПРОГРАММИРУЕМАЯ ОБЪЕКТНАЯ МОДЕЛЬ ДЛЯ ПОДДЕРЖКИ БИБЛИОТЕКИ ПРОСТРАНСТВ ИМЕН ИЛИ СХЕМ В ПРОГРАММНОМ ПРИЛОЖЕНИИ | 2004 |
|
RU2371759C2 |
СИСТЕМА АВТОМАТИЗАЦИИ ОБМЕНА КОДАМИ МАРКИРОВКИ | 2021 |
|
RU2773429C1 |
СПОСОБ СОЗДАНИЯ РОБОТОТЕХНИЧЕСКИХ СИСТЕМ | 2022 |
|
RU2815598C1 |
Изобретение относится к области вычислительной техники. Техническим результатом является обеспечение валидации сложных структур данных в комплексной микросервисной архитектуре. Раскрыт компьютерно-реализуемый способ валидации сложных структур данных в комплексной микросервисной архитектуре, содержащий этапы, на которых: получают сложную структуру данных (СД); извлекают метаинформацию, соответствующую типу полученной СД из библиотеки метаинформации; согласно метаинформации извлекают из библиотеки набор правил валидации, соответствующих полученной СД; применяют набор правил валидации к СД для проверки целостности и достоверности первичных данных; выявляют по меньшей мере одну ошибку проверки СД, причем ошибка проверки является аспектом структуры СД, которая не соответствует правилам валидации; при этом выявленная по меньшей мере одна ошибка валидации включает построение детерминированной конечной автоматизации из модели контента; выбирают шаблон из множества шаблонов предложений в соответствии с выявленным конкретным видом ошибки проверки и используют выбранный шаблон предложения; исправляют по меньшей мере одну ошибку в соответствии с правилами валидации; выводят результат проверки СД для отражения определения того, что СД является действительным. 2 н. и 5 з.п. ф-лы, 2 ил., 2 табл.
1. Компьютерно-реализуемый способ валидации сложных структур данных в комплексной микросервисной архитектуре, содержащий этапы, на которых:
получают сложную структуру данных (СД);
извлекают метаинформацию, соответствующую типу полученной СД из библиотеки метаинформации;
согласно метаинформации извлекают из библиотеки набор правил валидации, соответствующих полученной СД;
применяют набор правил валидации к СД для проверки целостности и достоверности первичных данных;
выявляют по меньшей мере одну ошибку проверки СД, причем ошибка проверки является аспектом структуры СД, которая не соответствует правилам валидации;
при этом выявленная по меньшей мере одна ошибка валидации включает построение детерминированной конечной автоматизации из модели контента;
выбирают шаблон из множества шаблонов предложений в соответствии с выявленным конкретным видом ошибки проверки и используют выбранный шаблон предложения;
исправляют по меньшей мере одну ошибку в соответствии с правилами валидации;
выводят результат проверки СД для отражения определения того, что СД является действительным.
2. Способ по п. 1, характеризующийся тем, что выбирают шаблон из множества шаблонов в соответствии с выявленным конкретным видом ошибки проверки и используют выбранный шаблон.
3. Способ по п. 2, характеризующийся тем, что шаблон реализован в виде списка программ.
4. Способ по п. 1, характеризующийся тем, что определение структуры СД включает в себя определение отсутствующего, постороннего, неуместного или несоответствующего структурного аспекта СД.
5. Способ по п. 1, характеризующийся тем, что набор правил валидации дополнительно включает в себя ссылочные правила идентификатора для изучения значений, которые назначены полям в основной части данных, и определения, имеют ли значения, соответствующие полям, ожидаемые критерии.
6. Система валидации сложных структур данных в комплексной микросервисной архитектуре для реализации способа по любому из пп. 1-5, содержащая:
по крайней мере, одно пользовательское устройство, необходимое для загрузки или формирования СД; имеющее связь, по крайней мере, с одним микросервисом системы дистанционного обслуживания, содержащим модули для хранения и применения правил валидации; по крайней мере, один прикладной микросервис, содержащий модули для хранения и применения правил валидации и хранения и выбора соответствующей типу СД метаинформации; по крайней мере, один микросервис контролей, содержащий модули для управления правилами валидации и хранения матриц проверок; микросервис управления параметрами микросервиса контролей.
7. Система по п. 6, отличающаяся тем, что позволяет применять правила валидации СД как на стороне пользователя, так и на стороне прикладного микросервиса.
US 7299408 B1, 20.11.2007 | |||
US 7657832 B1, 02.02.2010 | |||
Способ защиты переносных электрических установок от опасностей, связанных с заземлением одной из фаз | 1924 |
|
SU2014A1 |
СИНХРОНИЗАЦИЯ В РЕАЛЬНОМ ВРЕМЕНИ ДАННЫХ XML МЕЖДУ ПРИЛОЖЕНИЯМИ | 2006 |
|
RU2439680C2 |
Авторы
Даты
2020-07-31—Публикация
2019-12-30—Подача