NEW! Новый релиз 12.0.0 уже доступен! Подробности в Центре заботы

hexagon

0

Описание

Расширение для создания метамоделей и описания архитектуры в DocHub без использования jsonata

Языки

CODEOWNERS

Сообщить о нарушении
10 месяцев назад
10 месяцев назад
10 месяцев назад
10 месяцев назад
год назад
год назад
год назад
10 месяцев назад
10 месяцев назад
README.md
📙 Hexagon entry article (readme.md)

Hexagon

Hexagon – это функциональное расширение для создания метамоделей и описания архитектуры в DocHub без использования jsonata. В SEAF 1.0 слой Бизнес-архитектуры реализован с помощью Hexagon

Для описания архитектуры в виде кода в Hexagon используетсятся ограниченный набор yaml-конструкций, образующих hex-native язык:

  • декларирование объектов и отношений в формате направленного графа, где объекты представлены вершинами (узлами, nodes), а отношения -- ребрами (связями, edges);
  • запросы (queries) к графу следующего вида: все ноды, которые имеют связь (любую или определенную) с нодами, которые имеют связь... Не путать с jsonata-запросами.
  • описание представлений архитектуры в виде pattern(комбинация запросов) + landscape(результат комбинации запросов)
  • интерпретация кода архитектуры, написанного в других схемах (TBD)

Декларирование объектов и отношений

Все объекты архитектуры с точки зрения Hexagon являются однотипными или True Typeless (hex.ttl). То есть и объект "Медиа-платформа", и объект "Центр" будут относиться к типу hex.ttl. Поэтому декларирование этих объектов будет выглядеть следующим образом:

hex.ttl: # раздел манифеста, в котором объявляются любые объекты архитектуры
sber.berezka.media_platform_self: # уникальный идентификатор объекта (рекомендуем использовать концепцию DDD)
title: Медиа-платформа # наименование наименование объекта
sber.center:
title: Центр

Если между парой объектов архитектуры существует отношение, например "'Центр' владелец 'Оплаты онлайн' ", то объявляение такого отношения осуществляется следующим образом:

hex.ttl:
sber.center:
title: Центр
hex:
sber.center.aquiring: # объект-источник (source) связи
title: Оплата онлайн
hex: # атрибут объекта в котором объявляются связи
=>владелец: # направление и наименование связи
sber.center: # объект-приемник (target) связи

На данном этапе ни DH, ни Hexagon ничего "не знают" о природе декларируемых объектов. Это два каких-то связанных объекта. Для того, что бы в дальнейшем оперировать такими категориями как "Участник"(экосистемы) и "Продукт", их необходимо задекларировать, как и "обычные" объекты:

hex.ttl:
mm.party:
title: Участник
mm.product:
title: Продукт

Для того, чтобы "Центр" и "Эквайринг" относились к категории (классу, признаку и т.д.) "Участник" и "Продукт" соответственно, необходимо задеклариировать отношения между классами и экземплярами. В примере ниже используется отношение

map
, но можно выбрать любое отношение:

hex.ttl:
sber.center:
title: Центр
hex:
=>map: # мэппинг Центра
mm.party: # на класс Участник
sber.center.aquiring:
title: Оплата онлайн
hex:
=>map: # мэппинг Эквайринга
mm.product: # на класс Продукт
=>владелец:
sber.center:
Подключите пример "Березка" и в папке ba сможете увидеть болльше примеров

Для получения перечня всех объектов и отношений можно воспользоваться jsonata-запросами:

$eval($$.hexF.nodes) /* все объекты */
$eval($$.hexF.edges) /* все отношения */

подробнее о декларировании объектов и отношений

Запросы к графу

Запрос - это специальный атрибут

hexQ
hex.ttl-объекта, описывающий условия по наличию/отсутствию отношений с другими объектами. Запросы возвращают массив идентификаторов объектов архитектуры, удовлетворяющих заданным условиям.

Например, требуется получить перечень всех Участников:

hex.ttl:
all_parties: # идентификатор запроса
title: все Участники # имя запроса
hexQ: # атрибут, содержащий запрос
hex.ttl: # все hex.ttl-объекты, которые
EVERY=>map: # в обязательном порядке имеют исходящую связь "map"
mm.party: # к объекту mm.party

Выполнить запрос можно с помощью jsonata:

$eval($$.hexF.queryExe, {"qId": "all_parties"})

Поскольку запрос - это hex.ttl-объект, то мы можем поместить тело запроса, например в объект mm.party:

hex.ttl:
mm.party:
title: Участник
hexQ:
hex.ttl:
EVERY=>map:
mm.party:

Теперь при обращении mm.party является и обычным hex.ttl-объектом и запросом одновременно:

(
$lookup(hex.ttl, "mm.party").title; /* Участник */
eval($$.hexF.queryExe, {"qId": "terminal"}); /* [
"sber.center",
"sber.berezka",
"fl",
...
]
*/
)

Подробнее о запросах

Визуализация (views)

Визуализация определенной части графа называется "view" (вью, представление). В Hexagon представления описываютяся (декларируются) кодом и строятся следующим образом:

  • hex.ttl-объект, содержащий в себе определение view -- заголовок, описание, статья выводятся в верхней части view
  • декларируемая часть (определение) -- представляет собой pattern (что показывает view) и отображается в виде графа с селекторами
  • вычисляемая часть -- результат применения паттерна к графу -- подграф, соответствующий паттерну.

Рассмотрим пример:

hex.ttl:
ecosystem:
title: Экосистема
hexV:
modes: # данный вью содержит в себе subview
# - title: Предложения экосистемы
# hexV:
# # mm.parties_interested.hexQ:
# # mm.products_targeted.hexQ:
# mm.parties_providers.hexQ:
- title: Использование продуктов # наименование subview
hexV: # pattern, состоящий из
mm.party.hexQ: # запроса mm.party и
mm.product.hexQ: # запроса mm.product и
# всех связей между hex.ttl-объектом mm.party и hex.ttl-объектом mm.product (по умолчанию)
hexR: # параметры рендеринга
nest: # вложить
- <=используется в: # объекты источники в объекты-приемники
hexNav: # Добавление презентаций DH в меню, в частности,
- title: SEAF Business Architecture (Hexagon) # в раздел "Hexagon/SEAF Business Architecture (Hexagon)" добавить
link:
params:
includes:
- title: Экосистема # пункт "Экосистема" вью", ведущий к
link: "entities/hexV/view?id=ecosystem" # презентвции view of entity hexV и параметром id=ecosystem

Смотреть данный view

Подробнее о вью модах

Использование cookies

Мы используем файлы cookie в соответствии с Политикой конфиденциальности и Политикой использования cookies.

Нажимая кнопку «Принимаю», Вы даете АО «СберТех» согласие на обработку Ваших персональных данных в целях совершенствования нашего веб-сайта и Сервиса GitVerse, а также повышения удобства их использования.

Запретить использование cookies Вы можете самостоятельно в настройках Вашего браузера.