@trufnetwork/sdk-js 0.3.7 → 0.4.1

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 (108) hide show
  1. package/dist/cjs/client/browserClient.cjs +1 -1
  2. package/dist/cjs/client/browserClient.cjs.map +1 -1
  3. package/dist/cjs/client/client.cjs +1 -1
  4. package/dist/cjs/client/client.cjs.map +1 -1
  5. package/dist/cjs/client/getLastTransactions.cjs.map +1 -1
  6. package/dist/cjs/client/listStreams.cjs.map +1 -1
  7. package/dist/cjs/client/nodeClient.cjs +1 -1
  8. package/dist/cjs/client/nodeClient.cjs.map +1 -1
  9. package/dist/cjs/contracts-api/action.cjs +301 -77
  10. package/dist/cjs/contracts-api/action.cjs.map +3 -3
  11. package/dist/cjs/contracts-api/cache.integration.test.cjs +265 -0
  12. package/dist/cjs/contracts-api/cache.integration.test.cjs.map +7 -0
  13. package/dist/cjs/contracts-api/composedAction.cjs +1 -1
  14. package/dist/cjs/contracts-api/composedAction.cjs.map +1 -1
  15. package/dist/cjs/contracts-api/deleteStream.cjs.map +1 -1
  16. package/dist/cjs/contracts-api/deployStream.cjs.map +1 -1
  17. package/dist/cjs/contracts-api/primitiveAction.cjs +1 -1
  18. package/dist/cjs/contracts-api/primitiveAction.cjs.map +1 -1
  19. package/dist/cjs/contracts-api/roleManagement.cjs +1 -1
  20. package/dist/cjs/contracts-api/roleManagement.cjs.map +1 -1
  21. package/dist/cjs/types/cache.cjs +34 -0
  22. package/dist/cjs/types/cache.cjs.map +7 -0
  23. package/dist/cjs/types/cache.test.cjs +205 -0
  24. package/dist/cjs/types/cache.test.cjs.map +7 -0
  25. package/dist/cjs/util/cacheMetadataParser.cjs +174 -0
  26. package/dist/cjs/util/cacheMetadataParser.cjs.map +7 -0
  27. package/dist/cjs/util/cacheMetadataParser.test.cjs +329 -0
  28. package/dist/cjs/util/cacheMetadataParser.test.cjs.map +7 -0
  29. package/dist/cjs/util/cacheValidation.cjs +88 -0
  30. package/dist/cjs/util/cacheValidation.cjs.map +7 -0
  31. package/dist/cjs/util/cacheValidation.test.cjs +108 -0
  32. package/dist/cjs/util/cacheValidation.test.cjs.map +7 -0
  33. package/dist/esm/client/browserClient.mjs +1 -1
  34. package/dist/esm/client/browserClient.mjs.map +1 -1
  35. package/dist/esm/client/client.mjs +1 -1
  36. package/dist/esm/client/client.mjs.map +1 -1
  37. package/dist/esm/client/getLastTransactions.mjs.map +1 -1
  38. package/dist/esm/client/listStreams.mjs.map +1 -1
  39. package/dist/esm/client/nodeClient.mjs +1 -1
  40. package/dist/esm/client/nodeClient.mjs.map +1 -1
  41. package/dist/esm/contracts-api/action.mjs +302 -77
  42. package/dist/esm/contracts-api/action.mjs.map +3 -3
  43. package/dist/esm/contracts-api/cache.integration.test.mjs +263 -0
  44. package/dist/esm/contracts-api/cache.integration.test.mjs.map +7 -0
  45. package/dist/esm/contracts-api/composedAction.mjs +1 -1
  46. package/dist/esm/contracts-api/composedAction.mjs.map +1 -1
  47. package/dist/esm/contracts-api/deleteStream.mjs.map +1 -1
  48. package/dist/esm/contracts-api/deployStream.mjs.map +1 -1
  49. package/dist/esm/contracts-api/primitiveAction.mjs +1 -1
  50. package/dist/esm/contracts-api/primitiveAction.mjs.map +1 -1
  51. package/dist/esm/contracts-api/roleManagement.mjs +1 -1
  52. package/dist/esm/contracts-api/roleManagement.mjs.map +1 -1
  53. package/dist/esm/types/cache.mjs +13 -0
  54. package/dist/esm/types/cache.mjs.map +7 -0
  55. package/dist/esm/types/cache.test.mjs +203 -0
  56. package/dist/esm/types/cache.test.mjs.map +7 -0
  57. package/dist/esm/util/cacheMetadataParser.mjs +153 -0
  58. package/dist/esm/util/cacheMetadataParser.mjs.map +7 -0
  59. package/dist/esm/util/cacheMetadataParser.test.mjs +327 -0
  60. package/dist/esm/util/cacheMetadataParser.test.mjs.map +7 -0
  61. package/dist/esm/util/cacheValidation.mjs +67 -0
  62. package/dist/esm/util/cacheValidation.mjs.map +7 -0
  63. package/dist/esm/util/cacheValidation.test.mjs +106 -0
  64. package/dist/esm/util/cacheValidation.test.mjs.map +7 -0
  65. package/dist/tsconfig.build.tsbuildinfo +1 -1
  66. package/dist/types/client/browserClient.d.ts +1 -1
  67. package/dist/types/client/browserClient.d.ts.map +1 -1
  68. package/dist/types/client/client.d.ts +8 -8
  69. package/dist/types/client/client.d.ts.map +1 -1
  70. package/dist/types/client/getLastTransactions.d.ts +1 -1
  71. package/dist/types/client/getLastTransactions.d.ts.map +1 -1
  72. package/dist/types/client/listStreams.d.ts +1 -1
  73. package/dist/types/client/listStreams.d.ts.map +1 -1
  74. package/dist/types/client/nodeClient.d.ts +1 -1
  75. package/dist/types/client/nodeClient.d.ts.map +1 -1
  76. package/dist/types/contracts-api/action.d.ts +17 -7
  77. package/dist/types/contracts-api/action.d.ts.map +1 -1
  78. package/dist/types/contracts-api/cache.integration.test.d.ts +2 -0
  79. package/dist/types/contracts-api/cache.integration.test.d.ts.map +1 -0
  80. package/dist/types/contracts-api/composedAction.d.ts +3 -3
  81. package/dist/types/contracts-api/composedAction.d.ts.map +1 -1
  82. package/dist/types/contracts-api/deleteStream.d.ts +4 -4
  83. package/dist/types/contracts-api/deleteStream.d.ts.map +1 -1
  84. package/dist/types/contracts-api/deployStream.d.ts +4 -4
  85. package/dist/types/contracts-api/deployStream.d.ts.map +1 -1
  86. package/dist/types/contracts-api/primitiveAction.d.ts +3 -3
  87. package/dist/types/contracts-api/primitiveAction.d.ts.map +1 -1
  88. package/dist/types/contracts-api/roleManagement.d.ts +3 -3
  89. package/dist/types/contracts-api/roleManagement.d.ts.map +1 -1
  90. package/dist/types/types/cache.d.ts +129 -0
  91. package/dist/types/types/cache.d.ts.map +1 -0
  92. package/dist/types/types/cache.test.d.ts +2 -0
  93. package/dist/types/types/cache.test.d.ts.map +1 -0
  94. package/dist/types/util/cacheMetadataParser.d.ts +38 -0
  95. package/dist/types/util/cacheMetadataParser.d.ts.map +1 -0
  96. package/dist/types/util/cacheMetadataParser.test.d.ts +2 -0
  97. package/dist/types/util/cacheMetadataParser.test.d.ts.map +1 -0
  98. package/dist/types/util/cacheValidation.d.ts +27 -0
  99. package/dist/types/util/cacheValidation.d.ts.map +1 -0
  100. package/dist/types/util/cacheValidation.test.d.ts +2 -0
  101. package/dist/types/util/cacheValidation.test.d.ts.map +1 -0
  102. package/package.json +5 -3
  103. package/dist/cjs/client/client.test.cjs +0 -32
  104. package/dist/cjs/client/client.test.cjs.map +0 -7
  105. package/dist/esm/client/client.test.mjs +0 -30
  106. package/dist/esm/client/client.test.mjs.map +0 -7
  107. package/dist/types/client/client.test.d.ts +0 -2
  108. package/dist/types/client/client.test.d.ts.map +0 -1
@@ -24,7 +24,7 @@ __export(browserClient_exports, {
24
24
  default: () => browserClient_default
25
25
  });
