Create a Business Network Archive (BNA) with the appropriate models, transactions, and access constraints that fulfill the requirements below. The BNA must have an initial transaction (setupHomework
) that sets up a ledger state, where the fulfillment of each requirement can be demonstrated (assuming that the ledger is empty before the call of the initial transaction). Transactions that would dynamically add participants or assets are not needed, unless noted explicitly under the requirements, except the initializer transaction.
Please test your solution on Composer Playground before submission.
For every Participant and Asset type, the unique identifier must be a non-optional String
field with the name id
. The value of the field must conform to the following format: <TYPENAME>_<COUNTER>
. For example, if we have a Participant type named User
, then the id
of the first created user must be USER_0
, the id
of the second user must be USER_1
, etc.
Implement a BNA for gym membership management.
Additional requirements:
Alice and Bob live near "Claire's Gym". Alice is an active member, but Bob isn't. Alice quits the gym. Bob submits an application. Claire's Gym accepts is, switching Bob's gym membership status to active.
applyToGym
acceptApplication
rejectApplication
cancelMembership