@iota/kiosk 0.1.1 → 0.2.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (86) hide show
  1. package/CHANGELOG.md +21 -0
  2. package/README.md +2 -2
  3. package/dist/cjs/bcs.d.ts +38 -2
  4. package/dist/cjs/bcs.js +20 -18
  5. package/dist/cjs/bcs.js.map +2 -2
  6. package/dist/cjs/client/kiosk-client.d.ts +4 -2
  7. package/dist/cjs/client/kiosk-client.js +10 -5
  8. package/dist/cjs/client/kiosk-client.js.map +2 -2
  9. package/dist/cjs/client/kiosk-transaction.d.ts +11 -10
  10. package/dist/cjs/client/kiosk-transaction.js +102 -140
  11. package/dist/cjs/client/kiosk-transaction.js.map +2 -2
  12. package/dist/cjs/client/tp-transaction.d.ts +8 -6
  13. package/dist/cjs/client/tp-transaction.js +54 -65
  14. package/dist/cjs/client/tp-transaction.js.map +2 -2
  15. package/dist/cjs/constants.js.map +1 -1
  16. package/dist/cjs/query/kiosk.js +2 -4
  17. package/dist/cjs/query/kiosk.js.map +1 -1
  18. package/dist/cjs/query/transfer-policy.d.ts +1 -0
  19. package/dist/cjs/query/transfer-policy.js +5 -7
  20. package/dist/cjs/query/transfer-policy.js.map +3 -3
  21. package/dist/cjs/tx/kiosk.d.ts +14 -14
  22. package/dist/cjs/tx/kiosk.js.map +2 -2
  23. package/dist/cjs/tx/personal-kiosk.d.ts +3 -3
  24. package/dist/cjs/tx/personal-kiosk.js.map +2 -2
  25. package/dist/cjs/tx/rules/attach.d.ts +5 -5
  26. package/dist/cjs/tx/rules/attach.js.map +2 -2
  27. package/dist/cjs/tx/rules/resolve.js +18 -20
  28. package/dist/cjs/tx/rules/resolve.js.map +2 -2
  29. package/dist/cjs/tx/transfer-policy.d.ts +7 -7
  30. package/dist/cjs/tx/transfer-policy.js.map +2 -2
  31. package/dist/cjs/types/kiosk.d.ts +0 -1
  32. package/dist/cjs/types/kiosk.js.map +2 -2
  33. package/dist/cjs/types/transfer-policy.d.ts +4 -2
  34. package/dist/cjs/types/transfer-policy.js.map +2 -2
  35. package/dist/cjs/utils.js +4 -7
  36. package/dist/cjs/utils.js.map +2 -2
  37. package/dist/esm/bcs.d.ts +38 -2
  38. package/dist/esm/bcs.js +20 -18
  39. package/dist/esm/bcs.js.map +2 -2
  40. package/dist/esm/client/kiosk-client.d.ts +4 -2
  41. package/dist/esm/client/kiosk-client.js +10 -5
  42. package/dist/esm/client/kiosk-client.js.map +2 -2
  43. package/dist/esm/client/kiosk-transaction.d.ts +11 -10
  44. package/dist/esm/client/kiosk-transaction.js +101 -139
  45. package/dist/esm/client/kiosk-transaction.js.map +2 -2
  46. package/dist/esm/client/tp-transaction.d.ts +8 -6
  47. package/dist/esm/client/tp-transaction.js +53 -64
  48. package/dist/esm/client/tp-transaction.js.map +2 -2
  49. package/dist/esm/constants.js.map +1 -1
  50. package/dist/esm/query/kiosk.js +2 -4
  51. package/dist/esm/query/kiosk.js.map +1 -1
  52. package/dist/esm/query/transfer-policy.d.ts +1 -0
  53. package/dist/esm/query/transfer-policy.js +7 -9
  54. package/dist/esm/query/transfer-policy.js.map +2 -2
  55. package/dist/esm/tx/kiosk.d.ts +14 -14
  56. package/dist/esm/tx/kiosk.js.map +2 -2
  57. package/dist/esm/tx/personal-kiosk.d.ts +3 -3
  58. package/dist/esm/tx/personal-kiosk.js.map +2 -2
  59. package/dist/esm/tx/rules/attach.d.ts +5 -5
  60. package/dist/esm/tx/rules/attach.js.map +2 -2
  61. package/dist/esm/tx/rules/resolve.js +18 -20
  62. package/dist/esm/tx/rules/resolve.js.map +2 -2
  63. package/dist/esm/tx/transfer-policy.d.ts +7 -7
  64. package/dist/esm/tx/transfer-policy.js.map +2 -2
  65. package/dist/esm/types/kiosk.d.ts +0 -1
  66. package/dist/esm/types/kiosk.js.map +2 -2
  67. package/dist/esm/types/transfer-policy.d.ts +4 -2
  68. package/dist/esm/types/transfer-policy.js.map +2 -2
  69. package/dist/esm/utils.js +12 -10
  70. package/dist/esm/utils.js.map +2 -2
  71. package/dist/tsconfig.esm.tsbuildinfo +1 -1
  72. package/dist/tsconfig.tsbuildinfo +1 -1
  73. package/package.json +12 -11
  74. package/src/bcs.ts +16 -19
  75. package/src/client/kiosk-client.ts +15 -5
  76. package/src/client/kiosk-transaction.ts +52 -56
  77. package/src/client/tp-transaction.ts +31 -28
  78. package/src/query/transfer-policy.ts +5 -3
  79. package/src/tx/kiosk.ts +14 -14
  80. package/src/tx/personal-kiosk.ts +3 -3
  81. package/src/tx/rules/attach.ts +5 -5
  82. package/src/tx/rules/resolve.ts +16 -16
  83. package/src/tx/transfer-policy.ts +7 -7
  84. package/src/types/kiosk.ts +0 -1
  85. package/src/types/transfer-policy.ts +4 -2
  86. package/src/utils.ts +10 -5
