@oobe-protocol-labs/synapse-sap-sdk 0.4.1 → 0.5.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 (85) hide show
  1. package/dist/cjs/constants/index.js +4 -1
  2. package/dist/cjs/constants/index.js.map +1 -1
  3. package/dist/cjs/constants/network.js +81 -0
  4. package/dist/cjs/constants/network.js.map +1 -0
  5. package/dist/cjs/core/client.js +23 -0
  6. package/dist/cjs/core/client.js.map +1 -1
  7. package/dist/cjs/index.js +17 -2
  8. package/dist/cjs/index.js.map +1 -1
  9. package/dist/cjs/parser/client.js +146 -0
  10. package/dist/cjs/parser/client.js.map +1 -0
  11. package/dist/cjs/parser/complete.js +177 -0
  12. package/dist/cjs/parser/complete.js.map +1 -0
  13. package/dist/cjs/parser/index.js +57 -0
  14. package/dist/cjs/parser/index.js.map +1 -0
  15. package/dist/cjs/parser/inner.js +185 -0
  16. package/dist/cjs/parser/inner.js.map +1 -0
  17. package/dist/cjs/parser/instructions.js +114 -0
  18. package/dist/cjs/parser/instructions.js.map +1 -0
  19. package/dist/cjs/parser/transaction.js +153 -0
  20. package/dist/cjs/parser/transaction.js.map +1 -0
  21. package/dist/cjs/parser/types.js +14 -0
  22. package/dist/cjs/parser/types.js.map +1 -0
  23. package/dist/cjs/registries/x402.js +5 -2
  24. package/dist/cjs/registries/x402.js.map +1 -1
  25. package/dist/esm/constants/index.js +2 -0
  26. package/dist/esm/constants/index.js.map +1 -1
  27. package/dist/esm/constants/network.js +78 -0
  28. package/dist/esm/constants/network.js.map +1 -0
  29. package/dist/esm/core/client.js +23 -0
  30. package/dist/esm/core/client.js.map +1 -1
  31. package/dist/esm/index.js +4 -1
  32. package/dist/esm/index.js.map +1 -1
  33. package/dist/esm/parser/client.js +142 -0
  34. package/dist/esm/parser/client.js.map +1 -0
  35. package/dist/esm/parser/complete.js +173 -0
  36. package/dist/esm/parser/complete.js.map +1 -0
  37. package/dist/esm/parser/index.js +43 -0
  38. package/dist/esm/parser/index.js.map +1 -0
  39. package/dist/esm/parser/inner.js +180 -0
  40. package/dist/esm/parser/inner.js.map +1 -0
  41. package/dist/esm/parser/instructions.js +109 -0
  42. package/dist/esm/parser/instructions.js.map +1 -0
  43. package/dist/esm/parser/transaction.js +149 -0
  44. package/dist/esm/parser/transaction.js.map +1 -0
  45. package/dist/esm/parser/types.js +13 -0
  46. package/dist/esm/parser/types.js.map +1 -0
  47. package/dist/esm/registries/x402.js +5 -2
  48. package/dist/esm/registries/x402.js.map +1 -1
  49. package/dist/types/constants/index.d.ts +2 -0
  50. package/dist/types/constants/index.d.ts.map +1 -1
  51. package/dist/types/constants/network.d.ts +81 -0
  52. package/dist/types/constants/network.d.ts.map +1 -0
  53. package/dist/types/core/client.d.ts +19 -0
  54. package/dist/types/core/client.d.ts.map +1 -1
  55. package/dist/types/index.d.ts +5 -1
  56. package/dist/types/index.d.ts.map +1 -1
  57. package/dist/types/parser/client.d.ts +123 -0
  58. package/dist/types/parser/client.d.ts.map +1 -0
  59. package/dist/types/parser/complete.d.ts +90 -0
  60. package/dist/types/parser/complete.d.ts.map +1 -0
  61. package/dist/types/parser/index.d.ts +40 -0
  62. package/dist/types/parser/index.d.ts.map +1 -0
  63. package/dist/types/parser/inner.d.ts +114 -0
  64. package/dist/types/parser/inner.d.ts.map +1 -0
  65. package/dist/types/parser/instructions.d.ts +76 -0
  66. package/dist/types/parser/instructions.d.ts.map +1 -0
  67. package/dist/types/parser/transaction.d.ts +77 -0
  68. package/dist/types/parser/transaction.d.ts.map +1 -0
  69. package/dist/types/parser/types.d.ts +154 -0
  70. package/dist/types/parser/types.d.ts.map +1 -0
  71. package/dist/types/registries/x402.d.ts +35 -2
  72. package/dist/types/registries/x402.d.ts.map +1 -1
  73. package/package.json +6 -1
  74. package/src/constants/index.ts +4 -0
  75. package/src/constants/network.ts +89 -0
  76. package/src/core/client.ts +25 -0
  77. package/src/index.ts +27 -0
  78. package/src/parser/client.ts +211 -0
  79. package/src/parser/complete.ts +232 -0
  80. package/src/parser/index.ts +71 -0
  81. package/src/parser/inner.ts +255 -0
  82. package/src/parser/instructions.ts +135 -0
  83. package/src/parser/transaction.ts +200 -0
  84. package/src/parser/types.ts +182 -0
  85. package/src/registries/x402.ts +38 -3
