@agirails/sdk 2.0.4 → 2.2.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 (201) hide show
  1. package/README.md +536 -87
  2. package/dist/ACTPClient.d.ts +200 -0
  3. package/dist/ACTPClient.d.ts.map +1 -1
  4. package/dist/ACTPClient.js +266 -2
  5. package/dist/ACTPClient.js.map +1 -1
  6. package/dist/abi/ACTPKernel.json +16 -0
  7. package/dist/adapters/AdapterRegistry.d.ts +140 -0
  8. package/dist/adapters/AdapterRegistry.d.ts.map +1 -0
  9. package/dist/adapters/AdapterRegistry.js +166 -0
  10. package/dist/adapters/AdapterRegistry.js.map +1 -0
  11. package/dist/adapters/AdapterRouter.d.ts +165 -0
  12. package/dist/adapters/AdapterRouter.d.ts.map +1 -0
  13. package/dist/adapters/AdapterRouter.js +350 -0
  14. package/dist/adapters/AdapterRouter.js.map +1 -0
  15. package/dist/adapters/BaseAdapter.d.ts +17 -0
  16. package/dist/adapters/BaseAdapter.d.ts.map +1 -1
  17. package/dist/adapters/BaseAdapter.js +21 -0
  18. package/dist/adapters/BaseAdapter.js.map +1 -1
  19. package/dist/adapters/BasicAdapter.d.ts +72 -3
  20. package/dist/adapters/BasicAdapter.d.ts.map +1 -1
  21. package/dist/adapters/BasicAdapter.js +178 -2
  22. package/dist/adapters/BasicAdapter.js.map +1 -1
  23. package/dist/adapters/IAdapter.d.ts +230 -0
  24. package/dist/adapters/IAdapter.d.ts.map +1 -0
  25. package/dist/adapters/IAdapter.js +44 -0
  26. package/dist/adapters/IAdapter.js.map +1 -0
  27. package/dist/adapters/StandardAdapter.d.ts +80 -6
  28. package/dist/adapters/StandardAdapter.d.ts.map +1 -1
  29. package/dist/adapters/StandardAdapter.js +203 -6
  30. package/dist/adapters/StandardAdapter.js.map +1 -1
  31. package/dist/adapters/X402Adapter.d.ts +208 -0
  32. package/dist/adapters/X402Adapter.d.ts.map +1 -0
  33. package/dist/adapters/X402Adapter.js +423 -0
  34. package/dist/adapters/X402Adapter.js.map +1 -0
  35. package/dist/adapters/index.d.ts +8 -0
  36. package/dist/adapters/index.d.ts.map +1 -1
  37. package/dist/adapters/index.js +19 -1
  38. package/dist/adapters/index.js.map +1 -1
  39. package/dist/cli/commands/init.d.ts +4 -0
  40. package/dist/cli/commands/init.d.ts.map +1 -1
  41. package/dist/cli/commands/init.js +146 -4
  42. package/dist/cli/commands/init.js.map +1 -1
  43. package/dist/config/networks.d.ts +9 -0
  44. package/dist/config/networks.d.ts.map +1 -1
  45. package/dist/config/networks.js +27 -12
  46. package/dist/config/networks.js.map +1 -1
  47. package/dist/erc8004/ERC8004Bridge.d.ts +155 -0
  48. package/dist/erc8004/ERC8004Bridge.d.ts.map +1 -0
  49. package/dist/erc8004/ERC8004Bridge.js +325 -0
  50. package/dist/erc8004/ERC8004Bridge.js.map +1 -0
  51. package/dist/erc8004/ReputationReporter.d.ts +223 -0
  52. package/dist/erc8004/ReputationReporter.d.ts.map +1 -0
  53. package/dist/erc8004/ReputationReporter.js +266 -0
  54. package/dist/erc8004/ReputationReporter.js.map +1 -0
  55. package/dist/erc8004/index.d.ts +36 -0
  56. package/dist/erc8004/index.d.ts.map +1 -0
  57. package/dist/erc8004/index.js +46 -0
  58. package/dist/erc8004/index.js.map +1 -0
  59. package/dist/index.d.ts +11 -1
  60. package/dist/index.d.ts.map +1 -1
  61. package/dist/index.js +51 -2
  62. package/dist/index.js.map +1 -1
  63. package/dist/level0/provide.d.ts.map +1 -1
  64. package/dist/level0/provide.js +2 -1
  65. package/dist/level0/provide.js.map +1 -1
  66. package/dist/level1/Agent.d.ts.map +1 -1
  67. package/dist/level1/Agent.js +11 -3
  68. package/dist/level1/Agent.js.map +1 -1
  69. package/dist/protocol/ACTPKernel.d.ts +1 -1
  70. package/dist/protocol/ACTPKernel.d.ts.map +1 -1
  71. package/dist/protocol/ACTPKernel.js +23 -12
  72. package/dist/protocol/ACTPKernel.js.map +1 -1
  73. package/dist/protocol/DIDResolver.js +1 -1
  74. package/dist/protocol/DIDResolver.js.map +1 -1
  75. package/dist/protocol/EASHelper.d.ts.map +1 -1
  76. package/dist/protocol/EASHelper.js +2 -3
  77. package/dist/protocol/EASHelper.js.map +1 -1
  78. package/dist/protocol/MessageSigner.d.ts.map +1 -1
  79. package/dist/protocol/MessageSigner.js +8 -8
  80. package/dist/protocol/MessageSigner.js.map +1 -1
  81. package/dist/runtime/BlockchainRuntime.d.ts +7 -0
  82. package/dist/runtime/BlockchainRuntime.d.ts.map +1 -1
  83. package/dist/runtime/BlockchainRuntime.js +40 -22
  84. package/dist/runtime/BlockchainRuntime.js.map +1 -1
  85. package/dist/runtime/IACTPRuntime.d.ts +21 -0
  86. package/dist/runtime/IACTPRuntime.d.ts.map +1 -1
  87. package/dist/runtime/MockRuntime.d.ts +19 -0
  88. package/dist/runtime/MockRuntime.d.ts.map +1 -1
  89. package/dist/runtime/MockRuntime.js +56 -4
  90. package/dist/runtime/MockRuntime.js.map +1 -1
  91. package/dist/runtime/types/MockState.d.ts +11 -2
  92. package/dist/runtime/types/MockState.d.ts.map +1 -1
  93. package/dist/runtime/types/MockState.js.map +1 -1
  94. package/dist/storage/ArchiveBundleBuilder.d.ts +150 -0
  95. package/dist/storage/ArchiveBundleBuilder.d.ts.map +1 -0
  96. package/dist/storage/ArchiveBundleBuilder.js +468 -0
  97. package/dist/storage/ArchiveBundleBuilder.js.map +1 -0
  98. package/dist/storage/ArweaveClient.d.ts +271 -0
  99. package/dist/storage/ArweaveClient.d.ts.map +1 -0
  100. package/dist/storage/ArweaveClient.js +761 -0
  101. package/dist/storage/ArweaveClient.js.map +1 -0
  102. package/dist/storage/FilebaseClient.d.ts +193 -0
  103. package/dist/storage/FilebaseClient.d.ts.map +1 -0
  104. package/dist/storage/FilebaseClient.js +643 -0
  105. package/dist/storage/FilebaseClient.js.map +1 -0
  106. package/dist/storage/index.d.ts +47 -0
  107. package/dist/storage/index.d.ts.map +1 -0
  108. package/dist/storage/index.js +64 -0
  109. package/dist/storage/index.js.map +1 -0
  110. package/dist/storage/types.d.ts +291 -0
  111. package/dist/storage/types.d.ts.map +1 -0
  112. package/dist/storage/types.js +18 -0
  113. package/dist/storage/types.js.map +1 -0
  114. package/dist/types/adapter.d.ts +359 -0
  115. package/dist/types/adapter.d.ts.map +1 -0
  116. package/dist/types/adapter.js +115 -0
  117. package/dist/types/adapter.js.map +1 -0
  118. package/dist/types/erc8004.d.ts +184 -0
  119. package/dist/types/erc8004.d.ts.map +1 -0
  120. package/dist/types/erc8004.js +132 -0
  121. package/dist/types/erc8004.js.map +1 -0
  122. package/dist/types/index.d.ts +3 -0
  123. package/dist/types/index.d.ts.map +1 -1
  124. package/dist/types/index.js +3 -0
  125. package/dist/types/index.js.map +1 -1
  126. package/dist/types/state.d.ts +5 -4
  127. package/dist/types/state.d.ts.map +1 -1
  128. package/dist/types/state.js +10 -9
  129. package/dist/types/state.js.map +1 -1
  130. package/dist/types/transaction.d.ts +12 -0
  131. package/dist/types/transaction.d.ts.map +1 -1
  132. package/dist/types/x402.d.ts +162 -0
  133. package/dist/types/x402.d.ts.map +1 -0
  134. package/dist/types/x402.js +162 -0
  135. package/dist/types/x402.js.map +1 -0
  136. package/dist/utils/IPFSClient.d.ts.map +1 -1
  137. package/dist/utils/IPFSClient.js +5 -2
  138. package/dist/utils/IPFSClient.js.map +1 -1
  139. package/dist/utils/NonceManager.d.ts.map +1 -1
  140. package/dist/utils/NonceManager.js +3 -2
  141. package/dist/utils/NonceManager.js.map +1 -1
  142. package/dist/utils/UsedAttestationTracker.d.ts.map +1 -1
  143. package/dist/utils/UsedAttestationTracker.js +3 -3
  144. package/dist/utils/UsedAttestationTracker.js.map +1 -1
  145. package/dist/utils/circuitBreaker.d.ts +136 -0
  146. package/dist/utils/circuitBreaker.d.ts.map +1 -0
  147. package/dist/utils/circuitBreaker.js +253 -0
  148. package/dist/utils/circuitBreaker.js.map +1 -0
  149. package/dist/utils/retry.d.ts +120 -0
  150. package/dist/utils/retry.d.ts.map +1 -0
  151. package/dist/utils/retry.js +260 -0
  152. package/dist/utils/retry.js.map +1 -0
  153. package/dist/utils/validation.d.ts +100 -0
  154. package/dist/utils/validation.d.ts.map +1 -1
  155. package/dist/utils/validation.js +248 -1
  156. package/dist/utils/validation.js.map +1 -1
  157. package/package.json +16 -3
  158. package/src/ACTPClient.ts +318 -2
  159. package/src/abi/ACTPKernel.json +16 -0
  160. package/src/adapters/AdapterRegistry.ts +173 -0
  161. package/src/adapters/AdapterRouter.ts +417 -0
  162. package/src/adapters/BaseAdapter.ts +25 -0
  163. package/src/adapters/BasicAdapter.ts +210 -3
  164. package/src/adapters/IAdapter.ts +292 -0
  165. package/src/adapters/StandardAdapter.ts +246 -7
  166. package/src/adapters/X402Adapter.ts +653 -0
  167. package/src/adapters/index.ts +27 -0
  168. package/src/cli/commands/init.ts +166 -3
  169. package/src/config/networks.ts +36 -12
  170. package/src/erc8004/ERC8004Bridge.ts +461 -0
  171. package/src/erc8004/ReputationReporter.ts +472 -0
  172. package/src/erc8004/index.ts +61 -0
  173. package/src/index.ts +97 -0
  174. package/src/level0/provide.ts +2 -1
  175. package/src/level1/Agent.ts +13 -3
  176. package/src/protocol/ACTPKernel.ts +33 -12
  177. package/src/protocol/DIDResolver.ts +1 -1
  178. package/src/protocol/EASHelper.ts +2 -5
  179. package/src/protocol/MessageSigner.ts +8 -14
  180. package/src/runtime/BlockchainRuntime.ts +41 -45
  181. package/src/runtime/IACTPRuntime.ts +22 -0
  182. package/src/runtime/MockRuntime.ts +58 -4
  183. package/src/runtime/types/MockState.ts +12 -2
  184. package/src/storage/ArchiveBundleBuilder.ts +563 -0
  185. package/src/storage/ArweaveClient.ts +945 -0
  186. package/src/storage/FilebaseClient.ts +790 -0
  187. package/src/storage/index.ts +96 -0
  188. package/src/storage/types.ts +348 -0
  189. package/src/types/adapter.ts +296 -0
  190. package/src/types/erc8004.ts +293 -0
  191. package/src/types/index.ts +3 -0
  192. package/src/types/state.ts +10 -9
  193. package/src/types/transaction.ts +12 -0
  194. package/src/types/x402.ts +219 -0
  195. package/src/utils/IPFSClient.ts +5 -4
  196. package/src/utils/NonceManager.ts +3 -2
  197. package/src/utils/UsedAttestationTracker.ts +3 -5
  198. package/src/utils/circuitBreaker.ts +324 -0
  199. package/src/utils/fsSafe.ts +5 -0
  200. package/src/utils/retry.ts +365 -0
  201. package/src/utils/validation.ts +295 -1
