From 12ce004c73ae3425e5021ff8ea80fc55efb2f6a0 Mon Sep 17 00:00:00 2001 From: David Dal Busco Date: Wed, 20 Nov 2024 13:14:43 +0100 Subject: [PATCH 1/2] refactor: destruct candid service in ic-mgmt Signed-off-by: David Dal Busco --- .../src/ic-management.canister.ts | 74 +++++++++++++------ 1 file changed, 50 insertions(+), 24 deletions(-) diff --git a/packages/ic-management/src/ic-management.canister.ts b/packages/ic-management/src/ic-management.canister.ts index 4cb9f0e33..0247155c1 100644 --- a/packages/ic-management/src/ic-management.canister.ts +++ b/packages/ic-management/src/ic-management.canister.ts @@ -79,7 +79,9 @@ export class ICManagementCanister { settings, senderCanisterVersion, }: CreateCanisterParams = {}): Promise => { - const { canister_id } = await this.service.create_canister({ + const { create_canister } = this.service; + + const { canister_id } = await create_canister({ settings: toNullable(toCanisterSettings(settings)), sender_canister_version: toNullable(senderCanisterVersion), }); @@ -100,12 +102,15 @@ export class ICManagementCanister { canisterId, senderCanisterVersion, settings, - }: UpdateSettingsParams): Promise => - this.service.update_settings({ + }: UpdateSettingsParams): Promise => { + const { update_settings } = this.service; + + return update_settings({ canister_id: canisterId, sender_canister_version: toNullable(senderCanisterVersion), settings: toCanisterSettings(settings), }); + }; /** * Install code to a canister @@ -124,14 +129,17 @@ export class ICManagementCanister { wasmModule, arg, senderCanisterVersion, - }: InstallCodeParams): Promise => - this.service.install_code({ + }: InstallCodeParams): Promise => { + const { install_code } = this.service; + + return install_code({ mode: toInstallMode(mode), canister_id: canisterId, wasm_module: wasmModule, arg, sender_canister_version: toNullable(senderCanisterVersion), }); + }; /** * Upload chunks of Wasm modules that are too large to fit in a single message for installation purposes. @@ -243,11 +251,14 @@ export class ICManagementCanister { uninstallCode = ({ canisterId, senderCanisterVersion, - }: UninstallCodeParams): Promise => - this.service.uninstall_code({ + }: UninstallCodeParams): Promise => { + const { uninstall_code } = this.service; + + return uninstall_code({ canister_id: canisterId, sender_canister_version: toNullable(senderCanisterVersion), }); + }; /** * Start a canister @@ -255,8 +266,11 @@ export class ICManagementCanister { * @param {Principal} canisterId * @returns {Promise} */ - startCanister = (canisterId: Principal): Promise => - this.service.start_canister({ canister_id: canisterId }); + startCanister = (canisterId: Principal): Promise => { + const { start_canister } = this.service; + + return start_canister({ canister_id: canisterId }); + }; /** * Stop a canister @@ -264,8 +278,10 @@ export class ICManagementCanister { * @param {Principal} canisterId * @returns {Promise} */ - stopCanister = (canisterId: Principal): Promise => - this.service.stop_canister({ canister_id: canisterId }); + stopCanister = (canisterId: Principal): Promise => { + const { stop_canister } = this.service; + return stop_canister({ canister_id: canisterId }); + }; /** * Get canister details (memory size, status, etc.) @@ -273,10 +289,13 @@ export class ICManagementCanister { * @param {Principal} canisterId * @returns {Promise} */ - canisterStatus = (canisterId: Principal): Promise => - this.service.canister_status({ + canisterStatus = (canisterId: Principal): Promise => { + const { canister_status } = this.service; + + return canister_status({ canister_id: canisterId, }); + }; /** * Deletes a canister @@ -284,8 +303,11 @@ export class ICManagementCanister { * @param {Principal} canisterId * @returns {Promise} */ - deleteCanister = (canisterId: Principal): Promise => - this.service.delete_canister({ canister_id: canisterId }); + deleteCanister = (canisterId: Principal): Promise => { + const { delete_canister } = this.service; + + return delete_canister({ canister_id: canisterId }); + }; /** * Creates a canister. Only available on development instances. @@ -301,13 +323,14 @@ export class ICManagementCanister { amount, canisterId, }: ProvisionalCreateCanisterWithCyclesParams = {}): Promise => { - const { canister_id } = - await this.service.provisional_create_canister_with_cycles({ - settings: toNullable(toCanisterSettings(settings)), - amount: toNullable(amount), - specified_id: toNullable(canisterId), - sender_canister_version: [], - }); + const { provisional_create_canister_with_cycles } = this.service; + + const { canister_id } = await provisional_create_canister_with_cycles({ + settings: toNullable(toCanisterSettings(settings)), + amount: toNullable(amount), + specified_id: toNullable(canisterId), + sender_canister_version: [], + }); return canister_id; }; @@ -320,8 +343,11 @@ export class ICManagementCanister { */ fetchCanisterLogs = ( canisterId: Principal, - ): Promise => - this.service.fetch_canister_logs({ + ): Promise => { + const { fetch_canister_logs } = this.service; + + return fetch_canister_logs({ canister_id: canisterId, }); + }; } From eb92852978b0f3b47b3c6d4c63ccbf086d10640f Mon Sep 17 00:00:00 2001 From: github-actions <41898282+github-actions[bot]@users.noreply.github.com> Date: Wed, 20 Nov 2024 12:16:04 +0000 Subject: [PATCH 2/2] =?UTF-8?q?=F0=9F=A4=96=20Documentation=20auto-update?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- packages/ic-management/README.md | 26 +++++++++++++------------- 1 file changed, 13 insertions(+), 13 deletions(-) diff --git a/packages/ic-management/README.md b/packages/ic-management/README.md index 3c96930a9..0464dac0d 100644 --- a/packages/ic-management/README.md +++ b/packages/ic-management/README.md @@ -100,7 +100,7 @@ Update canister settings | ---------------- | ------------------------------------------------------------------------------------------- | | `updateSettings` | `({ canisterId, senderCanisterVersion, settings, }: UpdateSettingsParams) => Promise` | -[:link: Source](https://github.com/dfinity/ic-js/tree/main/packages/ic-management/src/ic-management.canister.ts#L99) +[:link: Source](https://github.com/dfinity/ic-js/tree/main/packages/ic-management/src/ic-management.canister.ts#L101) ##### :gear: installCode @@ -110,7 +110,7 @@ Install code to a canister | ------------- | ----------------------------------------------------------------------------------------------------- | | `installCode` | `({ mode, canisterId, wasmModule, arg, senderCanisterVersion, }: InstallCodeParams) => Promise` | -[:link: Source](https://github.com/dfinity/ic-js/tree/main/packages/ic-management/src/ic-management.canister.ts#L121) +[:link: Source](https://github.com/dfinity/ic-js/tree/main/packages/ic-management/src/ic-management.canister.ts#L126) ##### :gear: uploadChunk @@ -125,7 +125,7 @@ Parameters: - `params.canisterId`: The canister in which the chunks will be stored. - `params.chunk`: A chunk of Wasm module. -[:link: Source](https://github.com/dfinity/ic-js/tree/main/packages/ic-management/src/ic-management.canister.ts#L146) +[:link: Source](https://github.com/dfinity/ic-js/tree/main/packages/ic-management/src/ic-management.canister.ts#L154) ##### :gear: clearChunkStore @@ -139,7 +139,7 @@ Parameters: - `params.canisterId`: The canister in which the chunks are stored. -[:link: Source](https://github.com/dfinity/ic-js/tree/main/packages/ic-management/src/ic-management.canister.ts#L166) +[:link: Source](https://github.com/dfinity/ic-js/tree/main/packages/ic-management/src/ic-management.canister.ts#L174) ##### :gear: storedChunks @@ -153,7 +153,7 @@ Parameters: - `params.canisterId`: The canister in which the chunks are stored. -[:link: Source](https://github.com/dfinity/ic-js/tree/main/packages/ic-management/src/ic-management.canister.ts#L185) +[:link: Source](https://github.com/dfinity/ic-js/tree/main/packages/ic-management/src/ic-management.canister.ts#L193) ##### :gear: installChunkedCode @@ -173,7 +173,7 @@ Parameters: - `params.storeCanisterId`: Specifies the canister in whose chunk storage the chunks are stored (this parameter defaults to target_canister if not specified). - `params.wasmModuleHash`: The Wasm module hash as hex string. Used to check that the SHA-256 hash of wasm_module is equal to the wasm_module_hash parameter and can calls install_code with parameters. -[:link: Source](https://github.com/dfinity/ic-js/tree/main/packages/ic-management/src/ic-management.canister.ts#L210) +[:link: Source](https://github.com/dfinity/ic-js/tree/main/packages/ic-management/src/ic-management.canister.ts#L218) ##### :gear: uninstallCode @@ -183,7 +183,7 @@ Uninstall code from a canister | --------------- | -------------------------------------------------------------------------------- | | `uninstallCode` | `({ canisterId, senderCanisterVersion, }: UninstallCodeParams) => Promise` | -[:link: Source](https://github.com/dfinity/ic-js/tree/main/packages/ic-management/src/ic-management.canister.ts#L243) +[:link: Source](https://github.com/dfinity/ic-js/tree/main/packages/ic-management/src/ic-management.canister.ts#L251) ##### :gear: startCanister @@ -193,7 +193,7 @@ Start a canister | --------------- | ------------------------------------------ | | `startCanister` | `(canisterId: Principal) => Promise` | -[:link: Source](https://github.com/dfinity/ic-js/tree/main/packages/ic-management/src/ic-management.canister.ts#L258) +[:link: Source](https://github.com/dfinity/ic-js/tree/main/packages/ic-management/src/ic-management.canister.ts#L269) ##### :gear: stopCanister @@ -203,7 +203,7 @@ Stop a canister | -------------- | ------------------------------------------ | | `stopCanister` | `(canisterId: Principal) => Promise` | -[:link: Source](https://github.com/dfinity/ic-js/tree/main/packages/ic-management/src/ic-management.canister.ts#L267) +[:link: Source](https://github.com/dfinity/ic-js/tree/main/packages/ic-management/src/ic-management.canister.ts#L281) ##### :gear: canisterStatus @@ -213,7 +213,7 @@ Get canister details (memory size, status, etc.) | ---------------- | ------------------------------------------------------------ | | `canisterStatus` | `(canisterId: Principal) => Promise` | -[:link: Source](https://github.com/dfinity/ic-js/tree/main/packages/ic-management/src/ic-management.canister.ts#L276) +[:link: Source](https://github.com/dfinity/ic-js/tree/main/packages/ic-management/src/ic-management.canister.ts#L292) ##### :gear: deleteCanister @@ -223,7 +223,7 @@ Deletes a canister | ---------------- | ------------------------------------------ | | `deleteCanister` | `(canisterId: Principal) => Promise` | -[:link: Source](https://github.com/dfinity/ic-js/tree/main/packages/ic-management/src/ic-management.canister.ts#L287) +[:link: Source](https://github.com/dfinity/ic-js/tree/main/packages/ic-management/src/ic-management.canister.ts#L306) ##### :gear: provisionalCreateCanisterWithCycles @@ -233,7 +233,7 @@ Creates a canister. Only available on development instances. | ------------------------------------- | ------------------------------------------------------------------------------------------------------- | | `provisionalCreateCanisterWithCycles` | `({ settings, amount, canisterId, }?: ProvisionalCreateCanisterWithCyclesParams) => Promise` | -[:link: Source](https://github.com/dfinity/ic-js/tree/main/packages/ic-management/src/ic-management.canister.ts#L299) +[:link: Source](https://github.com/dfinity/ic-js/tree/main/packages/ic-management/src/ic-management.canister.ts#L321) ##### :gear: fetchCanisterLogs @@ -243,7 +243,7 @@ Given a canister ID as input, this method returns a vector of logs of that canis | ------------------- | ---------------------------------------------------------------- | | `fetchCanisterLogs` | `(canisterId: Principal) => Promise` | -[:link: Source](https://github.com/dfinity/ic-js/tree/main/packages/ic-management/src/ic-management.canister.ts#L321) +[:link: Source](https://github.com/dfinity/ic-js/tree/main/packages/ic-management/src/ic-management.canister.ts#L344)