@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.
- package/README.md +536 -87
- package/dist/ACTPClient.d.ts +200 -0
- package/dist/ACTPClient.d.ts.map +1 -1
- package/dist/ACTPClient.js +266 -2
- package/dist/ACTPClient.js.map +1 -1
- package/dist/abi/ACTPKernel.json +16 -0
- package/dist/adapters/AdapterRegistry.d.ts +140 -0
- package/dist/adapters/AdapterRegistry.d.ts.map +1 -0
- package/dist/adapters/AdapterRegistry.js +166 -0
- package/dist/adapters/AdapterRegistry.js.map +1 -0
- package/dist/adapters/AdapterRouter.d.ts +165 -0
- package/dist/adapters/AdapterRouter.d.ts.map +1 -0
- package/dist/adapters/AdapterRouter.js +350 -0
- package/dist/adapters/AdapterRouter.js.map +1 -0
- package/dist/adapters/BaseAdapter.d.ts +17 -0
- package/dist/adapters/BaseAdapter.d.ts.map +1 -1
- package/dist/adapters/BaseAdapter.js +21 -0
- package/dist/adapters/BaseAdapter.js.map +1 -1
- package/dist/adapters/BasicAdapter.d.ts +72 -3
- package/dist/adapters/BasicAdapter.d.ts.map +1 -1
- package/dist/adapters/BasicAdapter.js +178 -2
- package/dist/adapters/BasicAdapter.js.map +1 -1
- package/dist/adapters/IAdapter.d.ts +230 -0
- package/dist/adapters/IAdapter.d.ts.map +1 -0
- package/dist/adapters/IAdapter.js +44 -0
- package/dist/adapters/IAdapter.js.map +1 -0
- package/dist/adapters/StandardAdapter.d.ts +80 -6
- package/dist/adapters/StandardAdapter.d.ts.map +1 -1
- package/dist/adapters/StandardAdapter.js +203 -6
- package/dist/adapters/StandardAdapter.js.map +1 -1
- package/dist/adapters/X402Adapter.d.ts +208 -0
- package/dist/adapters/X402Adapter.d.ts.map +1 -0
- package/dist/adapters/X402Adapter.js +423 -0
- package/dist/adapters/X402Adapter.js.map +1 -0
- package/dist/adapters/index.d.ts +8 -0
- package/dist/adapters/index.d.ts.map +1 -1
- package/dist/adapters/index.js +19 -1
- package/dist/adapters/index.js.map +1 -1
- package/dist/cli/commands/init.d.ts +4 -0
- package/dist/cli/commands/init.d.ts.map +1 -1
- package/dist/cli/commands/init.js +146 -4
- package/dist/cli/commands/init.js.map +1 -1
- package/dist/config/networks.d.ts +9 -0
- package/dist/config/networks.d.ts.map +1 -1
- package/dist/config/networks.js +27 -12
- package/dist/config/networks.js.map +1 -1
- package/dist/erc8004/ERC8004Bridge.d.ts +155 -0
- package/dist/erc8004/ERC8004Bridge.d.ts.map +1 -0
- package/dist/erc8004/ERC8004Bridge.js +325 -0
- package/dist/erc8004/ERC8004Bridge.js.map +1 -0
- package/dist/erc8004/ReputationReporter.d.ts +223 -0
- package/dist/erc8004/ReputationReporter.d.ts.map +1 -0
- package/dist/erc8004/ReputationReporter.js +266 -0
- package/dist/erc8004/ReputationReporter.js.map +1 -0
- package/dist/erc8004/index.d.ts +36 -0
- package/dist/erc8004/index.d.ts.map +1 -0
- package/dist/erc8004/index.js +46 -0
- package/dist/erc8004/index.js.map +1 -0
- package/dist/index.d.ts +11 -1
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +51 -2
- package/dist/index.js.map +1 -1
- package/dist/level0/provide.d.ts.map +1 -1
- package/dist/level0/provide.js +2 -1
- package/dist/level0/provide.js.map +1 -1
- package/dist/level1/Agent.d.ts.map +1 -1
- package/dist/level1/Agent.js +11 -3
- package/dist/level1/Agent.js.map +1 -1
- package/dist/protocol/ACTPKernel.d.ts +1 -1
- package/dist/protocol/ACTPKernel.d.ts.map +1 -1
- package/dist/protocol/ACTPKernel.js +23 -12
- package/dist/protocol/ACTPKernel.js.map +1 -1
- package/dist/protocol/DIDResolver.js +1 -1
- package/dist/protocol/DIDResolver.js.map +1 -1
- package/dist/protocol/EASHelper.d.ts.map +1 -1
- package/dist/protocol/EASHelper.js +2 -3
- package/dist/protocol/EASHelper.js.map +1 -1
- package/dist/protocol/MessageSigner.d.ts.map +1 -1
- package/dist/protocol/MessageSigner.js +8 -8
- package/dist/protocol/MessageSigner.js.map +1 -1
- package/dist/runtime/BlockchainRuntime.d.ts +7 -0
- package/dist/runtime/BlockchainRuntime.d.ts.map +1 -1
- package/dist/runtime/BlockchainRuntime.js +40 -22
- package/dist/runtime/BlockchainRuntime.js.map +1 -1
- package/dist/runtime/IACTPRuntime.d.ts +21 -0
- package/dist/runtime/IACTPRuntime.d.ts.map +1 -1
- package/dist/runtime/MockRuntime.d.ts +19 -0
- package/dist/runtime/MockRuntime.d.ts.map +1 -1
- package/dist/runtime/MockRuntime.js +56 -4
- package/dist/runtime/MockRuntime.js.map +1 -1
- package/dist/runtime/types/MockState.d.ts +11 -2
- package/dist/runtime/types/MockState.d.ts.map +1 -1
- package/dist/runtime/types/MockState.js.map +1 -1
- package/dist/storage/ArchiveBundleBuilder.d.ts +150 -0
- package/dist/storage/ArchiveBundleBuilder.d.ts.map +1 -0
- package/dist/storage/ArchiveBundleBuilder.js +468 -0
- package/dist/storage/ArchiveBundleBuilder.js.map +1 -0
- package/dist/storage/ArweaveClient.d.ts +271 -0
- package/dist/storage/ArweaveClient.d.ts.map +1 -0
- package/dist/storage/ArweaveClient.js +761 -0
- package/dist/storage/ArweaveClient.js.map +1 -0
- package/dist/storage/FilebaseClient.d.ts +193 -0
- package/dist/storage/FilebaseClient.d.ts.map +1 -0
- package/dist/storage/FilebaseClient.js +643 -0
- package/dist/storage/FilebaseClient.js.map +1 -0
- package/dist/storage/index.d.ts +47 -0
- package/dist/storage/index.d.ts.map +1 -0
- package/dist/storage/index.js +64 -0
- package/dist/storage/index.js.map +1 -0
- package/dist/storage/types.d.ts +291 -0
- package/dist/storage/types.d.ts.map +1 -0
- package/dist/storage/types.js +18 -0
- package/dist/storage/types.js.map +1 -0
- package/dist/types/adapter.d.ts +359 -0
- package/dist/types/adapter.d.ts.map +1 -0
- package/dist/types/adapter.js +115 -0
- package/dist/types/adapter.js.map +1 -0
- package/dist/types/erc8004.d.ts +184 -0
- package/dist/types/erc8004.d.ts.map +1 -0
- package/dist/types/erc8004.js +132 -0
- package/dist/types/erc8004.js.map +1 -0
- package/dist/types/index.d.ts +3 -0
- package/dist/types/index.d.ts.map +1 -1
- package/dist/types/index.js +3 -0
- package/dist/types/index.js.map +1 -1
- package/dist/types/state.d.ts +5 -4
- package/dist/types/state.d.ts.map +1 -1
- package/dist/types/state.js +10 -9
- package/dist/types/state.js.map +1 -1
- package/dist/types/transaction.d.ts +12 -0
- package/dist/types/transaction.d.ts.map +1 -1
- package/dist/types/x402.d.ts +162 -0
- package/dist/types/x402.d.ts.map +1 -0
- package/dist/types/x402.js +162 -0
- package/dist/types/x402.js.map +1 -0
- package/dist/utils/IPFSClient.d.ts.map +1 -1
- package/dist/utils/IPFSClient.js +5 -2
- package/dist/utils/IPFSClient.js.map +1 -1
- package/dist/utils/NonceManager.d.ts.map +1 -1
- package/dist/utils/NonceManager.js +3 -2
- package/dist/utils/NonceManager.js.map +1 -1
- package/dist/utils/UsedAttestationTracker.d.ts.map +1 -1
- package/dist/utils/UsedAttestationTracker.js +3 -3
- package/dist/utils/UsedAttestationTracker.js.map +1 -1
- package/dist/utils/circuitBreaker.d.ts +136 -0
- package/dist/utils/circuitBreaker.d.ts.map +1 -0
- package/dist/utils/circuitBreaker.js +253 -0
- package/dist/utils/circuitBreaker.js.map +1 -0
- package/dist/utils/retry.d.ts +120 -0
- package/dist/utils/retry.d.ts.map +1 -0
- package/dist/utils/retry.js +260 -0
- package/dist/utils/retry.js.map +1 -0
- package/dist/utils/validation.d.ts +100 -0
- package/dist/utils/validation.d.ts.map +1 -1
- package/dist/utils/validation.js +248 -1
- package/dist/utils/validation.js.map +1 -1
- package/package.json +16 -3
- package/src/ACTPClient.ts +318 -2
- package/src/abi/ACTPKernel.json +16 -0
- package/src/adapters/AdapterRegistry.ts +173 -0
- package/src/adapters/AdapterRouter.ts +417 -0
- package/src/adapters/BaseAdapter.ts +25 -0
- package/src/adapters/BasicAdapter.ts +210 -3
- package/src/adapters/IAdapter.ts +292 -0
- package/src/adapters/StandardAdapter.ts +246 -7
- package/src/adapters/X402Adapter.ts +653 -0
- package/src/adapters/index.ts +27 -0
- package/src/cli/commands/init.ts +166 -3
- package/src/config/networks.ts +36 -12
- package/src/erc8004/ERC8004Bridge.ts +461 -0
- package/src/erc8004/ReputationReporter.ts +472 -0
- package/src/erc8004/index.ts +61 -0
- package/src/index.ts +97 -0
- package/src/level0/provide.ts +2 -1
- package/src/level1/Agent.ts +13 -3
- package/src/protocol/ACTPKernel.ts +33 -12
- package/src/protocol/DIDResolver.ts +1 -1
- package/src/protocol/EASHelper.ts +2 -5
- package/src/protocol/MessageSigner.ts +8 -14
- package/src/runtime/BlockchainRuntime.ts +41 -45
- package/src/runtime/IACTPRuntime.ts +22 -0
- package/src/runtime/MockRuntime.ts +58 -4
- package/src/runtime/types/MockState.ts +12 -2
- package/src/storage/ArchiveBundleBuilder.ts +563 -0
- package/src/storage/ArweaveClient.ts +945 -0
- package/src/storage/FilebaseClient.ts +790 -0
- package/src/storage/index.ts +96 -0
- package/src/storage/types.ts +348 -0
- package/src/types/adapter.ts +296 -0
- package/src/types/erc8004.ts +293 -0
- package/src/types/index.ts +3 -0
- package/src/types/state.ts +10 -9
- package/src/types/transaction.ts +12 -0
- package/src/types/x402.ts +219 -0
- package/src/utils/IPFSClient.ts +5 -4
- package/src/utils/NonceManager.ts +3 -2
- package/src/utils/UsedAttestationTracker.ts +3 -5
- package/src/utils/circuitBreaker.ts +324 -0
- package/src/utils/fsSafe.ts +5 -0
- package/src/utils/retry.ts +365 -0
- 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
|
+
}
|