package/CHANGELOG.md CHANGED
@@ -1,5 +1,26 @@
1
1
  # @iota/kiosk
2
2
 
3
+ ## 0.2.0
4
+
5
+ ### Minor Changes
6
+
7
+ - 6eabd18: Changes for compatibility with the node, simplification of exposed APIs and general
8
+ improvements.
9
+
10
+ ### Patch Changes
11
+
12
+ - Updated dependencies [6eabd18]
13
+ - @iota/iota-sdk@0.3.0
14
+
15
+ ## 0.1.2
16
+
17
+ ### Patch Changes
18
+
19
+ - Updated dependencies [d423314]
20
+ - Updated dependencies [b91a3d5]
21
+ - Updated dependencies [a3c1937]
22
+ - @iota/iota-sdk@0.2.0
23
+
3
24
  ## 0.1.1
4
25
 
5
26
  ### Patch Changes
package/README.md CHANGED
@@ -3,6 +3,6 @@
3
3
  This Kiosk SDK library provides different utilities to interact/create/manage a
4
4
  [Kiosk](https://github.com/iotaledger/iota/tree/main/kiosk).
5
5
 
6
- [You can read the documentation and see examples by clicking here.]()
6
+ [You can read the documentation and see examples by clicking here.](https://wiki.iota.org/references/ts-sdk/kiosk)
7
7
 
8
- [If you are migrating from `0.6.x`, you can follow these instructions]()
8
+ [If you are migrating from `0.6.x`, you can follow these instructions](https://wiki.iota.org/references/ts-sdk/kiosk/from-v1)
package/dist/cjs/bcs.d.ts CHANGED
@@ -1,2 +1,38 @@
1
- import { bcs } from '@iota/iota-sdk/bcs';
2
- export { bcs };
1
+ export declare const KioskType: import("@iota/iota-sdk/bcs").BcsType<{
2
+ id: string;
3
+ profits: string;
4
+ owner: string;
5
+ itemCount: number;
6
+ }, {
7
+ id: string | Uint8Array;
8
+ profits: string | number | bigint;
9
+ owner: string | Uint8Array;
10
+ itemCount: number;
11
+ }>;
12
+ export declare const KioskPurchaseCap: import("@iota/iota-sdk/bcs").BcsType<{
13
+ id: string;
14
+ kioskId: string;
15
+ itemId: string;
16
+ minPrice: string;
17
+ }, {
18
+ id: string | Uint8Array;
19
+ kioskId: string | Uint8Array;
20
+ itemId: string | Uint8Array;
21
+ minPrice: string | number | bigint;
22
+ }>;
23
+ export declare const TransferPolicyCreatedEvent: import("@iota/iota-sdk/bcs").BcsType<{
24
+ id: string;
25
+ }, {
26
+ id: string | Uint8Array;
27
+ }>;
28
+ export declare const TransferPolicyType: import("@iota/iota-sdk/bcs").BcsType<{
29
+ id: string;
30
+ balance: string;
31
+ rules: string[];
32
+ }, {
33
+ id: string | Uint8Array;
34
+ balance: string | number | bigint;
35
+ rules: Iterable<string> & {
36
+ length: number;
37
+ };
38
+ }>;
package/dist/cjs/bcs.js CHANGED
@@ -18,30 +18,32 @@ var __copyProps = (to, from, except, desc) => {
18
18
  var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
19
19
  var bcs_exports = {};
20
20
  __export(bcs_exports, {
21
- bcs: () => import_bcs.bcs
21
+ KioskPurchaseCap: () => KioskPurchaseCap,
22
+ KioskType: () => KioskType,
23
+ TransferPolicyCreatedEvent: () => TransferPolicyCreatedEvent,
24
+ TransferPolicyType: () => TransferPolicyType
22
25
  });
23
26
  module.exports = __toCommonJS(bcs_exports);
24
27
  var import_bcs = require("@iota/iota-sdk/bcs");
25
28
  var import_types = require("./types/index.js");
26
- import_bcs.bcs.registerStructType(import_types.KIOSK_TYPE, {
27
- id: "address",
28
- profits: "u64",
29
- owner: "address",
30
- itemCount: "u32",
31
- allowExtensions: "bool"
29
+ const KioskType = import_bcs.bcs.struct(import_types.KIOSK_TYPE, {
30
+ id: import_bcs.bcs.Address,
31
+ profits: import_bcs.bcs.u64(),
32
+ owner: import_bcs.bcs.Address,
33
+ itemCount: import_bcs.bcs.u32()
32
34
  });
33
- import_bcs.bcs.registerStructType(import_types.KIOSK_PURCHASE_CAP, {
34
- id: "address",
35
- kioskId: "address",
36
- itemId: "address",
37
- minPrice: "u64"
35
+ const KioskPurchaseCap = import_bcs.bcs.struct(import_types.KIOSK_PURCHASE_CAP, {
36
+ id: import_bcs.bcs.Address,
37
+ kioskId: import_bcs.bcs.Address,
38
+ itemId: import_bcs.bcs.Address,
39
+ minPrice: import_bcs.bcs.u64()
38
40
  });
39
- import_bcs.bcs.registerStructType(import_types.TRANSFER_POLICY_CREATED_EVENT, {
40
- id: "address"
41
+ const TransferPolicyCreatedEvent = import_bcs.bcs.struct(import_types.TRANSFER_POLICY_CREATED_EVENT, {
42
+ id: import_bcs.bcs.Address
41
43
  });
42
- import_bcs.bcs.registerStructType(import_types.TRANSFER_POLICY_TYPE, {
43
- id: "address",
44
- balance: "u64",
45
- rules: ["vector", "string"]
44
+ const TransferPolicyType = import_bcs.bcs.struct(import_types.TRANSFER_POLICY_TYPE, {
45
+ id: import_bcs.bcs.Address,
46
+ balance: import_bcs.bcs.u64(),
47
+ rules: import_bcs.bcs.vector(import_bcs.bcs.string())
46
48
  });
47
49
  //# sourceMappingURL=bcs.js.map
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "version": 3,
3
3
  "sources": ["../../src/bcs.ts"],
4
- "sourcesContent": ["// Copyright (c) Mysten Labs, Inc.\n// Modifications Copyright (c) 2024 IOTA Stiftung\n// SPDX-License-Identifier: Apache-2.0\n\nimport { bcs } from '@iota/iota-sdk/bcs';\n\nimport {\n KIOSK_PURCHASE_CAP,\n KIOSK_TYPE,\n TRANSFER_POLICY_CREATED_EVENT,\n TRANSFER_POLICY_TYPE,\n} from './types/index.js';\n\n// Register the `Kiosk` struct for faster queries.\nbcs.registerStructType(KIOSK_TYPE, {\n id: 'address',\n profits: 'u64',\n owner: 'address',\n itemCount: 'u32',\n allowExtensions: 'bool',\n});\n\n// Register the `PurchaseCap` for faster queries.\nbcs.registerStructType(KIOSK_PURCHASE_CAP, {\n id: 'address',\n kioskId: 'address',\n itemId: 'address',\n minPrice: 'u64',\n});\n\n// Register the `TransferPolicyCreated` event data.\nbcs.registerStructType(TRANSFER_POLICY_CREATED_EVENT, {\n id: 'address',\n});\n\nbcs.registerStructType(TRANSFER_POLICY_TYPE, {\n id: 'address',\n balance: 'u64',\n rules: ['vector', 'string'],\n});\n\nexport { bcs };\n"],
5
- "mappings": ";;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAIA,iBAAoB;AAEpB,mBAKO;AAGP,eAAI,mBAAmB,yBAAY;AAAA,EAC/B,IAAI;AAAA,EACJ,SAAS;AAAA,EACT,OAAO;AAAA,EACP,WAAW;AAAA,EACX,iBAAiB;AACrB,CAAC;AAGD,eAAI,mBAAmB,iCAAoB;AAAA,EACvC,IAAI;AAAA,EACJ,SAAS;AAAA,EACT,QAAQ;AAAA,EACR,UAAU;AACd,CAAC;AAGD,eAAI,mBAAmB,4CAA+B;AAAA,EAClD,IAAI;AACR,CAAC;AAED,eAAI,mBAAmB,mCAAsB;AAAA,EACzC,IAAI;AAAA,EACJ,SAAS;AAAA,EACT,OAAO,CAAC,UAAU,QAAQ;AAC9B,CAAC;",
4
+ "sourcesContent": ["// Copyright (c) Mysten Labs, Inc.\n// Modifications Copyright (c) 2024 IOTA Stiftung\n// SPDX-License-Identifier: Apache-2.0\n\nimport { bcs } from '@iota/iota-sdk/bcs';\n\nimport {\n KIOSK_PURCHASE_CAP,\n KIOSK_TYPE,\n TRANSFER_POLICY_CREATED_EVENT,\n TRANSFER_POLICY_TYPE,\n} from './types/index.js';\n\n// Register the `Kiosk` struct for faster queries.\nexport const KioskType = bcs.struct(KIOSK_TYPE, {\n id: bcs.Address,\n profits: bcs.u64(),\n owner: bcs.Address,\n itemCount: bcs.u32(),\n});\n\n// Register the `PurchaseCap` for faster queries.\nexport const KioskPurchaseCap = bcs.struct(KIOSK_PURCHASE_CAP, {\n id: bcs.Address,\n kioskId: bcs.Address,\n itemId: bcs.Address,\n minPrice: bcs.u64(),\n});\n\n// Register the `TransferPolicyCreated` event data.\nexport const TransferPolicyCreatedEvent = bcs.struct(TRANSFER_POLICY_CREATED_EVENT, {\n id: bcs.Address,\n});\n\nexport const TransferPolicyType = bcs.struct(TRANSFER_POLICY_TYPE, {\n id: bcs.Address,\n balance: bcs.u64(),\n rules: bcs.vector(bcs.string()),\n});\n"],
5
+ "mappings": ";;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAIA,iBAAoB;AAEpB,mBAKO;AAGA,MAAM,YAAY,eAAI,OAAO,yBAAY;AAAA,EAC5C,IAAI,eAAI;AAAA,EACR,SAAS,eAAI,IAAI;AAAA,EACjB,OAAO,eAAI;AAAA,EACX,WAAW,eAAI,IAAI;AACvB,CAAC;AAGM,MAAM,mBAAmB,eAAI,OAAO,iCAAoB;AAAA,EAC3D,IAAI,eAAI;AAAA,EACR,SAAS,eAAI;AAAA,EACb,QAAQ,eAAI;AAAA,EACZ,UAAU,eAAI,IAAI;AACtB,CAAC;AAGM,MAAM,6BAA6B,eAAI,OAAO,4CAA+B;AAAA,EAChF,IAAI,eAAI;AACZ,CAAC;AAEM,MAAM,qBAAqB,eAAI,OAAO,mCAAsB;AAAA,EAC/D,IAAI,eAAI;AAAA,EACR,SAAS,eAAI,IAAI;AAAA,EACjB,OAAO,eAAI,OAAO,eAAI,OAAO,CAAC;AAClC,CAAC;",
6
6
  "names": []
7
7
  }
@@ -1,5 +1,5 @@
1
1
  import type { NetworkId } from '@iota/iota-sdk/client';
2
- import type { IotaClient } from '@iota/iota-sdk/client';
2
+ import type { PaginationArguments, IotaClient } from '@iota/iota-sdk/client';
3
3
  import type { BaseRulePackageIds, TransferPolicyRule } from '../constants.js';
4
4
  import type { FetchKioskOptions, KioskClientOptions, KioskData, OwnedKiosks } from '../types/index.js';
5
5
  /**
@@ -17,10 +17,12 @@ export declare class KioskClient {
17
17
  /**
18
18
  * Get an addresses's owned kiosks.
19
19
  * @param address The address for which we want to retrieve the kiosks.
20
+ * @param pagination Optional pagination arguments.
20
21
  * @returns An Object containing all the `kioskOwnerCap` objects as well as the kioskIds.
21
22
  */
22
- getOwnedKiosks({ address }: {
23
+ getOwnedKiosks({ address, pagination, }: {
23
24
  address: string;
25
+ pagination?: PaginationArguments<string>;
24
26
  }): Promise<OwnedKiosks>;
25
27
  /**
26
28
  * Fetches the kiosk contents.
@@ -31,18 +31,22 @@ class KioskClient {
31
31
  this.network = options.network;
32
32
  this.rules = import_constants.rules;
33
33
  this.packageIds = options.packageIds;
34
- if (options.packageIds)
35
- this.rules.push(...(0, import_constants.getBaseRules)(options.packageIds));
34
+ if (options.packageIds) this.rules.push(...(0, import_constants.getBaseRules)(options.packageIds));
36
35
  }
37
36
  /// Querying
38
37
  /**
39
38
  * Get an addresses's owned kiosks.
40
39
  * @param address The address for which we want to retrieve the kiosks.
40
+ * @param pagination Optional pagination arguments.
41
41
  * @returns An Object containing all the `kioskOwnerCap` objects as well as the kioskIds.
42
42
  */
43
- async getOwnedKiosks({ address }) {
43
+ async getOwnedKiosks({
44
+ address,
45
+ pagination
46
+ }) {
44
47
  const personalPackageId = this.packageIds?.personalKioskRulePackageId || (0, import_client.getNetwork)(this.network).kiosk?.personalKioskRulePackageId || "";
45
48
  return (0, import_kiosk.getOwnedKiosks)(this.client, address, {
49
+ pagination,
46
50
  personalKioskType: personalPackageId ? `${personalPackageId}::personal_kiosk::PersonalKioskCap` : ""
47
51
  });
48
52
  }
@@ -112,10 +116,11 @@ class KioskClient {
112
116
  const rules2 = this.packageIds || {};
113
117
  const network = this.network;
114
118
  const networkKiosk = (0, import_client.getNetwork)(network).kiosk;
115
- if (!rules2[rule] || !networkKiosk) {
119
+ const rulePackageId = rules2[rule] || networkKiosk?.[rule];
120
+ if (!rulePackageId) {
116
121
  throw new Error(`Missing packageId for rule ${rule}`);
117
122
  }
118
- return rules2[rule] || networkKiosk[rule];
123
+ return rulePackageId;
119
124
  }
120
125
  }
121
126
  //# sourceMappingURL=kiosk-client.js.map
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "version": 3,
3
3
  "sources": ["../../../src/client/kiosk-client.ts"],
4
- "sourcesContent": ["// Copyright (c) Mysten Labs, Inc.\n// Modifications Copyright (c) 2024 IOTA Stiftung\n// SPDX-License-Identifier: Apache-2.0\n\nimport type { NetworkId } from '@iota/iota-sdk/client';\nimport { getNetwork } from '@iota/iota-sdk/client';\nimport type { IotaClient } from '@iota/iota-sdk/client';\n\nimport { getBaseRules, rules } from '../constants.js';\nimport type { BaseRulePackageIds, TransferPolicyRule } from '../constants.js';\nimport { fetchKiosk, fetchKioskExtension, getOwnedKiosks } from '../query/kiosk.js';\nimport {\n queryOwnedTransferPolicies,\n queryTransferPolicy,\n queryTransferPolicyCapsByType,\n} from '../query/transfer-policy.js';\nimport type {\n FetchKioskOptions,\n KioskClientOptions,\n KioskData,\n OwnedKiosks,\n} from '../types/index.js';\n\n/**\n * A Client that allows you to interact with kiosk.\n * Offers utilities to query kiosk, craft transactions to edit your own kiosk,\n * purchase, manage transfer policies, create new kiosks etc.\n * If you pass packageIds, all functionality will be managed using these packages.\n */\nexport class KioskClient {\n client: IotaClient;\n network: NetworkId;\n rules: TransferPolicyRule[];\n packageIds?: BaseRulePackageIds;\n\n constructor(options: KioskClientOptions) {\n this.client = options.client;\n this.network = options.network;\n this.rules = rules; // add all the default rules.\n this.packageIds = options.packageIds;\n\n // Add the custom Package Ids too on the rule list.\n // Only adds the rules that are passed in the packageId object.\n if (options.packageIds) this.rules.push(...getBaseRules(options.packageIds));\n }\n\n /// Querying\n\n /**\n * Get an addresses's owned kiosks.\n * @param address The address for which we want to retrieve the kiosks.\n * @returns An Object containing all the `kioskOwnerCap` objects as well as the kioskIds.\n */\n async getOwnedKiosks({ address }: { address: string }): Promise<OwnedKiosks> {\n const personalPackageId =\n this.packageIds?.personalKioskRulePackageId ||\n getNetwork(this.network).kiosk?.personalKioskRulePackageId ||\n '';\n\n return getOwnedKiosks(this.client, address, {\n personalKioskType: personalPackageId\n ? `${personalPackageId}::personal_kiosk::PersonalKioskCap`\n : '',\n });\n }\n\n /**\n * Fetches the kiosk contents.\n * @param kioskId The ID of the kiosk to fetch.\n * @param options Optioal\n * @returns\n */\n async getKiosk({\n id,\n options,\n }: {\n id: string;\n options?: FetchKioskOptions;\n }): Promise<KioskData> {\n return (\n await fetchKiosk(\n this.client,\n id,\n {\n limit: 1000,\n },\n options || {},\n )\n ).data;\n }\n\n /**\n * Fetch the extension data (if any) for a kiosk, by type\n * @param kioskId The ID of the kiosk to lookup\n * @param extensionType The Type of the extension (can be used from by using the type returned by `getKiosk()`)\n */\n async getKioskExtension({ kioskId, type }: { kioskId: string; type: string }) {\n return fetchKioskExtension(this.client, kioskId, type);\n }\n\n /**\n * Query the Transfer Policy(ies) for type `T`.\n * @param type The Type we're querying for (E.g `0xMyAddress::hero::Hero`)\n */\n async getTransferPolicies({ type }: { type: string }) {\n return queryTransferPolicy(this.client, type);\n }\n\n /**\n * Query all the owned transfer policies for an address.\n * Returns `TransferPolicyCap` which uncludes `policyId, policyCapId, type`.\n * @param address The address we're searching the owned transfer policies for.\n */\n async getOwnedTransferPolicies({ address }: { address: string }) {\n return queryOwnedTransferPolicies(this.client, address);\n }\n\n /**\n * Query the Transfer Policy Cap for type `T`, owned by `address`\n * @param type The Type `T` for the object\n * @param address The address that owns the cap.\n */\n async getOwnedTransferPoliciesByType({ type, address }: { type: string; address: string }) {\n return queryTransferPolicyCapsByType(this.client, address, type);\n }\n\n // Someone would just have to create a `kiosk-client.ts` file in their project, initialize a KioskClient\n // and call the `addRuleResolver` function. Each rule has a `resolve` function.\n // The resolve function is automatically called on `purchaseAndResolve` function call.\n addRuleResolver(rule: TransferPolicyRule) {\n if (this.rules.find((x) => x.rule === rule.rule))\n throw new Error(`Rule ${rule.rule} resolver already exists.`);\n this.rules.push(rule);\n }\n\n /**\n * A convenient helper to get the packageIds for our supported ruleset,\n * based on `kioskClient` configuration.\n */\n getRulePackageId(\n rule:\n | 'kioskLockRulePackageId'\n | 'royaltyRulePackageId'\n | 'personalKioskRulePackageId'\n | 'floorPriceRulePackageId',\n ) {\n const rules = this.packageIds || {};\n const network = this.network;\n\n const networkKiosk = getNetwork(network).kiosk;\n\n /// Check existence of rule based on network and throw an error if it's not found.\n if (!rules[rule] || !networkKiosk) {\n throw new Error(`Missing packageId for rule ${rule}`);\n }\n\n return rules[rule] || networkKiosk[rule];\n }\n}\n"],
5
- "mappings": ";;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAKA,oBAA2B;AAG3B,uBAAoC;AAEpC,mBAAgE;AAChE,6BAIO;AAcA,MAAM,YAAY;AAAA,EAMrB,YAAY,SAA6B;AACrC,SAAK,SAAS,QAAQ;AACtB,SAAK,UAAU,QAAQ;AACvB,SAAK,QAAQ;AACb,SAAK,aAAa,QAAQ;AAI1B,QAAI,QAAQ;AAAY,WAAK,MAAM,KAAK,OAAG,+BAAa,QAAQ,UAAU,CAAC;AAAA,EAC/E;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EASA,MAAM,eAAe,EAAE,QAAQ,GAA8C;AACzE,UAAM,oBACF,KAAK,YAAY,kCACjB,0BAAW,KAAK,OAAO,EAAE,OAAO,8BAChC;AAEJ,eAAO,6BAAe,KAAK,QAAQ,SAAS;AAAA,MACxC,mBAAmB,oBACb,GAAG,wDACH;AAAA,IACV,CAAC;AAAA,EACL;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAQA,MAAM,SAAS;AAAA,IACX;AAAA,IACA;AAAA,EACJ,GAGuB;AACnB,YACI,UAAM;AAAA,MACF,KAAK;AAAA,MACL;AAAA,MACA;AAAA,QACI,OAAO;AAAA,MACX;AAAA,MACA,WAAW,CAAC;AAAA,IAChB,GACF;AAAA,EACN;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOA,MAAM,kBAAkB,EAAE,SAAS,KAAK,GAAsC;AAC1E,eAAO,kCAAoB,KAAK,QAAQ,SAAS,IAAI;AAAA,EACzD;AAAA;AAAA;AAAA;AAAA;AAAA,EAMA,MAAM,oBAAoB,EAAE,KAAK,GAAqB;AAClD,eAAO,4CAAoB,KAAK,QAAQ,IAAI;AAAA,EAChD;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOA,MAAM,yBAAyB,EAAE,QAAQ,GAAwB;AAC7D,eAAO,mDAA2B,KAAK,QAAQ,OAAO;AAAA,EAC1D;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOA,MAAM,+BAA+B,EAAE,MAAM,QAAQ,GAAsC;AACvF,eAAO,sDAA8B,KAAK,QAAQ,SAAS,IAAI;AAAA,EACnE;AAAA;AAAA;AAAA;AAAA,EAKA,gBAAgB,MAA0B;AACtC,QAAI,KAAK,MAAM,KAAK,CAAC,MAAM,EAAE,SAAS,KAAK,IAAI;AAC3C,YAAM,IAAI,MAAM,QAAQ,KAAK,+BAA+B;AAChE,SAAK,MAAM,KAAK,IAAI;AAAA,EACxB;AAAA;AAAA;AAAA;AAAA;AAAA,EAMA,iBACI,MAKF;AACE,UAAMA,SAAQ,KAAK,cAAc,CAAC;AAClC,UAAM,UAAU,KAAK;AAErB,UAAM,mBAAe,0BAAW,OAAO,EAAE;AAGzC,QAAI,CAACA,OAAM,IAAI,KAAK,CAAC,cAAc;AAC/B,YAAM,IAAI,MAAM,8BAA8B,MAAM;AAAA,IACxD;AAEA,WAAOA,OAAM,IAAI,KAAK,aAAa,IAAI;AAAA,EAC3C;AACJ;",
4
+ "sourcesContent": ["// Copyright (c) Mysten Labs, Inc.\n// Modifications Copyright (c) 2024 IOTA Stiftung\n// SPDX-License-Identifier: Apache-2.0\n\nimport type { NetworkId } from '@iota/iota-sdk/client';\nimport { getNetwork } from '@iota/iota-sdk/client';\nimport type { PaginationArguments, IotaClient } from '@iota/iota-sdk/client';\n\nimport { getBaseRules, rules } from '../constants.js';\nimport type { BaseRulePackageIds, TransferPolicyRule } from '../constants.js';\nimport { fetchKiosk, fetchKioskExtension, getOwnedKiosks } from '../query/kiosk.js';\nimport {\n queryOwnedTransferPolicies,\n queryTransferPolicy,\n queryTransferPolicyCapsByType,\n} from '../query/transfer-policy.js';\nimport type {\n FetchKioskOptions,\n KioskClientOptions,\n KioskData,\n OwnedKiosks,\n} from '../types/index.js';\n\n/**\n * A Client that allows you to interact with kiosk.\n * Offers utilities to query kiosk, craft transactions to edit your own kiosk,\n * purchase, manage transfer policies, create new kiosks etc.\n * If you pass packageIds, all functionality will be managed using these packages.\n */\nexport class KioskClient {\n client: IotaClient;\n network: NetworkId;\n rules: TransferPolicyRule[];\n packageIds?: BaseRulePackageIds;\n\n constructor(options: KioskClientOptions) {\n this.client = options.client;\n this.network = options.network;\n this.rules = rules; // add all the default rules.\n this.packageIds = options.packageIds;\n\n // Add the custom Package Ids too on the rule list.\n // Only adds the rules that are passed in the packageId object.\n if (options.packageIds) this.rules.push(...getBaseRules(options.packageIds));\n }\n\n /// Querying\n\n /**\n * Get an addresses's owned kiosks.\n * @param address The address for which we want to retrieve the kiosks.\n * @param pagination Optional pagination arguments.\n * @returns An Object containing all the `kioskOwnerCap` objects as well as the kioskIds.\n */\n async getOwnedKiosks({\n address,\n pagination,\n }: {\n address: string;\n pagination?: PaginationArguments<string>;\n }): Promise<OwnedKiosks> {\n const personalPackageId =\n this.packageIds?.personalKioskRulePackageId ||\n getNetwork(this.network).kiosk?.personalKioskRulePackageId ||\n '';\n\n return getOwnedKiosks(this.client, address, {\n pagination,\n personalKioskType: personalPackageId\n ? `${personalPackageId}::personal_kiosk::PersonalKioskCap`\n : '',\n });\n }\n\n /**\n * Fetches the kiosk contents.\n * @param kioskId The ID of the kiosk to fetch.\n * @param options Optioal\n * @returns\n */\n async getKiosk({\n id,\n options,\n }: {\n id: string;\n options?: FetchKioskOptions;\n }): Promise<KioskData> {\n return (\n await fetchKiosk(\n this.client,\n id,\n {\n limit: 1000,\n },\n options || {},\n )\n ).data;\n }\n\n /**\n * Fetch the extension data (if any) for a kiosk, by type\n * @param kioskId The ID of the kiosk to lookup\n * @param extensionType The Type of the extension (can be used from by using the type returned by `getKiosk()`)\n */\n async getKioskExtension({ kioskId, type }: { kioskId: string; type: string }) {\n return fetchKioskExtension(this.client, kioskId, type);\n }\n\n /**\n * Query the Transfer Policy(ies) for type `T`.\n * @param type The Type we're querying for (E.g `0xMyAddress::hero::Hero`)\n */\n async getTransferPolicies({ type }: { type: string }) {\n return queryTransferPolicy(this.client, type);\n }\n\n /**\n * Query all the owned transfer policies for an address.\n * Returns `TransferPolicyCap` which uncludes `policyId, policyCapId, type`.\n * @param address The address we're searching the owned transfer policies for.\n */\n async getOwnedTransferPolicies({ address }: { address: string }) {\n return queryOwnedTransferPolicies(this.client, address);\n }\n\n /**\n * Query the Transfer Policy Cap for type `T`, owned by `address`\n * @param type The Type `T` for the object\n * @param address The address that owns the cap.\n */\n async getOwnedTransferPoliciesByType({ type, address }: { type: string; address: string }) {\n return queryTransferPolicyCapsByType(this.client, address, type);\n }\n\n // Someone would just have to create a `kiosk-client.ts` file in their project, initialize a KioskClient\n // and call the `addRuleResolver` function. Each rule has a `resolve` function.\n // The resolve function is automatically called on `purchaseAndResolve` function call.\n addRuleResolver(rule: TransferPolicyRule) {\n if (this.rules.find((x) => x.rule === rule.rule))\n throw new Error(`Rule ${rule.rule} resolver already exists.`);\n this.rules.push(rule);\n }\n\n /**\n * A convenient helper to get the packageIds for our supported ruleset,\n * based on `kioskClient` configuration.\n */\n getRulePackageId(\n rule:\n | 'kioskLockRulePackageId'\n | 'royaltyRulePackageId'\n | 'personalKioskRulePackageId'\n | 'floorPriceRulePackageId',\n ) {\n const rules = this.packageIds || {};\n const network = this.network;\n\n const networkKiosk = getNetwork(network).kiosk;\n\n const rulePackageId = rules[rule] || networkKiosk?.[rule];\n\n /// Check existence of rule throw an error if it's not found.\n if (!rulePackageId) {\n throw new Error(`Missing packageId for rule ${rule}`);\n }\n\n return rulePackageId;\n }\n}\n"],
5
+ "mappings": ";;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAKA,oBAA2B;AAG3B,uBAAoC;AAEpC,mBAAgE;AAChE,6BAIO;AAcA,MAAM,YAAY;AAAA,EAMrB,YAAY,SAA6B;AACrC,SAAK,SAAS,QAAQ;AACtB,SAAK,UAAU,QAAQ;AACvB,SAAK,QAAQ;AACb,SAAK,aAAa,QAAQ;AAI1B,QAAI,QAAQ,WAAY,MAAK,MAAM,KAAK,OAAG,+BAAa,QAAQ,UAAU,CAAC;AAAA,EAC/E;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAUA,MAAM,eAAe;AAAA,IACjB;AAAA,IACA;AAAA,EACJ,GAGyB;AACrB,UAAM,oBACF,KAAK,YAAY,kCACjB,0BAAW,KAAK,OAAO,EAAE,OAAO,8BAChC;AAEJ,eAAO,6BAAe,KAAK,QAAQ,SAAS;AAAA,MACxC;AAAA,MACA,mBAAmB,oBACb,GAAG,iBAAiB,uCACpB;AAAA,IACV,CAAC;AAAA,EACL;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAQA,MAAM,SAAS;AAAA,IACX;AAAA,IACA;AAAA,EACJ,GAGuB;AACnB,YACI,UAAM;AAAA,MACF,KAAK;AAAA,MACL;AAAA,MACA;AAAA,QACI,OAAO;AAAA,MACX;AAAA,MACA,WAAW,CAAC;AAAA,IAChB,GACF;AAAA,EACN;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOA,MAAM,kBAAkB,EAAE,SAAS,KAAK,GAAsC;AAC1E,eAAO,kCAAoB,KAAK,QAAQ,SAAS,IAAI;AAAA,EACzD;AAAA;AAAA;AAAA;AAAA;AAAA,EAMA,MAAM,oBAAoB,EAAE,KAAK,GAAqB;AAClD,eAAO,4CAAoB,KAAK,QAAQ,IAAI;AAAA,EAChD;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOA,MAAM,yBAAyB,EAAE,QAAQ,GAAwB;AAC7D,eAAO,mDAA2B,KAAK,QAAQ,OAAO;AAAA,EAC1D;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOA,MAAM,+BAA+B,EAAE,MAAM,QAAQ,GAAsC;AACvF,eAAO,sDAA8B,KAAK,QAAQ,SAAS,IAAI;AAAA,EACnE;AAAA;AAAA;AAAA;AAAA,EAKA,gBAAgB,MAA0B;AACtC,QAAI,KAAK,MAAM,KAAK,CAAC,MAAM,EAAE,SAAS,KAAK,IAAI;AAC3C,YAAM,IAAI,MAAM,QAAQ,KAAK,IAAI,2BAA2B;AAChE,SAAK,MAAM,KAAK,IAAI;AAAA,EACxB;AAAA;AAAA;AAAA;AAAA;AAAA,EAMA,iBACI,MAKF;AACE,UAAMA,SAAQ,KAAK,cAAc,CAAC;AAClC,UAAM,UAAU,KAAK;AAErB,UAAM,mBAAe,0BAAW,OAAO,EAAE;AAEzC,UAAM,gBAAgBA,OAAM,IAAI,KAAK,eAAe,IAAI;AAGxD,QAAI,CAAC,eAAe;AAChB,YAAM,IAAI,MAAM,8BAA8B,IAAI,EAAE;AAAA,IACxD;AAEA,WAAO;AAAA,EACX;AACJ;",
6
6
  "names": ["rules"]
7
7
  }
@@ -1,9 +1,11 @@
1
- import type { TransactionArgument, TransactionBlock, TransactionObjectArgument } from '@iota/iota-sdk/transactions';
1
+ import type { Transaction, TransactionArgument, TransactionObjectArgument } from '@iota/iota-sdk/transactions';
2
2
  import type { ItemId, ItemReference, ItemValue, KioskOwnerCap, ObjectArgument, Price, PurchaseOptions } from '../types/index.js';
3
3
  import type { KioskClient } from './kiosk-client.js';
4
4
  export type KioskTransactionParams = {
5
- /** The TransactionBlock for this run */
6
- transactionBlock: TransactionBlock;
5
+ /** The Transaction for this run */
6
+ transaction: Transaction;
7
+ /** @deprecated use transaction instead */
8
+ transactionBlock?: Transaction;
7
9
  /**
8
10
  * You can create a new KioskClient by calling `new KioskClient()`
9
11
  */
@@ -20,11 +22,11 @@ export type KioskTransactionParams = {
20
22
  */
21
23
  export declare class KioskTransaction {
22
24
  #private;
23
- transactionBlock: TransactionBlock;
25
+ transaction: Transaction;
24
26
  kioskClient: KioskClient;
25
27
  kiosk?: TransactionObjectArgument;
26
28
  kioskCap?: TransactionObjectArgument;
27
- constructor({ transactionBlock, kioskClient, cap }: KioskTransactionParams);
29
+ constructor({ transactionBlock, transaction, kioskClient, cap, }: KioskTransactionParams);
28
30
  /**
29
31
  * Creates a kiosk and saves `kiosk` and `kioskOwnerCap` in state.
30
32
  * Helpful if we want to chain some actions before sharing + transferring the cap to the specified address.
@@ -57,7 +59,6 @@ export declare class KioskTransaction {
57
59
  shareAndTransferCap(address: string): void;
58
60
  /**
59
61
  * A function to borrow an item from a kiosk & execute any function with it.
60
- * Example: You could borrow a Fren out of a kiosk, attach an accessory (or mix), and return it.
61
62
  */
62
63
  borrowTx({ itemType, itemId }: ItemId, callback: (item: TransactionArgument) => void): void;
63
64
  /**
@@ -90,14 +91,14 @@ export declare class KioskTransaction {
90
91
  * A function to place an item in the kiosk and list it for sale in one transaction.
91
92
  * @param itemType The type `T` of the item
92
93
  * @param item The ID or Transaction Argument of the item
93
- * @param price The price in nano
94
+ * @param price The price in NANOS
94
95
  */
95
96
  placeAndList({ itemType, item, price }: ItemReference & Price): this;
96
97
  /**
97
98
  * A function to list an item in the kiosk.
98
99
  * @param itemType The type `T` of the item
99
100
  * @param itemId The ID of the item
100
- * @param price The price in nano
101
+ * @param price The price in NANOS
101
102
  */
102
103
  list({ itemType, itemId, price }: ItemId & {
103
104
  price: string | bigint;
@@ -143,7 +144,7 @@ export declare class KioskTransaction {
143
144
  * Can be called like: `const [item, transferRequest] = kioskTx.purchase({...})`
144
145
  * @param itemType The type `T` of the item
145
146
  * @param itemId The ID of the item
146
- * @param price The price in nano
147
+ * @param price The price in NANOS
147
148
  * @param sellerKiosk The kiosk which is selling the item. Can be an id or an object argument.
148
149
  */
149
150
  purchase({ itemType, itemId, price, sellerKiosk, }: ItemId & Price & {
@@ -172,7 +173,7 @@ export declare class KioskTransaction {
172
173
  */
173
174
  setCap(cap: KioskOwnerCap): this | undefined;
174
175
  /**
175
- * A function that ends up the kiosk building txb & returns the `kioskOwnerCap` back to the
176
+ * A function that ends up the kiosk building tx & returns the `kioskOwnerCap` back to the
176
177
  * `PersonalKioskCap`, in case we are operating on a personal kiosk.
177
178
  * It will also share the `kiosk` if it's not shared, and finalize the transfer of the personal cap if it's pending.
178
179
  */