HW11 Composer: Gym machine rental

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.

Problem statement

Implement a BNA for gym machine rental.

Additional requirements:

Example scenario

Alice and Bob live near "Claire's Gym," which has a single treadmill, with prices 2-3-5. Alice has an account balance of 10 units. Alice rents the machine during the afternoon for 3 units. Bob tries to do the same, but the transaction fails.

Transactions