@@ -0,0 +1,78 @@
1
+ /**
2
+ * @module constants/network
3
+ * @description Solana network identifiers for x402 payment headers.
4
+ *
5
+ * x402 providers validate the `X-Payment-Network` header against their
6
+ * own network identifier. Some providers (e.g. Coinbase, Phantom) accept
7
+ * the human-readable cluster name (`solana:mainnet-beta`), while others
8
+ * (e.g. Kamiyo, Helius x402) require the Solana genesis-hash form
9
+ * (`solana:5eykt4UsFv8P8NJdTREpY1vzqKqZKvdp`).
10
+ *
11
+ * Use {@link SapNetwork} to select the correct format, or pass any
12
+ * custom string where needed.
13
+ *
14
+ * @category Constants
15
+ * @since v0.4.3
16
+ *
17
+ * @example
18
+ * ```ts
19
+ * import { SapNetwork } from "@synapse-sap/sdk";
20
+ *
21
+ * // Standard cluster name (default)
22
+ * const ctx = await x402.preparePayment(agentWallet, {
23
+ * pricePerCall: 1000, deposit: 100_000,
24
+ * networkIdentifier: SapNetwork.SOLANA_MAINNET,
25
+ * });
26
+ *
27
+ * // Genesis-hash form for providers that require it
28
+ * const ctx2 = await x402.preparePayment(agentWallet, {
29
+ * pricePerCall: 1000, deposit: 100_000,
30
+ * networkIdentifier: SapNetwork.SOLANA_MAINNET_GENESIS,
31
+ * });
32
+ * ```
33
+ */
34
+ // ═══════════════════════════════════════════════════════════════════
35
+ // SAP Network Identifiers
36
+ // ═══════════════════════════════════════════════════════════════════
37
+ /**
38
+ * @name SapNetwork
39
+ * @description Network identifier strings for x402 `X-Payment-Network` headers.
40
+ *
41
+ * Two mainnet forms exist because x402 providers disagree on the canonical
42
+ * identifier:
43
+ *
44
+ * | Constant | Value | Accepted by |
45
+ * |-------------------------|----------------------------------------------|----------------------|
46
+ * | `SOLANA_MAINNET` | `solana:mainnet-beta` | Coinbase, Phantom |
47
+ * | `SOLANA_MAINNET_GENESIS`| `solana:5eykt4UsFv8P8NJdTREpY1vzqKqZKvdp` | Kamiyo, Helius x402 |
48
+ * | `SOLANA_DEVNET` | `solana:EtWTRABZaYq6iMfeYKouRu166VU2xqa1` | Devnet providers |
49
+ * | `SOLANA_DEVNET_NAMED` | `solana:devnet` | Local / test flows |
50
+ *
51
+ * If your provider requires a different format, pass a raw string instead.
52
+ *
53
+ * @category Constants
54
+ * @since v0.4.3
55
+ */
56
+ export const SapNetwork = {
57
+ /**
58
+ * Mainnet-beta, human-readable cluster name.
59
+ * Default value used by the SDK prior to v0.4.3.
60
+ */
61
+ SOLANA_MAINNET: "solana:mainnet-beta",
62
+ /**
63
+ * Mainnet-beta, genesis-hash form (CAIP-2 compliant).
64
+ * Required by Kamiyo, Helius x402, and other providers that validate
65
+ * against the Solana genesis hash.
66
+ */
67
+ SOLANA_MAINNET_GENESIS: "solana:5eykt4UsFv8P8NJdTREpY1vzqKqZKvdp",
68
+ /**
69
+ * Devnet, genesis-hash form (CAIP-2 compliant).
70
+ */
71
+ SOLANA_DEVNET: "solana:EtWTRABZaYq6iMfeYKouRu166VU2xqa1",
72
+ /**
73
+ * Devnet, human-readable cluster name.
74
+ * Useful for local development and test validators.
75
+ */
76
+ SOLANA_DEVNET_NAMED: "solana:devnet",
77
+ };
78
+ //# sourceMappingURL=network.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"network.js","sourceRoot":"","sources":["../../../src/constants/network.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAgCG;AAEH,sEAAsE;AACtE,2BAA2B;AAC3B,sEAAsE;AAEtE;;;;;;;;;;;;;;;;;;GAkBG;AACH,MAAM,CAAC,MAAM,UAAU,GAAG;IACxB;;;OAGG;IACH,cAAc,EAAE,qBAAqB;IAErC;;;;OAIG;IACH,sBAAsB,EAAE,yCAAyC;IAEjE;;OAEG;IACH,aAAa,EAAE,yCAAyC;IAExD;;;OAGG;IACH,mBAAmB,EAAE,eAAe;CAC5B,CAAC"}
@@ -34,6 +34,7 @@ import { EscrowModule } from "../modules/escrow";
34
34
  import { AttestationModule } from "../modules/attestation";
35
35
  import { LedgerModule } from "../modules/ledger";
36
36
  import { EventParser } from "../events";
37
+ import { TransactionParser } from "../parser/client";
37
38
  import { DiscoveryRegistry } from "../registries/discovery";
38
39
  import { X402Registry } from "../registries/x402";
39
40
  import { SessionManager } from "../registries/session";