26
26
  module.exports = __toCommonJS(browserClient_exports);
27
- var import_kwil_js = require("@kwilteam/kwil-js");
27
+ var import_kwil_js = require("@trufnetwork/kwil-js");
28
28
  var import_client = require("./client.cjs");
29
29
  var BrowserTNClient = class extends import_client.BaseTNClient {
30
30
  constructor(options) {
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "version": 3,
3
3
  "sources": ["../../../src/client/browserClient.ts"],
4
- "sourcesContent": ["import { EnvironmentType } from \"@kwilteam/kwil-js/dist/core/enums\";\nimport { WebKwil } from \"@kwilteam/kwil-js\";\nimport { BaseTNClient, TNClientOptions } from \"./client\";\n\nexport class BrowserTNClient extends BaseTNClient<EnvironmentType.BROWSER> {\n constructor(options: TNClientOptions) {\n super(options);\n this.kwilClient = new WebKwil({\n ...options,\n timeout: options.timeout ?? 30000,\n kwilProvider: options.endpoint,\n });\n }\n}\n\nexport default BrowserTNClient;\n"],
4
+ "sourcesContent": ["import { EnvironmentType } from \"@trufnetwork/kwil-js/dist/core/enums\";\nimport { WebKwil } from \"@trufnetwork/kwil-js\";\nimport { BaseTNClient, TNClientOptions } from \"./client\";\n\nexport class BrowserTNClient extends BaseTNClient<EnvironmentType.BROWSER> {\n constructor(options: TNClientOptions) {\n super(options);\n this.kwilClient = new WebKwil({\n ...options,\n timeout: options.timeout ?? 30000,\n kwilProvider: options.endpoint,\n });\n }\n}\n\nexport default BrowserTNClient;\n"],
5
5
  "mappings": ";;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AACA,qBAAwB;AACxB,oBAA8C;AAEvC,IAAM,kBAAN,cAA8B,2BAAsC;AAAA,EACzE,YAAY,SAA0B;AACpC,UAAM,OAAO;AACb,SAAK,aAAa,IAAI,uBAAQ;AAAA,MAC5B,GAAG;AAAA,MACH,SAAS,QAAQ,WAAW;AAAA,MAC5B,cAAc,QAAQ;AAAA,IACxB,CAAC;AAAA,EACH;AACF;AAEA,IAAO,wBAAQ;",
6
6
  "names": []
7
7
  }
@@ -23,7 +23,7 @@ __export(client_exports, {
23
23
  BaseTNClient: () => BaseTNClient
24
24
  });
25
25
  module.exports = __toCommonJS(client_exports);
26
- var import_kwil_js = require("@kwilteam/kwil-js");
26
+ var import_kwil_js = require("@trufnetwork/kwil-js");
27
27
  var import_composedAction = require("../contracts-api/composedAction.cjs");
28
28
  var import_deployStream = require("../contracts-api/deployStream.cjs");
29
29
  var import_deleteStream = require("../contracts-api/deleteStream.cjs");
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "version": 3,
3
3
  "sources": ["../../../src/client/client.ts"],
4
- "sourcesContent": ["import { Client, KwilSigner, NodeKwil, WebKwil } from \"@kwilteam/kwil-js\";\nimport { KwilConfig } from \"@kwilteam/kwil-js/dist/api_client/config\";\nimport { Kwil } from \"@kwilteam/kwil-js/dist/client/kwil\";\nimport { EthSigner } from \"@kwilteam/kwil-js/dist/core/signature\";\nimport { EnvironmentType } from \"@kwilteam/kwil-js/dist/core/enums\";\nimport { GenericResponse } from \"@kwilteam/kwil-js/dist/core/resreq\";\nimport { TxReceipt } from \"@kwilteam/kwil-js/dist/core/tx\";\nimport { TxInfoReceipt } from \"@kwilteam/kwil-js/dist/core/txQuery\";\nimport { ComposedAction } from \"../contracts-api/composedAction\";\nimport { deployStream } from \"../contracts-api/deployStream\";\nimport { deleteStream } from \"../contracts-api/deleteStream\";\nimport { PrimitiveAction } from \"../contracts-api/primitiveAction\";\nimport { Action } from \"../contracts-api/action\";\nimport { StreamType } from \"../contracts-api/contractValues\";\nimport { StreamLocator, TNStream } from \"../types/stream\";\nimport { EthereumAddress } from \"../util/EthereumAddress\";\nimport { StreamId } from \"../util/StreamId\";\nimport { listStreams } from \"./listStreams\";\nimport { getLastTransactions } from \"./getLastTransactions\";\nimport { RoleManagement } from \"../contracts-api/roleManagement\";\nimport { OwnerIdentifier } from \"../types/role\";\n\nexport interface SignerInfo {\n // we need to have the address upfront to create the KwilSigner, instead of relying on the signer to return it asynchronously\n address: string;\n signer: EthSigner;\n}\n\nexport type TNClientOptions = {\n endpoint: string;\n signerInfo: SignerInfo;\n} & Omit<KwilConfig, \"kwilProvider\">;\n\nexport interface ListStreamsInput {\n dataProvider?: string;\n limit?: number;\n offset?: number;\n orderBy?: string;\n blockHeight?: number;\n}\n\n/**\n * @param dataProvider optional address; when omitted or null, returns for all providers\n * @param limitSize max rows to return (default 6, max 100)\n */\nexport interface GetLastTransactionsInput {\n dataProvider?: string;\n limitSize?: number;\n}\n\nexport abstract class BaseTNClient<T extends EnvironmentType> {\n protected kwilClient: Kwil<T> | undefined;\n protected signerInfo: SignerInfo;\n\n protected constructor(options: TNClientOptions) {\n this.signerInfo = options.signerInfo;\n }\n\n /**\n * Waits for a transaction to be mined by TN.\n * @param txHash - The transaction hash to wait for.\n * @param timeout - The timeout in milliseconds.\n * @returns A promise that resolves to the transaction info receipt.\n */\n async waitForTx(txHash: string, timeout = 12000): Promise<TxInfoReceipt> {\n return new Promise<TxInfoReceipt>(async (resolve, reject) => {\n const interval = setInterval(async () => {\n const receipt = await this.getKwilClient()\n [\"txInfoClient\"](txHash)\n .catch(() => ({ data: undefined, status: undefined }));\n switch (receipt.status) {\n case 200:\n if (receipt.data?.tx_result?.log !== undefined && receipt.data?.tx_result?.log.includes(\"ERROR\")) {\n reject(\n new Error(\n `Transaction failed: status ${receipt.status} : log message ${receipt.data?.tx_result.log}`,\n ))\n } else {\n resolve(receipt.data!);\n }\n break;\n case undefined:\n break;\n default:\n reject(\n new Error(\n `Transaction failed: status ${receipt.status} : log message ${receipt.data?.tx_result.log}`,\n ),\n );\n }\n }, 1000);\n setTimeout(() => {\n clearInterval(interval);\n reject(new Error(\"Transaction failed: Timeout\"));\n }, timeout);\n });\n }\n\n /**\n * Returns the Kwil signer used by the client.\n * @returns An instance of KwilSigner.\n */\n getKwilSigner(): KwilSigner {\n return new KwilSigner(\n this.signerInfo.signer,\n this.address().getAddress(),\n );\n }\n\n /**\n * Returns the Kwil client used by the client.\n * @returns An instance of Kwil.\n * @throws If the Kwil client is not initialized.\n */\n getKwilClient(): Kwil<EnvironmentType> {\n if (!this.kwilClient) {\n throw new Error(\"Kwil client not initialized\");\n }\n return this.kwilClient;\n }\n\n /**\n * Deploys a new stream.\n * @param streamId - The ID of the stream to deploy.\n * @param streamType - The type of the stream.\n * @param synchronous - Whether the deployment should be synchronous.\n * @param contractVersion\n * @returns A promise that resolves to a generic response containing the transaction receipt.\n */\n async deployStream(\n streamId: StreamId,\n streamType: StreamType,\n synchronous?: boolean,\n ): Promise<GenericResponse<TxReceipt>> {\n return await deployStream({\n streamId,\n streamType,\n synchronous,\n kwilClient: this.getKwilClient(),\n kwilSigner: this.getKwilSigner(),\n });\n }\n\n /**\n * Destroys a stream.\n * @param stream - The StreamLocator of the stream to destroy.\n * @param synchronous - Whether the destruction should be synchronous.\n * @returns A promise that resolves to a generic response containing the transaction receipt.\n */\n async destroyStream(\n stream: StreamLocator,\n synchronous?: boolean,\n ): Promise<GenericResponse<TxReceipt>> {\n return await deleteStream({\n stream,\n synchronous,\n kwilClient: this.getKwilClient(),\n kwilSigner: this.getKwilSigner(),\n });\n }\n\n /**\n * Loads an already deployed stream, permitting its API usage.\n * @returns An instance of IStream.\n */\n loadAction(): Action {\n return new Action(\n this.getKwilClient() as WebKwil | NodeKwil,\n this.getKwilSigner(),\n );\n }\n\n /**\n * Loads a primitive stream.\n * @returns An instance of IPrimitiveStream.\n */\n loadPrimitiveAction(): PrimitiveAction {\n return PrimitiveAction.fromStream(this.loadAction());\n }\n\n /**\n * Loads a composed stream.\n * @returns An instance of IComposedStream.\n */\n loadComposedAction(): ComposedAction {\n return ComposedAction.fromStream(this.loadAction());\n }\n\n /**\n * Loads the role management contract API, permitting its RBAC usage.\n */\n loadRoleManagementAction(): RoleManagement {\n return RoleManagement.fromClient(\n this.getKwilClient() as WebKwil | NodeKwil,\n this.getKwilSigner(),\n );\n }\n\n /**\n * Creates a new stream locator.\n * @param streamId - The ID of the stream.\n * @returns A StreamLocator object.\n */\n ownStreamLocator(streamId: StreamId): StreamLocator {\n return {\n streamId,\n dataProvider: this.address(),\n };\n }\n\n /**\n * Returns the address of the signer used by the client.\n * @returns An instance of EthereumAddress.\n */\n address(): EthereumAddress {\n return new EthereumAddress(this.signerInfo.address);\n }\n\n /**\n * Returns all streams from the TN network.\n * @param input - The input parameters for listing streams.\n * @returns A promise that resolves to a list of stream locators.\n */\n async getListStreams(input: ListStreamsInput): Promise<TNStream[]> {\n return listStreams(this.getKwilClient() as WebKwil | NodeKwil,this.getKwilSigner(),input);\n }\n\n /**\n * Returns the last write activity across streams.\n * @param input - The input parameters for getting last transactions.\n * @returns A promise that resolves to a list of last transactions.\n */\n async getLastTransactions(input: GetLastTransactionsInput): Promise<any[]> {\n return getLastTransactions(this.getKwilClient() as WebKwil | NodeKwil,this.getKwilSigner(),input);\n }\n\n /**\n * Get the default chain id for a provider. Use with caution, as this decreases the security of the TN.\n * @param provider - The provider URL.\n * @returns A promise that resolves to the chain ID.\n */\n public static async getDefaultChainId(provider: string) {\n const kwilClient = new Client({\n kwilProvider: provider,\n });\n const chainInfo = await kwilClient[\"chainInfoClient\"]();\n return chainInfo.data?.chain_id;\n }\n\n /*\n * High-level role-management helpers. These wrap the lower-level\n * RoleManagement contract calls and expose a simpler API on the\n * TN client.\n */\n\n /** Grants a role to one or more wallets. */\n async grantRole(input: {\n owner: OwnerIdentifier;\n roleName: string;\n wallets: EthereumAddress | EthereumAddress[];\n synchronous?: boolean;\n }): Promise<string> {\n const rm = this.loadRoleManagementAction();\n const walletsArr: EthereumAddress[] = Array.isArray(input.wallets)\n ? input.wallets\n : [input.wallets];\n const tx = await rm.grantRole(\n {\n owner: input.owner,\n roleName: input.roleName,\n wallets: walletsArr,\n },\n input.synchronous,\n );\n return tx.data?.tx_hash as unknown as string;\n }\n\n /** Revokes a role from one or more wallets. */\n async revokeRole(input: {\n owner: OwnerIdentifier;\n roleName: string;\n wallets: EthereumAddress | EthereumAddress[];\n synchronous?: boolean;\n }): Promise<string> {\n const rm = this.loadRoleManagementAction();\n const walletsArr: EthereumAddress[] = Array.isArray(input.wallets)\n ? input.wallets\n : [input.wallets];\n const tx = await rm.revokeRole(\n {\n owner: input.owner,\n roleName: input.roleName,\n wallets: walletsArr,\n },\n input.synchronous,\n );\n return tx.data?.tx_hash as unknown as string;\n }\n\n /**\n * Checks if a wallet is member of a role.\n * Returns true if the wallet is a member.\n */\n async isMemberOf(input: {\n owner: OwnerIdentifier;\n roleName: string;\n wallet: EthereumAddress;\n }): Promise<boolean> {\n const rm = this.loadRoleManagementAction();\n const res = await rm.areMembersOf({\n owner: input.owner,\n roleName: input.roleName,\n wallets: [input.wallet],\n });\n return res.length > 0 && res[0].isMember;\n }\n\n /**\n * Lists role members \u2013 currently unsupported in the\n * smart-contract layer.\n */\n async listRoleMembers(input: {\n owner: OwnerIdentifier;\n roleName: string;\n limit?: number;\n offset?: number;\n }): Promise<import(\"../types/role\").RoleMember[]> {\n const rm = this.loadRoleManagementAction();\n return rm.listRoleMembers({\n owner: input.owner,\n roleName: input.roleName,\n limit: input.limit,\n offset: input.offset,\n });\n }\n}\n"],
4
+ "sourcesContent": ["import { Client, KwilSigner, NodeKwil, WebKwil } from \"@trufnetwork/kwil-js\";\nimport { KwilConfig } from \"@trufnetwork/kwil-js/dist/api_client/config\";\nimport { Kwil } from \"@trufnetwork/kwil-js/dist/client/kwil\";\nimport { EthSigner } from \"@trufnetwork/kwil-js/dist/core/signature\";\nimport { EnvironmentType } from \"@trufnetwork/kwil-js/dist/core/enums\";\nimport { GenericResponse } from \"@trufnetwork/kwil-js/dist/core/resreq\";\nimport { TxReceipt } from \"@trufnetwork/kwil-js/dist/core/tx\";\nimport { TxInfoReceipt } from \"@trufnetwork/kwil-js/dist/core/txQuery\";\nimport { ComposedAction } from \"../contracts-api/composedAction\";\nimport { deployStream } from \"../contracts-api/deployStream\";\nimport { deleteStream } from \"../contracts-api/deleteStream\";\nimport { PrimitiveAction } from \"../contracts-api/primitiveAction\";\nimport { Action } from \"../contracts-api/action\";\nimport { StreamType } from \"../contracts-api/contractValues\";\nimport { StreamLocator, TNStream } from \"../types/stream\";\nimport { EthereumAddress } from \"../util/EthereumAddress\";\nimport { StreamId } from \"../util/StreamId\";\nimport { listStreams } from \"./listStreams\";\nimport { getLastTransactions } from \"./getLastTransactions\";\nimport { RoleManagement } from \"../contracts-api/roleManagement\";\nimport { OwnerIdentifier } from \"../types/role\";\n\nexport interface SignerInfo {\n // we need to have the address upfront to create the KwilSigner, instead of relying on the signer to return it asynchronously\n address: string;\n signer: EthSigner;\n}\n\nexport type TNClientOptions = {\n endpoint: string;\n signerInfo: SignerInfo;\n} & Omit<KwilConfig, \"kwilProvider\">;\n\nexport interface ListStreamsInput {\n dataProvider?: string;\n limit?: number;\n offset?: number;\n orderBy?: string;\n blockHeight?: number;\n}\n\n/**\n * @param dataProvider optional address; when omitted or null, returns for all providers\n * @param limitSize max rows to return (default 6, max 100)\n */\nexport interface GetLastTransactionsInput {\n dataProvider?: string;\n limitSize?: number;\n}\n\nexport abstract class BaseTNClient<T extends EnvironmentType> {\n protected kwilClient: Kwil<T> | undefined;\n protected signerInfo: SignerInfo;\n\n protected constructor(options: TNClientOptions) {\n this.signerInfo = options.signerInfo;\n }\n\n /**\n * Waits for a transaction to be mined by TN.\n * @param txHash - The transaction hash to wait for.\n * @param timeout - The timeout in milliseconds.\n * @returns A promise that resolves to the transaction info receipt.\n */\n async waitForTx(txHash: string, timeout = 12000): Promise<TxInfoReceipt> {\n return new Promise<TxInfoReceipt>(async (resolve, reject) => {\n const interval = setInterval(async () => {\n const receipt = await this.getKwilClient()\n [\"txInfoClient\"](txHash)\n .catch(() => ({ data: undefined, status: undefined }));\n switch (receipt.status) {\n case 200:\n if (receipt.data?.tx_result?.log !== undefined && receipt.data?.tx_result?.log.includes(\"ERROR\")) {\n reject(\n new Error(\n `Transaction failed: status ${receipt.status} : log message ${receipt.data?.tx_result.log}`,\n ))\n } else {\n resolve(receipt.data!);\n }\n break;\n case undefined:\n break;\n default:\n reject(\n new Error(\n `Transaction failed: status ${receipt.status} : log message ${receipt.data?.tx_result.log}`,\n ),\n );\n }\n }, 1000);\n setTimeout(() => {\n clearInterval(interval);\n reject(new Error(\"Transaction failed: Timeout\"));\n }, timeout);\n });\n }\n\n /**\n * Returns the Kwil signer used by the client.\n * @returns An instance of KwilSigner.\n */\n getKwilSigner(): KwilSigner {\n return new KwilSigner(\n this.signerInfo.signer,\n this.address().getAddress(),\n );\n }\n\n /**\n * Returns the Kwil client used by the client.\n * @returns An instance of Kwil.\n * @throws If the Kwil client is not initialized.\n */\n getKwilClient(): Kwil<EnvironmentType> {\n if (!this.kwilClient) {\n throw new Error(\"Kwil client not initialized\");\n }\n return this.kwilClient;\n }\n\n /**\n * Deploys a new stream.\n * @param streamId - The ID of the stream to deploy.\n * @param streamType - The type of the stream.\n * @param synchronous - Whether the deployment should be synchronous.\n * @param contractVersion\n * @returns A promise that resolves to a generic response containing the transaction receipt.\n */\n async deployStream(\n streamId: StreamId,\n streamType: StreamType,\n synchronous?: boolean,\n ): Promise<GenericResponse<TxReceipt>> {\n return await deployStream({\n streamId,\n streamType,\n synchronous,\n kwilClient: this.getKwilClient(),\n kwilSigner: this.getKwilSigner(),\n });\n }\n\n /**\n * Destroys a stream.\n * @param stream - The StreamLocator of the stream to destroy.\n * @param synchronous - Whether the destruction should be synchronous.\n * @returns A promise that resolves to a generic response containing the transaction receipt.\n */\n async destroyStream(\n stream: StreamLocator,\n synchronous?: boolean,\n ): Promise<GenericResponse<TxReceipt>> {\n return await deleteStream({\n stream,\n synchronous,\n kwilClient: this.getKwilClient(),\n kwilSigner: this.getKwilSigner(),\n });\n }\n\n /**\n * Loads an already deployed stream, permitting its API usage.\n * @returns An instance of IStream.\n */\n loadAction(): Action {\n return new Action(\n this.getKwilClient() as WebKwil | NodeKwil,\n this.getKwilSigner(),\n );\n }\n\n /**\n * Loads a primitive stream.\n * @returns An instance of IPrimitiveStream.\n */\n loadPrimitiveAction(): PrimitiveAction {\n return PrimitiveAction.fromStream(this.loadAction());\n }\n\n /**\n * Loads a composed stream.\n * @returns An instance of IComposedStream.\n */\n loadComposedAction(): ComposedAction {\n return ComposedAction.fromStream(this.loadAction());\n }\n\n /**\n * Loads the role management contract API, permitting its RBAC usage.\n */\n loadRoleManagementAction(): RoleManagement {\n return RoleManagement.fromClient(\n this.getKwilClient() as WebKwil | NodeKwil,\n this.getKwilSigner(),\n );\n }\n\n /**\n * Creates a new stream locator.\n * @param streamId - The ID of the stream.\n * @returns A StreamLocator object.\n */\n ownStreamLocator(streamId: StreamId): StreamLocator {\n return {\n streamId,\n dataProvider: this.address(),\n };\n }\n\n /**\n * Returns the address of the signer used by the client.\n * @returns An instance of EthereumAddress.\n */\n address(): EthereumAddress {\n return new EthereumAddress(this.signerInfo.address);\n }\n\n /**\n * Returns all streams from the TN network.\n * @param input - The input parameters for listing streams.\n * @returns A promise that resolves to a list of stream locators.\n */\n async getListStreams(input: ListStreamsInput): Promise<TNStream[]> {\n return listStreams(this.getKwilClient() as WebKwil | NodeKwil,this.getKwilSigner(),input);\n }\n\n /**\n * Returns the last write activity across streams.\n * @param input - The input parameters for getting last transactions.\n * @returns A promise that resolves to a list of last transactions.\n */\n async getLastTransactions(input: GetLastTransactionsInput): Promise<any[]> {\n return getLastTransactions(this.getKwilClient() as WebKwil | NodeKwil,this.getKwilSigner(),input);\n }\n\n /**\n * Get the default chain id for a provider. Use with caution, as this decreases the security of the TN.\n * @param provider - The provider URL.\n * @returns A promise that resolves to the chain ID.\n */\n public static async getDefaultChainId(provider: string) {\n const kwilClient = new Client({\n kwilProvider: provider,\n });\n const chainInfo = await kwilClient[\"chainInfoClient\"]();\n return chainInfo.data?.chain_id;\n }\n\n /*\n * High-level role-management helpers. These wrap the lower-level\n * RoleManagement contract calls and expose a simpler API on the\n * TN client.\n */\n\n /** Grants a role to one or more wallets. */\n async grantRole(input: {\n owner: OwnerIdentifier;\n roleName: string;\n wallets: EthereumAddress | EthereumAddress[];\n synchronous?: boolean;\n }): Promise<string> {\n const rm = this.loadRoleManagementAction();\n const walletsArr: EthereumAddress[] = Array.isArray(input.wallets)\n ? input.wallets\n : [input.wallets];\n const tx = await rm.grantRole(\n {\n owner: input.owner,\n roleName: input.roleName,\n wallets: walletsArr,\n },\n input.synchronous,\n );\n return tx.data?.tx_hash as unknown as string;\n }\n\n /** Revokes a role from one or more wallets. */\n async revokeRole(input: {\n owner: OwnerIdentifier;\n roleName: string;\n wallets: EthereumAddress | EthereumAddress[];\n synchronous?: boolean;\n }): Promise<string> {\n const rm = this.loadRoleManagementAction();\n const walletsArr: EthereumAddress[] = Array.isArray(input.wallets)\n ? input.wallets\n : [input.wallets];\n const tx = await rm.revokeRole(\n {\n owner: input.owner,\n roleName: input.roleName,\n wallets: walletsArr,\n },\n input.synchronous,\n );\n return tx.data?.tx_hash as unknown as string;\n }\n\n /**\n * Checks if a wallet is member of a role.\n * Returns true if the wallet is a member.\n */\n async isMemberOf(input: {\n owner: OwnerIdentifier;\n roleName: string;\n wallet: EthereumAddress;\n }): Promise<boolean> {\n const rm = this.loadRoleManagementAction();\n const res = await rm.areMembersOf({\n owner: input.owner,\n roleName: input.roleName,\n wallets: [input.wallet],\n });\n return res.length > 0 && res[0].isMember;\n }\n\n /**\n * Lists role members \u2013 currently unsupported in the\n * smart-contract layer.\n */\n async listRoleMembers(input: {\n owner: OwnerIdentifier;\n roleName: string;\n limit?: number;\n offset?: number;\n }): Promise<import(\"../types/role\").RoleMember[]> {\n const rm = this.loadRoleManagementAction();\n return rm.listRoleMembers({\n owner: input.owner,\n roleName: input.roleName,\n limit: input.limit,\n offset: input.offset,\n });\n }\n}\n"],
5
5
  "mappings": "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",
6
6
  "names": []
7
7
  }
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "version": 3,
3
3
  "sources": ["../../../src/client/getLastTransactions.ts"],
