Skip to content

Commit

Permalink
Merge pull request #1838 from demergent-labs/stable_canister_api
Browse files Browse the repository at this point in the history
Stable Canister API
  • Loading branch information
lastmjs authored Jun 24, 2024
2 parents 2ea8ac8 + c0e7321 commit 1cefab0
Show file tree
Hide file tree
Showing 550 changed files with 59,288 additions and 715 deletions.
10 changes: 9 additions & 1 deletion .github/workflows/test.yml
Original file line number Diff line number Diff line change
Expand Up @@ -197,7 +197,15 @@ jobs:
"property_tests/tests/text",
"property_tests/tests/tuple",
"property_tests/tests/variant",
"property_tests/tests/vec"
"property_tests/tests/vec",
"tests/end_to_end/candid_rpc/class_syntax/query",
"tests/end_to_end/candid_rpc/class_syntax/simple_erc20",
"tests/end_to_end/candid_rpc/class_syntax/simple_user_accounts",
"tests/end_to_end/candid_rpc/class_syntax/stable_b_tree_map_instruction_threshold",
"tests/end_to_end/candid_rpc/class_syntax/stable_memory",
"tests/end_to_end/candid_rpc/class_syntax/stable_structures",
"tests/end_to_end/candid_rpc/class_syntax/timers",
"tests/end_to_end/candid_rpc/class_syntax/update",
]
END
)
Expand Down
2 changes: 1 addition & 1 deletion examples/async_await/src/async_await.ts
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
import { blob, Canister, ic, update, Void } from 'azle';
import { managementCanister } from 'azle/canisters/management';
import { blob, Canister, ic, update, Void } from 'azle/experimental';