@@ -105,6 +106,8 @@ export class SapClient {
105
106
  #attestation;
106
107
  #ledger;
107
108
  #events;
109
+ // ── Lazy parser singleton ─────────────────────
110
+ #parser;
108
111
  // ── Lazy registry singletons ──────────────────────
109
112
  #discovery;
110
113
  #x402;
@@ -289,6 +292,26 @@ export class SapClient {
289
292
  get events() {
290
293
  return (this.#events ??= new EventParser(this.program));
291
294
  }
295
+ /**
296
+ * @name parser
297
+ * @description Transaction parser: decode instruction names, arguments,
298
+ * accounts, inner CPI calls, and protocol events from raw transaction
299
+ * responses. Designed for indexers and explorers.
300
+ * @returns {TransactionParser} The lazily-instantiated `TransactionParser` singleton.
301
+ * @category Modules
302
+ * @since v0.5.0
303
+ * @see {@link TransactionParser}
304
+ *
305
+ * @example
306
+ * ```ts
307
+ * const tx = await connection.getTransaction(sig, { ... });
308
+ * const parsed = client.parser.parseTransaction(tx);
309
+ * console.log(parsed?.instructions.map(i => i.name));
310
+ * ```
311
+ */
312
+ get parser() {
313
+ return (this.#parser ??= new TransactionParser(this.program));
314
+ }
292
315
  // ═════════════════════════════════════════════
293
316
  // Registry Accessors (high-level abstractions)
294
317
  // ═════════════════════════════════════════════
@@ -1 +1 @@
1
- {"version":3,"file":"client.js","sourceRoot":"","sources":["../../../src/core/client.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"client.js","sourceRoot":"","sources":["../../../src/core/client.ts"],"names":[],"mappings":"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"}
package/dist/esm/index.js CHANGED
@@ -15,6 +15,7 @@
15
15
  * | `modules/` | Low-level per-domain instruction wrappers |
16
16
  * | `registries/` | High-level abstractions (discovery, x402, …) |
17
17
  * | `plugin/` | SynapseAgentKit adapter (52 tools) |
18
+ * | `parser/` | Transaction decode, instruction + event parse |
18
19
  * | `idl/` | Embedded Anchor IDL |
19
20
  *
20
21
  * @example
@@ -46,7 +47,7 @@
46
47
  export { SapClient, SapConnection, KeypairWallet } from "./core";
47
48
  export { TokenType, PluginType, SettlementMode, ToolHttpMethod, ToolCategory, DelegatePermission, SchemaType, CompressionType, } from "./types";
48
49
  // ── Constants ────────────────────────────────────────
49
- export { SAP_PROGRAM_ADDRESS, SAP_PROGRAM_ID, MAINNET_SAP_PROGRAM_ID, DEVNET_SAP_PROGRAM_ID, LOCALNET_SAP_PROGRAM_ID, SEEDS, LIMITS, AGENT_VERSION, VAULT_PROTOCOL_VERSION, TOOL_CATEGORY_VALUES, HTTP_METHOD_VALUES, } from "./constants";
50
+ export { SAP_PROGRAM_ADDRESS, SAP_PROGRAM_ID, MAINNET_SAP_PROGRAM_ID, DEVNET_SAP_PROGRAM_ID, LOCALNET_SAP_PROGRAM_ID, SEEDS, LIMITS, AGENT_VERSION, VAULT_PROTOCOL_VERSION, TOOL_CATEGORY_VALUES, HTTP_METHOD_VALUES, SapNetwork, } from "./constants";
50
51
  // ── IDL ──────────────────────────────────────────────
51
52
  export { SAP_IDL, IDL_PROGRAM_ADDRESS, IDL_METADATA } from "./idl/index";
52
53
  // ── PDA Derivation ───────────────────────────────────
@@ -65,6 +66,8 @@ export { createSAPPlugin, SAPPlugin } from "./plugin/index";
65
66
  export { SAP_PROTOCOLS } from "./plugin/protocols";
66
67
  // ── PostgreSQL Adapter (off-chain mirror) ────────────────
67
68
  export { SapPostgres, SapSyncEngine, SAP_TABLE_MAP } from "./postgres";
69
+ // ── Parser (transaction decode + instruction + events) ─
70
+ export { parseSapInstructionsFromTransaction, parseSapInstructionNamesFromTransaction, parseSapInstructionsFromList, parseSapInstructionNamesFromList, containsSapInstruction, parseSapTransactionComplete, parseSapTransactionBatch, decodeInnerInstructions, filterSapInnerInstructions, extractAccountKeys, TransactionParser, } from "./parser";
68
71
  // ── Registries (high-level developer abstractions) ────
69
72
  export { DiscoveryRegistry, X402Registry, SessionManager, AgentBuilder, } from "./registries/index";
70
73
  //# sourceMappingURL=index.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA2CG;AAEH,wDAAwD;AACxD,OAAO,EAAE,SAAS,EAAE,aAAa,EAAE,aAAa,EAAE,MAAM,QAAQ,CAAC;AAoDjE,OAAO,EACL,SAAS,EACT,UAAU,EACV,cAAc,EACd,cAAc,EACd,YAAY,EACZ,kBAAkB,EAClB,UAAU,EACV,eAAe,GAChB,MAAM,SAAS,CAAC;AAEjB,wDAAwD;AACxD,OAAO,EACL,mBAAmB,EACnB,cAAc,EACd,sBAAsB,EACtB,qBAAqB,EACrB,uBAAuB,EACvB,KAAK,EACL,MAAM,EACN,aAAa,EACb,sBAAsB,EACtB,oBAAoB,EACpB,kBAAkB,GACnB,MAAM,aAAa,CAAC;AAErB,wDAAwD;AACxD,OAAO,EAAE,OAAO,EAAE,mBAAmB,EAAE,YAAY,EAAE,MAAM,aAAa,CAAC;AAGzE,wDAAwD;AACxD,OAAO,EACL,oBAAoB,EACpB,WAAW,EACX,gBAAgB,EAChB,cAAc,EACd,qBAAqB,EACrB,mBAAmB,EACnB,uBAAuB,EACvB,WAAW,EACX,aAAa,EACb,eAAe,EACf,mBAAmB,EACnB,gBAAgB,EAChB,UAAU,EACV,YAAY,EACZ,iBAAiB,EACjB,YAAY,EACZ,gBAAgB,GACjB,MAAM,OAAO,CAAC;AAEf,wDAAwD;AACxD,OAAO,EAAE,MAAM,EAAE,WAAW,EAAE,MAAM,EAAE,MAAM,SAAS,CAAC;AACtD,OAAO,EAAE,gBAAgB,EAAE,cAAc,EAAE,MAAM,SAAS,CAAC;AAE3D,wDAAwD;AACxD,OAAO,EACL,QAAQ,EACR,kBAAkB,EAClB,WAAW,EACX,uBAAuB,EACvB,eAAe,EACf,kBAAkB,GACnB,MAAM,UAAU,CAAC;AAElB,wDAAwD;AACxD,OAAO,EAAE,WAAW,EAAE,eAAe,EAAE,MAAM,UAAU,CAAC;AAaxD,wDAAwD;AACxD,OAAO,EACL,WAAW,EACX,cAAc,EACd,cAAc,EACd,WAAW,EACX,WAAW,EACX,YAAY,EACZ,iBAAiB,EACjB,YAAY,EACZ,UAAU,GACX,MAAM,iBAAiB,CAAC;AAGzB,wDAAwD;AACxD,OAAO,EAAE,eAAe,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;AAY5D,OAAO,EAAE,aAAa,EAAE,MAAM,oBAAoB,CAAC;AAEnD,4DAA4D;AAC5D,OAAO,EAAE,WAAW,EAAE,aAAa,EAAE,aAAa,EAAE,MAAM,YAAY,CAAC;AAevE,yDAAyD;AACzD,OAAO,EACL,iBAAiB,EACjB,YAAY,EACZ,cAAc,EACd,YAAY,GACb,MAAM,oBAAoB,CAAC"}
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA4CG;AAEH,wDAAwD;AACxD,OAAO,EAAE,SAAS,EAAE,aAAa,EAAE,aAAa,EAAE,MAAM,QAAQ,CAAC;AAoDjE,OAAO,EACL,SAAS,EACT,UAAU,EACV,cAAc,EACd,cAAc,EACd,YAAY,EACZ,kBAAkB,EAClB,UAAU,EACV,eAAe,GAChB,MAAM,SAAS,CAAC;AAEjB,wDAAwD;AACxD,OAAO,EACL,mBAAmB,EACnB,cAAc,EACd,sBAAsB,EACtB,qBAAqB,EACrB,uBAAuB,EACvB,KAAK,EACL,MAAM,EACN,aAAa,EACb,sBAAsB,EACtB,oBAAoB,EACpB,kBAAkB,EAClB,UAAU,GACX,MAAM,aAAa,CAAC;AAGrB,wDAAwD;AACxD,OAAO,EAAE,OAAO,EAAE,mBAAmB,EAAE,YAAY,EAAE,MAAM,aAAa,CAAC;AAGzE,wDAAwD;AACxD,OAAO,EACL,oBAAoB,EACpB,WAAW,EACX,gBAAgB,EAChB,cAAc,EACd,qBAAqB,EACrB,mBAAmB,EACnB,uBAAuB,EACvB,WAAW,EACX,aAAa,EACb,eAAe,EACf,mBAAmB,EACnB,gBAAgB,EAChB,UAAU,EACV,YAAY,EACZ,iBAAiB,EACjB,YAAY,EACZ,gBAAgB,GACjB,MAAM,OAAO,CAAC;AAEf,wDAAwD;AACxD,OAAO,EAAE,MAAM,EAAE,WAAW,EAAE,MAAM,EAAE,MAAM,SAAS,CAAC;AACtD,OAAO,EAAE,gBAAgB,EAAE,cAAc,EAAE,MAAM,SAAS,CAAC;AAE3D,wDAAwD;AACxD,OAAO,EACL,QAAQ,EACR,kBAAkB,EAClB,WAAW,EACX,uBAAuB,EACvB,eAAe,EACf,kBAAkB,GACnB,MAAM,UAAU,CAAC;AAElB,wDAAwD;AACxD,OAAO,EAAE,WAAW,EAAE,eAAe,EAAE,MAAM,UAAU,CAAC;AAaxD,wDAAwD;AACxD,OAAO,EACL,WAAW,EACX,cAAc,EACd,cAAc,EACd,WAAW,EACX,WAAW,EACX,YAAY,EACZ,iBAAiB,EACjB,YAAY,EACZ,UAAU,GACX,MAAM,iBAAiB,CAAC;AAGzB,wDAAwD;AACxD,OAAO,EAAE,eAAe,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;AAY5D,OAAO,EAAE,aAAa,EAAE,MAAM,oBAAoB,CAAC;AAEnD,4DAA4D;AAC5D,OAAO,EAAE,WAAW,EAAE,aAAa,EAAE,aAAa,EAAE,MAAM,YAAY,CAAC;AAevE,0DAA0D;AAC1D,OAAO,EACL,mCAAmC,EACnC,uCAAuC,EACvC,4BAA4B,EAC5B,gCAAgC,EAChC,sBAAsB,EACtB,2BAA2B,EAC3B,wBAAwB,EACxB,uBAAuB,EACvB,0BAA0B,EAC1B,kBAAkB,EAClB,iBAAiB,GAClB,MAAM,UAAU,CAAC;AAWlB,yDAAyD;AACzD,OAAO,EACL,iBAAiB,EACjB,YAAY,EACZ,cAAc,EACd,YAAY,GACb,MAAM,oBAAoB,CAAC"}
@@ -0,0 +1,142 @@
1
+ /**
2
+ * @module parser/client
3
+ * @description Object-oriented wrapper for transaction parsing.
4
+ *
5
+ * Binds the Anchor `Program` reference so callers do not need to
6
+ * pass it on every call. Designed as a lazy singleton accessible
7
+ * from {@link SapClient.parser}.
8
+ *
9
+ * @category Parser
10
+ * @since v0.5.0
11
+ *
12
+ * @example
13
+ * ```ts
14
+ * const client = SapClient.from(provider);
15
+ *
16
+ * // Parse a full transaction
17
+ * const parsed = client.parser.parseTransaction(txResponse);
18
+ *
19
+ * // Quick instruction names
20
+ * const names = client.parser.instructionNames(txResponse);
21
+ *
22
+ * // From pre-built instructions
23
+ * const decoded = client.parser.fromInstructions(ixList);
24
+ * ```
25
+ */
26
+ import { parseSapInstructionsFromTransaction } from "./transaction";
27
+ import { parseSapInstructionsFromList, containsSapInstruction } from "./instructions";
28
+ import { parseSapTransactionComplete, parseSapTransactionBatch } from "./complete";
29
+ import { decodeInnerInstructions, extractAccountKeys, } from "./inner";
30
+ /**
31
+ * Stateful transaction parser bound to a specific Anchor `Program`.
32
+ *
33
+ * Stores the program reference, instruction coder, and program ID
34
+ * internally so that repeated parse calls require only the
35
+ * transaction data as input.
36
+ *
37
+ * @name TransactionParser
38
+ * @category Parser
39
+ * @since v0.5.0
40
+ */
41
+ export class TransactionParser {
42
+ program;
43
+ coder;
44
+ programId;
45
+ /**
46
+ * Create a new TransactionParser.
47
+ *
48
+ * @param program - An Anchor `Program` built from the SAP IDL.
49
+ */
50
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
51
+ constructor(program) {
52
+ this.program = program;
53
+ this.coder = program.coder.instruction;
54
+ this.programId = program.programId;
55
+ }
56
+ /**
57
+ * Full parse: instructions + inner calls + events.
58
+ *
59
+ * @param tx - Raw transaction response from `connection.getTransaction`.
60
+ * @param options - Optional filters for instructions, events, and inner calls.
61
+ * @param addressLookupTables - Resolved lookup tables for v0 transactions.
62
+ * @returns Complete parsed transaction, or `null` if the input is nullish.
63
+ *
64
+ * @since v0.5.0
65
+ */
66
+ parseTransaction(tx, options, addressLookupTables) {
67
+ return parseSapTransactionComplete(tx, this.program, this.programId, options, addressLookupTables);
68
+ }
69
+ /**
70
+ * Parse a batch of transactions.
71
+ *
72
+ * @param txs - Array of transaction responses (may contain `null` entries).
73
+ * @param options - Optional parse filters.
74
+ * @param addressLookupTables - Resolved lookup tables for v0 transactions.
75
+ * @returns Non-null parsed transactions.
76
+ *
77
+ * @since v0.5.0
78
+ */
79
+ parseBatch(txs, options, addressLookupTables) {
80
+ return parseSapTransactionBatch(txs, this.program, this.programId, options, addressLookupTables);
81
+ }
82
+ /**
83
+ * Decode top-level SAP instructions from a transaction response.
84
+ *
85
+ * @param tx - Raw transaction response.
86
+ * @param addressLookupTables - Resolved lookup tables for v0 transactions.
87
+ * @returns Decoded SAP instructions.
88
+ *
89
+ * @since v0.5.0
90
+ */
91
+ instructionsFromTransaction(tx, addressLookupTables) {
92
+ return parseSapInstructionsFromTransaction(tx, this.coder, this.programId, addressLookupTables);
93
+ }
94
+ /**
95
+ * Extract only the instruction names from a transaction response.
96
+ *
97
+ * @param tx - Raw transaction response.
98
+ * @param addressLookupTables - Resolved lookup tables for v0 transactions.
99
+ * @returns Instruction name strings.
100
+ *
101
+ * @since v0.5.0
102
+ */
103
+ instructionNames(tx, addressLookupTables) {
104
+ return this.instructionsFromTransaction(tx, addressLookupTables).map((ix) => ix.name);
105
+ }
106
+ /**
107
+ * Decode SAP instructions from a pre-built instruction array.
108
+ *
109
+ * @param instructions - The instruction list to decode.
110
+ * @returns Decoded SAP instructions.
111
+ *
112
+ * @since v0.5.0
113
+ */
114
+ fromInstructions(instructions) {
115
+ return parseSapInstructionsFromList(instructions, this.coder, this.programId);
116
+ }
117
+ /**
118
+ * Check if any instruction in the list targets the SAP program.
119
+ *
120
+ * @param instructions - The instruction array to inspect.
121
+ * @returns `true` if at least one instruction targets SAP.
122
+ *
123
+ * @since v0.5.0
124
+ */
125
+ isSapTransaction(instructions) {
126
+ return containsSapInstruction(instructions, this.programId);
127
+ }
128
+ /**
129
+ * Decode inner (CPI) instructions from transaction metadata.
130
+ *
131
+ * @param innerGroups - The `tx.meta.innerInstructions` array.
132
+ * @param tx - The transaction response (for account key resolution).
133
+ * @returns Decoded inner instructions.
134
+ *
135
+ * @since v0.5.0
136
+ */
137
+ decodeInner(innerGroups, tx) {
138
+ const accountKeys = extractAccountKeys(tx);
139
+ return decodeInnerInstructions(innerGroups, accountKeys, this.coder, this.programId);
140
+ }
141
+ }
142
+ //# sourceMappingURL=client.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"client.js","sourceRoot":"","sources":["../../../src/parser/client.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;;;;;;;;GAwBG;AAiBH,OAAO,EAAE,mCAAmC,EAAE,MAAM,eAAe,CAAC;AACpE,OAAO,EAAE,4BAA4B,EAAE,sBAAsB,EAAE,MAAM,gBAAgB,CAAC;AACtF,OAAO,EAAE,2BAA2B,EAAE,wBAAwB,EAAE,MAAM,YAAY,CAAC;AACnF,OAAO,EACL,uBAAuB,EACvB,kBAAkB,GAEnB,MAAM,SAAS,CAAC;AAEjB;;;;;;;;;;GAUG;AACH,MAAM,OAAO,iBAAiB;IAUC;IATZ,KAAK,CAAsB;IAC3B,SAAS,CAAY;IAEtC;;;;OAIG;IACH,8DAA8D;IAC9D,YAA6B,OAAqB;QAArB,YAAO,GAAP,OAAO,CAAc;QAChD,IAAI,CAAC,KAAK,GAAG,OAAO,CAAC,KAAK,CAAC,WAA6C,CAAC;QACzE,IAAI,CAAC,SAAS,GAAG,OAAO,CAAC,SAAS,CAAC;IACrC,CAAC;IAED;;;;;;;;;OASG;IACH,gBAAgB,CACd,EAAyE,EACzE,OAA4B,EAC5B,mBAAiD;QAEjD,OAAO,2BAA2B,CAChC,EAAE,EACF,IAAI,CAAC,OAAO,EACZ,IAAI,CAAC,SAAS,EACd,OAAO,EACP,mBAAmB,CACpB,CAAC;IACJ,CAAC;IAED;;;;;;;;;OASG;IACH,UAAU,CACR,GAA8E,EAC9E,OAA4B,EAC5B,mBAAiD;QAEjD,OAAO,wBAAwB,CAC7B,GAAG,EACH,IAAI,CAAC,OAAO,EACZ,IAAI,CAAC,SAAS,EACd,OAAO,EACP,mBAAmB,CACpB,CAAC;IACJ,CAAC;IAED;;;;;;;;OAQG;IACH,2BAA2B,CACzB,EAAsD,EACtD,mBAAiD;QAEjD,OAAO,mCAAmC,CACxC,EAAE,EACF,IAAI,CAAC,KAAK,EACV,IAAI,CAAC,SAAS,EACd,mBAAmB,CACpB,CAAC;IACJ,CAAC;IAED;;;;;;;;OAQG;IACH,gBAAgB,CACd,EAAsD,EACtD,mBAAiD;QAEjD,OAAO,IAAI,CAAC,2BAA2B,CAAC,EAAE,EAAE,mBAAmB,CAAC,CAAC,GAAG,CAClE,CAAC,EAAE,EAAE,EAAE,CAAC,EAAE,CAAC,IAAI,CAChB,CAAC;IACJ,CAAC;IAED;;;;;;;OAOG;IACH,gBAAgB,CACd,YAAsC;QAEtC,OAAO,4BAA4B,CAAC,YAAY,EAAE,IAAI,CAAC,KAAK,EAAE,IAAI,CAAC,SAAS,CAAC,CAAC;IAChF,CAAC;IAED;;;;;;;OAOG;IACH,gBAAgB,CAAC,YAAsC;QACrD,OAAO,sBAAsB,CAAC,YAAY,EAAE,IAAI,CAAC,SAAS,CAAC,CAAC;IAC9D,CAAC;IAED;;;;;;;;OAQG;IACH,WAAW,CACT,WAAoC,EACpC,EAAsD;QAEtD,MAAM,WAAW,GAAG,kBAAkB,CAAC,EAAE,CAAC,CAAC;QAC3C,OAAO,uBAAuB,CAC5B,WAAW,EACX,WAAW,EACX,IAAI,CAAC,KAAK,EACV,IAAI,CAAC,SAAS,CACf,CAAC;IACJ,CAAC;CACF"}
@@ -0,0 +1,173 @@
1
+ /**
2
+ * @module parser/complete
3
+ * @description Full SAP transaction parser: instructions + args + accounts + events.
4
+ *
5
+ * This is "Case 2 Complete": given a raw transaction response, produce a
6
+ * single {@link ParsedSapTransaction} containing every decoded instruction,
7
+ * all inner (CPI) calls, and all SAP events extracted from the logs.
8
+ *
9
+ * Designed for indexer pipelines where the decode step must be pure,
10
+ * deterministic, and fully testable without an RPC connection.
11
+ *
12
+ * @category Parser
13
+ * @since v0.5.0
14
+ *
15
+ * @example
16
+ * ```ts
17
+ * import { parseSapTransactionComplete } from "@synapse-sap/sdk/parser";
18
+ * import { SAP_PROGRAM_ID, SAP_IDL } from "@synapse-sap/sdk";
19
+ * import { Program } from "\@coral-xyz/anchor";
20
+ *
21
+ * const program = new Program(SAP_IDL, provider);
22
+ * const tx = await connection.getTransaction(sig, {
23
+ * commitment: "confirmed",
24
+ * maxSupportedTransactionVersion: 0,
25
+ * });
26
+ *
27
+ * const parsed = parseSapTransactionComplete(tx, program, SAP_PROGRAM_ID);
28
+ * console.log(parsed.instructions.map(i => i.name));
29
+ * console.log(parsed.events.map(e => e.name));
30
+ * ```
31
+ */
32
+ import { EventParser } from "../events";
33
+ import { parseSapInstructionsFromTransaction } from "./transaction";
34
+ import { decodeInnerInstructions, extractAccountKeys, } from "./inner";
35
+ // ================================================================
36
+ // Public API
37
+ // ================================================================
38
+ /**
39
+ * Parse a complete SAP transaction into a unified result.
40
+ *
41
+ * Combines three stages:
42
+ * 1. **Instruction decode** - top-level SAP instructions with args and accounts
43
+ * 2. **Inner instruction decode** - CPI calls with full account reconstruction
44
+ * 3. **Event extraction** - SAP events decoded from the transaction logs
45
+ *
46
+ * All three stages are safe: malformed data produces `null` fields
47
+ * rather than exceptions. This makes the function suitable for
48
+ * batch-processing in indexer workers where a single bad transaction
49
+ * must not halt the pipeline.
50
+ *
51
+ * @param tx - The raw transaction response from `connection.getTransaction`.
52
+ * @param program - An Anchor `Program` instance built from the SAP IDL.
53
+ * The coder and program ID are extracted automatically.
54
+ * @param sapProgramId - The SAP program public key. Passed explicitly so
55
+ * callers can target devnet/localnet deployments independently.
56
+ * @param options - Optional filters for instructions, events, and inner calls.
57
+ * @param addressLookupTables - Resolved lookup table accounts for v0 transactions.
58
+ * @returns A fully parsed transaction, or `null` if the input is `null`/`undefined`.
59
+ *
60
+ * @category Parser
61
+ * @since v0.5.0
62
+ */
63
+ export function parseSapTransactionComplete(tx,
64
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
65
+ program, sapProgramId, options, addressLookupTables) {
66
+ if (!tx)
67
+ return null;
68
+ const opts = {
69
+ includeInner: options?.includeInner ?? false,
70
+ includeEvents: options?.includeEvents ?? true,
71
+ instructionFilter: options?.instructionFilter ?? [],
72
+ eventFilter: options?.eventFilter ?? [],
73
+ };
74
+ // Extract coder from the program
75
+ const coder = program.coder.instruction;
76
+ // 1. Top-level instructions
77
+ let instructions = parseSapInstructionsFromTransaction(tx, coder, sapProgramId, addressLookupTables);
78
+ if (opts.instructionFilter.length > 0) {
79
+ const filterSet = new Set(opts.instructionFilter);
80
+ instructions = instructions.filter((ix) => filterSet.has(ix.name));
81
+ }
82
+ // 2. Inner (CPI) instructions
83
+ let innerInstructions = [];
84
+ if (opts.includeInner && tx.meta?.innerInstructions) {
85
+ const accountKeys = extractAccountKeys(tx);
86
+ innerInstructions = decodeInnerInstructions(tx.meta.innerInstructions, accountKeys, coder, sapProgramId);
87
+ }
88
+ // 3. Events from logs
89
+ let events = [];
90
+ const logs = tx.meta?.logMessages ?? [];
91
+ if (opts.includeEvents && logs.length > 0) {
92
+ const eventParser = new EventParser(program);
93
+ events = eventParser.parseLogs(logs);
94
+ if (opts.eventFilter.length > 0) {
95
+ const filterSet = new Set(opts.eventFilter);
96
+ events = events.filter((e) => filterSet.has(e.name));
97
+ }
98
+ }
99
+ // 4. Metadata
100
+ const signature = extractSignature(tx);
101
+ const slot = tx.slot ?? null;
102
+ const blockTime = tx.blockTime ?? null;
103
+ const success = tx.meta?.err === null || tx.meta?.err === undefined;
104
+ return {
105
+ signature,
106
+ slot,
107
+ blockTime,
108
+ success,
109
+ instructions,
110
+ innerInstructions,
111
+ events,
112
+ logs,
113
+ };
114
+ }
115
+ /**
116
+ * Parse multiple transactions in batch.
117
+ *
118
+ * Convenience wrapper for indexer pipelines that process pages of
119
+ * transactions. Skips `null` entries and failed decodes silently.
120
+ *
121
+ * @param txs - Array of transaction responses (may contain `null` entries).
122
+ * @param program - The Anchor SAP program instance.
123
+ * @param sapProgramId - The SAP program public key.
124
+ * @param options - Optional parse filters applied to every transaction.
125
+ * @param addressLookupTables - Lookup tables for v0 transactions.
126
+ * @returns An array of non-null parsed transactions.
127
+ *
128
+ * @category Parser
129
+ * @since v0.5.0
130
+ *
131
+ * @example
132
+ * ```ts
133
+ * const signatures = await connection.getSignaturesForAddress(agentPda);
134
+ * const txs = await Promise.all(
135
+ * signatures.map(s => connection.getTransaction(s.signature, { ... }))
136
+ * );
137
+ * const parsed = parseSapTransactionBatch(txs, program, SAP_PROGRAM_ID, {
138
+ * includeEvents: true,
139
+ * includeInner: true,
140
+ * });
141
+ * ```
142
+ */
143
+ export function parseSapTransactionBatch(txs,
144
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
145
+ program, sapProgramId, options, addressLookupTables) {
146
+ const results = [];
147
+ for (const tx of txs) {
148
+ const parsed = parseSapTransactionComplete(tx, program, sapProgramId, options, addressLookupTables);
149
+ if (parsed)
150
+ results.push(parsed);
151
+ }
152
+ return results;
153
+ }
154
+ // ================================================================
155
+ // Internal
156
+ // ================================================================
157
+ /**
158
+ * Extract the transaction signature from the response.
159
+ * Different RPC clients expose it in different locations.
160
+ *
161
+ * @internal
162
+ */
163
+ function extractSignature(tx) {
164
+ // Some clients expose signatures on the transaction object
165
+ const txObj = tx.transaction;
166
+ if ("signatures" in txObj && Array.isArray(txObj.signatures) && txObj.signatures.length > 0) {
167
+ const first = txObj.signatures[0];
168
+ if (typeof first === "string")
169
+ return first;
170
+ }
171
+ return null;
172
+ }
173
+ //# sourceMappingURL=complete.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"complete.js","sourceRoot":"","sources":["../../../src/parser/complete.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,43 @@
1
+ /**
2
+ * @module parser
3
+ * @description Transaction parsing utilities for SAP v2.
4
+ *
5
+ * Provides modular, composable functions for decoding on-chain SAP
6
+ * transactions into typed instruction data, argument objects, account
7
+ * lists, and protocol events.
8
+ *
9
+ * Three levels of parsing are available depending on your use case:
10
+ *
11
+ * | Function | Input | Output |
12
+ * |----------|-------|--------|
13
+ * | `parseSapInstructionsFromTransaction` | `TransactionResponse` (RPC) | Decoded instructions |
14
+ * | `parseSapInstructionsFromList` | `TransactionInstruction[]` | Decoded instructions |
15
+ * | `parseSapTransactionComplete` | `TransactionResponse` (RPC) | Instructions + events + inner calls |
16
+ *
17
+ * All functions are pure and stateless: they accept the Anchor coder
18
+ * (or full Program) as a parameter, making them safe for server-side
19
+ * indexer workers, edge functions (Node.js runtime), and test suites.
20
+ *
21
+ * @category Parser
22
+ * @since v0.5.0
23
+ *
24
+ * @example
25
+ * ```ts
26
+ * import {
27
+ * parseSapTransactionComplete,
28
+ * parseSapInstructionsFromList,
29
+ * containsSapInstruction,
30
+ * } from "@synapse-sap/sdk/parser";
31
+ * ```
32
+ */
33
+ // ── Case 2A: from TransactionResponse ────────────────
34
+ export { parseSapInstructionsFromTransaction, parseSapInstructionNamesFromTransaction, } from "./transaction";
35
+ // ── Case 2B: from TransactionInstruction[] ───────────
36
+ export { parseSapInstructionsFromList, parseSapInstructionNamesFromList, containsSapInstruction, } from "./instructions";
37
+ // ── Case 2 Complete: instructions + events + inner ───
38
+ export { parseSapTransactionComplete, parseSapTransactionBatch, } from "./complete";
39
+ // ── Inner instruction utilities ──────────────────────
40
+ export { decodeInnerInstructions, filterSapInnerInstructions, extractAccountKeys, } from "./inner";
41
+ // ── OOP wrapper (for SapClient integration) ──────────
42
+ export { TransactionParser } from "./client";
43
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/parser/index.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA+BG;AAWH,wDAAwD;AACxD,OAAO,EACL,mCAAmC,EACnC,uCAAuC,GACxC,MAAM,eAAe,CAAC;AAEvB,wDAAwD;AACxD,OAAO,EACL,4BAA4B,EAC5B,gCAAgC,EAChC,sBAAsB,GACvB,MAAM,gBAAgB,CAAC;AAExB,wDAAwD;AACxD,OAAO,EACL,2BAA2B,EAC3B,wBAAwB,GACzB,MAAM,YAAY,CAAC;AAEpB,wDAAwD;AACxD,OAAO,EACL,uBAAuB,EACvB,0BAA0B,EAC1B,kBAAkB,GACnB,MAAM,SAAS,CAAC;AAGjB,wDAAwD;AACxD,OAAO,EAAE,iBAAiB,EAAE,MAAM,UAAU,CAAC"}