From 121180bef8fcfdf2ae47355dd18d7143432414a0 Mon Sep 17 00:00:00 2001 From: Lea Lobanov Date: Sun, 8 Dec 2024 14:56:42 +0400 Subject: [PATCH] Improve explanation content --- cadence/contracts/Recipe.cdc | 1 - explanations/contract.txt | 11 ++++------- explanations/transaction.txt | 4 ++-- 3 files changed, 6 insertions(+), 10 deletions(-) diff --git a/cadence/contracts/Recipe.cdc b/cadence/contracts/Recipe.cdc index a0e560c..b097edb 100644 --- a/cadence/contracts/Recipe.cdc +++ b/cadence/contracts/Recipe.cdc @@ -67,5 +67,4 @@ access(all) contract Recipe { } // Rest of TopShot contract below - } \ No newline at end of file diff --git a/explanations/contract.txt b/explanations/contract.txt index 1ea94f9..99df85e 100644 --- a/explanations/contract.txt +++ b/explanations/contract.txt @@ -1,10 +1,7 @@ -In the TopShot contract when you are creating a Play that will be included in sets as a moment you first have to start your contract off by creating a dictionary that stores all of the plays you create. Also you would create a variable called nextPlayID to make sure you aren't overlapping on ID's. +In the TopShot contract, creating a Play to be included in sets as a Moment starts with setting up a dictionary, playDatas, to store all Plays. You also define a nextPlayID variable to ensure each Play gets a unique ID without overlaps. -Then you would create a structure that would be stored in the playDatas dictionary. Here, all that is needed for the Play struct is to input a parameter for metadata which is an object containing strings. +A Play struct is then created, which stores a unique ID and a metadata object containing descriptive key-value pairs about the Play. This struct will be stored in the playDatas dictionary, ensuring organized and efficient data management. -Once these are established, you would have an admin resource that would hold the ability to create a new play. For more information on Admin resources check out the Admin resource example. - -Here you would call the createPlay function that takes in a metadata argument. You would then create the new play by passing in the metadata. You would also take the newPlay's ID so that you can use it to assign the struct to the dictionary. - -Then you would increment the ID so that it can't be used again, emit a PlayCreated event, and store the newPlay in the dictionary. +Next, an Admin resource is introduced to control the creation of new Plays securely. The createPlay function within this resource takes metadata as input, generates a new Play using the metadata, and assigns it a unique ID from nextPlayID. After storing the Play in the playDatas dictionary, the function increments nextPlayID to avoid reuse, emits a PlayCreated event to log the creation, and returns the new Play's ID. +This streamlined process ensures that Plays are uniquely identified, securely created, and properly logged, forming the foundation for Moments that reference them. \ No newline at end of file diff --git a/explanations/transaction.txt b/explanations/transaction.txt index 0c70af2..9af9da9 100644 --- a/explanations/transaction.txt +++ b/explanations/transaction.txt @@ -1,3 +1,3 @@ -To create a play, you first need to get a reference to the admin resource from the AuthAccount. +To create a Play in the TopShot contract, you first need to obtain a reference to the Admin resource. This is done by borrowing it from the signer's storage using the authorized account's storage.borrow method and specifying the path where the Admin resource is stored. If the resource is not found, the transaction will panic to prevent further execution. -Once you receive that reference you can then create a play that gets stored in the playDatas dictionary. +Once you have the Admin resource reference, you can use it to create Plays. In this transaction, the createPlay function is called twice with different metadata for each Play. Each Play is stored in the playDatas dictionary, ensuring it is properly recorded in the contract. This approach ensures secure access to the Admin resource and allows Plays to be created efficiently and logged for future reference. \ No newline at end of file