Я думаю о создании платформы регистрации курса блокчейна для «фитнес-центра». Я использовал Hyperledger Composer для просмотра примеров, но не нашел аналогичного примера для своей цели:
Каждый участник фитнес-центра должен иметь возможность
- записаться на курс.
- принять участие в нескольких курсах (отношение 1: n).
- удалить его посещаемость
- или передать свою регистрацию на курс другому члену фитнес-центра
Мой вопрос: Как бы вы создали умную модель проектирования в Hyperledger Composer с Fabric для моего варианта использования? Я сделал попытку здесь:
Моя главная проблема:
Является ли конструкция отношений 1: n и n: n (для полного заполнения компонентов бизнес-сети: актив / участники / транзакции и события), что один участник имеет несколько курсов, а один курс может иметь несколько групп.
В качестве «Активы в модели Fabric / Composer» я предлагаю указать «Курс и группа» (?), Но как насчет отношения MatchingCourseToGroup и отношения «Участники в группе»? Где я должен это разместить? Будет ли это частью «Бизнес-логики», написанной в функциях?
В качестве «участников модели Fabric / Composer» я бы разместил участников.
Чтобы прояснить, что я хочу сделать:
В SQL я создал бы эти таблицы для построения отношений (упрощенно для иллюстрации, * = PrimaryKey):
(tbl: Course)
----------------------------------
CourseID* / Name
----------------------------------
001 ; Swim
002 ; Basic Training
003 ; Personal Training Class
(tbl: PersonalData)
----------------------------------
UserID* / Name
----------------------------------
1 ; Marc Miller
2 ; Tom Wood
3 ; Mike Sun
(tbl: MatchingCourseToGroup)
----------------------------------
GroupID*/ CourseID
----------------------------------
A ; 001 (Group A belongs to the Swim Class)
B ; 001 (Group B also belongs to the Swim Class)
C ; 002 (Group C belongs to Basic Training)
D ; 003 (and so on...)
E ; 003
F ; 003
(tbl: ParticipantsInGroup)
----------------------------------
TicketID*/ UserID / CourseID
----------------------------------
01 ; 1 ; A
02 ; 1 ; B
03 ; 1 ; C
04 ; 2 ; A
05 ; 3 ; B
06 ; 3 ; C
Note:
Marc: takes part in 2 swim classes (Course with ID 001, received with primary key A) and (Course with ID 001, received with primary key B).
Other members can also take part in his Course.
Чтобы подойти к концу: я не совсем уверен, будет ли этот дизайн, как я это делал, работать в композиторе, возможно, у вас есть несколько хороших предложений для лучшего дизайна или подобного примера.
Потому что моей следующей проблемой будет создание хорошей реализации конфиденциальности, и поэтому, как я понял, я должен создать каналы для инкапсуляции членов с доступом для чтения, изменения возможностей или перемещения члена одной группы в другую и достижения права администратора.
(Идея состоит в том, что пользователи могут самостоятельно регистрировать их через планшет на входе).
Спасибо за вашу поддержку!