@@ -0,0 +1,96 @@
1
+ /**
2
+ * Storage Module - Hybrid Storage Architecture (AIP-7 §4)
3
+ *
4
+ * Two-tier storage model:
5
+ * - Tier 1: IPFS (Filebase) for hot storage
6
+ * - Tier 2: Arweave (Irys) for permanent archive
7
+ *
8
+ * @module storage
9
+ *
10
+ * @example
11
+ * ```typescript
12
+ * import {
13
+ * FilebaseClient,
14
+ * ArweaveClient,
15
+ * ArchiveBundleBuilder
16
+ * } from '@agirails/sdk/storage';
17
+ *
18
+ * // IPFS hot storage
19
+ * const ipfs = new FilebaseClient({
20
+ * accessKey: process.env.FILEBASE_ACCESS_KEY!,
21
+ * secretKey: process.env.FILEBASE_SECRET_KEY!
22
+ * });
23
+ *
24
+ * // Arweave permanent storage
25
+ * const arweave = await ArweaveClient.create({
26
+ * privateKey: process.env.ARCHIVE_KEY!,
27
+ * rpcUrl: process.env.BASE_RPC!
28
+ * });
29
+ *
30
+ * // Build archive bundle
31
+ * const bundle = new ArchiveBundleBuilder()
32
+ * .setTransactionId(txId)
33
+ * .setChainId(8453)
34
+ * // ... other fields
35
+ * .build();
36
+ *
37
+ * // Upload to Arweave
38
+ * const result = await arweave.uploadBundle(bundle);
39
+ * console.log('Archived at:', result.txId);
40
+ * ```
41
+ */
42
+
43
+ // ============================================================================
44
+ // Clients
45
+ // ============================================================================
46
+
47
+ export { FilebaseClient } from './FilebaseClient';
48
+ export { ArweaveClient } from './ArweaveClient';
49
+
50
+ // ============================================================================
51
+ // Builders
52
+ // ============================================================================
53
+
54
+ export {
55
+ ArchiveBundleBuilder,
56
+ computeContentHash,
57
+ validateArchiveBundle
58
+ } from './ArchiveBundleBuilder';
59
+
60
+ // ============================================================================
61
+ // Types
62
+ // ============================================================================
63
+
64
+ export type {
65
+ // Filebase
66
+ FilebaseConfig,
67
+
68
+ // Arweave
69
+ ArweaveConfig,
70
+ IrysCurrency,
71
+ IrysNetwork,
72
+
73
+ // Archive Bundle
74
+ ArchiveBundle,
75
+ ArchiveChainId,
76
+ ArchiveFinalState,
77
+ ArchiveParticipants,
78
+ ArchiveReferences,
79
+ ArchiveHashes,
80
+ ArchiveSignatures,
81
+ ArchiveAttestation,
82
+ ArchiveSettlement,
83
+ EscrowRelease,
84
+ ArchiveTags,
85
+
86
+ // Results
87
+ IPFSUploadResult,
88
+ ArweaveUploadResult,
89
+ DownloadResult
90
+ } from './types';
91
+
92
+ // ============================================================================
93
+ // Constants
94
+ // ============================================================================
95
+
96
+ export { ARCHIVE_BUNDLE_TYPE } from './types';
@@ -0,0 +1,348 @@
1
+ /**
2
+ * Storage Types (AIP-7 §4)
3
+ *
4
+ * Type definitions for the AGIRAILS hybrid storage architecture:
5
+ * - Tier 1: IPFS (Filebase) for hot storage
6
+ * - Tier 2: Arweave (Irys) for permanent archive
7
+ */
8
+
9
+ // ============================================================================
10
+ // Filebase Configuration
11
+ // ============================================================================
12
+
13
+ /**
14
+ * Configuration for Filebase S3-compatible IPFS client
15
+ */
16
+ export interface FilebaseConfig {
17
+ /**
18
+ * Filebase access key ID
19
+ * Get from: https://console.filebase.com/keys
20
+ */
21
+ accessKey: string;
22
+
23
+ /**
24
+ * Filebase secret access key
25
+ * SECURITY: Store in environment variable, never in code
26
+ */
27
+ secretKey: string;
28
+
29
+ /**
30
+ * Filebase bucket name
31
+ * @default 'agirails-storage'
32
+ */
33
+ bucket?: string;
34
+
35
+ /**
36
+ * Filebase S3 endpoint
37
+ * @default 'https://s3.filebase.com'
38
+ */
39
+ endpoint?: string;
40
+
41
+ /**
42
+ * IPFS gateway URL for retrieval
43
+ * @default 'https://ipfs.filebase.io/ipfs/'
44
+ */
45
+ gatewayUrl?: string;
46
+
47
+ /**
48
+ * Request timeout in milliseconds
49
+ * @default 30000 (30 seconds)
50
+ */
51
+ timeout?: number;
52
+
53
+ /**
54
+ * Maximum file size in bytes for uploads
55
+ * @default 104857600 (100MB)
56
+ */
57
+ maxFileSize?: number;
58
+
59
+ /**
60
+ * Maximum download size in bytes (P1-1: DoS protection)
61
+ * Downloads exceeding this limit will be rejected
62
+ * @default 52428800 (50MB)
63
+ */
64
+ maxDownloadSize?: number;
65
+
66
+ /**
67
+ * Circuit breaker configuration for gateway health tracking
68
+ * When enabled, tracks gateway failures and temporarily blocks
69
+ * requests to unhealthy gateways (retry amplification protection)
70
+ */
71
+ circuitBreaker?: {
72
+ /** Enable circuit breaker (default: true) */
73
+ enabled?: boolean;
74
+ /** Number of failures before opening circuit (default: 5) */
75
+ failureThreshold?: number;
76
+ /** Cooldown period in ms before attempting reset (default: 60000) */
77
+ resetTimeoutMs?: number;
78
+ /** Time window in ms for counting failures (default: 300000) */
79
+ failureWindowMs?: number;
80
+ /** Number of successes in half-open to close circuit (default: 2) */
81
+ successThreshold?: number;
82
+ };
83
+ }
84
+
85
+ // ============================================================================
86
+ // Arweave Configuration
87
+ // ============================================================================
88
+
89
+ /**
90
+ * Supported Irys payment tokens
91
+ * @see https://docs.irys.xyz/build/d/features/supported-tokens
92
+ */
93
+ export type IrysCurrency =
94
+ | 'base-eth' // RECOMMENDED: Base ETH (native to AGIRAILS)
95
+ | 'ethereum' // Ethereum mainnet ETH
96
+ | 'matic' // Polygon MATIC
97
+ | 'arbitrum' // Arbitrum ETH
98
+ | 'usdc-eth' // USDC on Ethereum
99
+ | 'usdc-polygon'; // USDC on Polygon
100
+
101
+ /**
102
+ * Irys network
103
+ */
104
+ export type IrysNetwork = 'mainnet' | 'devnet';
105
+
106
+ /**
107
+ * Configuration for Arweave client via Irys
108
+ */
109
+ export interface ArweaveConfig {
110
+ /**
111
+ * Private key for signing transactions
112
+ * SECURITY: Store in environment variable, never in code
113
+ */
114
+ privateKey: string;
115
+
116
+ /**
117
+ * RPC URL for the payment chain
118
+ * Required for blockchain operations
119
+ */
120
+ rpcUrl: string;
121
+
122
+ /**
123
+ * Payment currency/token
124
+ * @default 'base-eth'
125
+ */
126
+ currency?: IrysCurrency;
127
+
128
+ /**
129
+ * Irys network (mainnet or devnet)
130
+ * @default 'mainnet'
131
+ */
132
+ network?: IrysNetwork;
133
+
134
+ /**
135
+ * Request timeout in milliseconds
136
+ * @default 60000 (60 seconds)
137
+ */
138
+ timeout?: number;
139
+
140
+ /**
141
+ * Circuit breaker configuration for gateway health tracking
142
+ * When enabled, tracks gateway failures and temporarily blocks
143
+ * requests to unhealthy gateways (retry amplification protection)
144
+ */
145
+ circuitBreaker?: {
146
+ /** Enable circuit breaker (default: true) */
147
+ enabled?: boolean;
148
+ /** Number of failures before opening circuit (default: 5) */
149
+ failureThreshold?: number;
150
+ /** Cooldown period in ms before attempting reset (default: 60000) */
151
+ resetTimeoutMs?: number;
152
+ /** Time window in ms for counting failures (default: 300000) */
153
+ failureWindowMs?: number;
154
+ /** Number of successes in half-open to close circuit (default: 2) */
155
+ successThreshold?: number;
156
+ };
157
+ }
158
+
159
+ // ============================================================================
160
+ // Archive Bundle Types (AIP-7 §4.4)
161
+ // ============================================================================
162
+
163
+ /**
164
+ * Archive bundle type identifier
165
+ */
166
+ export const ARCHIVE_BUNDLE_TYPE = 'actp.archive.v1.minimal' as const;
167
+
168
+ /**
169
+ * Supported chain IDs for archive bundles
170
+ */
171
+ export type ArchiveChainId = 8453 | 84532; // Base Mainnet | Base Sepolia
172
+
173
+ /**
174
+ * Final transaction states that can be archived
175
+ */
176
+ export type ArchiveFinalState = 'SETTLED' | 'CANCELLED';
177
+
178
+ /**
179
+ * Transaction participants (addresses only, not full profiles)
180
+ */
181
+ export interface ArchiveParticipants {
182
+ /** Requester Ethereum address */
183
+ requester: string;
184
+ /** Provider Ethereum address */
185
+ provider: string;
186
+ }
187
+
188
+ /**
189
+ * IPFS CID references to full content
190
+ */
191
+ export interface ArchiveReferences {
192
+ /** IPFS CID of AIP-1 request metadata */
193
+ requestCID: string;
194
+ /** IPFS CID of AIP-4 delivery proof */
195
+ deliveryCID: string;
196
+ /** IPFS CID of actual result/output (optional) */
197
+ resultCID?: string;
198
+ }
199
+
200
+ /**
201
+ * Cryptographic hashes for verification
202
+ */
203
+ export interface ArchiveHashes {
204
+ /** keccak256 of canonical request metadata JSON */
205
+ requestHash: string;
206
+ /** keccak256 of canonical delivery proof JSON */
207
+ deliveryHash: string;
208
+ /** serviceHash from ACTPKernel transaction */
209
+ serviceHash: string;
210
+ }
211
+
212
+ /**
213
+ * Cryptographic signatures for self-verification
214
+ */
215
+ export interface ArchiveSignatures {
216
+ /** EIP-712 signature by provider over deliveryHash */
217
+ providerDeliverySignature: string;
218
+ /** Optional: requester signature authorizing settlement */
219
+ requesterSettlementSignature?: string;
220
+ }
221
+
222
+ /**
223
+ * EAS attestation reference
224
+ */
225
+ export interface ArchiveAttestation {
226
+ /** Ethereum Attestation Service UID */
227
+ easUID: string;
228
+ /** EAS schema UID used for attestation (optional) */
229
+ schemaUID?: string;
230
+ }
231
+
232
+ /**
233
+ * Escrow release details
234
+ */
235
+ export interface EscrowRelease {
236
+ /** Recipient address (provider or requester) */
237
+ to: string;
238
+ /** Released amount (USDC base units, string for BigInt safety) */
239
+ amount: string;
240
+ }
241
+
242
+ /**
243
+ * Settlement information
244
+ */
245
+ export interface ArchiveSettlement {
246
+ /** Settlement timestamp (Unix seconds) */
247
+ settledAt: number;
248
+ /** Final transaction state */
249
+ finalState: ArchiveFinalState;
250
+ /** Escrow release details */
251
+ escrowReleased: EscrowRelease;
252
+ /** Platform fee collected (USDC base units) */
253
+ platformFee: string;
254
+ /** Whether transaction went through dispute */
255
+ wasDisputed: boolean;
256
+ }
257
+
258
+ /**
259
+ * Archive Bundle (AIP-7 §4.4 - Minimal Hash-First)
260
+ *
261
+ * Contains minimal metadata with cryptographic hashes and references.
262
+ * Full content (request metadata, delivery proof) remains on IPFS.
263
+ */
264
+ export interface ArchiveBundle {
265
+ /** AGIRAILS protocol version (e.g., "1.0.0") */
266
+ protocolVersion: string;
267
+ /** Archive bundle schema version (e.g., "1.0.0") */
268
+ archiveSchemaVersion: string;
269
+ /** Archive bundle type identifier */
270
+ type: typeof ARCHIVE_BUNDLE_TYPE;
271
+ /** ACTP transaction ID (bytes32) */
272
+ txId: string;
273
+ /** Blockchain network chain ID */
274
+ chainId: ArchiveChainId;
275
+ /** Archive timestamp (Unix seconds) */
276
+ archivedAt: number;
277
+ /** Transaction participants (addresses only) */
278
+ participants: ArchiveParticipants;
279
+ /** IPFS CID references to full content */
280
+ references: ArchiveReferences;
281
+ /** Cryptographic hashes for verification */
282
+ hashes: ArchiveHashes;
283
+ /** Cryptographic signatures */
284
+ signatures: ArchiveSignatures;
285
+ /** EAS attestation reference (optional for cancelled transactions) */
286
+ attestation?: ArchiveAttestation;
287
+ /** Settlement information */
288
+ settlement: ArchiveSettlement;
289
+ }
290
+
291
+ // ============================================================================
292
+ // Upload/Download Results
293
+ // ============================================================================
294
+
295
+ /**
296
+ * Result of uploading to IPFS
297
+ */
298
+ export interface IPFSUploadResult {
299
+ /** IPFS CID (CIDv1, base32) */
300
+ cid: string;
301
+ /** Size of uploaded content in bytes */
302
+ size: number;
303
+ /** Upload timestamp */
304
+ uploadedAt: Date;
305
+ }
306
+
307
+ /**
308
+ * Result of uploading to Arweave
309
+ */
310
+ export interface ArweaveUploadResult {
311
+ /** Arweave transaction ID */
312
+ txId: string;
313
+ /** Size of uploaded content in bytes */
314
+ size: number;
315
+ /** Upload timestamp */
316
+ uploadedAt: Date;
317
+ /** Cost in the payment currency (wei for ETH) */
318
+ cost: string;
319
+ }
320
+
321
+ /**
322
+ * Result of downloading content
323
+ */
324
+ export interface DownloadResult<T = unknown> {
325
+ /** Downloaded and parsed content */
326
+ data: T;
327
+ /** Size of downloaded content in bytes */
328
+ size: number;
329
+ /** Download timestamp */
330
+ downloadedAt: Date;
331
+ }
332
+
333
+ // ============================================================================
334
+ // Irys Tags
335
+ // ============================================================================
336
+
337
+ /**
338
+ * Arweave/Irys tags for archive bundles
339
+ */
340
+ export interface ArchiveTags {
341
+ 'Content-Type': 'application/json';
342
+ Protocol: 'AGIRAILS';
343
+ Version: string;
344
+ Schema: string;
345
+ Type: typeof ARCHIVE_BUNDLE_TYPE;
346
+ ChainId: string;
347
+ TxId: string;
348
+ }