4
- "sourcesContent": ["import { WebKwil, NodeKwil, KwilSigner } from \"@kwilteam/kwil-js\";\r\nimport { GetLastTransactionsInput } from \"./client\";\r\nimport { LastTransaction } from \"../types/transaction\";\r\n\r\nconst INDEXER_BASE = \"https://indexer.infra.truf.network\";\r\nconst RPC_URL = \"https://gateway.mainnet.truf.network/rpc/v1\";\r\n\r\nexport async function getLastTransactions(\r\n kwilClient: WebKwil | NodeKwil,\r\n kwilSigner: KwilSigner,\r\n input: GetLastTransactionsInput\r\n): Promise<LastTransaction[]> {\r\n // 1) call your SQL action\r\n const res = await kwilClient.call(\r\n {\r\n name: \"get_last_transactions\",\r\n namespace: \"main\",\r\n inputs: {\r\n $data_provider: input.dataProvider ?? null,\r\n $limit_size: input.limitSize ?? 6,\r\n },\r\n },\r\n kwilSigner\r\n );\r\n const rows = (res.data?.result as { created_at: number; method: string }[]) || [];\r\n\r\n // 2) build per-block Promises\r\n const tasks = rows.map(({ created_at, method }) => {\r\n const blockHeight = Number(created_at);\r\n if (Number.isNaN(blockHeight)) {\r\n return Promise.reject(new Error(`Invalid block height returned: ${created_at}`));\r\n }\r\n\r\n const txUrl = `${INDEXER_BASE}/v0/chain/transactions`\r\n + `?from-block=${blockHeight}&to-block=${blockHeight}`\r\n + `&order=asc&limit=1`;\r\n\r\n // INDEXER: always return a { sender, hash } object\r\n const txPromise = fetch(txUrl).then(async (resp) => {\r\n if (!resp.ok) throw new Error(`Indexer fetch failed: ${resp.status}`);\r\n const json = (await resp.json()) as {\r\n ok: boolean;\r\n data: Array<{ hash: string; sender: string }>;\r\n };\r\n if (!json.ok || json.data.length === 0) {\r\n return { sender: \"(unknown)\", hash: \"(unknown)\" };\r\n }\r\n const { hash, sender } = json.data[0];\r\n return { sender, hash };\r\n });\r\n\r\n // RPC: get stamp_ms\r\n const rpcPromise = fetch(RPC_URL, {\r\n method: \"POST\",\r\n headers: { \"Content-Type\": \"application/json\" },\r\n body: JSON.stringify({\r\n jsonrpc: \"2.0\",\r\n method: \"chain.block\",\r\n params: { height: blockHeight },\r\n id: 1,\r\n }),\r\n }).then(async (resp) => {\r\n if (!resp.ok) {\r\n const txt = await resp.text();\r\n throw new Error(`RPC fetch failed: ${resp.status} \u2013 ${txt}`);\r\n }\r\n const rpc = (await resp.json()) as {\r\n result: { block: { header: { stamp_ms: number } } };\r\n };\r\n return rpc.result.block.header.stamp_ms;\r\n });\r\n\r\n // wait for both\r\n return Promise.all([txPromise, rpcPromise]).then(\r\n ([{ sender, hash }, stampMs]) => ({\r\n blockHeight,\r\n method,\r\n sender,\r\n transactionHash: hash,\r\n stampMs,\r\n })\r\n );\r\n });\r\n\r\n // 3) await all in parallel\r\n return Promise.all(tasks);\r\n}\r\n"],
4
+ "sourcesContent": ["import { WebKwil, NodeKwil, KwilSigner } from \"@trufnetwork/kwil-js\";\r\nimport { GetLastTransactionsInput } from \"./client\";\r\nimport { LastTransaction } from \"../types/transaction\";\r\n\r\nconst INDEXER_BASE = \"https://indexer.infra.truf.network\";\r\nconst RPC_URL = \"https://gateway.mainnet.truf.network/rpc/v1\";\r\n\r\nexport async function getLastTransactions(\r\n kwilClient: WebKwil | NodeKwil,\r\n kwilSigner: KwilSigner,\r\n input: GetLastTransactionsInput\r\n): Promise<LastTransaction[]> {\r\n // 1) call your SQL action\r\n const res = await kwilClient.call(\r\n {\r\n name: \"get_last_transactions\",\r\n namespace: \"main\",\r\n inputs: {\r\n $data_provider: input.dataProvider ?? null,\r\n $limit_size: input.limitSize ?? 6,\r\n },\r\n },\r\n kwilSigner\r\n );\r\n const rows = (res.data?.result as { created_at: number; method: string }[]) || [];\r\n\r\n // 2) build per-block Promises\r\n const tasks = rows.map(({ created_at, method }) => {\r\n const blockHeight = Number(created_at);\r\n if (Number.isNaN(blockHeight)) {\r\n return Promise.reject(new Error(`Invalid block height returned: ${created_at}`));\r\n }\r\n\r\n const txUrl = `${INDEXER_BASE}/v0/chain/transactions`\r\n + `?from-block=${blockHeight}&to-block=${blockHeight}`\r\n + `&order=asc&limit=1`;\r\n\r\n // INDEXER: always return a { sender, hash } object\r\n const txPromise = fetch(txUrl).then(async (resp) => {\r\n if (!resp.ok) throw new Error(`Indexer fetch failed: ${resp.status}`);\r\n const json = (await resp.json()) as {\r\n ok: boolean;\r\n data: Array<{ hash: string; sender: string }>;\r\n };\r\n if (!json.ok || json.data.length === 0) {\r\n return { sender: \"(unknown)\", hash: \"(unknown)\" };\r\n }\r\n const { hash, sender } = json.data[0];\r\n return { sender, hash };\r\n });\r\n\r\n // RPC: get stamp_ms\r\n const rpcPromise = fetch(RPC_URL, {\r\n method: \"POST\",\r\n headers: { \"Content-Type\": \"application/json\" },\r\n body: JSON.stringify({\r\n jsonrpc: \"2.0\",\r\n method: \"chain.block\",\r\n params: { height: blockHeight },\r\n id: 1,\r\n }),\r\n }).then(async (resp) => {\r\n if (!resp.ok) {\r\n const txt = await resp.text();\r\n throw new Error(`RPC fetch failed: ${resp.status} \u2013 ${txt}`);\r\n }\r\n const rpc = (await resp.json()) as {\r\n result: { block: { header: { stamp_ms: number } } };\r\n };\r\n return rpc.result.block.header.stamp_ms;\r\n });\r\n\r\n // wait for both\r\n return Promise.all([txPromise, rpcPromise]).then(\r\n ([{ sender, hash }, stampMs]) => ({\r\n blockHeight,\r\n method,\r\n sender,\r\n transactionHash: hash,\r\n stampMs,\r\n })\r\n );\r\n });\r\n\r\n // 3) await all in parallel\r\n return Promise.all(tasks);\r\n}\r\n"],
5
5
  "mappings": ";;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAIA,IAAM,eAAe;AACrB,IAAM,UAAe;AAErB,eAAsB,oBAClB,YACA,YACA,OAC0B;AAE1B,QAAM,MAAM,MAAM,WAAW;AAAA,IACzB;AAAA,MACI,MAAM;AAAA,MACN,WAAW;AAAA,MACX,QAAQ;AAAA,QACJ,gBAAgB,MAAM,gBAAgB;AAAA,QACtC,aAAa,MAAM,aAAa;AAAA,MACpC;AAAA,IACJ;AAAA,IACA;AAAA,EACJ;AACA,QAAM,OAAQ,IAAI,MAAM,UAAuD,CAAC;AAGhF,QAAM,QAAQ,KAAK,IAAI,CAAC,EAAE,YAAY,OAAO,MAAM;AAC/C,UAAM,cAAc,OAAO,UAAU;AACrC,QAAI,OAAO,MAAM,WAAW,GAAG;AAC3B,aAAO,QAAQ,OAAO,IAAI,MAAM,kCAAkC,UAAU,EAAE,CAAC;AAAA,IACnF;AAEA,UAAM,QAAQ,GAAG,YAAY,qCACR,WAAW,aAAa,WAAW;AAIxD,UAAM,YAAY,MAAM,KAAK,EAAE,KAAK,OAAO,SAAS;AAChD,UAAI,CAAC,KAAK,GAAI,OAAM,IAAI,MAAM,yBAAyB,KAAK,MAAM,EAAE;AACpE,YAAM,OAAQ,MAAM,KAAK,KAAK;AAI9B,UAAI,CAAC,KAAK,MAAM,KAAK,KAAK,WAAW,GAAG;AACpC,eAAO,EAAE,QAAQ,aAAa,MAAM,YAAY;AAAA,MACpD;AACA,YAAM,EAAE,MAAM,OAAO,IAAI,KAAK,KAAK,CAAC;AACpC,aAAO,EAAE,QAAQ,KAAK;AAAA,IAC1B,CAAC;AAGD,UAAM,aAAa,MAAM,SAAS;AAAA,MAC9B,QAAS;AAAA,MACT,SAAS,EAAE,gBAAgB,mBAAmB;AAAA,MAC9C,MAAS,KAAK,UAAU;AAAA,QACpB,SAAS;AAAA,QACT,QAAS;AAAA,QACT,QAAS,EAAE,QAAQ,YAAY;AAAA,QAC/B,IAAS;AAAA,MACb,CAAC;AAAA,IACL,CAAC,EAAE,KAAK,OAAO,SAAS;AACpB,UAAI,CAAC,KAAK,IAAI;AACV,cAAM,MAAM,MAAM,KAAK,KAAK;AAC5B,cAAM,IAAI,MAAM,qBAAqB,KAAK,MAAM,WAAM,GAAG,EAAE;AAAA,MAC/D;AACA,YAAM,MAAO,MAAM,KAAK,KAAK;AAG7B,aAAO,IAAI,OAAO,MAAM,OAAO;AAAA,IACnC,CAAC;AAGD,WAAO,QAAQ,IAAI,CAAC,WAAW,UAAU,CAAC,EAAE;AAAA,MACxC,CAAC,CAAC,EAAE,QAAQ,KAAK,GAAG,OAAO,OAAO;AAAA,QAC9B;AAAA,QACA;AAAA,QACA;AAAA,QACA,iBAAiB;AAAA,QACjB;AAAA,MACJ;AAAA,IACJ;AAAA,EACJ,CAAC;AAGD,SAAO,QAAQ,IAAI,KAAK;AAC5B;",