export default Canister({
getRandomnessDirectly: update([], blob, async () => {
Expand Down
1 change: 1 addition & 0 deletions examples/async_await/test/tests.ts
Original file line number Diff line number Diff line change
@@ -1,6 +1,7 @@
import { ActorSubclass } from '@dfinity/agent';
import { expect, it, Test } from 'azle/test/jest';

// @ts-ignore this path may not exist when these tests are imported into other test projects
import { _SERVICE } from './dfx_generated/async_await/async_await.did';

export function getTests(async_await_canister: ActorSubclass<_SERVICE>): Test {
Expand Down
2 changes: 1 addition & 1 deletion examples/audio_recorder/src/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -15,7 +15,7 @@ import {
update,
Variant,
Vec
} from 'azle';
} from 'azle/experimental';

const User = Record({
id: Principal,
Expand Down
1 change: 1 addition & 0 deletions examples/audio_recorder/test/tests.ts
Original file line number Diff line number Diff line change
@@ -1,6 +1,7 @@
import { ActorSubclass } from '@dfinity/agent';
import { expect, it, Test } from 'azle/test/jest';

// @ts-ignore this path may not exist when these tests are imported into other test projects
import { _SERVICE } from './dfx_generated/audio_recorder/audio_recorder.did';

// TODO to be more thorough we could test all of the error cases as well
Expand Down
2 changes: 1 addition & 1 deletion examples/basic_bitcoin/src/bitcoin_api.ts
Original file line number Diff line number Diff line change
@@ -1,9 +1,9 @@
import { serialize } from 'azle';
import {
BitcoinNetwork,
GetUtxosResult,
MillisatoshiPerByte
} from 'azle/canisters/management/bitcoin';
import { serialize } from 'azle/experimental';

// The fees for the various bitcoin endpoints.
const GET_BALANCE_COST_CYCLES: bigint = 100_000_000n;
Expand Down
2 changes: 1 addition & 1 deletion examples/basic_bitcoin/src/ecdsa_api.ts
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
import { serialize } from 'azle';
import { serialize } from 'azle/experimental';

// The fee for the `sign_with_ecdsa` endpoint using the test key.
const SIGN_WITH_ECDSA_COST_CYCLES: bigint = 10_000_000_000n;
Expand Down
2 changes: 1 addition & 1 deletion examples/basic_bitcoin/src/index.ts
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
import { jsonParse, jsonStringify } from 'azle';
import { BitcoinNetwork } from 'azle/canisters/management';
import { jsonParse, jsonStringify } from 'azle/experimental';
import express, { Request } from 'express';

import * as bitcoinApi from './bitcoin_api';
Expand Down
2 changes: 1 addition & 1 deletion examples/basic_bitcoin/test/tests.ts
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
import { beforeAll } from '@jest/globals';
import { jsonParse, jsonStringify } from 'azle';
import { GetUtxosResult, Utxo } from 'azle/canisters/management';
import { jsonParse, jsonStringify } from 'azle/experimental';
import { expect, it, please, Test, wait } from 'azle/test/jest';
import { Transaction } from 'bitcoinjs-lib';

Expand Down
10 changes: 9 additions & 1 deletion examples/bitcoin/src/index.ts
Original file line number Diff line number Diff line change
@@ -1,9 +1,17 @@
import { blob, bool, Canister, serialize, text, update, Vec } from 'azle';
import {
GetUtxosResult,
MillisatoshiPerByte,
Satoshi
} from 'azle/canisters/management';
import {
blob,
bool,
Canister,
serialize,
text,
update,
Vec
} from 'azle/experimental';

const BITCOIN_API_CYCLE_COST = 100_000_000n;
const BITCOIN_BASE_TRANSACTION_COST = 5_000_000_000n;
Expand Down
1 change: 1 addition & 0 deletions examples/bitcoin/test/tests.ts
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,7 @@ import { afterAll, beforeAll } from '@jest/globals';
import { expect, it, please, Test, wait } from 'azle/test/jest';

import { bitcoinCli } from './bitcoin_cli';
// @ts-ignore this path may not exist when these tests are imported into other test projects
import { _SERVICE } from './dfx_generated/bitcoin/bitcoin.did';
import {
BitcoinDaemon,
Expand Down
2 changes: 1 addition & 1 deletion examples/bitcoin_psbt/src/index.ts
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
import { jsonParse, jsonStringify } from 'azle';
import { BitcoinNetwork } from 'azle/canisters/management';
import { jsonParse, jsonStringify } from 'azle/experimental';
import { determineKeyName, determineNetwork } from 'basic_bitcoin/src';
import * as bitcoinApi from 'basic_bitcoin/src/bitcoin_api';
import express, { Request } from 'express';
Expand Down
2 changes: 1 addition & 1 deletion examples/blob_array/src/index.ts
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
import { blob, Canister, query, Vec } from 'azle';
import { blob, Canister, query, Vec } from 'azle/experimental';

export default Canister({
getBlob: query([], blob, () => {
Expand Down
1 change: 1 addition & 0 deletions examples/blob_array/test/tests.ts
Original file line number Diff line number Diff line change
@@ -1,6 +1,7 @@
import { ActorSubclass } from '@dfinity/agent';
import { expect, it, Test } from 'azle/test/jest';

// @ts-ignore this path may not exist when these tests are imported into other test projects
import { _SERVICE } from './dfx_generated/blob_array/blob_array.did';

const HELLO_BYTES = Uint8Array.from([104, 101, 108, 108, 111]);
Expand Down
2 changes: 1 addition & 1 deletion examples/bytes/src/index.ts
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
import { blob, Canister, update } from 'azle';
import { blob, Canister, update } from 'azle/experimental';

export default Canister({
getBytes: update([blob], blob, (bytes) => {
Expand Down
2 changes: 1 addition & 1 deletion examples/call_raw/src/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -8,7 +8,7 @@ import {
Result,
text,
update
} from 'azle';
} from 'azle/experimental';

export default Canister({
executeCallRaw: update(
Expand Down
1 change: 1 addition & 0 deletions examples/call_raw/test/tests.ts
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,7 @@ import { ActorSubclass } from '@dfinity/agent';
import { Principal } from '@dfinity/principal';
import { expect, it, Test } from 'azle/test/jest';

// @ts-ignore this path may not exist when these tests are imported into other test projects
import { _SERVICE } from './dfx_generated/call_raw/call_raw.did';

export function getTests(call_raw_canister: ActorSubclass<_SERVICE>): Test {
Expand Down
2 changes: 1 addition & 1 deletion examples/candid_encoding/src/index.ts
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
import { blob, Canister, ic, query, text } from 'azle';
import { blob, Canister, ic, query, text } from 'azle/experimental';

export default Canister({
// encodes a Candid string to Candid bytes
Expand Down
1 change: 1 addition & 0 deletions examples/candid_encoding/test/tests.ts
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,7 @@ import { describe } from '@jest/globals';
import { expect, it, please, Test } from 'azle/test/jest';
import { execSync } from 'child_process';

// @ts-ignore this path may not exist when these tests are imported into other test projects
import { _SERVICE } from './dfx_generated/candid_encoding/candid_encoding.did';

export function getTests(
Expand Down
2 changes: 1 addition & 1 deletion examples/candid_keywords/src/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -27,7 +27,7 @@ import {
Variant,
Vec,
Void
} from 'azle';
} from 'azle/experimental';

const MyCanister = Canister({
query1: query([], bool),
Expand Down
1 change: 1 addition & 0 deletions examples/candid_keywords/test/tests.ts
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,7 @@ import { ActorSubclass } from '@dfinity/agent';
import { Principal } from '@dfinity/principal';
import { expect, it, Test } from 'azle/test/jest';

// @ts-ignore this path may not exist when these tests are imported into other test projects
import { _SERVICE } from './dfx_generated/candid_keywords/candid_keywords.did';

export function getTests(candid_canister: ActorSubclass<_SERVICE>): Test {
Expand Down
2 changes: 1 addition & 1 deletion examples/canister/src/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -8,7 +8,7 @@ import {
text,
update,
Vec
} from 'azle';
} from 'azle/experimental';

import SomeCanister from './some_canister';

Expand Down
2 changes: 1 addition & 1 deletion examples/canister/src/some_canister.ts
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
import { bool, Canister, query, text, update } from 'azle';
import { bool, Canister, query, text, update } from 'azle/experimental';

export default Canister({
query1: query([], bool, () => {
Expand Down
1 change: 1 addition & 0 deletions examples/canister/test/tests.ts
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,7 @@ import { Principal } from '@dfinity/principal';
import { getCanisterId } from 'azle/dfx';
import { expect, it, Test } from 'azle/test/jest';

// @ts-ignore this path may not exist when these tests are imported into other test projects
import { _SERVICE } from './dfx_generated/canister/canister.did';

export function getTests(canister: ActorSubclass<_SERVICE>): Test {
Expand Down
6 changes: 3 additions & 3 deletions examples/ckbtc/wallet/backend/index.ts
Original file line number Diff line number Diff line change
@@ -1,6 +1,8 @@
// TODO maybe this should be Ledger? We should look into making the Ledger
// better using the latest Wasm and did that I know of

import { ICRC } from 'azle/canisters/icrc';
import { TransferError } from 'azle/canisters/icrc/icrc_1';
import {
blob,
Canister,
Expand All @@ -16,9 +18,7 @@ import {
Some,
text,
update
} from 'azle';
import { ICRC } from 'azle/canisters/icrc';
import { TransferError } from 'azle/canisters/icrc/icrc_1';
} from 'azle/experimental';

import { Minter, UpdateBalanceResult } from './minter';

Expand Down
2 changes: 1 addition & 1 deletion examples/ckbtc/wallet/backend/minter.ts
Original file line number Diff line number Diff line change
Expand Up @@ -13,7 +13,7 @@ import {
update,
Variant,
Vec
} from 'azle';
} from 'azle/experimental';

const Utxo = Record({
outpoint: Record({ txid: Vec(nat8), vout: nat32 }),
Expand Down
2 changes: 1 addition & 1 deletion examples/ckbtc/wallet/frontend/elements/ck-app.ts
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@

import { ActorSubclass, HttpAgent, Identity } from '@dfinity/agent';
import { AuthClient } from '@dfinity/auth-client';
import { nat, nat64 } from 'azle';
import { nat, nat64 } from 'azle/experimental';
import { html, LitElement } from 'lit';
import { customElement, state } from 'lit/decorators.js';

Expand Down
2 changes: 1 addition & 1 deletion examples/complex_init/src/complex_init/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -8,7 +8,7 @@ import {
Some,
text,
Tuple
} from 'azle';
} from 'azle/experimental';

const User = Record({
id: text
Expand Down
10 changes: 9 additions & 1 deletion examples/complex_init/src/rec_init/index.ts
Original file line number Diff line number Diff line change
@@ -1,4 +1,12 @@
import { Canister, init, nat, Null, query, Recursive, Variant } from 'azle';
import {
Canister,
init,
nat,
Null,
query,
Recursive,
Variant
} from 'azle/experimental';

const Node = Recursive(() =>
Variant({
Expand Down
2 changes: 1 addition & 1 deletion examples/complex_types/src/candid_types.ts
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
import { Null, Record, Recursive, text, Variant, Vec } from 'azle';
import { Null, Record, Recursive, text, Variant, Vec } from 'azle/experimental';

export const ReactionType = Variant({
Fire: Null,
Expand Down
2 changes: 1 addition & 1 deletion examples/complex_types/src/index.ts
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
import { Canister } from 'azle';
import { Canister } from 'azle/experimental';

import { createPost, getAllPosts } from './posts';
import { createReaction, getAllReactions } from './reactions';
Expand Down
2 changes: 1 addition & 1 deletion examples/complex_types/src/posts.ts
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
import { nat32, query, text, update, Vec } from 'azle';
import { nat32, query, text, update, Vec } from 'azle/experimental';

import { Post } from './candid_types';
import { getReactionFromStateReaction } from './reactions';
Expand Down
2 changes: 1 addition & 1 deletion examples/complex_types/src/reactions.ts
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
import { nat32, query, text, update, Vec } from 'azle';
import { nat32, query, text, update, Vec } from 'azle/experimental';

import { Reaction, ReactionType } from './candid_types';
import { getPostFromStatePost } from './posts';
Expand Down
2 changes: 1 addition & 1 deletion examples/complex_types/src/state.ts
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
import { Vec } from 'azle';
import { Vec } from 'azle/experimental';

import { ReactionType } from './candid_types';

Expand Down
2 changes: 1 addition & 1 deletion examples/complex_types/src/threads.ts
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
import { nat32, query, text, update, Vec } from 'azle';
import { nat32, query, text, update, Vec } from 'azle/experimental';

import { Thread } from './candid_types';
import { getPostFromStatePost } from './posts';
Expand Down
2 changes: 1 addition & 1 deletion examples/complex_types/src/users.ts
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
import { nat32, query, text, update, Vec } from 'azle';
import { nat32, query, text, update, Vec } from 'azle/experimental';

import { User } from './candid_types';
import { getPostFromStatePost } from './posts';
Expand Down
2 changes: 1 addition & 1 deletion examples/composite_queries/src/canister1/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -9,7 +9,7 @@ import {
serialize,
text,
update
} from 'azle';
} from 'azle/experimental';

import Canister2 from '../canister2';

Expand Down
2 changes: 1 addition & 1 deletion examples/composite_queries/src/canister2/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -9,7 +9,7 @@ import {
serialize,
text,
update
} from 'azle';
} from 'azle/experimental';

import Canister3 from '../canister3';

Expand Down
2 changes: 1 addition & 1 deletion examples/composite_queries/src/canister3/index.ts
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
import { Canister, query, text } from 'azle';
import { Canister, query, text } from 'azle/experimental';

export default Canister({
deepQuery: query([], text, () => {
Expand Down
1 change: 1 addition & 0 deletions examples/composite_queries/test/tests.ts
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,7 @@ import { ActorSubclass } from '@dfinity/agent';
import { getCanisterId } from 'azle/dfx';
import { expect, it, Test } from 'azle/test/jest';

// @ts-ignore this path may not exist when these tests are imported into other test projects
import { _SERVICE } from './dfx_generated/canister1/canister1.did';

export function getTests(canister1: ActorSubclass<_SERVICE>): Test {
Expand Down
2 changes: 1 addition & 1 deletion examples/counter/src/index.ts
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
import { Canister, nat64, query, update } from 'azle';
import { Canister, nat64, query, update } from 'azle/experimental';

let count: nat64 = 0n;

Expand Down
1 change: 1 addition & 0 deletions examples/counter/test/tests.ts
Original file line number Diff line number Diff line change
@@ -1,6 +1,7 @@
import { ActorSubclass } from '@dfinity/agent';
import { expect, it, Test } from 'azle/test/jest';

// @ts-ignore this path may not exist when these tests are imported into other test projects
import { _SERVICE } from './dfx_generated/counter/counter.did';

export function getTests(counterCanister: ActorSubclass<_SERVICE>): Test {
Expand Down
2 changes: 1 addition & 1 deletion examples/cross_canister_calls/src/canister1/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -12,7 +12,7 @@ import {
update,
Vec,
Void
} from 'azle';
} from 'azle/experimental';

import Canister2 from '../canister2';
import { Account, AccountArgs } from '../canister2/types';
Expand Down
2 changes: 1 addition & 1 deletion examples/cross_canister_calls/src/canister2/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -10,7 +10,7 @@ import {
update,
Vec,
Void
} from 'azle';
} from 'azle/experimental';

import { Account, AccountArgs, State } from './types';

Expand Down
2 changes: 1 addition & 1 deletion examples/cross_canister_calls/src/canister2/types.ts
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
import { nat64, Record, text } from 'azle';
import { nat64, Record, text } from 'azle/experimental';

// TODO start using principals instead of strings for ids
export type State = {
Expand Down
2 changes: 1 addition & 1 deletion examples/cycles/src/cycles/index.ts
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
import { Canister, ic, nat, nat64, query, update } from 'azle';
import { Canister, ic, nat, nat64, query, update } from 'azle/experimental';

export default Canister({
receiveCycles: update([], nat64, () => {
Expand Down
2 changes: 1 addition & 1 deletion examples/cycles/src/intermediary/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -9,7 +9,7 @@ import {
serialize,
update,
Void
} from 'azle';
} from 'azle/experimental';

import Cycles from '../cycles';

Expand Down
2 changes: 1 addition & 1 deletion examples/date/src/index.ts
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
import { Canister, nat32, nat64, query, text } from 'azle';
import { Canister, nat32, nat64, query, text } from 'azle/experimental';

export default Canister({
getDate: query([text], nat32, (isoString) => {
Expand Down
Loading

0 comments on commit 1cefab0

Please sign in to comment.