moneyos 0.2.1 → 0.3.2

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.
@@ -1,570 +0,0 @@
1
- #!/usr/bin/env node
2
-
3
- // src/cli/index.ts
4
- import { Command as Command5 } from "commander";
5
-
6
- // src/cli/commands/init.ts
7
- import { Command } from "commander";
8
- import { generatePrivateKey, privateKeyToAccount } from "viem/accounts";
9
-
10
- // src/cli/config.ts
11
- import { readFileSync, writeFileSync, existsSync, mkdirSync } from "fs";
12
- import { join } from "path";
13
- import { homedir } from "os";
14
- var CONFIG_DIR = join(homedir(), ".moneyos");
15
- var CONFIG_FILE = join(CONFIG_DIR, "config.json");
16
- function loadConfig() {
17
- if (!existsSync(CONFIG_FILE)) {
18
- return {};
19
- }
20
- const raw = readFileSync(CONFIG_FILE, "utf-8");
21
- return JSON.parse(raw);
22
- }
23
- function saveConfig(config) {
24
- if (!existsSync(CONFIG_DIR)) {
25
- mkdirSync(CONFIG_DIR, { recursive: true, mode: 448 });
26
- }
27
- writeFileSync(CONFIG_FILE, JSON.stringify(config, null, 2), {
28
- mode: 384
29
- });
30
- }
31
- function getConfigPath() {
32
- return CONFIG_FILE;
33
- }
34
-
35
- // src/cli/commands/init.ts
36
- var initCommand = new Command("init").description("Initialize MoneyOS with a new or existing account").option("-k, --key <privateKey>", "Import an existing private key").option("--chain <chainId>", "Default chain ID (default: 42161 Arbitrum)").option("--rpc <url>", "Custom RPC URL").action(async (options) => {
37
- const existing = loadConfig();
38
- if (existing.privateKey && !options.key) {
39
- const account2 = privateKeyToAccount(existing.privateKey);
40
- console.log(`Already initialized.`);
41
- console.log(`Address: ${account2.address}`);
42
- console.log(`Config: ${getConfigPath()}`);
43
- console.log(`
44
- To reinitialize, run: moneyos init --key <privateKey>`);
45
- return;
46
- }
47
- const privateKey = options.key ?? generatePrivateKey();
48
- const account = privateKeyToAccount(privateKey);
49
- const config = {
50
- ...existing,
51
- privateKey,
52
- chainId: options.chain ? parseInt(options.chain) : existing.chainId ?? 42161,
53
- rpcUrl: options.rpc ?? existing.rpcUrl
54
- };
55
- saveConfig(config);
56
- console.log(`MoneyOS initialized.`);
57
- console.log(`Address: ${account.address}`);
58
- console.log(`Config: ${getConfigPath()}`);
59
- if (!options.key) {
60
- console.log(`
61
- This is a new account. Fund it before sending transactions.`);
62
- }
63
- });
64
-
65
- // src/cli/commands/balance.ts
66
- import { Command as Command2 } from "commander";
67
-
68
- // src/core/client.ts
69
- import {
70
- createPublicClient,
71
- createWalletClient,
72
- http,
73
- formatUnits,
74
- parseUnits
75
- } from "viem";
76
- import { privateKeyToAccount as privateKeyToAccount2 } from "viem/accounts";
77
- import { arbitrum, mainnet, polygon } from "viem/chains";
78
-
79
- // src/core/chains.ts
80
- var chains = {
81
- arbitrum: {
82
- id: 42161,
83
- name: "Arbitrum One",
84
- rpcUrl: "https://arb1.arbitrum.io/rpc",
85
- nativeCurrency: { name: "Ether", symbol: "ETH", decimals: 18 },
86
- blockExplorer: "https://arbiscan.io"
87
- },
88
- ethereum: {
89
- id: 1,
90
- name: "Ethereum",
91
- rpcUrl: "https://eth.public-rpc.com",
92
- nativeCurrency: { name: "Ether", symbol: "ETH", decimals: 18 },
93
- blockExplorer: "https://etherscan.io"
94
- },
95
- polygon: {
96
- id: 137,
97
- name: "Polygon",
98
- rpcUrl: "https://polygon-rpc.com",
99
- nativeCurrency: { name: "POL", symbol: "POL", decimals: 18 },
100
- blockExplorer: "https://polygonscan.com"
101
- }
102
- };
103
- var defaultChain = chains.arbitrum;
104
- function getChain(idOrName) {
105
- if (typeof idOrName === "number") {
106
- return Object.values(chains).find((c) => c.id === idOrName);
107
- }
108
- return chains[idOrName.toLowerCase()];
109
- }
110
-
111
- // src/core/tokens.ts
112
- var NATIVE_TOKEN_ADDRESS = "0xEeeeeEeeeEeEeeEeEeEeeEEEeeeeEeeeeeeeEEeE";
113
- var tokens = {
114
- ETH: {
115
- symbol: "ETH",
116
- name: "Ether",
117
- decimals: 18,
118
- addresses: {
119
- 42161: NATIVE_TOKEN_ADDRESS,
120
- 1: NATIVE_TOKEN_ADDRESS,
121
- 137: NATIVE_TOKEN_ADDRESS
122
- }
123
- },
124
- USDC: {
125
- symbol: "USDC",
126
- name: "USD Coin",
127
- decimals: 6,
128
- addresses: {
129
- 42161: "0xaf88d065e77c8cC2239327C5EDb3A432268e5831",
130
- 1: "0xA0b86991c6218b36c1d19D4a2e9Eb0cE3606eB48",
131
- 137: "0x3c499c542cEF5E3811e1192ce70d8cC03d5c3359"
132
- }
133
- },
134
- USDT: {
135
- symbol: "USDT",
136
- name: "Tether USD",
137
- decimals: 6,
138
- addresses: {
139
- 42161: "0xFd086bC7CD5C481DCC9C85ebE478A1C0b69FCbb9",
140
- 1: "0xdAC17F958D2ee523a2206206994597C13D831ec7",
141
- 137: "0xc2132D05D31c914a87C6611C10748AEb04B58e8F"
142
- }
143
- },
144
- RYZE: {
145
- symbol: "RYZE",
146
- name: "RYZE",
147
- decimals: 18,
148
- addresses: {
149
- 42161: "0x7712da72127d5dD213B621497D6E4899d5989e5C"
150
- }
151
- }
152
- };
153
- function getToken(symbol) {
154
- return tokens[symbol.toUpperCase()];
155
- }
156
- function getTokenAddress(symbol, chainId) {
157
- return getToken(symbol)?.addresses[chainId];
158
- }
159
-
160
- // src/core/client.ts
161
- var ERC20_ABI = [
162
- {
163
- name: "balanceOf",
164
- type: "function",
165
- stateMutability: "view",
166
- inputs: [{ name: "account", type: "address" }],
167
- outputs: [{ name: "", type: "uint256" }]
168
- },
169
- {
170
- name: "transfer",
171
- type: "function",
172
- stateMutability: "nonpayable",
173
- inputs: [
174
- { name: "to", type: "address" },
175
- { name: "amount", type: "uint256" }
176
- ],
177
- outputs: [{ name: "", type: "bool" }]
178
- },
179
- {
180
- name: "decimals",
181
- type: "function",
182
- stateMutability: "view",
183
- inputs: [],
184
- outputs: [{ name: "", type: "uint8" }]
185
- },
186
- {
187
- name: "symbol",
188
- type: "function",
189
- stateMutability: "view",
190
- inputs: [],
191
- outputs: [{ name: "", type: "string" }]
192
- },
193
- {
194
- name: "approve",
195
- type: "function",
196
- stateMutability: "nonpayable",
197
- inputs: [
198
- { name: "spender", type: "address" },
199
- { name: "amount", type: "uint256" }
200
- ],
201
- outputs: [{ name: "", type: "bool" }]
202
- },
203
- {
204
- name: "allowance",
205
- type: "function",
206
- stateMutability: "view",
207
- inputs: [
208
- { name: "owner", type: "address" },
209
- { name: "spender", type: "address" }
210
- ],
211
- outputs: [{ name: "", type: "uint256" }]
212
- }
213
- ];
214
- var viemChains = {
215
- 42161: arbitrum,
216
- 1: mainnet,
217
- 137: polygon
218
- };
219
- var MoneyOS = class {
220
- config;
221
- publicClients = /* @__PURE__ */ new Map();
222
- walletClient;
223
- constructor(config) {
224
- this.config = {
225
- ...config,
226
- chainId: config.chainId ?? defaultChain.id
227
- };
228
- }
229
- getPublicClient(chainId) {
230
- const id = chainId ?? this.config.chainId;
231
- let client = this.publicClients.get(id);
232
- if (!client) {
233
- const chain = viemChains[id];
234
- const chainInfo = getChain(id);
235
- const rpcUrl = id === this.config.chainId ? this.config.rpcUrl : void 0;
236
- client = createPublicClient({
237
- chain,
238
- transport: http(rpcUrl ?? chainInfo?.rpcUrl)
239
- });
240
- this.publicClients.set(id, client);
241
- }
242
- return client;
243
- }
244
- getWalletClient() {
245
- if (!this.walletClient) {
246
- if (!this.config.privateKey) {
247
- throw new Error(
248
- "No private key configured. Set privateKey in MoneyOS config."
249
- );
250
- }
251
- const account = privateKeyToAccount2(this.config.privateKey);
252
- const chain = viemChains[this.config.chainId];
253
- const chainInfo = getChain(this.config.chainId);
254
- this.walletClient = createWalletClient({
255
- account,
256
- chain,
257
- transport: http(this.config.rpcUrl ?? chainInfo?.rpcUrl)
258
- });
259
- }
260
- return this.walletClient;
261
- }
262
- get address() {
263
- if (!this.config.privateKey) {
264
- throw new Error("No private key configured.");
265
- }
266
- return privateKeyToAccount2(this.config.privateKey).address;
267
- }
268
- async balance(token, options) {
269
- const chainId = options?.chainId ?? this.config.chainId;
270
- const account = options?.address ?? this.address;
271
- const client = this.getPublicClient(chainId);
272
- if (token.toUpperCase() === "ETH") {
273
- const raw2 = await client.getBalance({ address: account });
274
- return {
275
- token: "ETH",
276
- symbol: "ETH",
277
- amount: formatUnits(raw2, 18),
278
- rawAmount: raw2,
279
- decimals: 18,
280
- chainId
281
- };
282
- }
283
- const tokenAddress = getTokenAddress(token, chainId);
284
- if (!tokenAddress) {
285
- throw new Error(`Token ${token} not found on chain ${chainId}`);
286
- }
287
- const tokenInfo = getToken(token);
288
- const raw = await client.readContract({
289
- address: tokenAddress,
290
- abi: ERC20_ABI,
291
- functionName: "balanceOf",
292
- args: [account]
293
- });
294
- return {
295
- token: tokenInfo.name,
296
- symbol: tokenInfo.symbol,
297
- amount: formatUnits(raw, tokenInfo.decimals),
298
- rawAmount: raw,
299
- decimals: tokenInfo.decimals,
300
- chainId
301
- };
302
- }
303
- async send(token, to, amount, options) {
304
- const chainId = options?.chainId ?? this.config.chainId;
305
- const walletClient = this.getWalletClient();
306
- const from = this.address;
307
- if (token.toUpperCase() === "ETH") {
308
- const value2 = parseUnits(amount, 18);
309
- const account = privateKeyToAccount2(this.config.privateKey);
310
- const hash2 = await walletClient.sendTransaction({
311
- account,
312
- to,
313
- value: value2,
314
- chain: viemChains[chainId]
315
- });
316
- return { hash: hash2, from, to, amount, token: "ETH", chainId };
317
- }
318
- const tokenAddress = getTokenAddress(token, chainId);
319
- if (!tokenAddress) {
320
- throw new Error(`Token ${token} not found on chain ${chainId}`);
321
- }
322
- const tokenInfo = getToken(token);
323
- const value = parseUnits(amount, tokenInfo.decimals);
324
- const client = this.getPublicClient(chainId);
325
- const { request } = await client.simulateContract({
326
- address: tokenAddress,
327
- abi: ERC20_ABI,
328
- functionName: "transfer",
329
- args: [to, value],
330
- account: privateKeyToAccount2(this.config.privateKey)
331
- });
332
- const hash = await walletClient.writeContract(request);
333
- return { hash, from, to, amount, token: tokenInfo.symbol, chainId };
334
- }
335
- async swap(tokenIn, tokenOut, amount, provider, options) {
336
- const chainId = options?.chainId ?? this.config.chainId;
337
- const walletClient = this.getWalletClient();
338
- const client = this.getPublicClient(chainId);
339
- const sender = this.address;
340
- const tokenInAddress = getTokenAddress(tokenIn, chainId);
341
- const tokenOutAddress = getTokenAddress(tokenOut, chainId);
342
- if (!tokenInAddress) {
343
- throw new Error(`Token ${tokenIn} not found on chain ${chainId}`);
344
- }
345
- if (!tokenOutAddress) {
346
- throw new Error(`Token ${tokenOut} not found on chain ${chainId}`);
347
- }
348
- const tokenInInfo = getToken(tokenIn);
349
- const amountWei = parseUnits(amount, tokenInInfo.decimals);
350
- const quote = await provider.getQuote({
351
- chainId,
352
- tokenIn: tokenInAddress,
353
- tokenOut: tokenOutAddress,
354
- amount: amountWei,
355
- sender,
356
- slippage: options?.slippage
357
- });
358
- const calldata = await provider.getCalldata(quote);
359
- const isNativeIn = tokenInAddress === NATIVE_TOKEN_ADDRESS;
360
- if (!isNativeIn) {
361
- const currentAllowance = await client.readContract({
362
- address: tokenInAddress,
363
- abi: ERC20_ABI,
364
- functionName: "allowance",
365
- args: [sender, calldata.to]
366
- });
367
- if (currentAllowance < amountWei) {
368
- const account2 = privateKeyToAccount2(this.config.privateKey);
369
- const { request: approveRequest } = await client.simulateContract({
370
- address: tokenInAddress,
371
- abi: ERC20_ABI,
372
- functionName: "approve",
373
- args: [calldata.to, amountWei],
374
- account: account2
375
- });
376
- await walletClient.writeContract(approveRequest);
377
- }
378
- }
379
- const account = privateKeyToAccount2(this.config.privateKey);
380
- const hash = await walletClient.sendTransaction({
381
- account,
382
- to: calldata.to,
383
- data: calldata.data,
384
- value: isNativeIn ? amountWei : calldata.value,
385
- chain: viemChains[chainId]
386
- });
387
- const tokenOutInfo = getToken(tokenOut);
388
- return {
389
- hash,
390
- tokenIn: tokenInInfo.symbol,
391
- tokenOut: tokenOutInfo.symbol,
392
- amountIn: amount,
393
- amountOut: formatUnits(BigInt(quote.expectedOut), tokenOutInfo.decimals),
394
- chainId
395
- };
396
- }
397
- };
398
-
399
- // src/cli/commands/balance.ts
400
- var balanceCommand = new Command2("balance").description("Check token balance").argument("<token>", "Token symbol (e.g. USDC, ETH, RYZE)").option("-a, --address <address>", "Address to check (defaults to your own)").option("-c, --chain <chainId>", "Chain ID (default: 42161 Arbitrum)").action(async (token, options) => {
401
- const config = loadConfig();
402
- const chainId = options.chain ? parseInt(options.chain) : config.chainId;
403
- const moneyos = new MoneyOS({
404
- chainId: chainId ?? 42161,
405
- rpcUrl: config.rpcUrl,
406
- privateKey: options.address ? void 0 : config.privateKey
407
- });
408
- const address = options.address;
409
- const result = await moneyos.balance(token, {
410
- address,
411
- chainId
412
- });
413
- console.log(`${result.amount} ${result.symbol}`);
414
- });
415
-
416
- // src/cli/commands/send.ts
417
- import { Command as Command3 } from "commander";
418
- var sendCommand = new Command3("send").description("Send tokens to an address").argument("<amount>", "Amount to send (e.g. 10)").argument("<token>", "Token symbol (e.g. USDC, ETH, RYZE)").argument("<to>", "Recipient address").option("-c, --chain <chainId>", "Chain ID (default: 42161 Arbitrum)").action(async (amount, token, to, options) => {
419
- const config = loadConfig();
420
- if (!config.privateKey) {
421
- console.error(
422
- "No private key configured. Run: moneyos init"
423
- );
424
- process.exit(1);
425
- }
426
- const chainId = options.chain ? parseInt(options.chain) : config.chainId ?? 42161;
427
- const moneyos = new MoneyOS({
428
- chainId,
429
- rpcUrl: config.rpcUrl,
430
- privateKey: config.privateKey
431
- });
432
- const chain = getChain(chainId);
433
- console.log(
434
- `Sending ${amount} ${token.toUpperCase()} to ${to} on ${chain?.name ?? chainId}...`
435
- );
436
- const result = await moneyos.send(token, to, amount, {
437
- chainId
438
- });
439
- console.log(`Sent. tx: ${result.hash}`);
440
- });
441
-
442
- // src/cli/commands/swap.ts
443
- import { Command as Command4 } from "commander";
444
-
445
- // src/providers/odos.ts
446
- var ODOS_API = "https://api.odos.xyz";
447
- var ODOS_NATIVE_ADDRESS = "0x0000000000000000000000000000000000000000";
448
- var OdosProvider = class {
449
- name = "odos";
450
- apiKey;
451
- constructor(options) {
452
- this.apiKey = options?.apiKey;
453
- }
454
- toOdosAddress(address) {
455
- return address === NATIVE_TOKEN_ADDRESS ? ODOS_NATIVE_ADDRESS : address;
456
- }
457
- async getQuote(params) {
458
- const headers = {
459
- "Content-Type": "application/json"
460
- };
461
- if (this.apiKey) {
462
- headers["Authorization"] = `Bearer ${this.apiKey}`;
463
- }
464
- const response = await fetch(`${ODOS_API}/sor/quote/v2`, {
465
- method: "POST",
466
- headers,
467
- body: JSON.stringify({
468
- chainId: params.chainId,
469
- inputTokens: [
470
- {
471
- tokenAddress: this.toOdosAddress(params.tokenIn),
472
- amount: params.amount.toString()
473
- }
474
- ],
475
- outputTokens: [
476
- {
477
- tokenAddress: this.toOdosAddress(params.tokenOut),
478
- proportion: 1
479
- }
480
- ],
481
- userAddr: params.sender,
482
- slippageLimitPercent: params.slippage ?? 1,
483
- referralCode: 0,
484
- compact: true
485
- })
486
- });
487
- if (!response.ok) {
488
- const text = await response.text();
489
- throw new Error(`Odos quote failed: ${response.status} ${text}`);
490
- }
491
- const data = await response.json();
492
- return {
493
- tokenIn: params.tokenIn,
494
- tokenOut: params.tokenOut,
495
- amountIn: params.amount.toString(),
496
- expectedOut: data.outAmounts[0],
497
- router: "",
498
- chainId: params.chainId,
499
- pathId: data.pathId,
500
- sender: params.sender
501
- };
502
- }
503
- async getCalldata(quote) {
504
- const headers = {
505
- "Content-Type": "application/json"
506
- };
507
- if (this.apiKey) {
508
- headers["Authorization"] = `Bearer ${this.apiKey}`;
509
- }
510
- const response = await fetch(`${ODOS_API}/sor/assemble`, {
511
- method: "POST",
512
- headers,
513
- body: JSON.stringify({
514
- userAddr: quote.sender,
515
- pathId: quote.pathId,
516
- simulate: false
517
- })
518
- });
519
- if (!response.ok) {
520
- const text = await response.text();
521
- throw new Error(`Odos assemble failed: ${response.status} ${text}`);
522
- }
523
- const data = await response.json();
524
- return {
525
- to: data.transaction.to,
526
- data: data.transaction.data,
527
- value: BigInt(data.transaction.value)
528
- };
529
- }
530
- };
531
-
532
- // src/cli/commands/swap.ts
533
- var swapCommand = new Command4("swap").description("Swap tokens").argument("<amount>", "Amount to swap (e.g. 100)").argument("<tokenIn>", "Token to sell (e.g. USDC)").argument("<tokenOut>", "Token to buy (e.g. RYZE)").option("-c, --chain <chainId>", "Chain ID (default: 42161 Arbitrum)").option("-s, --slippage <percent>", "Slippage tolerance in percent (default: 1)").action(async (amount, tokenIn, tokenOut, options) => {
534
- const config = loadConfig();
535
- if (!config.privateKey) {
536
- console.error("No private key configured. Run: moneyos init");
537
- process.exit(1);
538
- }
539
- const chainId = options.chain ? parseInt(options.chain) : config.chainId ?? 42161;
540
- const moneyos = new MoneyOS({
541
- chainId,
542
- rpcUrl: config.rpcUrl,
543
- privateKey: config.privateKey
544
- });
545
- const provider = new OdosProvider();
546
- const chain = getChain(chainId);
547
- const slippage = options.slippage ? parseFloat(options.slippage) : void 0;
548
- console.log(
549
- `Swapping ${amount} ${tokenIn.toUpperCase()} \u2192 ${tokenOut.toUpperCase()} on ${chain?.name ?? chainId}...`
550
- );
551
- const result = await moneyos.swap(tokenIn, tokenOut, amount, provider, {
552
- chainId,
553
- slippage
554
- });
555
- console.log(`Swapped. Expected: ~${result.amountOut} ${result.tokenOut}`);
556
- console.log(`tx: ${result.hash}`);
557
- });
558
-
559
- // src/cli/version.ts
560
- var version = "0.2.1";
561
-
562
- // src/cli/index.ts
563
- var program = new Command5();
564
- program.name("moneyos").description("The operating system for money").version(version);
565
- program.addCommand(initCommand);
566
- program.addCommand(balanceCommand);
567
- program.addCommand(sendCommand);
568
- program.addCommand(swapCommand);
569
- program.parse();
570
- //# sourceMappingURL=index.mjs.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../../src/cli/index.ts","../../src/cli/commands/init.ts","../../src/cli/config.ts","../../src/cli/commands/balance.ts","../../src/core/client.ts","../../src/core/chains.ts","../../src/core/tokens.ts","../../src/cli/commands/send.ts","../../src/cli/commands/swap.ts","../../src/providers/odos.ts","../../src/cli/version.ts"],"sourcesContent":["import { Command } from \"commander\";\nimport { initCommand } from \"./commands/init.js\";\nimport { balanceCommand } from \"./commands/balance.js\";\nimport { sendCommand } from \"./commands/send.js\";\nimport { swapCommand } from \"./commands/swap.js\";\nimport { version } from \"./version.js\";\n\nconst program = new Command();\n\nprogram\n .name(\"moneyos\")\n .description(\"The operating system for money\")\n .version(version);\n\nprogram.addCommand(initCommand);\nprogram.addCommand(balanceCommand);\nprogram.addCommand(sendCommand);\nprogram.addCommand(swapCommand);\n\nprogram.parse();\n","import { Command } from \"commander\";\nimport { generatePrivateKey, privateKeyToAccount } from \"viem/accounts\";\nimport { loadConfig, saveConfig, getConfigPath } from \"../config.js\";\n\nexport const initCommand = new Command(\"init\")\n .description(\"Initialize MoneyOS with a new or existing account\")\n .option(\"-k, --key <privateKey>\", \"Import an existing private key\")\n .option(\"--chain <chainId>\", \"Default chain ID (default: 42161 Arbitrum)\")\n .option(\"--rpc <url>\", \"Custom RPC URL\")\n .action(async (options) => {\n const existing = loadConfig();\n\n if (existing.privateKey && !options.key) {\n const account = privateKeyToAccount(existing.privateKey);\n console.log(`Already initialized.`);\n console.log(`Address: ${account.address}`);\n console.log(`Config: ${getConfigPath()}`);\n console.log(`\\nTo reinitialize, run: moneyos init --key <privateKey>`);\n return;\n }\n\n const privateKey = options.key ?? generatePrivateKey();\n const account = privateKeyToAccount(privateKey);\n\n const config = {\n ...existing,\n privateKey,\n chainId: options.chain ? parseInt(options.chain) : existing.chainId ?? 42161,\n rpcUrl: options.rpc ?? existing.rpcUrl,\n };\n\n saveConfig(config);\n\n console.log(`MoneyOS initialized.`);\n console.log(`Address: ${account.address}`);\n console.log(`Config: ${getConfigPath()}`);\n\n if (!options.key) {\n console.log(`\\nThis is a new account. Fund it before sending transactions.`);\n }\n });\n","import { readFileSync, writeFileSync, existsSync, mkdirSync } from \"node:fs\";\nimport { join } from \"node:path\";\nimport { homedir } from \"node:os\";\nimport type { Hex } from \"viem\";\n\nconst CONFIG_DIR = join(homedir(), \".moneyos\");\nconst CONFIG_FILE = join(CONFIG_DIR, \"config.json\");\n\nexport interface CLIConfig {\n chainId?: number;\n rpcUrl?: string;\n privateKey?: Hex;\n}\n\nexport function loadConfig(): CLIConfig {\n if (!existsSync(CONFIG_FILE)) {\n return {};\n }\n const raw = readFileSync(CONFIG_FILE, \"utf-8\");\n return JSON.parse(raw) as CLIConfig;\n}\n\nexport function saveConfig(config: CLIConfig): void {\n if (!existsSync(CONFIG_DIR)) {\n mkdirSync(CONFIG_DIR, { recursive: true, mode: 0o700 });\n }\n writeFileSync(CONFIG_FILE, JSON.stringify(config, null, 2), {\n mode: 0o600,\n });\n}\n\nexport function getConfigPath(): string {\n return CONFIG_FILE;\n}\n","import { Command } from \"commander\";\nimport { MoneyOS } from \"../../core/client.js\";\nimport { loadConfig } from \"../config.js\";\nimport type { Address } from \"viem\";\n\nexport const balanceCommand = new Command(\"balance\")\n .description(\"Check token balance\")\n .argument(\"<token>\", \"Token symbol (e.g. USDC, ETH, RYZE)\")\n .option(\"-a, --address <address>\", \"Address to check (defaults to your own)\")\n .option(\"-c, --chain <chainId>\", \"Chain ID (default: 42161 Arbitrum)\")\n .action(async (token: string, options) => {\n const config = loadConfig();\n const chainId = options.chain ? parseInt(options.chain) : config.chainId;\n\n const moneyos = new MoneyOS({\n chainId: chainId ?? 42161,\n rpcUrl: config.rpcUrl,\n privateKey: options.address ? undefined : config.privateKey,\n });\n\n const address = options.address as Address | undefined;\n const result = await moneyos.balance(token, {\n address,\n chainId,\n });\n\n console.log(`${result.amount} ${result.symbol}`);\n });\n","import {\n createPublicClient,\n createWalletClient,\n http,\n formatUnits,\n parseUnits,\n type Address,\n type Chain as ViemChain,\n type Hex,\n type PublicClient,\n type WalletClient,\n} from \"viem\";\nimport { privateKeyToAccount } from \"viem/accounts\";\nimport { arbitrum, mainnet, polygon } from \"viem/chains\";\nimport type {\n MoneyOSConfig,\n Balance,\n SendResult,\n SwapProvider,\n SwapResult,\n} from \"./types.js\";\nimport { getChain, defaultChain } from \"./chains.js\";\nimport { getToken, getTokenAddress, NATIVE_TOKEN_ADDRESS } from \"./tokens.js\";\n\nconst ERC20_ABI = [\n {\n name: \"balanceOf\",\n type: \"function\",\n stateMutability: \"view\",\n inputs: [{ name: \"account\", type: \"address\" }],\n outputs: [{ name: \"\", type: \"uint256\" }],\n },\n {\n name: \"transfer\",\n type: \"function\",\n stateMutability: \"nonpayable\",\n inputs: [\n { name: \"to\", type: \"address\" },\n { name: \"amount\", type: \"uint256\" },\n ],\n outputs: [{ name: \"\", type: \"bool\" }],\n },\n {\n name: \"decimals\",\n type: \"function\",\n stateMutability: \"view\",\n inputs: [],\n outputs: [{ name: \"\", type: \"uint8\" }],\n },\n {\n name: \"symbol\",\n type: \"function\",\n stateMutability: \"view\",\n inputs: [],\n outputs: [{ name: \"\", type: \"string\" }],\n },\n {\n name: \"approve\",\n type: \"function\",\n stateMutability: \"nonpayable\",\n inputs: [\n { name: \"spender\", type: \"address\" },\n { name: \"amount\", type: \"uint256\" },\n ],\n outputs: [{ name: \"\", type: \"bool\" }],\n },\n {\n name: \"allowance\",\n type: \"function\",\n stateMutability: \"view\",\n inputs: [\n { name: \"owner\", type: \"address\" },\n { name: \"spender\", type: \"address\" },\n ],\n outputs: [{ name: \"\", type: \"uint256\" }],\n },\n] as const;\n\nconst viemChains: Record<number, ViemChain> = {\n 42161: arbitrum,\n 1: mainnet,\n 137: polygon,\n};\n\nexport class MoneyOS {\n private config: MoneyOSConfig;\n private publicClients: Map<number, PublicClient> = new Map();\n private walletClient: WalletClient | undefined;\n\n constructor(config: MoneyOSConfig) {\n this.config = {\n ...config,\n chainId: config.chainId ?? defaultChain.id,\n };\n }\n\n private getPublicClient(chainId?: number): PublicClient {\n const id = chainId ?? this.config.chainId;\n let client = this.publicClients.get(id);\n if (!client) {\n const chain = viemChains[id];\n const chainInfo = getChain(id);\n const rpcUrl =\n id === this.config.chainId ? this.config.rpcUrl : undefined;\n\n client = createPublicClient({\n chain,\n transport: http(rpcUrl ?? chainInfo?.rpcUrl),\n });\n this.publicClients.set(id, client);\n }\n return client;\n }\n\n private getWalletClient(): WalletClient {\n if (!this.walletClient) {\n if (!this.config.privateKey) {\n throw new Error(\n \"No private key configured. Set privateKey in MoneyOS config.\",\n );\n }\n const account = privateKeyToAccount(this.config.privateKey);\n const chain = viemChains[this.config.chainId];\n const chainInfo = getChain(this.config.chainId);\n this.walletClient = createWalletClient({\n account,\n chain,\n transport: http(this.config.rpcUrl ?? chainInfo?.rpcUrl),\n });\n }\n return this.walletClient;\n }\n\n get address(): Address {\n if (!this.config.privateKey) {\n throw new Error(\"No private key configured.\");\n }\n return privateKeyToAccount(this.config.privateKey).address;\n }\n\n async balance(\n token: string,\n options?: { address?: Address; chainId?: number },\n ): Promise<Balance> {\n const chainId = options?.chainId ?? this.config.chainId;\n const account = options?.address ?? this.address;\n const client = this.getPublicClient(chainId);\n\n if (token.toUpperCase() === \"ETH\") {\n const raw = await client.getBalance({ address: account });\n return {\n token: \"ETH\",\n symbol: \"ETH\",\n amount: formatUnits(raw, 18),\n rawAmount: raw,\n decimals: 18,\n chainId,\n };\n }\n\n const tokenAddress = getTokenAddress(token, chainId);\n if (!tokenAddress) {\n throw new Error(`Token ${token} not found on chain ${chainId}`);\n }\n\n const tokenInfo = getToken(token)!;\n const raw = await client.readContract({\n address: tokenAddress,\n abi: ERC20_ABI,\n functionName: \"balanceOf\",\n args: [account],\n });\n\n return {\n token: tokenInfo.name,\n symbol: tokenInfo.symbol,\n amount: formatUnits(raw, tokenInfo.decimals),\n rawAmount: raw,\n decimals: tokenInfo.decimals,\n chainId,\n };\n }\n\n async send(\n token: string,\n to: Address,\n amount: string,\n options?: { chainId?: number },\n ): Promise<SendResult> {\n const chainId = options?.chainId ?? this.config.chainId;\n const walletClient = this.getWalletClient();\n const from = this.address;\n\n if (token.toUpperCase() === \"ETH\") {\n const value = parseUnits(amount, 18);\n const account = privateKeyToAccount(this.config.privateKey!);\n const hash = await walletClient.sendTransaction({\n account,\n to,\n value,\n chain: viemChains[chainId],\n });\n return { hash, from, to, amount, token: \"ETH\", chainId };\n }\n\n const tokenAddress = getTokenAddress(token, chainId);\n if (!tokenAddress) {\n throw new Error(`Token ${token} not found on chain ${chainId}`);\n }\n\n const tokenInfo = getToken(token)!;\n const value = parseUnits(amount, tokenInfo.decimals);\n const client = this.getPublicClient(chainId);\n\n const { request } = await client.simulateContract({\n address: tokenAddress,\n abi: ERC20_ABI,\n functionName: \"transfer\",\n args: [to, value],\n account: privateKeyToAccount(this.config.privateKey!),\n });\n\n const hash = await walletClient.writeContract(request);\n return { hash, from, to, amount, token: tokenInfo.symbol, chainId };\n }\n\n async swap(\n tokenIn: string,\n tokenOut: string,\n amount: string,\n provider: SwapProvider,\n options?: { chainId?: number; slippage?: number },\n ): Promise<SwapResult> {\n const chainId = options?.chainId ?? this.config.chainId;\n const walletClient = this.getWalletClient();\n const client = this.getPublicClient(chainId);\n const sender = this.address;\n\n const tokenInAddress = getTokenAddress(tokenIn, chainId);\n const tokenOutAddress = getTokenAddress(tokenOut, chainId);\n if (!tokenInAddress) {\n throw new Error(`Token ${tokenIn} not found on chain ${chainId}`);\n }\n if (!tokenOutAddress) {\n throw new Error(`Token ${tokenOut} not found on chain ${chainId}`);\n }\n\n const tokenInInfo = getToken(tokenIn)!;\n const amountWei = parseUnits(amount, tokenInInfo.decimals);\n\n const quote = await provider.getQuote({\n chainId,\n tokenIn: tokenInAddress,\n tokenOut: tokenOutAddress,\n amount: amountWei,\n sender,\n slippage: options?.slippage,\n });\n\n const calldata = await provider.getCalldata(quote);\n\n const isNativeIn = tokenInAddress === NATIVE_TOKEN_ADDRESS;\n\n if (!isNativeIn) {\n const currentAllowance = await client.readContract({\n address: tokenInAddress,\n abi: ERC20_ABI,\n functionName: \"allowance\",\n args: [sender, calldata.to],\n });\n\n if (currentAllowance < amountWei) {\n const account = privateKeyToAccount(this.config.privateKey!);\n const { request: approveRequest } = await client.simulateContract({\n address: tokenInAddress,\n abi: ERC20_ABI,\n functionName: \"approve\",\n args: [calldata.to, amountWei],\n account,\n });\n await walletClient.writeContract(approveRequest);\n }\n }\n\n const account = privateKeyToAccount(this.config.privateKey!);\n const hash = await walletClient.sendTransaction({\n account,\n to: calldata.to,\n data: calldata.data,\n value: isNativeIn ? amountWei : calldata.value,\n chain: viemChains[chainId],\n });\n\n const tokenOutInfo = getToken(tokenOut)!;\n return {\n hash,\n tokenIn: tokenInInfo.symbol,\n tokenOut: tokenOutInfo.symbol,\n amountIn: amount,\n amountOut: formatUnits(BigInt(quote.expectedOut), tokenOutInfo.decimals),\n chainId,\n };\n }\n}\n","import type { Chain } from \"./types.js\";\n\nexport const chains: Record<string, Chain> = {\n arbitrum: {\n id: 42161,\n name: \"Arbitrum One\",\n rpcUrl: \"https://arb1.arbitrum.io/rpc\",\n nativeCurrency: { name: \"Ether\", symbol: \"ETH\", decimals: 18 },\n blockExplorer: \"https://arbiscan.io\",\n },\n ethereum: {\n id: 1,\n name: \"Ethereum\",\n rpcUrl: \"https://eth.public-rpc.com\",\n nativeCurrency: { name: \"Ether\", symbol: \"ETH\", decimals: 18 },\n blockExplorer: \"https://etherscan.io\",\n },\n polygon: {\n id: 137,\n name: \"Polygon\",\n rpcUrl: \"https://polygon-rpc.com\",\n nativeCurrency: { name: \"POL\", symbol: \"POL\", decimals: 18 },\n blockExplorer: \"https://polygonscan.com\",\n },\n};\n\nexport const defaultChain = chains.arbitrum;\n\nexport function getChain(idOrName: number | string): Chain | undefined {\n if (typeof idOrName === \"number\") {\n return Object.values(chains).find((c) => c.id === idOrName);\n }\n return chains[idOrName.toLowerCase()];\n}\n","import type { Address } from \"viem\";\n\nexport interface Token {\n symbol: string;\n name: string;\n decimals: number;\n addresses: Record<number, Address>;\n}\n\nexport const NATIVE_TOKEN_ADDRESS =\n \"0xEeeeeEeeeEeEeeEeEeEeeEEEeeeeEeeeeeeeEEeE\" as Address;\n\nexport const tokens: Record<string, Token> = {\n ETH: {\n symbol: \"ETH\",\n name: \"Ether\",\n decimals: 18,\n addresses: {\n 42161: NATIVE_TOKEN_ADDRESS,\n 1: NATIVE_TOKEN_ADDRESS,\n 137: NATIVE_TOKEN_ADDRESS,\n },\n },\n USDC: {\n symbol: \"USDC\",\n name: \"USD Coin\",\n decimals: 6,\n addresses: {\n 42161: \"0xaf88d065e77c8cC2239327C5EDb3A432268e5831\",\n 1: \"0xA0b86991c6218b36c1d19D4a2e9Eb0cE3606eB48\",\n 137: \"0x3c499c542cEF5E3811e1192ce70d8cC03d5c3359\",\n },\n },\n USDT: {\n symbol: \"USDT\",\n name: \"Tether USD\",\n decimals: 6,\n addresses: {\n 42161: \"0xFd086bC7CD5C481DCC9C85ebE478A1C0b69FCbb9\",\n 1: \"0xdAC17F958D2ee523a2206206994597C13D831ec7\",\n 137: \"0xc2132D05D31c914a87C6611C10748AEb04B58e8F\",\n },\n },\n RYZE: {\n symbol: \"RYZE\",\n name: \"RYZE\",\n decimals: 18,\n addresses: {\n 42161: \"0x7712da72127d5dD213B621497D6E4899d5989e5C\",\n },\n },\n};\n\nexport function getToken(symbol: string): Token | undefined {\n return tokens[symbol.toUpperCase()];\n}\n\nexport function getTokenAddress(\n symbol: string,\n chainId: number,\n): Address | undefined {\n return getToken(symbol)?.addresses[chainId];\n}\n","import { Command } from \"commander\";\nimport { MoneyOS } from \"../../core/client.js\";\nimport { loadConfig } from \"../config.js\";\nimport { getChain } from \"../../core/chains.js\";\nimport type { Address } from \"viem\";\n\nexport const sendCommand = new Command(\"send\")\n .description(\"Send tokens to an address\")\n .argument(\"<amount>\", \"Amount to send (e.g. 10)\")\n .argument(\"<token>\", \"Token symbol (e.g. USDC, ETH, RYZE)\")\n .argument(\"<to>\", \"Recipient address\")\n .option(\"-c, --chain <chainId>\", \"Chain ID (default: 42161 Arbitrum)\")\n .action(async (amount: string, token: string, to: string, options) => {\n const config = loadConfig();\n\n if (!config.privateKey) {\n console.error(\n \"No private key configured. Run: moneyos init\",\n );\n process.exit(1);\n }\n\n const chainId = options.chain\n ? parseInt(options.chain)\n : config.chainId ?? 42161;\n\n const moneyos = new MoneyOS({\n chainId,\n rpcUrl: config.rpcUrl,\n privateKey: config.privateKey,\n });\n\n const chain = getChain(chainId);\n console.log(\n `Sending ${amount} ${token.toUpperCase()} to ${to} on ${chain?.name ?? chainId}...`,\n );\n\n const result = await moneyos.send(token, to as Address, amount, {\n chainId,\n });\n\n console.log(`Sent. tx: ${result.hash}`);\n });\n","import { Command } from \"commander\";\nimport { MoneyOS } from \"../../core/client.js\";\nimport { OdosProvider } from \"../../providers/odos.js\";\nimport { loadConfig } from \"../config.js\";\nimport { getChain } from \"../../core/chains.js\";\n\nexport const swapCommand = new Command(\"swap\")\n .description(\"Swap tokens\")\n .argument(\"<amount>\", \"Amount to swap (e.g. 100)\")\n .argument(\"<tokenIn>\", \"Token to sell (e.g. USDC)\")\n .argument(\"<tokenOut>\", \"Token to buy (e.g. RYZE)\")\n .option(\"-c, --chain <chainId>\", \"Chain ID (default: 42161 Arbitrum)\")\n .option(\"-s, --slippage <percent>\", \"Slippage tolerance in percent (default: 1)\")\n .action(async (amount: string, tokenIn: string, tokenOut: string, options) => {\n const config = loadConfig();\n\n if (!config.privateKey) {\n console.error(\"No private key configured. Run: moneyos init\");\n process.exit(1);\n }\n\n const chainId = options.chain\n ? parseInt(options.chain)\n : config.chainId ?? 42161;\n\n const moneyos = new MoneyOS({\n chainId,\n rpcUrl: config.rpcUrl,\n privateKey: config.privateKey,\n });\n\n const provider = new OdosProvider();\n const chain = getChain(chainId);\n const slippage = options.slippage ? parseFloat(options.slippage) : undefined;\n\n console.log(\n `Swapping ${amount} ${tokenIn.toUpperCase()} \\u2192 ${tokenOut.toUpperCase()} on ${chain?.name ?? chainId}...`,\n );\n\n const result = await moneyos.swap(tokenIn, tokenOut, amount, provider, {\n chainId,\n slippage,\n });\n\n console.log(`Swapped. Expected: ~${result.amountOut} ${result.tokenOut}`);\n console.log(`tx: ${result.hash}`);\n });\n","import type { Address, Hex } from \"viem\";\nimport type { SwapProvider, SwapQuote } from \"../core/types.js\";\nimport { NATIVE_TOKEN_ADDRESS } from \"../core/tokens.js\";\n\nconst ODOS_API = \"https://api.odos.xyz\";\nconst ODOS_NATIVE_ADDRESS = \"0x0000000000000000000000000000000000000000\" as Address;\n\ninterface OdosQuoteResponse {\n pathId: string;\n outAmounts: string[];\n outValues: number[];\n}\n\ninterface OdosAssembleResponse {\n transaction: {\n to: string;\n data: string;\n value: string;\n };\n}\n\nexport class OdosProvider implements SwapProvider {\n name = \"odos\";\n private apiKey?: string;\n\n constructor(options?: { apiKey?: string }) {\n this.apiKey = options?.apiKey;\n }\n\n private toOdosAddress(address: Address): Address {\n return address === NATIVE_TOKEN_ADDRESS ? ODOS_NATIVE_ADDRESS : address;\n }\n\n async getQuote(params: {\n chainId: number;\n tokenIn: Address;\n tokenOut: Address;\n amount: bigint;\n sender: Address;\n slippage?: number;\n }): Promise<SwapQuote & { pathId: string; sender: Address }> {\n const headers: Record<string, string> = {\n \"Content-Type\": \"application/json\",\n };\n if (this.apiKey) {\n headers[\"Authorization\"] = `Bearer ${this.apiKey}`;\n }\n\n const response = await fetch(`${ODOS_API}/sor/quote/v2`, {\n method: \"POST\",\n headers,\n body: JSON.stringify({\n chainId: params.chainId,\n inputTokens: [\n {\n tokenAddress: this.toOdosAddress(params.tokenIn),\n amount: params.amount.toString(),\n },\n ],\n outputTokens: [\n {\n tokenAddress: this.toOdosAddress(params.tokenOut),\n proportion: 1,\n },\n ],\n userAddr: params.sender,\n slippageLimitPercent: params.slippage ?? 1,\n referralCode: 0,\n compact: true,\n }),\n });\n\n if (!response.ok) {\n const text = await response.text();\n throw new Error(`Odos quote failed: ${response.status} ${text}`);\n }\n\n const data = (await response.json()) as OdosQuoteResponse;\n\n return {\n tokenIn: params.tokenIn,\n tokenOut: params.tokenOut,\n amountIn: params.amount.toString(),\n expectedOut: data.outAmounts[0],\n router: \"\" as Address,\n chainId: params.chainId,\n pathId: data.pathId,\n sender: params.sender,\n };\n }\n\n async getCalldata(\n quote: SwapQuote & { pathId: string; sender: Address },\n ): Promise<{ to: Address; data: Hex; value: bigint }> {\n const headers: Record<string, string> = {\n \"Content-Type\": \"application/json\",\n };\n if (this.apiKey) {\n headers[\"Authorization\"] = `Bearer ${this.apiKey}`;\n }\n\n const response = await fetch(`${ODOS_API}/sor/assemble`, {\n method: \"POST\",\n headers,\n body: JSON.stringify({\n userAddr: quote.sender,\n pathId: quote.pathId,\n simulate: false,\n }),\n });\n\n if (!response.ok) {\n const text = await response.text();\n throw new Error(`Odos assemble failed: ${response.status} ${text}`);\n }\n\n const data = (await response.json()) as OdosAssembleResponse;\n\n return {\n to: data.transaction.to as Address,\n data: data.transaction.data as Hex,\n value: BigInt(data.transaction.value),\n };\n }\n}\n","export const version = \"0.2.1\";\n"],"mappings":"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","names":["Command","account","Command","privateKeyToAccount","privateKeyToAccount","raw","value","hash","account","Command","Command","Command","Command","Command","Command"]}