@x402scan/mcp 0.0.7-beta.1 → 0.0.7-beta.3

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.
@@ -0,0 +1,925 @@
1
+ import * as fs from 'fs/promises';
2
+ import * as fs2 from 'fs';
3
+ import fs2__default, { existsSync } from 'fs';
4
+ import { join } from 'path';
5
+ import { homedir } from 'os';
6
+ import open from 'open';
7
+ import z3 from 'zod';
8
+ import { getAddress } from 'viem';
9
+ import { privateKeyToAccount, generatePrivateKey } from 'viem/accounts';
10
+ import { polygon, arbitrum, optimism, sepolia, mainnet, baseSepolia, base } from 'viem/chains';
11
+
12
+ // src/shared/neverthrow/fs/index.ts
13
+
14
+ // ../../../node_modules/.pnpm/neverthrow@8.2.0/node_modules/neverthrow/dist/index.es.js
15
+ var defaultErrorConfig = {
16
+ withStackTrace: false
17
+ };
18
+ var createNeverThrowError = (message, result, config = defaultErrorConfig) => {
19
+ const data = result.isOk() ? { type: "Ok", value: result.value } : { type: "Err", value: result.error };
20
+ const maybeStack = config.withStackTrace ? new Error().stack : void 0;
21
+ return {
22
+ data,
23
+ message,
24
+ stack: maybeStack
25
+ };
26
+ };
27
+ function __awaiter(thisArg, _arguments, P, generator) {
28
+ function adopt(value) {
29
+ return value instanceof P ? value : new P(function(resolve) {
30
+ resolve(value);
31
+ });
32
+ }
33
+ return new (P || (P = Promise))(function(resolve, reject) {
34
+ function fulfilled(value) {
35
+ try {
36
+ step(generator.next(value));
37
+ } catch (e) {
38
+ reject(e);
39
+ }
40
+ }
41
+ function rejected(value) {
42
+ try {
43
+ step(generator["throw"](value));
44
+ } catch (e) {
45
+ reject(e);
46
+ }
47
+ }
48
+ function step(result) {
49
+ result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected);
50
+ }
51
+ step((generator = generator.apply(thisArg, [])).next());
52
+ });
53
+ }
54
+ function __values(o) {
55
+ var s = typeof Symbol === "function" && Symbol.iterator, m = s && o[s], i = 0;
56
+ if (m) return m.call(o);
57
+ if (o && typeof o.length === "number") return {
58
+ next: function() {
59
+ if (o && i >= o.length) o = void 0;
60
+ return { value: o && o[i++], done: !o };
61
+ }
62
+ };
63
+ throw new TypeError(s ? "Object is not iterable." : "Symbol.iterator is not defined.");
64
+ }
65
+ function __await(v) {
66
+ return this instanceof __await ? (this.v = v, this) : new __await(v);
67
+ }
68
+ function __asyncGenerator(thisArg, _arguments, generator) {
69
+ if (!Symbol.asyncIterator) throw new TypeError("Symbol.asyncIterator is not defined.");
70
+ var g = generator.apply(thisArg, _arguments || []), i, q = [];
71
+ return i = Object.create((typeof AsyncIterator === "function" ? AsyncIterator : Object).prototype), verb("next"), verb("throw"), verb("return", awaitReturn), i[Symbol.asyncIterator] = function() {
72
+ return this;
73
+ }, i;
74
+ function awaitReturn(f) {
75
+ return function(v) {
76
+ return Promise.resolve(v).then(f, reject);
77
+ };
78
+ }
79
+ function verb(n, f) {
80
+ if (g[n]) {
81
+ i[n] = function(v) {
82
+ return new Promise(function(a, b) {
83
+ q.push([n, v, a, b]) > 1 || resume(n, v);
84
+ });
85
+ };
86
+ if (f) i[n] = f(i[n]);
87
+ }
88
+ }
89
+ function resume(n, v) {
90
+ try {
91
+ step(g[n](v));
92
+ } catch (e) {
93
+ settle(q[0][3], e);
94
+ }
95
+ }
96
+ function step(r) {
97
+ r.value instanceof __await ? Promise.resolve(r.value.v).then(fulfill, reject) : settle(q[0][2], r);
98
+ }
99
+ function fulfill(value) {
100
+ resume("next", value);
101
+ }
102
+ function reject(value) {
103
+ resume("throw", value);
104
+ }
105
+ function settle(f, v) {
106
+ if (f(v), q.shift(), q.length) resume(q[0][0], q[0][1]);
107
+ }
108
+ }
109
+ function __asyncDelegator(o) {
110
+ var i, p;
111
+ return i = {}, verb("next"), verb("throw", function(e) {
112
+ throw e;
113
+ }), verb("return"), i[Symbol.iterator] = function() {
114
+ return this;
115
+ }, i;
116
+ function verb(n, f) {
117
+ i[n] = o[n] ? function(v) {
118
+ return (p = !p) ? { value: __await(o[n](v)), done: false } : f ? f(v) : v;
119
+ } : f;
120
+ }
121
+ }
122
+ function __asyncValues(o) {
123
+ if (!Symbol.asyncIterator) throw new TypeError("Symbol.asyncIterator is not defined.");
124
+ var m = o[Symbol.asyncIterator], i;
125
+ return m ? m.call(o) : (o = typeof __values === "function" ? __values(o) : o[Symbol.iterator](), i = {}, verb("next"), verb("throw"), verb("return"), i[Symbol.asyncIterator] = function() {
126
+ return this;
127
+ }, i);
128
+ function verb(n) {
129
+ i[n] = o[n] && function(v) {
130
+ return new Promise(function(resolve, reject) {
131
+ v = o[n](v), settle(resolve, reject, v.done, v.value);
132
+ });
133
+ };
134
+ }
135
+ function settle(resolve, reject, d, v) {
136
+ Promise.resolve(v).then(function(v2) {
137
+ resolve({ value: v2, done: d });
138
+ }, reject);
139
+ }
140
+ }
141
+ var ResultAsync = class _ResultAsync {
142
+ constructor(res) {
143
+ this._promise = res;
144
+ }
145
+ static fromSafePromise(promise) {
146
+ const newPromise = promise.then((value) => new Ok(value));
147
+ return new _ResultAsync(newPromise);
148
+ }
149
+ static fromPromise(promise, errorFn) {
150
+ const newPromise = promise.then((value) => new Ok(value)).catch((e) => new Err(errorFn(e)));
151
+ return new _ResultAsync(newPromise);
152
+ }
153
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
154
+ static fromThrowable(fn, errorFn) {
155
+ return (...args) => {
156
+ return new _ResultAsync((() => __awaiter(this, void 0, void 0, function* () {
157
+ try {
158
+ return new Ok(yield fn(...args));
159
+ } catch (error) {
160
+ return new Err(errorFn ? errorFn(error) : error);
161
+ }
162
+ }))());
163
+ };
164
+ }
165
+ static combine(asyncResultList) {
166
+ return combineResultAsyncList(asyncResultList);
167
+ }
168
+ static combineWithAllErrors(asyncResultList) {
169
+ return combineResultAsyncListWithAllErrors(asyncResultList);
170
+ }
171
+ map(f) {
172
+ return new _ResultAsync(this._promise.then((res) => __awaiter(this, void 0, void 0, function* () {
173
+ if (res.isErr()) {
174
+ return new Err(res.error);
175
+ }
176
+ return new Ok(yield f(res.value));
177
+ })));
178
+ }
179
+ andThrough(f) {
180
+ return new _ResultAsync(this._promise.then((res) => __awaiter(this, void 0, void 0, function* () {
181
+ if (res.isErr()) {
182
+ return new Err(res.error);
183
+ }
184
+ const newRes = yield f(res.value);
185
+ if (newRes.isErr()) {
186
+ return new Err(newRes.error);
187
+ }
188
+ return new Ok(res.value);
189
+ })));
190
+ }
191
+ andTee(f) {
192
+ return new _ResultAsync(this._promise.then((res) => __awaiter(this, void 0, void 0, function* () {
193
+ if (res.isErr()) {
194
+ return new Err(res.error);
195
+ }
196
+ try {
197
+ yield f(res.value);
198
+ } catch (e) {
199
+ }
200
+ return new Ok(res.value);
201
+ })));
202
+ }
203
+ orTee(f) {
204
+ return new _ResultAsync(this._promise.then((res) => __awaiter(this, void 0, void 0, function* () {
205
+ if (res.isOk()) {
206
+ return new Ok(res.value);
207
+ }
208
+ try {
209
+ yield f(res.error);
210
+ } catch (e) {
211
+ }
212
+ return new Err(res.error);
213
+ })));
214
+ }
215
+ mapErr(f) {
216
+ return new _ResultAsync(this._promise.then((res) => __awaiter(this, void 0, void 0, function* () {
217
+ if (res.isOk()) {
218
+ return new Ok(res.value);
219
+ }
220
+ return new Err(yield f(res.error));
221
+ })));
222
+ }
223
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any, @typescript-eslint/explicit-module-boundary-types
224
+ andThen(f) {
225
+ return new _ResultAsync(this._promise.then((res) => {
226
+ if (res.isErr()) {
227
+ return new Err(res.error);
228
+ }
229
+ const newValue = f(res.value);
230
+ return newValue instanceof _ResultAsync ? newValue._promise : newValue;
231
+ }));
232
+ }
233
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any, @typescript-eslint/explicit-module-boundary-types
234
+ orElse(f) {
235
+ return new _ResultAsync(this._promise.then((res) => __awaiter(this, void 0, void 0, function* () {
236
+ if (res.isErr()) {
237
+ return f(res.error);
238
+ }
239
+ return new Ok(res.value);
240
+ })));
241
+ }
242
+ match(ok3, _err) {
243
+ return this._promise.then((res) => res.match(ok3, _err));
244
+ }
245
+ unwrapOr(t) {
246
+ return this._promise.then((res) => res.unwrapOr(t));
247
+ }
248
+ /**
249
+ * @deprecated will be removed in 9.0.0.
250
+ *
251
+ * You can use `safeTry` without this method.
252
+ * @example
253
+ * ```typescript
254
+ * safeTry(async function* () {
255
+ * const okValue = yield* yourResult
256
+ * })
257
+ * ```
258
+ * Emulates Rust's `?` operator in `safeTry`'s body. See also `safeTry`.
259
+ */
260
+ safeUnwrap() {
261
+ return __asyncGenerator(this, arguments, function* safeUnwrap_1() {
262
+ return yield __await(yield __await(yield* __asyncDelegator(__asyncValues(yield __await(this._promise.then((res) => res.safeUnwrap()))))));
263
+ });
264
+ }
265
+ // Makes ResultAsync implement PromiseLike<Result>
266
+ then(successCallback, failureCallback) {
267
+ return this._promise.then(successCallback, failureCallback);
268
+ }
269
+ [Symbol.asyncIterator]() {
270
+ return __asyncGenerator(this, arguments, function* _a() {
271
+ const result = yield __await(this._promise);
272
+ if (result.isErr()) {
273
+ yield yield __await(errAsync(result.error));
274
+ }
275
+ return yield __await(result.value);
276
+ });
277
+ }
278
+ };
279
+ function errAsync(err3) {
280
+ return new ResultAsync(Promise.resolve(new Err(err3)));
281
+ }
282
+ var combineResultList = (resultList) => {
283
+ let acc = ok([]);
284
+ for (const result of resultList) {
285
+ if (result.isErr()) {
286
+ acc = err(result.error);
287
+ break;
288
+ } else {
289
+ acc.map((list) => list.push(result.value));
290
+ }
291
+ }
292
+ return acc;
293
+ };
294
+ var combineResultAsyncList = (asyncResultList) => ResultAsync.fromSafePromise(Promise.all(asyncResultList)).andThen(combineResultList);
295
+ var combineResultListWithAllErrors = (resultList) => {
296
+ let acc = ok([]);
297
+ for (const result of resultList) {
298
+ if (result.isErr() && acc.isErr()) {
299
+ acc.error.push(result.error);
300
+ } else if (result.isErr() && acc.isOk()) {
301
+ acc = err([result.error]);
302
+ } else if (result.isOk() && acc.isOk()) {
303
+ acc.value.push(result.value);
304
+ }
305
+ }
306
+ return acc;
307
+ };
308
+ var combineResultAsyncListWithAllErrors = (asyncResultList) => ResultAsync.fromSafePromise(Promise.all(asyncResultList)).andThen(combineResultListWithAllErrors);
309
+ var Result;
310
+ (function(Result2) {
311
+ function fromThrowable2(fn, errorFn) {
312
+ return (...args) => {
313
+ try {
314
+ const result = fn(...args);
315
+ return ok(result);
316
+ } catch (e) {
317
+ return err(errorFn ? errorFn(e) : e);
318
+ }
319
+ };
320
+ }
321
+ Result2.fromThrowable = fromThrowable2;
322
+ function combine(resultList) {
323
+ return combineResultList(resultList);
324
+ }
325
+ Result2.combine = combine;
326
+ function combineWithAllErrors(resultList) {
327
+ return combineResultListWithAllErrors(resultList);
328
+ }
329
+ Result2.combineWithAllErrors = combineWithAllErrors;
330
+ })(Result || (Result = {}));
331
+ function ok(value) {
332
+ return new Ok(value);
333
+ }
334
+ function err(err3) {
335
+ return new Err(err3);
336
+ }
337
+ var Ok = class {
338
+ constructor(value) {
339
+ this.value = value;
340
+ }
341
+ isOk() {
342
+ return true;
343
+ }
344
+ isErr() {
345
+ return !this.isOk();
346
+ }
347
+ map(f) {
348
+ return ok(f(this.value));
349
+ }
350
+ // eslint-disable-next-line @typescript-eslint/no-unused-vars
351
+ mapErr(_f) {
352
+ return ok(this.value);
353
+ }
354
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any, @typescript-eslint/explicit-module-boundary-types
355
+ andThen(f) {
356
+ return f(this.value);
357
+ }
358
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any, @typescript-eslint/explicit-module-boundary-types
359
+ andThrough(f) {
360
+ return f(this.value).map((_value) => this.value);
361
+ }
362
+ andTee(f) {
363
+ try {
364
+ f(this.value);
365
+ } catch (e) {
366
+ }
367
+ return ok(this.value);
368
+ }
369
+ orTee(_f) {
370
+ return ok(this.value);
371
+ }
372
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any, @typescript-eslint/explicit-module-boundary-types
373
+ orElse(_f) {
374
+ return ok(this.value);
375
+ }
376
+ asyncAndThen(f) {
377
+ return f(this.value);
378
+ }
379
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any, @typescript-eslint/explicit-module-boundary-types
380
+ asyncAndThrough(f) {
381
+ return f(this.value).map(() => this.value);
382
+ }
383
+ asyncMap(f) {
384
+ return ResultAsync.fromSafePromise(f(this.value));
385
+ }
386
+ // eslint-disable-next-line @typescript-eslint/no-unused-vars
387
+ unwrapOr(_v) {
388
+ return this.value;
389
+ }
390
+ // eslint-disable-next-line @typescript-eslint/no-unused-vars
391
+ match(ok3, _err) {
392
+ return ok3(this.value);
393
+ }
394
+ safeUnwrap() {
395
+ const value = this.value;
396
+ return (function* () {
397
+ return value;
398
+ })();
399
+ }
400
+ _unsafeUnwrap(_) {
401
+ return this.value;
402
+ }
403
+ _unsafeUnwrapErr(config) {
404
+ throw createNeverThrowError("Called `_unsafeUnwrapErr` on an Ok", this, config);
405
+ }
406
+ // eslint-disable-next-line @typescript-eslint/no-this-alias, require-yield
407
+ *[Symbol.iterator]() {
408
+ return this.value;
409
+ }
410
+ };
411
+ var Err = class {
412
+ constructor(error) {
413
+ this.error = error;
414
+ }
415
+ isOk() {
416
+ return false;
417
+ }
418
+ isErr() {
419
+ return !this.isOk();
420
+ }
421
+ // eslint-disable-next-line @typescript-eslint/no-unused-vars
422
+ map(_f) {
423
+ return err(this.error);
424
+ }
425
+ mapErr(f) {
426
+ return err(f(this.error));
427
+ }
428
+ andThrough(_f) {
429
+ return err(this.error);
430
+ }
431
+ andTee(_f) {
432
+ return err(this.error);
433
+ }
434
+ orTee(f) {
435
+ try {
436
+ f(this.error);
437
+ } catch (e) {
438
+ }
439
+ return err(this.error);
440
+ }
441
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any, @typescript-eslint/explicit-module-boundary-types
442
+ andThen(_f) {
443
+ return err(this.error);
444
+ }
445
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any, @typescript-eslint/explicit-module-boundary-types
446
+ orElse(f) {
447
+ return f(this.error);
448
+ }
449
+ // eslint-disable-next-line @typescript-eslint/no-unused-vars
450
+ asyncAndThen(_f) {
451
+ return errAsync(this.error);
452
+ }
453
+ asyncAndThrough(_f) {
454
+ return errAsync(this.error);
455
+ }
456
+ // eslint-disable-next-line @typescript-eslint/no-unused-vars
457
+ asyncMap(_f) {
458
+ return errAsync(this.error);
459
+ }
460
+ unwrapOr(v) {
461
+ return v;
462
+ }
463
+ match(_ok, err3) {
464
+ return err3(this.error);
465
+ }
466
+ safeUnwrap() {
467
+ const error = this.error;
468
+ return (function* () {
469
+ yield err(error);
470
+ throw new Error("Do not use this generator out of `safeTry`");
471
+ })();
472
+ }
473
+ _unsafeUnwrap(config) {
474
+ throw createNeverThrowError("Called `_unsafeUnwrap` on an Err", this, config);
475
+ }
476
+ _unsafeUnwrapErr(_) {
477
+ return this.error;
478
+ }
479
+ *[Symbol.iterator]() {
480
+ const self = this;
481
+ yield self;
482
+ return self;
483
+ }
484
+ };
485
+ Result.fromThrowable;
486
+
487
+ // ../../internal/neverthrow/dist/index.js
488
+ function resultFromPromise(type3, surface, promise, error) {
489
+ return ResultAsync.fromPromise(promise, (e) => ({
490
+ ...error(e),
491
+ type: type3,
492
+ surface
493
+ }));
494
+ }
495
+ function resultFromThrowable(type3, surface, fn, error) {
496
+ return Result.fromThrowable(fn, (e) => ({
497
+ ...error(e),
498
+ type: type3,
499
+ surface
500
+ }))();
501
+ }
502
+ function ok2(data) {
503
+ return ok(data);
504
+ }
505
+ function err2(type3, surface, error) {
506
+ return err({
507
+ ...error,
508
+ type: type3,
509
+ surface
510
+ });
511
+ }
512
+
513
+ // src/shared/neverthrow/fs/index.ts
514
+ var errorType = "fs";
515
+ var fsErr = (surface, error) => err2(errorType, surface, error);
516
+ var fsResultFromPromise = (surface, promise, error) => resultFromPromise(errorType, surface, promise, error);
517
+ var safeReadFile = (surface, path) => fsResultFromPromise(surface, fs.readFile(path, "utf-8"), () => ({
518
+ cause: "file_not_readable",
519
+ message: "Failed to read file"
520
+ }));
521
+ var safeWriteFile = (surface, path, data) => fsResultFromPromise(surface, fs.writeFile(path, data), () => ({
522
+ cause: "file_not_writable",
523
+ message: "Failed to write file"
524
+ }));
525
+ var safeAppendFile = (surface, path, data) => fsResultFromPromise(surface, fs.appendFile(path, data), () => ({
526
+ cause: "file_not_writable",
527
+ message: "Failed to append file"
528
+ }));
529
+ var safeChmod = (surface, path, mode) => fsResultFromPromise(surface, fs.chmod(path, mode), () => ({
530
+ cause: "file_not_chmodable",
531
+ message: "Failed to chmod file"
532
+ }));
533
+ var safeFileExists = (surface, path) => {
534
+ const fileExists = existsSync(path);
535
+ if (fileExists) {
536
+ return ok2(true);
537
+ }
538
+ return err2(errorType, surface, {
539
+ cause: "file_not_found",
540
+ message: "File not found"
541
+ });
542
+ };
543
+ var BASE_DIRECTORY = join(homedir(), ".x402scan-mcp");
544
+ if (!fs2.existsSync(BASE_DIRECTORY)) {
545
+ fs2.mkdirSync(BASE_DIRECTORY, { recursive: true });
546
+ }
547
+ var configFile = (name, defaultValue) => {
548
+ if (!fs2.existsSync(BASE_DIRECTORY)) {
549
+ fs2.mkdirSync(BASE_DIRECTORY, { recursive: true });
550
+ }
551
+ const filePath = join(BASE_DIRECTORY, name);
552
+ if (!fs2.existsSync(filePath)) {
553
+ fs2.writeFileSync(filePath, defaultValue);
554
+ }
555
+ return filePath;
556
+ };
557
+
558
+ // src/shared/log.ts
559
+ var LOG_FILE = configFile("mcp.log", "");
560
+ var DEBUG = process.env.X402_DEBUG === "true";
561
+ function format(args) {
562
+ return args.map(
563
+ (a) => typeof a === "object" && a !== null ? JSON.stringify(a) : String(a)
564
+ ).join(" ");
565
+ }
566
+ function write(level, msg, args) {
567
+ const formatted = args.length ? `${msg} ${format(args)}` : msg;
568
+ const line = `[${(/* @__PURE__ */ new Date()).toISOString()}] [${level}] ${formatted}
569
+ `;
570
+ safeAppendFile("log", LOG_FILE, line);
571
+ if (process.env.X402_DEBUG === "true") {
572
+ console.error(`[x402scan] ${formatted}`);
573
+ }
574
+ }
575
+ var log = {
576
+ info: (msg, ...args) => write("INFO", msg, args),
577
+ error: (msg, ...args) => write("ERROR", msg, args),
578
+ debug: (msg, ...args) => DEBUG && write("DEBUG", msg, args),
579
+ path: LOG_FILE
580
+ };
581
+
582
+ // src/shared/neverthrow/fetch/index.ts
583
+ var errorType2 = "fetch";
584
+ var fetchErr = (surface, error) => err2(errorType2, surface, error);
585
+ var fetchHttpErr = (surface, response) => fetchErr(surface, {
586
+ cause: "http",
587
+ statusCode: response.status,
588
+ message: response.statusText,
589
+ response
590
+ });
591
+ var safeFetch = (surface, request) => {
592
+ return resultFromPromise(
593
+ errorType2,
594
+ surface,
595
+ fetch(request),
596
+ (error) => ({
597
+ cause: "network",
598
+ message: error instanceof Error ? error.message : "Network error"
599
+ })
600
+ );
601
+ };
602
+ var safeFetchJson = (surface, request) => {
603
+ return safeFetch(surface, request).andThen((response) => {
604
+ if (!response.ok) {
605
+ return fetchHttpErr(surface, response);
606
+ }
607
+ return resultFromPromise(
608
+ errorType2,
609
+ surface,
610
+ response.json(),
611
+ () => ({
612
+ cause: "parse",
613
+ message: "Could not parse JSON from response",
614
+ statusCode: response.status,
615
+ contentType: response.headers.get("content-type") ?? "Not specified"
616
+ })
617
+ );
618
+ });
619
+ };
620
+ var safeParseResponse = (surface, response) => {
621
+ return resultFromPromise(
622
+ errorType2,
623
+ surface,
624
+ (async () => {
625
+ const contentType = response.headers.get("content-type") ?? "";
626
+ switch (contentType) {
627
+ case "application/json":
628
+ return {
629
+ type: "json",
630
+ data: await response.json()
631
+ };
632
+ case "image/png":
633
+ case "image/jpeg":
634
+ case "image/gif":
635
+ case "image/webp":
636
+ case "image/svg+xml":
637
+ case "image/tiff":
638
+ case "image/bmp":
639
+ case "image/ico":
640
+ return {
641
+ type: "image",
642
+ mimeType: contentType,
643
+ data: await response.arrayBuffer()
644
+ };
645
+ case "audio/":
646
+ return {
647
+ type: "audio",
648
+ mimeType: contentType,
649
+ data: await response.arrayBuffer()
650
+ };
651
+ case "video/":
652
+ return {
653
+ type: "video",
654
+ mimeType: contentType,
655
+ data: await response.arrayBuffer()
656
+ };
657
+ case "application/pdf":
658
+ return {
659
+ type: "pdf",
660
+ mimeType: contentType,
661
+ data: await response.arrayBuffer()
662
+ };
663
+ case "application/octet-stream":
664
+ return {
665
+ type: "octet-stream",
666
+ mimeType: contentType,
667
+ data: await response.arrayBuffer()
668
+ };
669
+ case "multipart/form-data":
670
+ return { type: "formData", data: await response.formData() };
671
+ case "text/":
672
+ return { type: "text", data: await response.text() };
673
+ default:
674
+ throw new Error(`Unsupported content type: ${contentType}`);
675
+ }
676
+ })(),
677
+ (e) => ({
678
+ cause: "parse",
679
+ message: e instanceof Error ? e.message : "Could not parse response",
680
+ statusCode: response.status,
681
+ contentType: response.headers.get("content-type") ?? "Not specified"
682
+ })
683
+ );
684
+ };
685
+ var isFetchError = (error) => {
686
+ return error.type === errorType2;
687
+ };
688
+ var getBaseUrl = (dev) => {
689
+ return dev ? "http://localhost:3000" : "https://x402scan.com";
690
+ };
691
+ var getDepositLink = (address, flags) => {
692
+ return `${getBaseUrl(flags.dev)}/mcp/deposit/${address}`;
693
+ };
694
+ var openDepositLink = async (address, flags) => {
695
+ const depositLink = getDepositLink(address, flags);
696
+ await open(depositLink);
697
+ };
698
+ var STATE_FILE = configFile("state.json", "{}");
699
+ var stateSchema = z3.looseObject({
700
+ redeemedCodes: z3.array(z3.string())
701
+ }).partial();
702
+ var getState = () => {
703
+ const result = stateSchema.safeParse(
704
+ JSON.parse(fs2__default.readFileSync(STATE_FILE, "utf-8"))
705
+ );
706
+ if (!result.success) {
707
+ log.error("Failed to parse state", { error: result.error });
708
+ return {};
709
+ }
710
+ return result.data;
711
+ };
712
+ var setState = (state) => {
713
+ const existing = getState();
714
+ const newState = stateSchema.parse({ ...existing, ...state });
715
+ fs2__default.writeFileSync(STATE_FILE, JSON.stringify(newState, null, 2));
716
+ };
717
+
718
+ // src/shared/redeem-invite.ts
719
+ var redeemInviteCode = async ({
720
+ code,
721
+ dev,
722
+ address,
723
+ surface
724
+ }) => {
725
+ const state = getState();
726
+ if (state.redeemedCodes?.includes(code)) {
727
+ return err2("user", surface, {
728
+ cause: "conflict",
729
+ message: "This invite code has already been redeemed"
730
+ });
731
+ }
732
+ const result = await safeFetchJson(
733
+ surface,
734
+ new Request(`${getBaseUrl(dev)}/api/invite/redeem`, {
735
+ method: "POST",
736
+ headers: {
737
+ "Content-Type": "application/json"
738
+ },
739
+ body: JSON.stringify({
740
+ code,
741
+ recipientAddr: address
742
+ })
743
+ })
744
+ );
745
+ if (result.isOk()) {
746
+ setState({
747
+ redeemedCodes: [...state.redeemedCodes ?? [], code]
748
+ });
749
+ }
750
+ return result;
751
+ };
752
+
753
+ // src/shared/neverthrow/json/index.ts
754
+ var type = "json";
755
+ var jsonErr = (surface, error) => {
756
+ return err2(type, surface, error);
757
+ };
758
+ var safeStringifyJson = (surface, value) => {
759
+ return resultFromThrowable(
760
+ type,
761
+ surface,
762
+ () => JSON.stringify(value),
763
+ () => ({
764
+ cause: "stringify",
765
+ message: "Could not stringify JSON"
766
+ })
767
+ );
768
+ };
769
+ var safeParseJson = (surface, value) => {
770
+ return resultFromThrowable(
771
+ type,
772
+ surface,
773
+ () => JSON.parse(value),
774
+ (e) => ({
775
+ cause: "parse",
776
+ message: e instanceof Error ? e.message : "Could not parse JSON"
777
+ })
778
+ );
779
+ };
780
+ var type2 = "json";
781
+ var parseErr = (surface, error) => err2(type2, surface, error);
782
+ var safeParse = (surface, schema, value) => {
783
+ const parseResult = schema.safeParse(value);
784
+ if (!parseResult.success) {
785
+ return parseErr(surface, {
786
+ cause: "invalid_data",
787
+ message: JSON.stringify(z3.treeifyError(parseResult.error), null, 2),
788
+ error: parseResult.error
789
+ });
790
+ }
791
+ return ok2(parseResult.data);
792
+ };
793
+
794
+ // src/shared/wallet.ts
795
+ var WALLET_FILE = configFile("wallet.json", "");
796
+ var storedWalletSchema = z3.object({
797
+ privateKey: z3.string().regex(/^0x[a-fA-F0-9]{64}$/, "Invalid Ethereum private key").transform((privateKey) => privateKey),
798
+ address: z3.string().regex(/^0x[a-fA-F0-9]{40}$/, "Invalid Ethereum address").transform((address) => getAddress(address)),
799
+ createdAt: z3.string()
800
+ });
801
+ var walletSurface = "wallet";
802
+ async function getWallet() {
803
+ if (process.env.X402_PRIVATE_KEY) {
804
+ const account2 = privateKeyToAccount(process.env.X402_PRIVATE_KEY);
805
+ log.info(`Using wallet from env: ${account2.address}`);
806
+ return ok2({ account: account2, isNew: false });
807
+ }
808
+ const readFileResult = await safeReadFile(walletSurface, WALLET_FILE);
809
+ if (!readFileResult.isOk()) {
810
+ const fileExistsResult = safeFileExists(walletSurface, WALLET_FILE);
811
+ if (fileExistsResult.isOk()) {
812
+ return fsErr(walletSurface, {
813
+ cause: "file_not_readable",
814
+ message: `The file exists but is not readable. Fix corrupted state file: ${WALLET_FILE}`
815
+ });
816
+ }
817
+ }
818
+ if (readFileResult.isOk()) {
819
+ const data = readFileResult.value;
820
+ const jsonParseResult = safeParseJson(walletSurface, data);
821
+ if (jsonParseResult.isErr()) {
822
+ return jsonErr(walletSurface, {
823
+ cause: "parse",
824
+ message: `The data in ${WALLET_FILE} is not valid JSON`
825
+ });
826
+ }
827
+ const parseResult = safeParse(
828
+ walletSurface,
829
+ storedWalletSchema,
830
+ jsonParseResult.value
831
+ );
832
+ if (parseResult.isErr()) {
833
+ return parseResult;
834
+ }
835
+ const account2 = privateKeyToAccount(parseResult.value.privateKey);
836
+ log.info(`Loaded wallet: ${account2.address}`);
837
+ return ok2({ account: account2, isNew: false });
838
+ }
839
+ const privateKey = generatePrivateKey();
840
+ const account = privateKeyToAccount(privateKey);
841
+ const stored = {
842
+ privateKey,
843
+ address: account.address,
844
+ createdAt: (/* @__PURE__ */ new Date()).toISOString()
845
+ };
846
+ const saveResult = await safeWriteFile(
847
+ walletSurface,
848
+ WALLET_FILE,
849
+ JSON.stringify(stored, null, 2)
850
+ ).andThen(() => safeChmod(walletSurface, WALLET_FILE, 384));
851
+ if (saveResult.isErr()) {
852
+ return saveResult;
853
+ }
854
+ log.info(`Created wallet: ${account.address}`);
855
+ log.info(`Saved to: ${WALLET_FILE}`);
856
+ return ok2({ account, isNew: true });
857
+ }
858
+ var CHAIN_CONFIGS = {
859
+ "eip155:8453": {
860
+ chain: base,
861
+ caip2: "eip155:8453",
862
+ v1Name: "base",
863
+ usdcAddress: "0x833589fCD6eDb6E08f4c7C32D4f71b54bdA02913"
864
+ },
865
+ "eip155:84532": {
866
+ chain: baseSepolia,
867
+ caip2: "eip155:84532",
868
+ v1Name: "base-sepolia",
869
+ usdcAddress: "0x036CbD53842c5426634e7929541eC2318f3dCF7e"
870
+ },
871
+ "eip155:1": {
872
+ chain: mainnet,
873
+ caip2: "eip155:1",
874
+ v1Name: "ethereum",
875
+ usdcAddress: "0xA0b86991c6218b36c1d19D4a2e9Eb0cE3606eB48"
876
+ },
877
+ "eip155:11155111": {
878
+ chain: sepolia,
879
+ caip2: "eip155:11155111",
880
+ v1Name: "ethereum-sepolia",
881
+ usdcAddress: "0x1c7D4B196Cb0C7B01d743Fbc6116a902379C7238"
882
+ },
883
+ "eip155:10": {
884
+ chain: optimism,
885
+ caip2: "eip155:10",
886
+ v1Name: "optimism",
887
+ usdcAddress: "0x0b2C639c533813f4Aa9D7837CAf62653d097Ff85"
888
+ },
889
+ "eip155:42161": {
890
+ chain: arbitrum,
891
+ caip2: "eip155:42161",
892
+ v1Name: "arbitrum",
893
+ usdcAddress: "0xaf88d065e77c8cC2239327C5EDb3A432268e5831"
894
+ },
895
+ "eip155:137": {
896
+ chain: polygon,
897
+ caip2: "eip155:137",
898
+ v1Name: "polygon",
899
+ usdcAddress: "0x3c499c542cEF5E3811e1192ce70d8cC03d5c3359"
900
+ }
901
+ };
902
+ var V1_TO_CAIP2 = {
903
+ base: "eip155:8453",
904
+ "base-sepolia": "eip155:84532",
905
+ ethereum: "eip155:1",
906
+ "ethereum-sepolia": "eip155:11155111",
907
+ optimism: "eip155:10",
908
+ arbitrum: "eip155:42161",
909
+ polygon: "eip155:137"
910
+ };
911
+ var DEFAULT_NETWORK = "eip155:8453";
912
+ function toCaip2(network) {
913
+ if (network.startsWith("eip155:")) return network;
914
+ return V1_TO_CAIP2[network.toLowerCase()] ?? network;
915
+ }
916
+ function getChainConfig(network) {
917
+ return CHAIN_CONFIGS[toCaip2(network)];
918
+ }
919
+ function getChainName(network) {
920
+ return getChainConfig(network)?.chain.name ?? network;
921
+ }
922
+
923
+ export { DEFAULT_NETWORK, err2 as err, fetchHttpErr, getBaseUrl, getChainName, getDepositLink, getWallet, isFetchError, log, ok2 as ok, openDepositLink, redeemInviteCode, resultFromPromise, resultFromThrowable, safeFetch, safeFetchJson, safeParseResponse, safeReadFile, safeStringifyJson, safeWriteFile };
924
+ //# sourceMappingURL=chunk-4ESXGYV6.js.map
925
+ //# sourceMappingURL=chunk-4ESXGYV6.js.map