6
6
  "names": []
7
7
  }
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "version": 3,
3
3
  "sources": ["../../../src/client/listStreams.ts"],
4
- "sourcesContent": ["import {TNStream} from \"../types/stream\";\nimport {EthereumAddress} from \"../util/EthereumAddress\";\nimport {StreamId} from \"../util/StreamId\";\nimport {Database} from \"@kwilteam/kwil-js/dist/core/database\";\nimport {ListStreamsInput} from \"./client\";\nimport {KwilSigner, NodeKwil, WebKwil} from \"@kwilteam/kwil-js\";\n\n/**\n * List all streams from the TN network.\n * @param kwilClient - The Kwil client.\n * @param kwilSigner - The Kwil signer.\n * @param input - The input parameters for listing streams.\n * @returns A list of stream locators.\n */\nexport async function listStreams(\n kwilClient: WebKwil | NodeKwil,\n kwilSigner: KwilSigner,\n input: ListStreamsInput\n): Promise<TNStream[]> {\n const result = await kwilClient.call({\n inputs: {\n $data_provider: input.dataProvider,\n $limit: input.limit,\n $offset: input.offset,\n $order_by: input.orderBy,\n $block_height: input.blockHeight,\n },\n name: \"list_streams\",\n namespace: \"main\",\n }, kwilSigner);\n\n return await Promise.all(\n (result.data?.result as {\n data_provider: string;\n stream_id: string;\n stream_type: string;\n created_at: number;\n }[]).map(async (database) => ({\n streamId: await StreamId.generate(database.stream_id),\n dataProvider: new EthereumAddress(database.data_provider),\n streamType: database.stream_type,\n createdAt: database.created_at\n }))\n );\n}"],
4
+ "sourcesContent": ["import {TNStream} from \"../types/stream\";\nimport {EthereumAddress} from \"../util/EthereumAddress\";\nimport {StreamId} from \"../util/StreamId\";\nimport {Database} from \"@trufnetwork/kwil-js/dist/core/database\";\nimport {ListStreamsInput} from \"./client\";\nimport {KwilSigner, NodeKwil, WebKwil} from \"@trufnetwork/kwil-js\";\n\n/**\n * List all streams from the TN network.\n * @param kwilClient - The Kwil client.\n * @param kwilSigner - The Kwil signer.\n * @param input - The input parameters for listing streams.\n * @returns A list of stream locators.\n */\nexport async function listStreams(\n kwilClient: WebKwil | NodeKwil,\n kwilSigner: KwilSigner,\n input: ListStreamsInput\n): Promise<TNStream[]> {\n const result = await kwilClient.call({\n inputs: {\n $data_provider: input.dataProvider,\n $limit: input.limit,\n $offset: input.offset,\n $order_by: input.orderBy,\n $block_height: input.blockHeight,\n },\n name: \"list_streams\",\n namespace: \"main\",\n }, kwilSigner);\n\n return await Promise.all(\n (result.data?.result as {\n data_provider: string;\n stream_id: string;\n stream_type: string;\n created_at: number;\n }[]).map(async (database) => ({\n streamId: await StreamId.generate(database.stream_id),\n dataProvider: new EthereumAddress(database.data_provider),\n streamType: database.stream_type,\n createdAt: database.created_at\n }))\n );\n}"],
5
5
  "mappings": ";;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AACA,6BAA8B;AAC9B,sBAAuB;AAYvB,eAAsB,YACpB,YACA,YACA,OACqB;AACnB,QAAM,SAAS,MAAM,WAAW,KAAK;AAAA,IACjC,QAAQ;AAAA,MACJ,gBAAgB,MAAM;AAAA,MACtB,QAAQ,MAAM;AAAA,MACd,SAAS,MAAM;AAAA,MACf,WAAW,MAAM;AAAA,MACjB,eAAe,MAAM;AAAA,IACzB;AAAA,IACA,MAAM;AAAA,IACN,WAAW;AAAA,EACf,GAAG,UAAU;AAEb,SAAO,MAAM,QAAQ;AAAA,KAChB,OAAO,MAAM,QAKT,IAAI,OAAO,cAAc;AAAA,MAC1B,UAAU,MAAM,yBAAS,SAAS,SAAS,SAAS;AAAA,MACpD,cAAc,IAAI,uCAAgB,SAAS,aAAa;AAAA,MACxD,YAAY,SAAS;AAAA,MACrB,WAAW,SAAS;AAAA,IACxB,EAAE;AAAA,EACN;AACJ;",
