diff --git a/.github/workflows/provision-darwin.sh b/.github/workflows/provision-darwin.sh index 9b37a68a7..df20c5e36 100755 --- a/.github/workflows/provision-darwin.sh +++ b/.github/workflows/provision-darwin.sh @@ -18,7 +18,7 @@ rm node.pkg # Install DFINITY SDK. curl --location --output install-dfx.sh "https://raw.githubusercontent.com/dfinity/sdk/master/public/install-dfxvm.sh" -DFX_VERSION=${DFX_VERSION:=0.20.1} DFXVM_INIT_YES=true bash install-dfx.sh +DFX_VERSION=${DFX_VERSION:=0.21.0} DFXVM_INIT_YES=true bash install-dfx.sh rm install-dfx.sh echo "$HOME/Library/Application Support/org.dfinity.dfx/bin" >> $GITHUB_PATH source "$HOME/Library/Application Support/org.dfinity.dfx/env" diff --git a/.github/workflows/provision-linux.sh b/.github/workflows/provision-linux.sh index 1ec2ece00..fca667b0a 100755 --- a/.github/workflows/provision-linux.sh +++ b/.github/workflows/provision-linux.sh @@ -13,7 +13,7 @@ rm install-node.sh # Install DFINITY SDK. wget --output-document install-dfx.sh "https://raw.githubusercontent.com/dfinity/sdk/master/public/install-dfxvm.sh" -DFX_VERSION=${DFX_VERSION:=0.20.1} DFXVM_INIT_YES=true bash install-dfx.sh +DFX_VERSION=${DFX_VERSION:=0.21.0} DFXVM_INIT_YES=true bash install-dfx.sh rm install-dfx.sh echo "$HOME/.local/share/dfx/bin" >> $GITHUB_PATH source "$HOME/.local/share/dfx/env" diff --git a/motoko/icp_transfer/README.md b/motoko/icp_transfer/README.md index 33d9f67e4..3b56c51fe 100644 --- a/motoko/icp_transfer/README.md +++ b/motoko/icp_transfer/README.md @@ -179,10 +179,7 @@ Replace the contents of the `src/icp_transfer_backend/main.mo` file with the fol import IcpLedger "canister:icp_ledger_canister"; import Debug "mo:base/Debug"; import Result "mo:base/Result"; -import Option "mo:base/Option"; -import Blob "mo:base/Blob"; import Error "mo:base/Error"; -import Array "mo:base/Array"; import Principal "mo:base/Principal"; actor { @@ -193,10 +190,10 @@ actor { type TransferArgs = { amount : Tokens; toPrincipal : Principal; - toSubaccount : ?Blob; + toSubaccount : ?IcpLedger.SubAccount; }; - public shared ({ caller }) func transfer(args : TransferArgs) : async Result.Result { + public shared func transfer(args : TransferArgs) : async Result.Result { Debug.print( "Transferring " # debug_show (args.amount) @@ -216,7 +213,7 @@ actor { // we are transferring from the canisters default subaccount, therefore we don't need to specify it from_subaccount = null; // we take the principal and subaccount from the arguments and convert them into an account identifier - to = Blob.toArray(Principal.toLedgerAccount(args.toPrincipal, args.toSubaccount)); + to = Principal.toLedgerAccount(args.toPrincipal, args.toSubaccount); // a timestamp indicating when the transaction was created by the caller; if it is not specified by the caller then this is set to the current ICP time created_at_time = null; }; diff --git a/motoko/icp_transfer/src/icp_transfer_backend/main.mo b/motoko/icp_transfer/src/icp_transfer_backend/main.mo index 2bff5f3bb..8e5e19e80 100644 --- a/motoko/icp_transfer/src/icp_transfer_backend/main.mo +++ b/motoko/icp_transfer/src/icp_transfer_backend/main.mo @@ -1,10 +1,7 @@ import IcpLedger "canister:icp_ledger_canister"; import Debug "mo:base/Debug"; import Result "mo:base/Result"; -import Option "mo:base/Option"; -import Blob "mo:base/Blob"; import Error "mo:base/Error"; -import Array "mo:base/Array"; import Principal "mo:base/Principal"; actor { @@ -15,10 +12,10 @@ actor { type TransferArgs = { amount : Tokens; toPrincipal : Principal; - toSubaccount : ?Blob; + toSubaccount : ?IcpLedger.SubAccount; }; - public shared ({ caller }) func transfer(args : TransferArgs) : async Result.Result { + public shared func transfer(args : TransferArgs) : async Result.Result { Debug.print( "Transferring " # debug_show (args.amount) @@ -38,7 +35,7 @@ actor { // we are transferring from the canisters default subaccount, therefore we don't need to specify it from_subaccount = null; // we take the principal and subaccount from the arguments and convert them into an account identifier - to = Blob.toArray(Principal.toLedgerAccount(args.toPrincipal, args.toSubaccount)); + to = Principal.toLedgerAccount(args.toPrincipal, args.toSubaccount); // a timestamp indicating when the transaction was created by the caller; if it is not specified by the caller then this is set to the current ICP time created_at_time = null; }; diff --git a/motoko/token_transfer/README.md b/motoko/token_transfer/README.md index 783a440d9..1d5c330b9 100644 --- a/motoko/token_transfer/README.md +++ b/motoko/token_transfer/README.md @@ -103,12 +103,10 @@ If you chose to download the ICRC-1 ledger files with the script, you need to re dfx start --background --clean ``` -### Step 5: Create a new identity that will work as a minting account: +### Step 5: Use the anonymous identity as the minting account: ```bash -dfx identity new minter --storage-mode plaintext -dfx identity use minter -export MINTER=$(dfx identity get-principal) +export MINTER=$(dfx --identity anonymous identity get-principal) ``` :::info @@ -117,10 +115,9 @@ Transfers from the minting account will create Mint transactions. Transfers to t ::: -### Step 6: Switch back to your default identity and record its principal to mint an initial balance to when deploying the ledger: +### Step 6: Record your default identity's principal to mint an initial balance to when deploying the ledger: ```bash -dfx identity use default export DEFAULT=$(dfx identity get-principal) ``` @@ -128,7 +125,7 @@ export DEFAULT=$(dfx identity get-principal) Take a moment to read the details of the call made below. Not only are you deploying an ICRC-1 ledger canister, you are also: -- Setting the minting account to the principal you saved in a previous step (`MINTER`) +- Setting the minting account to the anonymous principal you saved in a previous step (`MINTER`) - Minting 100 tokens to the DEFAULT principal - Setting the transfer fee to 0.0001 tokens - Naming the token Local ICRC1 / L-ICRC1 @@ -189,23 +186,16 @@ Replace the contents of the `src/token_transfer_backend/main.mo` file with the f import Icrc1Ledger "canister:icrc1_ledger_canister"; import Debug "mo:base/Debug"; import Result "mo:base/Result"; -import Option "mo:base/Option"; -import Blob "mo:base/Blob"; import Error "mo:base/Error"; actor { - type Account = { - owner : Principal; - subaccount : ?[Nat8]; - }; - type TransferArgs = { amount : Nat; - toAccount : Account; + toAccount : Icrc1Ledger.Account; }; - public shared ({ caller }) func transfer(args : TransferArgs) : async Result.Result { + public shared func transfer(args : TransferArgs) : async Result.Result { Debug.print( "Transferring " # debug_show (args.amount) @@ -222,7 +212,7 @@ actor { from_subaccount = null; // if not specified, the default fee for the canister is used fee = null; - // we take the principal and subaccount from the arguments and convert them into an account identifier + // the account we want to transfer tokens to to = args.toAccount; // a timestamp indicating when the transaction was created by the caller; if it is not specified by the caller then this is set to the current ICP time created_at_time = null; diff --git a/motoko/token_transfer/demo.sh b/motoko/token_transfer/demo.sh index f26936d2f..55d3ab6a5 100755 --- a/motoko/token_transfer/demo.sh +++ b/motoko/token_transfer/demo.sh @@ -5,7 +5,6 @@ trap 'dfx stop' EXIT echo "===========SETUP=========" dfx start --background --clean -dfx identity new alice_token_transfer --storage-mode plaintext --force export MINTER=$(dfx --identity anonymous identity get-principal) export DEFAULT=$(dfx identity get-principal) dfx deploy icrc1_ledger_canister --argument "(variant { Init = diff --git a/motoko/token_transfer/src/token_transfer_backend/main.mo b/motoko/token_transfer/src/token_transfer_backend/main.mo index e38105beb..ae6d52b3f 100644 --- a/motoko/token_transfer/src/token_transfer_backend/main.mo +++ b/motoko/token_transfer/src/token_transfer_backend/main.mo @@ -1,23 +1,16 @@ import Icrc1Ledger "canister:icrc1_ledger_canister"; import Debug "mo:base/Debug"; import Result "mo:base/Result"; -import Option "mo:base/Option"; -import Blob "mo:base/Blob"; import Error "mo:base/Error"; actor { - type Account = { - owner : Principal; - subaccount : ?[Nat8]; - }; - type TransferArgs = { amount : Nat; - toAccount : Account; + toAccount : Icrc1Ledger.Account; }; - public shared ({ caller }) func transfer(args : TransferArgs) : async Result.Result { + public shared func transfer(args : TransferArgs) : async Result.Result { Debug.print( "Transferring " # debug_show (args.amount)