@sherwoodagent/cli 0.15.2 → 0.17.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 (32) hide show
  1. package/dist/{chat-YWDHMM5X.js → chat-G5TRNY5S.js} +5 -5
  2. package/dist/chunk-A4F6KTXA.js +442 -0
  3. package/dist/chunk-A4F6KTXA.js.map +1 -0
  4. package/dist/{chunk-F275BM3F.js → chunk-EDH6ICCT.js} +2 -2
  5. package/dist/{chunk-6UOHBF44.js → chunk-EMPYAZNP.js} +22 -10
  6. package/dist/chunk-EMPYAZNP.js.map +1 -0
  7. package/dist/{chunk-GH3F42AO.js → chunk-N65F7HRF.js} +11 -2
  8. package/dist/{chunk-GH3F42AO.js.map → chunk-N65F7HRF.js.map} +1 -1
  9. package/dist/{chunk-GC5J54OC.js → chunk-UQKNCRDW.js} +120 -72
  10. package/dist/chunk-UQKNCRDW.js.map +1 -0
  11. package/dist/{chunk-Q54E7IM6.js → chunk-X3L57WGW.js} +3 -3
  12. package/dist/{eas-T4PYJXLI.js → eas-INBAMX7K.js} +4 -4
  13. package/dist/governor-P6YV4YR7.js +77 -0
  14. package/dist/index.js +894 -839
  15. package/dist/index.js.map +1 -1
  16. package/dist/{research-F3VWIQAO.js → research-FNH3VT57.js} +5 -5
  17. package/dist/{research-DNR46NSK.js → research-IUHVRHR3.js} +3 -3
  18. package/dist/research-IUHVRHR3.js.map +1 -0
  19. package/dist/{session-UPNQXTMI.js → session-VEF5BZIX.js} +12 -7
  20. package/dist/session-VEF5BZIX.js.map +1 -0
  21. package/dist/{xmtp-HSOIJAUU.js → xmtp-DX73F6I4.js} +4 -4
  22. package/package.json +1 -1
  23. package/dist/chunk-6UOHBF44.js.map +0 -1
  24. package/dist/chunk-GC5J54OC.js.map +0 -1
  25. package/dist/session-UPNQXTMI.js.map +0 -1
  26. /package/dist/{chat-YWDHMM5X.js.map → chat-G5TRNY5S.js.map} +0 -0
  27. /package/dist/{chunk-F275BM3F.js.map → chunk-EDH6ICCT.js.map} +0 -0
  28. /package/dist/{chunk-Q54E7IM6.js.map → chunk-X3L57WGW.js.map} +0 -0
  29. /package/dist/{eas-T4PYJXLI.js.map → eas-INBAMX7K.js.map} +0 -0
  30. /package/dist/{research-DNR46NSK.js.map → governor-P6YV4YR7.js.map} +0 -0
  31. /package/dist/{research-F3VWIQAO.js.map → research-FNH3VT57.js.map} +0 -0
  32. /package/dist/{xmtp-HSOIJAUU.js.map → xmtp-DX73F6I4.js.map} +0 -0
@@ -2,11 +2,11 @@ import {
2
2
  getTextRecord,
3
3
  resolveSyndicate,
4
4
  setTextRecord
5
- } from "./chunk-6UOHBF44.js";
6
- import "./chunk-GC5J54OC.js";
5
+ } from "./chunk-EMPYAZNP.js";
6
+ import "./chunk-UQKNCRDW.js";
7
7
  import {
8
8
  getAccount
9
- } from "./chunk-GH3F42AO.js";
9
+ } from "./chunk-N65F7HRF.js";
10
10
  import "./chunk-MJMWA4LY.js";
