@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.
- package/dist/cjs/constants/index.js +4 -1
- package/dist/cjs/constants/index.js.map +1 -1
- package/dist/cjs/constants/network.js +81 -0
- package/dist/cjs/constants/network.js.map +1 -0
- package/dist/cjs/core/client.js +23 -0
- package/dist/cjs/core/client.js.map +1 -1
- package/dist/cjs/index.js +17 -2
- package/dist/cjs/index.js.map +1 -1
- package/dist/cjs/parser/client.js +146 -0
- package/dist/cjs/parser/client.js.map +1 -0
- package/dist/cjs/parser/complete.js +177 -0
- package/dist/cjs/parser/complete.js.map +1 -0
- package/dist/cjs/parser/index.js +57 -0
- package/dist/cjs/parser/index.js.map +1 -0
- package/dist/cjs/parser/inner.js +185 -0
- package/dist/cjs/parser/inner.js.map +1 -0
- package/dist/cjs/parser/instructions.js +114 -0
- package/dist/cjs/parser/instructions.js.map +1 -0
- package/dist/cjs/parser/transaction.js +153 -0
- package/dist/cjs/parser/transaction.js.map +1 -0
- package/dist/cjs/parser/types.js +14 -0
- package/dist/cjs/parser/types.js.map +1 -0
- package/dist/cjs/registries/x402.js +5 -2
- package/dist/cjs/registries/x402.js.map +1 -1
- package/dist/esm/constants/index.js +2 -0
- package/dist/esm/constants/index.js.map +1 -1
- package/dist/esm/constants/network.js +78 -0
- package/dist/esm/constants/network.js.map +1 -0
- package/dist/esm/core/client.js +23 -0
- package/dist/esm/core/client.js.map +1 -1
- package/dist/esm/index.js +4 -1
- package/dist/esm/index.js.map +1 -1
- package/dist/esm/parser/client.js +142 -0
- package/dist/esm/parser/client.js.map +1 -0
- package/dist/esm/parser/complete.js +173 -0
- package/dist/esm/parser/complete.js.map +1 -0
- package/dist/esm/parser/index.js +43 -0
- package/dist/esm/parser/index.js.map +1 -0
- package/dist/esm/parser/inner.js +180 -0
- package/dist/esm/parser/inner.js.map +1 -0
- package/dist/esm/parser/instructions.js +109 -0
- package/dist/esm/parser/instructions.js.map +1 -0
- package/dist/esm/parser/transaction.js +149 -0
- package/dist/esm/parser/transaction.js.map +1 -0
- package/dist/esm/parser/types.js +13 -0
- package/dist/esm/parser/types.js.map +1 -0
- package/dist/esm/registries/x402.js +5 -2
- package/dist/esm/registries/x402.js.map +1 -1
- package/dist/types/constants/index.d.ts +2 -0
- package/dist/types/constants/index.d.ts.map +1 -1
- package/dist/types/constants/network.d.ts +81 -0
- package/dist/types/constants/network.d.ts.map +1 -0
- package/dist/types/core/client.d.ts +19 -0
- package/dist/types/core/client.d.ts.map +1 -1
- package/dist/types/index.d.ts +5 -1
- package/dist/types/index.d.ts.map +1 -1
- package/dist/types/parser/client.d.ts +123 -0
- package/dist/types/parser/client.d.ts.map +1 -0
- package/dist/types/parser/complete.d.ts +90 -0
- package/dist/types/parser/complete.d.ts.map +1 -0
- package/dist/types/parser/index.d.ts +40 -0
- package/dist/types/parser/index.d.ts.map +1 -0
- package/dist/types/parser/inner.d.ts +114 -0
- package/dist/types/parser/inner.d.ts.map +1 -0
- package/dist/types/parser/instructions.d.ts +76 -0
- package/dist/types/parser/instructions.d.ts.map +1 -0
- package/dist/types/parser/transaction.d.ts +77 -0
- package/dist/types/parser/transaction.d.ts.map +1 -0
- package/dist/types/parser/types.d.ts +154 -0
- package/dist/types/parser/types.d.ts.map +1 -0
- package/dist/types/registries/x402.d.ts +35 -2
- package/dist/types/registries/x402.d.ts.map +1 -1
- package/package.json +6 -1
- package/src/constants/index.ts +4 -0
- package/src/constants/network.ts +89 -0
- package/src/core/client.ts +25 -0
- package/src/index.ts +27 -0
- package/src/parser/client.ts +211 -0
- package/src/parser/complete.ts +232 -0
- package/src/parser/index.ts +71 -0
- package/src/parser/inner.ts +255 -0
- package/src/parser/instructions.ts +135 -0
- package/src/parser/transaction.ts +200 -0
- package/src/parser/types.ts +182 -0
- 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"}
|
package/dist/esm/core/client.js
CHANGED
|
@@ -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
|
package/dist/esm/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA
|
|
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"}
|