6
6
  "names": []
7
7
  }
@@ -24,7 +24,7 @@ __export(nodeClient_exports, {
24
24
  default: () => nodeClient_default
25
25
  });
26
26
  module.exports = __toCommonJS(nodeClient_exports);
27
- var import_kwil_js = require("@kwilteam/kwil-js");
27
+ var import_kwil_js = require("@trufnetwork/kwil-js");
28
28
  var import_client = require("./client.cjs");
29
29
  var NodeTNClient = class extends import_client.BaseTNClient {
30
30
  constructor(options) {
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "version": 3,
3
3
  "sources": ["../../../src/client/nodeClient.ts"],
4
- "sourcesContent": ["import { EnvironmentType } from \"@kwilteam/kwil-js/dist/core/enums\";\nimport { NodeKwil } from \"@kwilteam/kwil-js\";\nimport { BaseTNClient, TNClientOptions } from \"./client\";\n\nexport class NodeTNClient extends BaseTNClient<EnvironmentType.NODE> {\n constructor(options: TNClientOptions) {\n super(options);\n this.kwilClient = new NodeKwil({\n ...options,\n timeout: options.timeout ?? 30000,\n kwilProvider: options.endpoint,\n });\n }\n}\n\nexport default NodeTNClient;\n"],
4
+ "sourcesContent": ["import { EnvironmentType } from \"@trufnetwork/kwil-js/dist/core/enums\";\nimport { NodeKwil } from \"@trufnetwork/kwil-js\";\nimport { BaseTNClient, TNClientOptions } from \"./client\";\n\nexport class NodeTNClient extends BaseTNClient<EnvironmentType.NODE> {\n constructor(options: TNClientOptions) {\n super(options);\n this.kwilClient = new NodeKwil({\n ...options,\n timeout: options.timeout ?? 30000,\n kwilProvider: options.endpoint,\n });\n }\n}\n\nexport default NodeTNClient;\n"],
5
5
  "mappings": ";;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AACA,qBAAyB;AACzB,oBAA8C;AAEvC,IAAM,eAAN,cAA2B,2BAAmC;AAAA,EACnE,YAAY,SAA0B;AACpC,UAAM,OAAO;AACb,SAAK,aAAa,IAAI,wBAAS;AAAA,MAC7B,GAAG;AAAA,MACH,SAAS,QAAQ,WAAW;AAAA,MAC5B,cAAc,QAAQ;AAAA,IACxB,CAAC;AAAA,EACH;AACF;AAEA,IAAO,qBAAQ;",
6
6
  "names": []
7
7
  }
@@ -28,10 +28,19 @@ var import_EthereumAddress = require("../util/EthereumAddress.cjs");
28
28
  var import_head = require("../util/head.cjs");
29
29
  var import_StreamId = require("../util/StreamId.cjs");
30
30
  var import_visibility = require("../util/visibility.cjs");
31
+ var import_cacheMetadataParser = require("../util/cacheMetadataParser.cjs");
32
+ var import_cacheValidation = require("../util/cacheValidation.cjs");
31
33
  var import_contractValues = require("./contractValues.cjs");
32
- var Action = class {
34
+ var Action = class _Action {
33
35
  kwilClient;
34
36
  kwilSigner;
37
+ /** Track if deprecation warnings were already emitted */
38
+ static _legacyWarnEmitted = {
39
+ getRecord: false,
40
+ getIndex: false,
41
+ getFirstRecord: false,
42
+ getIndexChange: false
43
+ };
35
44
  constructor(kwilClient, kwilSigner) {
36
45
  this.kwilClient = kwilClient;
37
46
  this.kwilSigner = kwilSigner;
@@ -73,50 +82,159 @@ var Action = class {
73
82
  }
74
83
  return import_monads_io.Either.right(result.data?.result);
75
84
  }
76
- /**
77
- * Returns the records of the stream within the given date range
78
- */
79
- async getRecord(input) {
80
- const prefix = input.prefix ? input.prefix : "";
81
- const result = await this.call(
82
- prefix + "get_record",
83
- {
84
- $data_provider: input.stream.dataProvider.getAddress(),
85
- $stream_id: input.stream.streamId.getId(),
86
- $from: input.from,
87
- $to: input.to,
88
- $frozen_at: input.frozenAt
85
+ async getRecord(inputOrStream, options) {
86
+ if ("stream" in inputOrStream) {
87
+ const input = inputOrStream;
88
+ if (!_Action._legacyWarnEmitted.getRecord) {
89
+ _Action._legacyWarnEmitted.getRecord = true;
90
+ if (typeof console !== "undefined" && console.warn) {
91
+ console.warn("[TN SDK] Deprecated signature: getRecord(input). Use getRecord(stream, options?) instead.");
92
+ }
89
93
  }
94
+ const prefix2 = input.prefix ? input.prefix : "";
95
+ const result2 = await this.call(
96
+ prefix2 + "get_record",
97
+ {
98
+ $data_provider: input.stream.dataProvider.getAddress(),
99
+ $stream_id: input.stream.streamId.getId(),
100
+ $from: input.from,
101
+ $to: input.to,
102
+ $frozen_at: input.frozenAt
103
+ }
104
+ );
105
+ return result2.mapRight(
106
+ (result3) => result3.map((row) => ({
107
+ eventTime: row.event_time,
108
+ value: row.value
109
+ }))
110
+ ).throw();
111
+ }
112
+ const stream = inputOrStream;
113
+ if (options) {
114
+ import_cacheValidation.CacheValidation.validateGetRecordOptions(options);
115
+ import_cacheValidation.CacheValidation.validateTimeRange(options.from, options.to);
116
+ }
117
+ const prefix = options?.prefix ? options.prefix : "";
118
+ const params = {
119
+ $data_provider: stream.dataProvider.getAddress(),
120
+ $stream_id: stream.streamId.getId(),
121
+ $from: options?.from,
122
+ $to: options?.to,
123
+ $frozen_at: options?.frozenAt
124
+ };
125
+ if (options?.useCache !== void 0) {
126
+ params.$use_cache = options.useCache;
127
+ }
128
+ const result = await this.kwilClient.call(
129
+ {
130
+ namespace: "main",
131
+ name: prefix + "get_record",
132
+ inputs: params
133
+ },
134
+ this.kwilSigner
90
135
  );
91
- return result.mapRight(
92
- (result2) => result2.map((row) => ({
93
- eventTime: row.event_time,
94
- value: row.value
95
- }))
96
- ).throw();
136
+ if (result.status !== 200) {
137
+ throw new Error(`Failed to get record: ${result.status}`);
138
+ }
139
+ const data = (result.data?.result).map((row) => ({
140
+ eventTime: row.event_time,
141
+ value: row.value
142
+ }));
143
+ let cache = import_cacheMetadataParser.CacheMetadataParser.extractFromResponse(result);
144
+ if (cache) {
145
+ cache = {
146
+ ...cache,
147
+ streamId: stream.streamId.getId(),
148
+ dataProvider: stream.dataProvider.getAddress(),
149
+ from: options?.from,
150
+ to: options?.to,
151
+ frozenAt: options?.frozenAt,
152
+ rowsServed: data.length
153
+ };
154
+ }
155
+ return {
156
+ data,
157
+ cache: cache || void 0,
158
+ logs: result.data?.logs ? import_cacheMetadataParser.CacheMetadataParser.parseLogsForMetadata(result.data.logs) : void 0
159
+ };
97
160
  }
98
- /**
99
- * Returns the index of the stream within the given date range
100
- */
101
- async getIndex(input) {
102
- const prefix = input.prefix ? input.prefix : "";
103
- const result = await this.call(
104
- prefix + "get_index",
105
- {
106
- $data_provider: input.stream.dataProvider.getAddress(),
107
- $stream_id: input.stream.streamId.getId(),
108
- $from: input.from,
109
- $to: input.to,
110
- $frozen_at: input.frozenAt,
111
- $base_time: input.baseTime
161
+ async getIndex(inputOrStream, options) {
162
+ if ("stream" in inputOrStream) {
163
+ const input = inputOrStream;
164
+ if (!_Action._legacyWarnEmitted.getIndex) {
165
+ _Action._legacyWarnEmitted.getIndex = true;
166
+ if (typeof console !== "undefined" && console.warn) {
167
+ console.warn("[TN SDK] Deprecated signature: getIndex(input). Use getIndex(stream, options?) instead.");
168
+ }
112
169
  }
170
+ const prefix2 = input.prefix ? input.prefix : "";
171
+ const result2 = await this.call(
172
+ prefix2 + "get_index",
173
+ {
174
+ $data_provider: input.stream.dataProvider.getAddress(),
175
+ $stream_id: input.stream.streamId.getId(),
176
+ $from: input.from,
177
+ $to: input.to,
178
+ $frozen_at: input.frozenAt,
179
+ $base_time: input.baseTime
180
+ }
181
+ );
182
+ return result2.mapRight(
183
+ (result3) => result3.map((row) => ({
184
+ eventTime: row.event_time,
185
+ value: row.value
186
+ }))
187
+ ).throw();
188
+ }
189
+ const stream = inputOrStream;
190
+ if (options) {
191
+ import_cacheValidation.CacheValidation.validateGetIndexOptions(options);
192
+ import_cacheValidation.CacheValidation.validateTimeRange(options.from, options.to);
193
+ }
194
+ const prefix = options?.prefix ? options.prefix : "";
195
+ const params = {
196
+ $data_provider: stream.dataProvider.getAddress(),
197
+ $stream_id: stream.streamId.getId(),
198
+ $from: options?.from,
199
+ $to: options?.to,
200
+ $frozen_at: options?.frozenAt,
201
+ $base_time: options?.baseTime
202
+ };
203
+ if (options?.useCache !== void 0) {
204
+ params.$use_cache = options.useCache;
205
+ }
206
+ const result = await this.kwilClient.call(
207
+ {
208
+ namespace: "main",
209
+ name: prefix + "get_index",
210
+ inputs: params
211
+ },
212
+ this.kwilSigner
113
213
  );
114
- return result.mapRight(
115
- (result2) => result2.map((row) => ({
116
- eventTime: row.event_time,
117
- value: row.value
118
- }))
119
- ).throw();
214
+ if (result.status !== 200) {
215
+ throw new Error(`Failed to get index: ${result.status}`);
216
+ }
217
+ const data = (result.data?.result).map((row) => ({
218
+ eventTime: row.event_time,
219
+ value: row.value
220
+ }));
221
+ let cache = import_cacheMetadataParser.CacheMetadataParser.extractFromResponse(result);
222
+ if (cache) {
223
+ cache = {
224
+ ...cache,
225
+ streamId: stream.streamId.getId(),
226
+ dataProvider: stream.dataProvider.getAddress(),
227
+ from: options?.from,
228
+ to: options?.to,
229
+ frozenAt: options?.frozenAt,
230
+ rowsServed: data.length
231
+ };
232
+ }
233
+ return {
234
+ data,
235
+ cache: cache || void 0,
236
+ logs: result.data?.logs ? import_cacheMetadataParser.CacheMetadataParser.parseLogsForMetadata(result.data.logs) : void 0
237
+ };
120
238
  }
121
239
  /**
122
240
  * Returns the type of the stream
@@ -140,25 +258,75 @@ var Action = class {
140
258
  }
141
259
  return type.value;
142
260
  }
143
- /**
144
- * Returns the first record of the stream
145
- */
146
- async getFirstRecord(input) {
147
- const result = await this.call(
148
- "get_first_record",
149
- {
150
- $data_provider: input.stream.dataProvider.getAddress(),
151
- $stream_id: input.stream.streamId.getId(),
152
- $after: input.after,
153
- $frozen_at: input.frozenAt
261
+ async getFirstRecord(inputOrStream, options) {
262
+ if ("stream" in inputOrStream) {
263
+ const input = inputOrStream;
264
+ if (!_Action._legacyWarnEmitted.getFirstRecord) {
265
+ _Action._legacyWarnEmitted.getFirstRecord = true;
266
+ if (typeof console !== "undefined" && console.warn) {
267
+ console.warn("[TN SDK] Deprecated signature: getFirstRecord(input). Use getFirstRecord(stream, options?) instead.");
268
+ }
154
269
  }
270
+ const result2 = await this.call(
271
+ "get_first_record",
272
+ {
273
+ $data_provider: input.stream.dataProvider.getAddress(),
274
+ $stream_id: input.stream.streamId.getId(),
275
+ $after: input.after,
276
+ $frozen_at: input.frozenAt
277
+ }
278
+ );
279
+ return result2.mapRight(import_head.head).mapRight(
280
+ (result3) => result3.map((result4) => ({
281
+ eventTime: result4.event_time,
282
+ value: result4.value
283
+ })).unwrapOr(null)
284
+ ).throw();
285
+ }
286
+ const stream = inputOrStream;
287
+ if (options) {
288
+ import_cacheValidation.CacheValidation.validateGetFirstRecordOptions(options);
289
+ }
290
+ const params = {
291
+ $data_provider: stream.dataProvider.getAddress(),
292
+ $stream_id: stream.streamId.getId(),
293
+ $after: options?.after,
294
+ $frozen_at: options?.frozenAt
295
+ };
296
+ if (options?.useCache !== void 0) {
297
+ params.$use_cache = options.useCache;
298
+ }
299
+ const result = await this.kwilClient.call(
300
+ {
301
+ namespace: "main",
302
+ name: "get_first_record",
303
+ inputs: params
304
+ },
305
+ this.kwilSigner
155
306
  );
156
- return result.mapRight(import_head.head).mapRight(
157
- (result2) => result2.map((result3) => ({
158
- eventTime: result3.event_time,
159
- value: result3.value
160
- })).unwrapOr(null)
161
- ).throw();
307
+ if (result.status !== 200) {
308
+ throw new Error(`Failed to get first record: ${result.status}`);
309
+ }
310
+ const rawData = result.data?.result;
311
+ const data = rawData && rawData.length > 0 ? {
312
+ eventTime: rawData[0].event_time,
313
+ value: rawData[0].value
314
+ } : null;
315
+ let cache = import_cacheMetadataParser.CacheMetadataParser.extractFromResponse(result);
316
+ if (cache) {
317
+ cache = {
318
+ ...cache,
319
+ streamId: stream.streamId.getId(),
320
+ dataProvider: stream.dataProvider.getAddress(),
321
+ frozenAt: options?.frozenAt,
322
+ rowsServed: data ? 1 : 0
323
+ };
324
+ }
325
+ return {
326
+ data,
327
+ cache: cache || void 0,
328
+ logs: result.data?.logs ? import_cacheMetadataParser.CacheMetadataParser.parseLogsForMetadata(result.data.logs) : void 0
329
+ };
162
330
  }
163
331
  async setMetadata(stream, key, value) {
164
332
  return await this.executeWithNamedParams("insert_metadata", [
@@ -315,28 +483,84 @@ var Action = class {
315
483
  };
316
484
  });
317
485
  }
318
- /**
319
- * Returns the index change of the stream within the given date range
320
- */
321
- async getIndexChange(input) {
322
- const result = await this.call(
323
- "get_index_change",
324
- {
325
- $data_provider: input.stream.dataProvider.getAddress(),
326
- $stream_id: input.stream.streamId.getId(),
327
- $from: input.from,
328
- $to: input.to,
329
- $frozen_at: input.frozenAt,
330
- $base_time: input.baseTime,
331
- $time_interval: input.timeInterval
486
+ async getIndexChange(inputOrStream, options) {
487
+ if ("stream" in inputOrStream) {
488
+ const input = inputOrStream;
489
+ if (!_Action._legacyWarnEmitted.getIndexChange) {
490
+ _Action._legacyWarnEmitted.getIndexChange = true;
491
+ if (typeof console !== "undefined" && console.warn) {
492
+ console.warn("[TN SDK] Deprecated signature: getIndexChange(input). Use getIndexChange(stream, options?) instead.");
493
+ }
332
494
  }
495
+ const result2 = await this.call(
496
+ "get_index_change",
497
+ {
498
+ $data_provider: input.stream.dataProvider.getAddress(),
499
+ $stream_id: input.stream.streamId.getId(),
500
+ $from: input.from,
501
+ $to: input.to,
502
+ $frozen_at: input.frozenAt,
503
+ $base_time: input.baseTime,
504
+ $time_interval: input.timeInterval
505
+ }
506
+ );
507
+ return result2.mapRight(
508
+ (result3) => result3.map((row) => ({
509
+ eventTime: row.event_time,
510
+ value: row.value
511
+ }))
512
+ ).throw();
513
+ }
514
+ const stream = inputOrStream;
515
+ if (!options) {
516
+ throw new Error("Options parameter is required for cache-aware getIndexChange");
517
+ }
518
+ import_cacheValidation.CacheValidation.validateGetIndexChangeOptions(options);
519
+ import_cacheValidation.CacheValidation.validateTimeRange(options.from, options.to);
520
+ const params = {
521
+ $data_provider: stream.dataProvider.getAddress(),
522
+ $stream_id: stream.streamId.getId(),
523
+ $from: options.from,
524
+ $to: options.to,
525
+ $frozen_at: options.frozenAt,
526
+ $base_time: options.baseTime,
527
+ $time_interval: options.timeInterval
528
+ };
529
+ if (options.useCache !== void 0) {
530
+ params.$use_cache = options.useCache;
531
+ }
532
+ const result = await this.kwilClient.call(
533
+ {
534
+ namespace: "main",
535
+ name: "get_index_change",
536
+ inputs: params
537
+ },
538
+ this.kwilSigner
333
539
  );
334
- return result.mapRight(
335
- (result2) => result2.map((row) => ({
336
- eventTime: row.event_time,
337
- value: row.value
338
- }))
339
- ).throw();
540
+ if (result.status !== 200) {
541
+ throw new Error(`Failed to get index change: ${result.status}`);
542
+ }
543
+ const data = (result.data?.result).map((row) => ({
544
+ eventTime: row.event_time,
545
+ value: row.value
546
+ }));
547
+ let cache = import_cacheMetadataParser.CacheMetadataParser.extractFromResponse(result);
548
+ if (cache) {
549
+ cache = {
550
+ ...cache,
551
+ streamId: stream.streamId.getId(),
552
+ dataProvider: stream.dataProvider.getAddress(),
553
+ from: options.from,
554
+ to: options.to,
555
+ frozenAt: options.frozenAt,
556
+ rowsServed: data.length
557
+ };
558
+ }
559
+ return {
560
+ data,
561
+ cache: cache || void 0,
562
+ logs: result.data?.logs ? import_cacheMetadataParser.CacheMetadataParser.parseLogsForMetadata(result.data.logs) : void 0
563
+ };
340
564
  }
341
565
  /**
342
566
  * A custom method that accepts the procedure name and the input of GetRecordInput