11
11
  import {
12
12
  cacheGroupId,
@@ -17,7 +17,7 @@ import {
17
17
  import chalk from "chalk";
18
18
  import ora from "ora";
19
19
  async function loadXmtp() {
20
- return import("./xmtp-HSOIJAUU.js");
20
+ return import("./xmtp-DX73F6I4.js");
21
21
  }
22
22
  function formatTimestamp(date) {
23
23
  return `${date.getHours().toString().padStart(2, "0")}:${date.getMinutes().toString().padStart(2, "0")}`;
@@ -352,4 +352,4 @@ function registerChatCommands(program) {
352
352
  export {
353
353
  registerChatCommands
354
354
  };
355
- //# sourceMappingURL=chat-YWDHMM5X.js.map
355
+ //# sourceMappingURL=chat-G5TRNY5S.js.map
@@ -0,0 +1,442 @@
1
+ import {
2
+ SHERWOOD,
3
+ SYNDICATE_GOVERNOR_ABI
4
+ } from "./chunk-UQKNCRDW.js";
5
+ import {
6
+ getAccount,
7
+ getPublicClient,
8
+ getWalletClient
9
+ } from "./chunk-N65F7HRF.js";
10
+ import {
11
+ getChain
12
+ } from "./chunk-MJMWA4LY.js";
13
+
14
+ // src/lib/governor.ts
15
+ var PROPOSAL_STATES = [
16
+ "Draft",
17
+ "Pending",
18
+ "Approved",
19
+ "Rejected",
20
+ "Expired",
21
+ "Executed",
22
+ "Settled",
23
+ "Cancelled"
24
+ ];
25
+ var PROPOSAL_STATE = {
26
+ Draft: 0,
27
+ Pending: 1,
28
+ Approved: 2,
29
+ Rejected: 3,
30
+ Expired: 4,
31
+ Executed: 5,
32
+ Settled: 6,
33
+ Cancelled: 7
34
+ };
35
+ var VOTE_TYPE = {
36
+ For: 0,
37
+ Against: 1,
38
+ Abstain: 2
39
+ };
40
+ function parseDuration(input) {
41
+ const match = input.match(/^(\d+)(d|h|m|s)?$/);
42
+ if (!match) throw new Error(`Invalid duration: ${input}`);
43
+ const value = BigInt(match[1]);
44
+ switch (match[2]) {
45
+ case "d":
46
+ return value * 86400n;
47
+ case "h":
48
+ return value * 3600n;
49
+ case "m":
50
+ return value * 60n;
51
+ case "s":
52
+ case void 0:
53
+ return value;
54
+ default:
55
+ throw new Error(`Unknown duration unit: ${match[2]}`);
56
+ }
57
+ }
58
+ function getGovernorAddress() {
59
+ return SHERWOOD().GOVERNOR;
60
+ }
61
+ async function getGovernorParams() {
62
+ const client = getPublicClient();
63
+ const result = await client.readContract({
64
+ address: getGovernorAddress(),
65
+ abi: SYNDICATE_GOVERNOR_ABI,
66
+ functionName: "getGovernorParams"
67
+ });
68
+ return result;
69
+ }
70
+ async function getProposal(id) {
71
+ const client = getPublicClient();
72
+ const result = await client.readContract({
73
+ address: getGovernorAddress(),
74
+ abi: SYNDICATE_GOVERNOR_ABI,
75
+ functionName: "getProposal",
76
+ args: [id]
77
+ });
78
+ return result;
79
+ }
80
+ async function getProposalState(id) {
81
+ const client = getPublicClient();
82
+ return client.readContract({
83
+ address: getGovernorAddress(),
84
+ abi: SYNDICATE_GOVERNOR_ABI,
85
+ functionName: "getProposalState",
86
+ args: [id]
87
+ });
88
+ }
89
+ async function proposalCount() {
90
+ const client = getPublicClient();
91
+ return client.readContract({
92
+ address: getGovernorAddress(),
93
+ abi: SYNDICATE_GOVERNOR_ABI,
94
+ functionName: "proposalCount"
95
+ });
96
+ }
97
+ async function getVoteWeight(proposalId, voter) {
98
+ const client = getPublicClient();
99
+ return client.readContract({
100
+ address: getGovernorAddress(),
101
+ abi: SYNDICATE_GOVERNOR_ABI,
102
+ functionName: "getVoteWeight",
103
+ args: [proposalId, voter]
104
+ });
105
+ }
106
+ async function hasVoted(proposalId, voter) {
107
+ const client = getPublicClient();
108
+ return client.readContract({
109
+ address: getGovernorAddress(),
110
+ abi: SYNDICATE_GOVERNOR_ABI,
111
+ functionName: "hasVoted",
112
+ args: [proposalId, voter]
113
+ });
114
+ }
115
+ async function getProposalCalls(proposalId) {
116
+ const client = getPublicClient();
117
+ const result = await client.readContract({
118
+ address: getGovernorAddress(),
119
+ abi: SYNDICATE_GOVERNOR_ABI,
120
+ functionName: "getProposalCalls",
121
+ args: [proposalId]
122
+ });
123
+ return result.map((c) => ({ target: c.target, data: c.data, value: c.value }));
124
+ }
125
+ async function getExecuteCalls(proposalId) {
126
+ const client = getPublicClient();
127
+ const result = await client.readContract({
128
+ address: getGovernorAddress(),
129
+ abi: SYNDICATE_GOVERNOR_ABI,
130
+ functionName: "getExecuteCalls",
131
+ args: [proposalId]
132
+ });
133
+ return result.map((c) => ({ target: c.target, data: c.data, value: c.value }));
134
+ }
135
+ async function getSettlementCalls(proposalId) {
136
+ const client = getPublicClient();
137
+ const result = await client.readContract({
138
+ address: getGovernorAddress(),
139
+ abi: SYNDICATE_GOVERNOR_ABI,
140
+ functionName: "getSettlementCalls",
141
+ args: [proposalId]
142
+ });
143
+ return result.map((c) => ({ target: c.target, data: c.data, value: c.value }));
144
+ }
145
+ async function getRegisteredVaults() {
146
+ const client = getPublicClient();
147
+ return client.readContract({
148
+ address: getGovernorAddress(),
149
+ abi: SYNDICATE_GOVERNOR_ABI,
150
+ functionName: "getRegisteredVaults"
151
+ });
152
+ }
153
+ async function getActiveProposal(vault) {
154
+ const client = getPublicClient();
155
+ return client.readContract({
156
+ address: getGovernorAddress(),
157
+ abi: SYNDICATE_GOVERNOR_ABI,
158
+ functionName: "getActiveProposal",
159
+ args: [vault]
160
+ });
161
+ }
162
+ async function getCooldownEnd(vault) {
163
+ const client = getPublicClient();
164
+ return client.readContract({
165
+ address: getGovernorAddress(),
166
+ abi: SYNDICATE_GOVERNOR_ABI,
167
+ functionName: "getCooldownEnd",
168
+ args: [vault]
169
+ });
170
+ }
171
+ async function getCapitalSnapshot(proposalId) {
172
+ const client = getPublicClient();
173
+ return client.readContract({
174
+ address: getGovernorAddress(),
175
+ abi: SYNDICATE_GOVERNOR_ABI,
176
+ functionName: "getCapitalSnapshot",
177
+ args: [proposalId]
178
+ });
179
+ }
180
+ async function isRegisteredVault(vault) {
181
+ const client = getPublicClient();
182
+ return client.readContract({
183
+ address: getGovernorAddress(),
184
+ abi: SYNDICATE_GOVERNOR_ABI,
185
+ functionName: "isRegisteredVault",
186
+ args: [vault]
187
+ });
188
+ }
189
+ async function propose(vault, metadataURI, performanceFeeBps, strategyDuration, executeCalls, settlementCalls, coProposers = []) {
190
+ const wallet = getWalletClient();
191
+ const client = getPublicClient();
192
+ const hash = await wallet.writeContract({
193
+ account: getAccount(),
194
+ chain: getChain(),
195
+ address: getGovernorAddress(),
196
+ abi: SYNDICATE_GOVERNOR_ABI,
197
+ functionName: "propose",
198
+ args: [vault, metadataURI, performanceFeeBps, strategyDuration, executeCalls, settlementCalls, coProposers]
199
+ });
200
+ const receipt = await client.waitForTransactionReceipt({ hash });
201
+ let proposalId;
202
+ try {
203
+ proposalId = await proposalCount();
204
+ } catch {
205
+ proposalId = 0n;
206
+ }
207
+ return { hash: receipt.transactionHash, proposalId };
208
+ }
209
+ async function vote(proposalId, support) {
210
+ const wallet = getWalletClient();
211
+ const client = getPublicClient();
212
+ const hash = await wallet.writeContract({
213
+ account: getAccount(),
214
+ chain: getChain(),
215
+ address: getGovernorAddress(),
216
+ abi: SYNDICATE_GOVERNOR_ABI,
217
+ functionName: "vote",
218
+ args: [proposalId, support]
219
+ });
220
+ const receipt = await client.waitForTransactionReceipt({ hash });
221
+ return receipt.transactionHash;
222
+ }
223
+ async function executeProposal(proposalId) {
224
+ const wallet = getWalletClient();
225
+ const client = getPublicClient();
226
+ const hash = await wallet.writeContract({
227
+ account: getAccount(),
228
+ chain: getChain(),
229
+ address: getGovernorAddress(),
230
+ abi: SYNDICATE_GOVERNOR_ABI,
231
+ functionName: "executeProposal",
232
+ args: [proposalId]
233
+ });
234
+ const receipt = await client.waitForTransactionReceipt({ hash });
235
+ return receipt.transactionHash;
236
+ }
237
+ async function settleProposal(proposalId) {
238
+ const wallet = getWalletClient();
239
+ const client = getPublicClient();
240
+ const hash = await wallet.writeContract({
241
+ account: getAccount(),
242
+ chain: getChain(),
243
+ address: getGovernorAddress(),
244
+ abi: SYNDICATE_GOVERNOR_ABI,
245
+ functionName: "settleProposal",
246
+ args: [proposalId]
247
+ });
248
+ const receipt = await client.waitForTransactionReceipt({ hash });
249
+ return receipt.transactionHash;
250
+ }
251
+ async function emergencySettle(proposalId, calls) {
252
+ const wallet = getWalletClient();
253
+ const client = getPublicClient();
254
+ const hash = await wallet.writeContract({
255
+ account: getAccount(),
256
+ chain: getChain(),
257
+ address: getGovernorAddress(),
258
+ abi: SYNDICATE_GOVERNOR_ABI,
259
+ functionName: "emergencySettle",
260
+ args: [proposalId, calls]
261
+ });
262
+ const receipt = await client.waitForTransactionReceipt({ hash });
263
+ return receipt.transactionHash;
264
+ }
265
+ async function cancelProposal(proposalId) {
266
+ const wallet = getWalletClient();
267
+ const client = getPublicClient();
268
+ const hash = await wallet.writeContract({
269
+ account: getAccount(),
270
+ chain: getChain(),
271
+ address: getGovernorAddress(),
272
+ abi: SYNDICATE_GOVERNOR_ABI,
273
+ functionName: "cancelProposal",
274
+ args: [proposalId]
275
+ });
276
+ const receipt = await client.waitForTransactionReceipt({ hash });
277
+ return receipt.transactionHash;
278
+ }
279
+ async function emergencyCancel(proposalId) {
280
+ const wallet = getWalletClient();
281
+ const client = getPublicClient();
282
+ const hash = await wallet.writeContract({
283
+ account: getAccount(),
284
+ chain: getChain(),
285
+ address: getGovernorAddress(),
286
+ abi: SYNDICATE_GOVERNOR_ABI,
287
+ functionName: "emergencyCancel",
288
+ args: [proposalId]
289
+ });
290
+ const receipt = await client.waitForTransactionReceipt({ hash });
291
+ return receipt.transactionHash;
292
+ }
293
+ async function setVotingPeriod(seconds) {
294
+ const wallet = getWalletClient();
295
+ const client = getPublicClient();
296
+ const hash = await wallet.writeContract({
297
+ account: getAccount(),
298
+ chain: getChain(),
299
+ address: getGovernorAddress(),
300
+ abi: SYNDICATE_GOVERNOR_ABI,
301
+ functionName: "setVotingPeriod",
302
+ args: [seconds]
303
+ });
304
+ const receipt = await client.waitForTransactionReceipt({ hash });
305
+ return receipt.transactionHash;
306
+ }
307
+ async function setExecutionWindow(seconds) {
308
+ const wallet = getWalletClient();
309
+ const client = getPublicClient();
310
+ const hash = await wallet.writeContract({
311
+ account: getAccount(),
312
+ chain: getChain(),
313
+ address: getGovernorAddress(),
314
+ abi: SYNDICATE_GOVERNOR_ABI,
315
+ functionName: "setExecutionWindow",
316
+ args: [seconds]
317
+ });
318
+ const receipt = await client.waitForTransactionReceipt({ hash });
319
+ return receipt.transactionHash;
320
+ }
321
+ async function setVetoThresholdBps(bps) {
322
+ const wallet = getWalletClient();
323
+ const client = getPublicClient();
324
+ const hash = await wallet.writeContract({
325
+ account: getAccount(),
326
+ chain: getChain(),
327
+ address: getGovernorAddress(),
328
+ abi: SYNDICATE_GOVERNOR_ABI,
329
+ functionName: "setVetoThresholdBps",
330
+ args: [bps]
331
+ });
332
+ const receipt = await client.waitForTransactionReceipt({ hash });
333
+ return receipt.transactionHash;
334
+ }
335
+ async function setMaxPerformanceFeeBps(bps) {
336
+ const wallet = getWalletClient();
337
+ const client = getPublicClient();
338
+ const hash = await wallet.writeContract({
339
+ account: getAccount(),
340
+ chain: getChain(),
341
+ address: getGovernorAddress(),
342
+ abi: SYNDICATE_GOVERNOR_ABI,
343
+ functionName: "setMaxPerformanceFeeBps",
344
+ args: [bps]
345
+ });
346
+ const receipt = await client.waitForTransactionReceipt({ hash });
347
+ return receipt.transactionHash;
348
+ }
349
+ async function setMaxStrategyDuration(seconds) {
350
+ const wallet = getWalletClient();
351
+ const client = getPublicClient();
352
+ const hash = await wallet.writeContract({
353
+ account: getAccount(),
354
+ chain: getChain(),
355
+ address: getGovernorAddress(),
356
+ abi: SYNDICATE_GOVERNOR_ABI,
357
+ functionName: "setMaxStrategyDuration",
358
+ args: [seconds]
359
+ });
360
+ const receipt = await client.waitForTransactionReceipt({ hash });
361
+ return receipt.transactionHash;
362
+ }
363
+ async function setCooldownPeriod(seconds) {
364
+ const wallet = getWalletClient();
365
+ const client = getPublicClient();
366
+ const hash = await wallet.writeContract({
367
+ account: getAccount(),
368
+ chain: getChain(),
369
+ address: getGovernorAddress(),
370
+ abi: SYNDICATE_GOVERNOR_ABI,
371
+ functionName: "setCooldownPeriod",
372
+ args: [seconds]
373
+ });
374
+ const receipt = await client.waitForTransactionReceipt({ hash });
375
+ return receipt.transactionHash;
376
+ }
377
+ async function vetoProposal(proposalId) {
378
+ const wallet = getWalletClient();
379
+ const client = getPublicClient();
380
+ const hash = await wallet.writeContract({
381
+ account: getAccount(),
382
+ chain: getChain(),
383
+ address: getGovernorAddress(),
384
+ abi: SYNDICATE_GOVERNOR_ABI,
385
+ functionName: "vetoProposal",
386
+ args: [proposalId]
387
+ });
388
+ const receipt = await client.waitForTransactionReceipt({ hash });
389
+ return receipt.transactionHash;
390
+ }
391
+ async function setProtocolFeeBps(bps) {
392
+ const wallet = getWalletClient();
393
+ const client = getPublicClient();
394
+ const hash = await wallet.writeContract({
395
+ account: getAccount(),
396
+ chain: getChain(),
397
+ address: getGovernorAddress(),
398
+ abi: SYNDICATE_GOVERNOR_ABI,
399
+ functionName: "setProtocolFeeBps",
400
+ args: [bps]
401
+ });
402
+ const receipt = await client.waitForTransactionReceipt({ hash });
403
+ return receipt.transactionHash;
404
+ }
405
+
406
+ export {
407
+ PROPOSAL_STATES,
408
+ PROPOSAL_STATE,
409
+ VOTE_TYPE,
410
+ parseDuration,
411
+ getGovernorAddress,
412
+ getGovernorParams,
413
+ getProposal,
414
+ getProposalState,
415
+ proposalCount,
416
+ getVoteWeight,
417
+ hasVoted,
418
+ getProposalCalls,
419
+ getExecuteCalls,
420
+ getSettlementCalls,
421
+ getRegisteredVaults,
422
+ getActiveProposal,
423
+ getCooldownEnd,
424
+ getCapitalSnapshot,
425
+ isRegisteredVault,
426
+ propose,
427
+ vote,
428
+ executeProposal,
429
+ settleProposal,
430
+ emergencySettle,
431
+ cancelProposal,
432
+ emergencyCancel,
433
+ setVotingPeriod,
434
+ setExecutionWindow,
435
+ setVetoThresholdBps,
436
+ setMaxPerformanceFeeBps,
437
+ setMaxStrategyDuration,
438
+ setCooldownPeriod,
439
+ vetoProposal,
440
+ setProtocolFeeBps
441
+ };
442
+ //# sourceMappingURL=chunk-A4F6KTXA.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/lib/governor.ts"],"sourcesContent":["/**\n * Governor contract wrapper — reads/writes to SyndicateGovernor.\n *\n * Provides typed helpers for the proposal lifecycle, voting,\n * settlement, and parameter management.\n */\n\nimport type { Address, Hex } from \"viem\";\nimport { getPublicClient, getWalletClient, getAccount } from \"./client.js\";\nimport { getChain } from \"./network.js\";\nimport { SHERWOOD } from \"./addresses.js\";\nimport { SYNDICATE_GOVERNOR_ABI } from \"./abis.js\";\n\n// ── Types ──\n\nexport interface GovernorParams {\n votingPeriod: bigint;\n executionWindow: bigint;\n vetoThresholdBps: bigint;\n maxPerformanceFeeBps: bigint;\n cooldownPeriod: bigint;\n collaborationWindow: bigint;\n maxCoProposers: bigint;\n minStrategyDuration: bigint;\n maxStrategyDuration: bigint;\n}\n\nexport interface StrategyProposal {\n id: bigint;\n proposer: Address;\n vault: Address;\n metadataURI: string;\n performanceFeeBps: bigint;\n strategyDuration: bigint;\n votesFor: bigint;\n votesAgainst: bigint;\n votesAbstain: bigint;\n snapshotTimestamp: bigint;\n voteEnd: bigint;\n executeBy: bigint;\n executedAt: bigint;\n state: number;\n}\n\nexport interface CoProposer {\n agent: Address;\n splitBps: bigint;\n}\n\nexport interface BatchCall {\n target: Address;\n data: Hex;\n value: bigint;\n}\n\nexport const PROPOSAL_STATES = [\n \"Draft\",\n \"Pending\",\n \"Approved\",\n \"Rejected\",\n \"Expired\",\n \"Executed\",\n \"Settled\",\n \"Cancelled\",\n] as const;\n\nexport const PROPOSAL_STATE = {\n Draft: 0,\n Pending: 1,\n Approved: 2,\n Rejected: 3,\n Expired: 4,\n Executed: 5,\n Settled: 6,\n Cancelled: 7,\n} as const;\n\nexport const VOTE_TYPE = {\n For: 0,\n Against: 1,\n Abstain: 2,\n} as const;\n\n// ── Duration parser ──\n\nexport function parseDuration(input: string): bigint {\n const match = input.match(/^(\\d+)(d|h|m|s)?$/);\n if (!match) throw new Error(`Invalid duration: ${input}`);\n const value = BigInt(match[1]);\n switch (match[2]) {\n case \"d\":\n return value * 86400n;\n case \"h\":\n return value * 3600n;\n case \"m\":\n return value * 60n;\n case \"s\":\n case undefined:\n return value;\n default:\n throw new Error(`Unknown duration unit: ${match[2]}`);\n }\n}\n\n// ── Address helper ──\n\nexport function getGovernorAddress(): Address {\n return SHERWOOD().GOVERNOR;\n}\n\n// ── Read helpers ──\n\nexport async function getGovernorParams(): Promise<GovernorParams> {\n const client = getPublicClient();\n const result = await client.readContract({\n address: getGovernorAddress(),\n abi: SYNDICATE_GOVERNOR_ABI,\n functionName: \"getGovernorParams\",\n }) as {\n votingPeriod: bigint;\n executionWindow: bigint;\n vetoThresholdBps: bigint;\n maxPerformanceFeeBps: bigint;\n cooldownPeriod: bigint;\n collaborationWindow: bigint;\n maxCoProposers: bigint;\n minStrategyDuration: bigint;\n maxStrategyDuration: bigint;\n };\n return result;\n}\n\nexport async function getProposal(id: bigint): Promise<StrategyProposal> {\n const client = getPublicClient();\n const result = await client.readContract({\n address: getGovernorAddress(),\n abi: SYNDICATE_GOVERNOR_ABI,\n functionName: \"getProposal\",\n args: [id],\n }) as {\n id: bigint;\n proposer: Address;\n vault: Address;\n metadataURI: string;\n performanceFeeBps: bigint;\n strategyDuration: bigint;\n votesFor: bigint;\n votesAgainst: bigint;\n votesAbstain: bigint;\n snapshotTimestamp: bigint;\n voteEnd: bigint;\n executeBy: bigint;\n executedAt: bigint;\n state: number;\n };\n return result;\n}\n\nexport async function getProposalState(id: bigint): Promise<number> {\n const client = getPublicClient();\n return client.readContract({\n address: getGovernorAddress(),\n abi: SYNDICATE_GOVERNOR_ABI,\n functionName: \"getProposalState\",\n args: [id],\n }) as Promise<number>;\n}\n\nexport async function proposalCount(): Promise<bigint> {\n const client = getPublicClient();\n return client.readContract({\n address: getGovernorAddress(),\n abi: SYNDICATE_GOVERNOR_ABI,\n functionName: \"proposalCount\",\n }) as Promise<bigint>;\n}\n\nexport async function getVoteWeight(proposalId: bigint, voter: Address): Promise<bigint> {\n const client = getPublicClient();\n return client.readContract({\n address: getGovernorAddress(),\n abi: SYNDICATE_GOVERNOR_ABI,\n functionName: \"getVoteWeight\",\n args: [proposalId, voter],\n }) as Promise<bigint>;\n}\n\nexport async function hasVoted(proposalId: bigint, voter: Address): Promise<boolean> {\n const client = getPublicClient();\n return client.readContract({\n address: getGovernorAddress(),\n abi: SYNDICATE_GOVERNOR_ABI,\n functionName: \"hasVoted\",\n args: [proposalId, voter],\n }) as Promise<boolean>;\n}\n\nexport async function getProposalCalls(proposalId: bigint): Promise<BatchCall[]> {\n const client = getPublicClient();\n const result = await client.readContract({\n address: getGovernorAddress(),\n abi: SYNDICATE_GOVERNOR_ABI,\n functionName: \"getProposalCalls\",\n args: [proposalId],\n }) as { target: Address; data: Hex; value: bigint }[];\n return result.map((c) => ({ target: c.target, data: c.data, value: c.value }));\n}\n\nexport async function getExecuteCalls(proposalId: bigint): Promise<BatchCall[]> {\n const client = getPublicClient();\n const result = await client.readContract({\n address: getGovernorAddress(),\n abi: SYNDICATE_GOVERNOR_ABI,\n functionName: \"getExecuteCalls\",\n args: [proposalId],\n }) as { target: Address; data: Hex; value: bigint }[];\n return result.map((c) => ({ target: c.target, data: c.data, value: c.value }));\n}\n\nexport async function getSettlementCalls(proposalId: bigint): Promise<BatchCall[]> {\n const client = getPublicClient();\n const result = await client.readContract({\n address: getGovernorAddress(),\n abi: SYNDICATE_GOVERNOR_ABI,\n functionName: \"getSettlementCalls\",\n args: [proposalId],\n }) as { target: Address; data: Hex; value: bigint }[];\n return result.map((c) => ({ target: c.target, data: c.data, value: c.value }));\n}\n\nexport async function getRegisteredVaults(): Promise<Address[]> {\n const client = getPublicClient();\n return client.readContract({\n address: getGovernorAddress(),\n abi: SYNDICATE_GOVERNOR_ABI,\n functionName: \"getRegisteredVaults\",\n }) as Promise<Address[]>;\n}\n\nexport async function getActiveProposal(vault: Address): Promise<bigint> {\n const client = getPublicClient();\n return client.readContract({\n address: getGovernorAddress(),\n abi: SYNDICATE_GOVERNOR_ABI,\n functionName: \"getActiveProposal\",\n args: [vault],\n }) as Promise<bigint>;\n}\n\nexport async function getCooldownEnd(vault: Address): Promise<bigint> {\n const client = getPublicClient();\n return client.readContract({\n address: getGovernorAddress(),\n abi: SYNDICATE_GOVERNOR_ABI,\n functionName: \"getCooldownEnd\",\n args: [vault],\n }) as Promise<bigint>;\n}\n\nexport async function getCapitalSnapshot(proposalId: bigint): Promise<bigint> {\n const client = getPublicClient();\n return client.readContract({\n address: getGovernorAddress(),\n abi: SYNDICATE_GOVERNOR_ABI,\n functionName: \"getCapitalSnapshot\",\n args: [proposalId],\n }) as Promise<bigint>;\n}\n\nexport async function isRegisteredVault(vault: Address): Promise<boolean> {\n const client = getPublicClient();\n return client.readContract({\n address: getGovernorAddress(),\n abi: SYNDICATE_GOVERNOR_ABI,\n functionName: \"isRegisteredVault\",\n args: [vault],\n }) as Promise<boolean>;\n}\n\n// ── Write helpers ──\n\nexport async function propose(\n vault: Address,\n metadataURI: string,\n performanceFeeBps: bigint,\n strategyDuration: bigint,\n executeCalls: BatchCall[],\n settlementCalls: BatchCall[],\n coProposers: CoProposer[] = [],\n): Promise<{ hash: Hex; proposalId: bigint }> {\n const wallet = getWalletClient();\n const client = getPublicClient();\n\n const hash = await wallet.writeContract({\n account: getAccount(),\n chain: getChain(),\n address: getGovernorAddress(),\n abi: SYNDICATE_GOVERNOR_ABI,\n functionName: \"propose\",\n args: [vault, metadataURI, performanceFeeBps, strategyDuration, executeCalls, settlementCalls, coProposers],\n });\n\n const receipt = await client.waitForTransactionReceipt({ hash });\n\n // Parse proposalId from return value — use proposalCount as fallback.\n // NOTE: In concurrent environments, another proposal could be created between\n // our tx and this read, returning the wrong ID. The event log path above is preferred.\n let proposalId: bigint;\n try {\n proposalId = await proposalCount();\n } catch {\n proposalId = 0n;\n }\n\n return { hash: receipt.transactionHash, proposalId };\n}\n\nexport async function vote(proposalId: bigint, support: number): Promise<Hex> {\n const wallet = getWalletClient();\n const client = getPublicClient();\n\n const hash = await wallet.writeContract({\n account: getAccount(),\n chain: getChain(),\n address: getGovernorAddress(),\n abi: SYNDICATE_GOVERNOR_ABI,\n functionName: \"vote\",\n args: [proposalId, support],\n });\n\n const receipt = await client.waitForTransactionReceipt({ hash });\n return receipt.transactionHash;\n}\n\nexport async function executeProposal(proposalId: bigint): Promise<Hex> {\n const wallet = getWalletClient();\n const client = getPublicClient();\n\n const hash = await wallet.writeContract({\n account: getAccount(),\n chain: getChain(),\n address: getGovernorAddress(),\n abi: SYNDICATE_GOVERNOR_ABI,\n functionName: \"executeProposal\",\n args: [proposalId],\n });\n\n const receipt = await client.waitForTransactionReceipt({ hash });\n return receipt.transactionHash;\n}\n\nexport async function settleProposal(proposalId: bigint): Promise<Hex> {\n const wallet = getWalletClient();\n const client = getPublicClient();\n\n const hash = await wallet.writeContract({\n account: getAccount(),\n chain: getChain(),\n address: getGovernorAddress(),\n abi: SYNDICATE_GOVERNOR_ABI,\n functionName: \"settleProposal\",\n args: [proposalId],\n });\n\n const receipt = await client.waitForTransactionReceipt({ hash });\n return receipt.transactionHash;\n}\n\nexport async function emergencySettle(proposalId: bigint, calls: BatchCall[]): Promise<Hex> {\n const wallet = getWalletClient();\n const client = getPublicClient();\n\n const hash = await wallet.writeContract({\n account: getAccount(),\n chain: getChain(),\n address: getGovernorAddress(),\n abi: SYNDICATE_GOVERNOR_ABI,\n functionName: \"emergencySettle\",\n args: [proposalId, calls],\n });\n\n const receipt = await client.waitForTransactionReceipt({ hash });\n return receipt.transactionHash;\n}\n\nexport async function cancelProposal(proposalId: bigint): Promise<Hex> {\n const wallet = getWalletClient();\n const client = getPublicClient();\n\n const hash = await wallet.writeContract({\n account: getAccount(),\n chain: getChain(),\n address: getGovernorAddress(),\n abi: SYNDICATE_GOVERNOR_ABI,\n functionName: \"cancelProposal\",\n args: [proposalId],\n });\n\n const receipt = await client.waitForTransactionReceipt({ hash });\n return receipt.transactionHash;\n}\n\nexport async function emergencyCancel(proposalId: bigint): Promise<Hex> {\n const wallet = getWalletClient();\n const client = getPublicClient();\n\n const hash = await wallet.writeContract({\n account: getAccount(),\n chain: getChain(),\n address: getGovernorAddress(),\n abi: SYNDICATE_GOVERNOR_ABI,\n functionName: \"emergencyCancel\",\n args: [proposalId],\n });\n\n const receipt = await client.waitForTransactionReceipt({ hash });\n return receipt.transactionHash;\n}\n\n// ── Parameter setters (owner-only) ──\n\nexport async function setVotingPeriod(seconds: bigint): Promise<Hex> {\n const wallet = getWalletClient();\n const client = getPublicClient();\n const hash = await wallet.writeContract({\n account: getAccount(),\n chain: getChain(),\n address: getGovernorAddress(),\n abi: SYNDICATE_GOVERNOR_ABI,\n functionName: \"setVotingPeriod\",\n args: [seconds],\n });\n const receipt = await client.waitForTransactionReceipt({ hash });\n return receipt.transactionHash;\n}\n\nexport async function setExecutionWindow(seconds: bigint): Promise<Hex> {\n const wallet = getWalletClient();\n const client = getPublicClient();\n const hash = await wallet.writeContract({\n account: getAccount(),\n chain: getChain(),\n address: getGovernorAddress(),\n abi: SYNDICATE_GOVERNOR_ABI,\n functionName: \"setExecutionWindow\",\n args: [seconds],\n });\n const receipt = await client.waitForTransactionReceipt({ hash });\n return receipt.transactionHash;\n}\n\nexport async function setVetoThresholdBps(bps: bigint): Promise<Hex> {\n const wallet = getWalletClient();\n const client = getPublicClient();\n const hash = await wallet.writeContract({\n account: getAccount(),\n chain: getChain(),\n address: getGovernorAddress(),\n abi: SYNDICATE_GOVERNOR_ABI,\n functionName: \"setVetoThresholdBps\",\n args: [bps],\n });\n const receipt = await client.waitForTransactionReceipt({ hash });\n return receipt.transactionHash;\n}\n\nexport async function setMaxPerformanceFeeBps(bps: bigint): Promise<Hex> {\n const wallet = getWalletClient();\n const client = getPublicClient();\n const hash = await wallet.writeContract({\n account: getAccount(),\n chain: getChain(),\n address: getGovernorAddress(),\n abi: SYNDICATE_GOVERNOR_ABI,\n functionName: \"setMaxPerformanceFeeBps\",\n args: [bps],\n });\n const receipt = await client.waitForTransactionReceipt({ hash });\n return receipt.transactionHash;\n}\n\nexport async function setMaxStrategyDuration(seconds: bigint): Promise<Hex> {\n const wallet = getWalletClient();\n const client = getPublicClient();\n const hash = await wallet.writeContract({\n account: getAccount(),\n chain: getChain(),\n address: getGovernorAddress(),\n abi: SYNDICATE_GOVERNOR_ABI,\n functionName: \"setMaxStrategyDuration\",\n args: [seconds],\n });\n const receipt = await client.waitForTransactionReceipt({ hash });\n return receipt.transactionHash;\n}\n\nexport async function setCooldownPeriod(seconds: bigint): Promise<Hex> {\n const wallet = getWalletClient();\n const client = getPublicClient();\n const hash = await wallet.writeContract({\n account: getAccount(),\n chain: getChain(),\n address: getGovernorAddress(),\n abi: SYNDICATE_GOVERNOR_ABI,\n functionName: \"setCooldownPeriod\",\n args: [seconds],\n });\n const receipt = await client.waitForTransactionReceipt({ hash });\n return receipt.transactionHash;\n}\n\nexport async function vetoProposal(proposalId: bigint): Promise<Hex> {\n const wallet = getWalletClient();\n const client = getPublicClient();\n const hash = await wallet.writeContract({\n account: getAccount(),\n chain: getChain(),\n address: getGovernorAddress(),\n abi: SYNDICATE_GOVERNOR_ABI,\n functionName: \"vetoProposal\",\n args: [proposalId],\n });\n const receipt = await client.waitForTransactionReceipt({ hash });\n return receipt.transactionHash;\n}\n\nexport async function setProtocolFeeBps(bps: bigint): Promise<Hex> {\n const wallet = getWalletClient();\n const client = getPublicClient();\n const hash = await wallet.writeContract({\n account: getAccount(),\n chain: getChain(),\n address: getGovernorAddress(),\n abi: SYNDICATE_GOVERNOR_ABI,\n functionName: \"setProtocolFeeBps\",\n args: [bps],\n });\n const receipt = await client.waitForTransactionReceipt({ hash });\n return receipt.transactionHash;\n}\n"],"mappings":"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","names":[]}
@@ -1,6 +1,6 @@
1
1
  import {
2
2
  getAccount
3
- } from "./chunk-GH3F42AO.js";
3
+ } from "./chunk-N65F7HRF.js";
4
4
 
5
5
  // src/providers/research/messari.ts
6
6
  import { base, baseSepolia } from "viem/chains";
@@ -436,4 +436,4 @@ export {
436
436
  NansenProvider,
437
437
  getResearchProvider
438
438
  };
439
- //# sourceMappingURL=chunk-F275BM3F.js.map
439
+ //# sourceMappingURL=chunk-EDH6ICCT.js.map
@@ -5,12 +5,13 @@ import {
5
5
  SHERWOOD,
6
6
  SYNDICATE_FACTORY_ABI,
7
7
  SYNDICATE_VAULT_ABI
8
- } from "./chunk-GC5J54OC.js";
8
+ } from "./chunk-UQKNCRDW.js";
9
9
  import {
10
+ estimateFeesWithBuffer,
10
11
  getAccount,
11
12
  getPublicClient,
12
13
  getWalletClient
13
- } from "./chunk-GH3F42AO.js";
14
+ } from "./chunk-N65F7HRF.js";
14
15
  import {
15
16
  getChain
16
17
  } from "./chunk-MJMWA4LY.js";
@@ -56,22 +57,33 @@ async function deposit(amount) {
56
57
  const vaultAddress = getVaultAddress();
57
58
  const account = getAccount();
58
59
  const asset = await getAssetAddress();
59
- const approveHash = await wallet.writeContract({
60
- account: getAccount(),
61
- chain: getChain(),
60
+ const fees = await estimateFeesWithBuffer();
61
+ const currentAllowance = await client.readContract({
62
62
  address: asset,
63
63
  abi: ERC20_ABI,
64
- functionName: "approve",
65
- args: [vaultAddress, amount]
64
+ functionName: "allowance",
65
+ args: [account.address, vaultAddress]
66
66
  });
67
- await client.waitForTransactionReceipt({ hash: approveHash });
67
+ if (currentAllowance < amount) {
68
+ const approveHash = await wallet.writeContract({
69
+ account: getAccount(),
70
+ chain: getChain(),
71
+ address: asset,
72
+ abi: ERC20_ABI,
73
+ functionName: "approve",
74
+ args: [vaultAddress, amount],
75
+ ...fees
76
+ });
77
+ await client.waitForTransactionReceipt({ hash: approveHash });
78
+ }
68
79
  const depositHash = await wallet.writeContract({
69
80
  account: getAccount(),
70
81
  chain: getChain(),
71
82
  address: vaultAddress,
72
83
  abi: SYNDICATE_VAULT_ABI,
73
84
  functionName: "deposit",
74
- args: [amount, account.address]
85
+ args: [amount, account.address],
86
+ ...fees
75
87
  });
76
88
  await client.waitForTransactionReceipt({ hash: depositHash });
77
89
  return depositHash;
@@ -317,4 +329,4 @@ export {
317
329
  setTextRecord,
318
330
  getTextRecord
319
331
  };
320
- //# sourceMappingURL=chunk-6UOHBF44.js.map
332
+ //# sourceMappingURL=chunk-EMPYAZNP.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/lib/vault.ts","../src/lib/ens.ts"],"sourcesContent":["/**\n * SyndicateVault contract wrapper.\n *\n * The vault is the onchain identity — it holds all positions via delegatecall\n * to a shared BatchExecutorLib. No separate executor contract needed.\n */\n\nimport type { Address, Hex } from \"viem\";\nimport { formatUnits } from \"viem\";\nimport { getChain } from \"./network.js\";\nimport {\n getPublicClient,\n getWalletClient,\n getAccount,\n estimateFeesWithBuffer,\n} from \"./client.js\";\nimport { SYNDICATE_VAULT_ABI, ERC20_ABI } from \"./abis.js\";\nimport type { BatchCall } from \"./batch.js\";\nimport { getChainContracts } from \"./config.js\";\n\n// Per-command override (set by --vault flag in index.ts)\nlet _vaultOverride: Address | null = null;\n\nexport function setVaultAddress(addr: Address): void {\n _vaultOverride = addr;\n}\n\nexport function getVaultAddress(): Address {\n // 1. Per-command override (--vault flag)\n if (_vaultOverride) return _vaultOverride;\n\n // 2. Config (~/.sherwood/config.json) — default vault\n const chainId = getChain().id;\n const fromConfig = getChainContracts(chainId).vault;\n if (fromConfig) return fromConfig as Address;\n\n throw new Error(\n \"Vault address not found. Pass --vault <addr> or run 'sherwood config set --vault <addr>'.\",\n );\n}\n\n// ── Asset Helpers ──\n\n/**\n * Read the vault's underlying ERC-20 asset address.\n */\nexport async function getAssetAddress(): Promise<Address> {\n const client = getPublicClient();\n return client.readContract({\n address: getVaultAddress(),\n abi: SYNDICATE_VAULT_ABI,\n functionName: \"asset\",\n }) as Promise<Address>;\n}\n\n/**\n * Read decimals from the vault's underlying asset.\n * Works with any ERC-20 (USDC=6, WETH=18, WBTC=8, etc.).\n */\nexport async function getAssetDecimals(): Promise<number> {\n const client = getPublicClient();\n const asset = await getAssetAddress();\n return client.readContract({\n address: asset,\n abi: ERC20_ABI,\n functionName: \"decimals\",\n }) as Promise<number>;\n}\n\n// ── LP Functions ──\n\n/**\n * Deposit into the vault. Handles approval + deposit for the vault's asset.\n */\nexport async function deposit(amount: bigint): Promise<Hex> {\n const wallet = getWalletClient();\n const client = getPublicClient();\n const vaultAddress = getVaultAddress();\n const account = getAccount();\n const asset = await getAssetAddress();\n const fees = await estimateFeesWithBuffer();\n\n // Check existing allowance — skip approve if sufficient\n const currentAllowance = (await client.readContract({\n address: asset,\n abi: ERC20_ABI,\n functionName: \"allowance\",\n args: [account.address, vaultAddress],\n })) as bigint;\n\n if (currentAllowance < amount) {\n const approveHash = await wallet.writeContract({\n account: getAccount(),\n chain: getChain(),\n address: asset,\n abi: ERC20_ABI,\n functionName: \"approve\",\n args: [vaultAddress, amount],\n ...fees,\n });\n await client.waitForTransactionReceipt({ hash: approveHash });\n }\n\n // Deposit\n const depositHash = await wallet.writeContract({\n account: getAccount(),\n chain: getChain(),\n address: vaultAddress,\n abi: SYNDICATE_VAULT_ABI,\n functionName: \"deposit\",\n args: [amount, account.address],\n ...fees,\n });\n await client.waitForTransactionReceipt({ hash: depositHash });\n return depositHash;\n}\n\n// ── Batch Execution ──\n\n/**\n * Execute a batch of protocol calls through the vault (owner only).\n * The vault delegatecalls to the executor lib.\n * All calls execute as the vault — positions live on the vault.\n */\nexport async function executeBatch(calls: BatchCall[]): Promise<Hex> {\n const wallet = getWalletClient();\n const client = getPublicClient();\n\n const hash = await wallet.writeContract({\n account: getAccount(),\n chain: getChain(),\n address: getVaultAddress(),\n abi: SYNDICATE_VAULT_ABI,\n functionName: \"executeBatch\",\n args: [\n calls.map((c) => ({\n target: c.target,\n data: c.data,\n value: c.value,\n })),\n ],\n });\n await client.waitForTransactionReceipt({ hash });\n return hash;\n}\n\n// ── Depositor Management ──\n\n/**\n * Approve a depositor address (owner only).\n */\nexport async function approveDepositor(depositor: Address): Promise<Hex> {\n const wallet = getWalletClient();\n const client = getPublicClient();\n const hash = await wallet.writeContract({\n account: getAccount(),\n chain: getChain(),\n address: getVaultAddress(),\n abi: SYNDICATE_VAULT_ABI,\n functionName: \"approveDepositor\",\n args: [depositor],\n });\n await client.waitForTransactionReceipt({ hash });\n return hash;\n}\n\n/**\n * Remove a depositor from the whitelist (owner only).\n */\nexport async function removeDepositor(depositor: Address): Promise<Hex> {\n const wallet = getWalletClient();\n const client = getPublicClient();\n const hash = await wallet.writeContract({\n account: getAccount(),\n chain: getChain(),\n address: getVaultAddress(),\n abi: SYNDICATE_VAULT_ABI,\n functionName: \"removeDepositor\",\n args: [depositor],\n });\n await client.waitForTransactionReceipt({ hash });\n return hash;\n}\n\n/**\n * Approve multiple depositors in a batch (owner only).\n */\nexport async function approveDepositors(depositors: Address[]): Promise<Hex> {\n const wallet = getWalletClient();\n const client = getPublicClient();\n const hash = await wallet.writeContract({\n account: getAccount(),\n chain: getChain(),\n address: getVaultAddress(),\n abi: SYNDICATE_VAULT_ABI,\n functionName: \"approveDepositors\",\n args: [depositors],\n });\n await client.waitForTransactionReceipt({ hash });\n return hash;\n}\n\n/**\n * Check if an address is a registered agent on the vault.\n */\nexport async function isAgent(agentAddress: Address): Promise<boolean> {\n const client = getPublicClient();\n return client.readContract({\n address: getVaultAddress(),\n abi: SYNDICATE_VAULT_ABI,\n functionName: \"isAgent\",\n args: [agentAddress],\n }) as Promise<boolean>;\n}\n\n/**\n * Check if an address is an approved depositor.\n */\nexport async function isApprovedDepositor(depositor: Address): Promise<boolean> {\n const client = getPublicClient();\n return client.readContract({\n address: getVaultAddress(),\n abi: SYNDICATE_VAULT_ABI,\n functionName: \"isApprovedDepositor\",\n args: [depositor],\n }) as Promise<boolean>;\n}\n\n/**\n * Get LP share balance and asset value.\n */\nexport async function getBalance(address?: Address): Promise<{\n shares: bigint;\n assetsValue: string;\n percentOfVault: string;\n}> {\n const client = getPublicClient();\n const vaultAddress = getVaultAddress();\n const account = address || getAccount().address;\n\n const [shares, totalSupply] = await Promise.all([\n client.readContract({\n address: vaultAddress,\n abi: SYNDICATE_VAULT_ABI,\n functionName: \"balanceOf\",\n args: [account],\n }) as Promise<bigint>,\n client.readContract({\n address: vaultAddress,\n abi: SYNDICATE_VAULT_ABI,\n functionName: \"totalSupply\",\n }) as Promise<bigint>,\n ]);\n\n let assetsValue = 0n;\n if (shares > 0n) {\n assetsValue = (await client.readContract({\n address: vaultAddress,\n abi: SYNDICATE_VAULT_ABI,\n functionName: \"convertToAssets\",\n args: [shares],\n })) as bigint;\n }\n\n const percent =\n totalSupply > 0n ? ((Number(shares) / Number(totalSupply)) * 100).toFixed(2) : \"0.00\";\n\n const decimals = await getAssetDecimals();\n\n return {\n shares,\n assetsValue: formatUnits(assetsValue, decimals),\n percentOfVault: `${percent}%`,\n };\n}\n\n// ── Agent Management ──\n\n/**\n * Register a new agent (owner only). Requires ERC-8004 agent identity.\n */\nexport async function registerAgent(\n agentId: bigint,\n agentAddress: Address,\n): Promise<Hex> {\n const wallet = getWalletClient();\n const client = getPublicClient();\n\n const hash = await wallet.writeContract({\n account: getAccount(),\n chain: getChain(),\n address: getVaultAddress(),\n abi: SYNDICATE_VAULT_ABI,\n functionName: \"registerAgent\",\n args: [agentId, agentAddress],\n });\n\n await client.waitForTransactionReceipt({ hash });\n return hash;\n}\n\n// ── Views ──\n\nexport interface VaultInfo {\n address: Address;\n totalAssets: string;\n agentCount: bigint;\n redemptionsLocked: boolean;\n managementFeeBps: bigint;\n}\n\n/**\n * Get vault overview info.\n */\nexport async function getVaultInfo(): Promise<VaultInfo> {\n const client = getPublicClient();\n const vaultAddress = getVaultAddress();\n\n const [totalAssets, agentCount, redemptionsLocked, managementFeeBps, decimals] =\n await Promise.all([\n client.readContract({\n address: vaultAddress,\n abi: SYNDICATE_VAULT_ABI,\n functionName: \"totalAssets\",\n }) as Promise<bigint>,\n client.readContract({\n address: vaultAddress,\n abi: SYNDICATE_VAULT_ABI,\n functionName: \"getAgentCount\",\n }) as Promise<bigint>,\n client.readContract({\n address: vaultAddress,\n abi: SYNDICATE_VAULT_ABI,\n functionName: \"redemptionsLocked\",\n }) as Promise<boolean>,\n client.readContract({\n address: vaultAddress,\n abi: SYNDICATE_VAULT_ABI,\n functionName: \"managementFeeBps\",\n }) as Promise<bigint>,\n getAssetDecimals(),\n ]);\n\n return {\n address: vaultAddress,\n totalAssets: formatUnits(totalAssets, decimals),\n agentCount,\n redemptionsLocked,\n managementFeeBps,\n };\n}\n","/**\n * ENS resolution + text records via Durin L2Registry on Base.\n *\n * Two responsibilities:\n * 1. Resolve syndicate subdomain → on-chain syndicate data (via factory)\n * 2. Read/write ENS text records (via L2Registry, routed through vault's executeBatch)\n *\n * The vault owns the ENS subdomain node (registered in the factory via\n * `ensRegistrar.register(subdomain, vault)`). Only the vault can write text\n * records. We route writes through vault.executeBatch → L2Registry.setText,\n * which executes as the vault via delegatecall to the shared executor lib.\n */\n\nimport { encodeFunctionData } from \"viem\";\nimport type { Address, Hex } from \"viem\";\nimport { namehash } from \"viem/ens\";\nimport { getPublicClient, getWalletClient, getAccount } from \"./client.js\";\nimport { getChain, getNetwork } from \"./network.js\";\nimport { SYNDICATE_FACTORY_ABI, L2_REGISTRY_ABI } from \"./abis.js\";\nimport { ENS, SHERWOOD } from \"./addresses.js\";\nimport * as vaultLib from \"./vault.js\";\n\n/**\n * Wait for a transaction to be mined before proceeding.\n */\nasync function waitForTx(hash: Hex): Promise<void> {\n const client = getPublicClient();\n await client.waitForTransactionReceipt({ hash });\n}\n\nconst ENS_DOMAIN = \"sherwoodagent.eth\";\n\nfunction getFactoryAddress(): Address {\n return SHERWOOD().FACTORY;\n}\n\n// ── Syndicate Resolution (via factory) ──\n\nexport interface SyndicateResolution {\n id: bigint;\n vault: Address;\n creator: Address;\n subdomain: string;\n}\n\n/**\n * Resolve a syndicate subdomain to its on-chain data.\n * Uses factory.subdomainToSyndicate() → factory.syndicates().\n */\nexport async function resolveSyndicate(subdomain: string): Promise<SyndicateResolution> {\n const client = getPublicClient();\n const factory = getFactoryAddress();\n\n // Get syndicate ID from subdomain\n const syndicateId = (await client.readContract({\n address: factory,\n abi: SYNDICATE_FACTORY_ABI,\n functionName: \"subdomainToSyndicate\",\n args: [subdomain],\n })) as bigint;\n\n if (syndicateId === 0n) {\n throw new Error(`Syndicate \"${subdomain}\" not found`);\n }\n\n // Get full syndicate record\n const result = (await client.readContract({\n address: factory,\n abi: SYNDICATE_FACTORY_ABI,\n functionName: \"syndicates\",\n args: [syndicateId],\n })) as [bigint, Address, Address, string, bigint, boolean, string];\n\n return {\n id: result[0],\n vault: result[1],\n creator: result[2],\n subdomain: result[6],\n };\n}\n\n/**\n * Reverse lookup: vault address → syndicate info.\n * Uses factory.vaultToSyndicate() → factory.syndicates().\n */\nexport async function resolveVaultSyndicate(\n vaultAddress: Address,\n): Promise<SyndicateResolution> {\n const client = getPublicClient();\n const factory = getFactoryAddress();\n\n const syndicateId = (await client.readContract({\n address: factory,\n abi: SYNDICATE_FACTORY_ABI,\n functionName: \"vaultToSyndicate\",\n args: [vaultAddress],\n })) as bigint;\n\n if (syndicateId === 0n) {\n throw new Error(`No syndicate found for vault ${vaultAddress}`);\n }\n\n const result = (await client.readContract({\n address: factory,\n abi: SYNDICATE_FACTORY_ABI,\n functionName: \"syndicates\",\n args: [syndicateId],\n })) as [bigint, Address, Address, string, bigint, boolean, string];\n\n return {\n id: result[0],\n vault: result[1],\n creator: result[2],\n subdomain: result[6],\n };\n}\n\n// ── ENS Text Records (via L2Registry) ──\n\n/**\n * Compute the ENS node hash for a subdomain under sherwoodagent.eth.\n */\nfunction getSubdomainNode(subdomain: string): Hex {\n return namehash(`${subdomain}.${ENS_DOMAIN}`);\n}\n\n/**\n * Write a text record to the L2Registry via the vault's executeBatch.\n *\n * The vault owns the ENS node, so only the vault can call setText.\n * We route the call through vault.executeBatch (delegatecall → executor lib → L2Registry),\n * which means L2Registry sees msg.sender = vault address.\n *\n * Requires the caller to be a registered agent on the vault (creator is auto-registered).\n */\nexport async function setTextRecord(\n subdomain: string,\n key: string,\n value: string,\n vaultAddress: Address,\n): Promise<Hex> {\n const l2Registry = ENS().L2_REGISTRY;\n const node = getSubdomainNode(subdomain);\n\n vaultLib.setVaultAddress(vaultAddress);\n\n // Encode the L2Registry.setText call\n const setTextData = encodeFunctionData({\n abi: L2_REGISTRY_ABI,\n functionName: \"setText\",\n args: [node, key, value],\n });\n\n // Route through vault.executeBatch (owner only)\n return vaultLib.executeBatch(\n [{ target: l2Registry, data: setTextData, value: 0n }],\n );\n}\n\n/**\n * Read a text record from the L2Registry.\n * Used to look up xmtpGroupId when not cached locally.\n */\nexport async function getTextRecord(\n subdomain: string,\n key: string,\n): Promise<string> {\n const client = getPublicClient();\n const node = getSubdomainNode(subdomain);\n\n return client.readContract({\n address: ENS().L2_REGISTRY,\n abi: L2_REGISTRY_ABI,\n functionName: \"text\",\n args: [node, key],\n }) as Promise<string>;\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;;AAQA,SAAS,mBAAmB;AAa5B,IAAI,iBAAiC;AAE9B,SAAS,gBAAgB,MAAqB;AACnD,mBAAiB;AACnB;AAEO,SAAS,kBAA2B;AAEzC,MAAI,eAAgB,QAAO;AAG3B,QAAM,UAAU,SAAS,EAAE;AAC3B,QAAM,aAAa,kBAAkB,OAAO,EAAE;AAC9C,MAAI,WAAY,QAAO;AAEvB,QAAM,IAAI;AAAA,IACR;AAAA,EACF;AACF;AAOA,eAAsB,kBAAoC;AACxD,QAAM,SAAS,gBAAgB;AAC/B,SAAO,OAAO,aAAa;AAAA,IACzB,SAAS,gBAAgB;AAAA,IACzB,KAAK;AAAA,IACL,cAAc;AAAA,EAChB,CAAC;AACH;AAMA,eAAsB,mBAAoC;AACxD,QAAM,SAAS,gBAAgB;AAC/B,QAAM,QAAQ,MAAM,gBAAgB;AACpC,SAAO,OAAO,aAAa;AAAA,IACzB,SAAS;AAAA,IACT,KAAK;AAAA,IACL,cAAc;AAAA,EAChB,CAAC;AACH;AAOA,eAAsB,QAAQ,QAA8B;AAC1D,QAAM,SAAS,gBAAgB;AAC/B,QAAM,SAAS,gBAAgB;AAC/B,QAAM,eAAe,gBAAgB;AACrC,QAAM,UAAU,WAAW;AAC3B,QAAM,QAAQ,MAAM,gBAAgB;AACpC,QAAM,OAAO,MAAM,uBAAuB;AAG1C,QAAM,mBAAoB,MAAM,OAAO,aAAa;AAAA,IAClD,SAAS;AAAA,IACT,KAAK;AAAA,IACL,cAAc;AAAA,IACd,MAAM,CAAC,QAAQ,SAAS,YAAY;AAAA,EACtC,CAAC;AAED,MAAI,mBAAmB,QAAQ;AAC7B,UAAM,cAAc,MAAM,OAAO,cAAc;AAAA,MAC7C,SAAS,WAAW;AAAA,MACpB,OAAO,SAAS;AAAA,MAChB,SAAS;AAAA,MACT,KAAK;AAAA,MACL,cAAc;AAAA,MACd,MAAM,CAAC,cAAc,MAAM;AAAA,MAC3B,GAAG;AAAA,IACL,CAAC;AACD,UAAM,OAAO,0BAA0B,EAAE,MAAM,YAAY,CAAC;AAAA,EAC9D;AAGA,QAAM,cAAc,MAAM,OAAO,cAAc;AAAA,IAC7C,SAAS,WAAW;AAAA,IACpB,OAAO,SAAS;AAAA,IAChB,SAAS;AAAA,IACT,KAAK;AAAA,IACL,cAAc;AAAA,IACd,MAAM,CAAC,QAAQ,QAAQ,OAAO;AAAA,IAC9B,GAAG;AAAA,EACL,CAAC;AACD,QAAM,OAAO,0BAA0B,EAAE,MAAM,YAAY,CAAC;AAC5D,SAAO;AACT;AASA,eAAsB,aAAa,OAAkC;AACnE,QAAM,SAAS,gBAAgB;AAC/B,QAAM,SAAS,gBAAgB;AAE/B,QAAM,OAAO,MAAM,OAAO,cAAc;AAAA,IACtC,SAAS,WAAW;AAAA,IACpB,OAAO,SAAS;AAAA,IAChB,SAAS,gBAAgB;AAAA,IACzB,KAAK;AAAA,IACL,cAAc;AAAA,IACd,MAAM;AAAA,MACJ,MAAM,IAAI,CAAC,OAAO;AAAA,QAChB,QAAQ,EAAE;AAAA,QACV,MAAM,EAAE;AAAA,QACR,OAAO,EAAE;AAAA,MACX,EAAE;AAAA,IACJ;AAAA,EACF,CAAC;AACD,QAAM,OAAO,0BAA0B,EAAE,KAAK,CAAC;AAC/C,SAAO;AACT;AAOA,eAAsB,iBAAiB,WAAkC;AACvE,QAAM,SAAS,gBAAgB;AAC/B,QAAM,SAAS,gBAAgB;AAC/B,QAAM,OAAO,MAAM,OAAO,cAAc;AAAA,IACtC,SAAS,WAAW;AAAA,IACpB,OAAO,SAAS;AAAA,IAChB,SAAS,gBAAgB;AAAA,IACzB,KAAK;AAAA,IACL,cAAc;AAAA,IACd,MAAM,CAAC,SAAS;AAAA,EAClB,CAAC;AACD,QAAM,OAAO,0BAA0B,EAAE,KAAK,CAAC;AAC/C,SAAO;AACT;AAKA,eAAsB,gBAAgB,WAAkC;AACtE,QAAM,SAAS,gBAAgB;AAC/B,QAAM,SAAS,gBAAgB;AAC/B,QAAM,OAAO,MAAM,OAAO,cAAc;AAAA,IACtC,SAAS,WAAW;AAAA,IACpB,OAAO,SAAS;AAAA,IAChB,SAAS,gBAAgB;AAAA,IACzB,KAAK;AAAA,IACL,cAAc;AAAA,IACd,MAAM,CAAC,SAAS;AAAA,EAClB,CAAC;AACD,QAAM,OAAO,0BAA0B,EAAE,KAAK,CAAC;AAC/C,SAAO;AACT;AAuBA,eAAsB,QAAQ,cAAyC;AACrE,QAAM,SAAS,gBAAgB;AAC/B,SAAO,OAAO,aAAa;AAAA,IACzB,SAAS,gBAAgB;AAAA,IACzB,KAAK;AAAA,IACL,cAAc;AAAA,IACd,MAAM,CAAC,YAAY;AAAA,EACrB,CAAC;AACH;AAkBA,eAAsB,WAAW,SAI9B;AACD,QAAM,SAAS,gBAAgB;AAC/B,QAAM,eAAe,gBAAgB;AACrC,QAAM,UAAU,WAAW,WAAW,EAAE;AAExC,QAAM,CAAC,QAAQ,WAAW,IAAI,MAAM,QAAQ,IAAI;AAAA,IAC9C,OAAO,aAAa;AAAA,MAClB,SAAS;AAAA,MACT,KAAK;AAAA,MACL,cAAc;AAAA,MACd,MAAM,CAAC,OAAO;AAAA,IAChB,CAAC;AAAA,IACD,OAAO,aAAa;AAAA,MAClB,SAAS;AAAA,MACT,KAAK;AAAA,MACL,cAAc;AAAA,IAChB,CAAC;AAAA,EACH,CAAC;AAED,MAAI,cAAc;AAClB,MAAI,SAAS,IAAI;AACf,kBAAe,MAAM,OAAO,aAAa;AAAA,MACvC,SAAS;AAAA,MACT,KAAK;AAAA,MACL,cAAc;AAAA,MACd,MAAM,CAAC,MAAM;AAAA,IACf,CAAC;AAAA,EACH;AAEA,QAAM,UACJ,cAAc,MAAO,OAAO,MAAM,IAAI,OAAO,WAAW,IAAK,KAAK,QAAQ,CAAC,IAAI;AAEjF,QAAM,WAAW,MAAM,iBAAiB;AAExC,SAAO;AAAA,IACL;AAAA,IACA,aAAa,YAAY,aAAa,QAAQ;AAAA,IAC9C,gBAAgB,GAAG,OAAO;AAAA,EAC5B;AACF;AAOA,eAAsB,cACpB,SACA,cACc;AACd,QAAM,SAAS,gBAAgB;AAC/B,QAAM,SAAS,gBAAgB;AAE/B,QAAM,OAAO,MAAM,OAAO,cAAc;AAAA,IACtC,SAAS,WAAW;AAAA,IACpB,OAAO,SAAS;AAAA,IAChB,SAAS,gBAAgB;AAAA,IACzB,KAAK;AAAA,IACL,cAAc;AAAA,IACd,MAAM,CAAC,SAAS,YAAY;AAAA,EAC9B,CAAC;AAED,QAAM,OAAO,0BAA0B,EAAE,KAAK,CAAC;AAC/C,SAAO;AACT;AAeA,eAAsB,eAAmC;AACvD,QAAM,SAAS,gBAAgB;AAC/B,QAAM,eAAe,gBAAgB;AAErC,QAAM,CAAC,aAAa,YAAY,mBAAmB,kBAAkB,QAAQ,IAC3E,MAAM,QAAQ,IAAI;AAAA,IAChB,OAAO,aAAa;AAAA,MAClB,SAAS;AAAA,MACT,KAAK;AAAA,MACL,cAAc;AAAA,IAChB,CAAC;AAAA,IACD,OAAO,aAAa;AAAA,MAClB,SAAS;AAAA,MACT,KAAK;AAAA,MACL,cAAc;AAAA,IAChB,CAAC;AAAA,IACD,OAAO,aAAa;AAAA,MAClB,SAAS;AAAA,MACT,KAAK;AAAA,MACL,cAAc;AAAA,IAChB,CAAC;AAAA,IACD,OAAO,aAAa;AAAA,MAClB,SAAS;AAAA,MACT,KAAK;AAAA,MACL,cAAc;AAAA,IAChB,CAAC;AAAA,IACD,iBAAiB;AAAA,EACnB,CAAC;AAEH,SAAO;AAAA,IACL,SAAS;AAAA,IACT,aAAa,YAAY,aAAa,QAAQ;AAAA,IAC9C;AAAA,IACA;AAAA,IACA;AAAA,EACF;AACF;;;ACjVA,SAAS,0BAA0B;AAEnC,SAAS,gBAAgB;AAezB,IAAM,aAAa;AAEnB,SAAS,oBAA6B;AACpC,SAAO,SAAS,EAAE;AACpB;AAeA,eAAsB,iBAAiB,WAAiD;AACtF,QAAM,SAAS,gBAAgB;AAC/B,QAAM,UAAU,kBAAkB;AAGlC,QAAM,cAAe,MAAM,OAAO,aAAa;AAAA,IAC7C,SAAS;AAAA,IACT,KAAK;AAAA,IACL,cAAc;AAAA,IACd,MAAM,CAAC,SAAS;AAAA,EAClB,CAAC;AAED,MAAI,gBAAgB,IAAI;AACtB,UAAM,IAAI,MAAM,cAAc,SAAS,aAAa;AAAA,EACtD;AAGA,QAAM,SAAU,MAAM,OAAO,aAAa;AAAA,IACxC,SAAS;AAAA,IACT,KAAK;AAAA,IACL,cAAc;AAAA,IACd,MAAM,CAAC,WAAW;AAAA,EACpB,CAAC;AAED,SAAO;AAAA,IACL,IAAI,OAAO,CAAC;AAAA,IACZ,OAAO,OAAO,CAAC;AAAA,IACf,SAAS,OAAO,CAAC;AAAA,IACjB,WAAW,OAAO,CAAC;AAAA,EACrB;AACF;AAMA,eAAsB,sBACpB,cAC8B;AAC9B,QAAM,SAAS,gBAAgB;AAC/B,QAAM,UAAU,kBAAkB;AAElC,QAAM,cAAe,MAAM,OAAO,aAAa;AAAA,IAC7C,SAAS;AAAA,IACT,KAAK;AAAA,IACL,cAAc;AAAA,IACd,MAAM,CAAC,YAAY;AAAA,EACrB,CAAC;AAED,MAAI,gBAAgB,IAAI;AACtB,UAAM,IAAI,MAAM,gCAAgC,YAAY,EAAE;AAAA,EAChE;AAEA,QAAM,SAAU,MAAM,OAAO,aAAa;AAAA,IACxC,SAAS;AAAA,IACT,KAAK;AAAA,IACL,cAAc;AAAA,IACd,MAAM,CAAC,WAAW;AAAA,EACpB,CAAC;AAED,SAAO;AAAA,IACL,IAAI,OAAO,CAAC;AAAA,IACZ,OAAO,OAAO,CAAC;AAAA,IACf,SAAS,OAAO,CAAC;AAAA,IACjB,WAAW,OAAO,CAAC;AAAA,EACrB;AACF;AAOA,SAAS,iBAAiB,WAAwB;AAChD,SAAO,SAAS,GAAG,SAAS,IAAI,UAAU,EAAE;AAC9C;AAWA,eAAsB,cACpB,WACA,KACA,OACA,cACc;AACd,QAAM,aAAa,IAAI,EAAE;AACzB,QAAM,OAAO,iBAAiB,SAAS;AAEvC,EAAS,gBAAgB,YAAY;AAGrC,QAAM,cAAc,mBAAmB;AAAA,IACrC,KAAK;AAAA,IACL,cAAc;AAAA,IACd,MAAM,CAAC,MAAM,KAAK,KAAK;AAAA,EACzB,CAAC;AAGD,SAAgB;AAAA,IACd,CAAC,EAAE,QAAQ,YAAY,MAAM,aAAa,OAAO,GAAG,CAAC;AAAA,EACvD;AACF;AAMA,eAAsB,cACpB,WACA,KACiB;AACjB,QAAM,SAAS,gBAAgB;AAC/B,QAAM,OAAO,iBAAiB,SAAS;AAEvC,SAAO,OAAO,aAAa;AAAA,IACzB,SAAS,IAAI,EAAE;AAAA,IACf,KAAK;AAAA,IACL,cAAc;AAAA,IACd,MAAM,CAAC,MAAM,GAAG;AAAA,EAClB,CAAC;AACH;","names":[]}
@@ -56,10 +56,19 @@ function getWalletClient() {
56
56
  function getAccount() {
57
57
  return privateKeyToAccount(getPrivateKey());
58
58
  }
59
+ async function estimateFeesWithBuffer() {
60
+ const client = getPublicClient();
61
+ const { maxFeePerGas, maxPriorityFeePerGas } = await client.estimateFeesPerGas();
62
+ return {
63
+ maxFeePerGas: maxFeePerGas * 120n / 100n,
64
+ maxPriorityFeePerGas: maxPriorityFeePerGas * 120n / 100n
65
+ };
66
+ }
59
67
 
60
68
  export {
61
69
  getPublicClient,
62
70
  getWalletClient,
63
- getAccount
71
+ getAccount,
72
+ estimateFeesWithBuffer
64
73
  };
65
- //# sourceMappingURL=chunk-GH3F42AO.js.map
74
+ //# sourceMappingURL=chunk-N65F7HRF.js.map