@lunch-money/ethereum-to-lunch-money 1.1.0 → 1.3.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +8 -2
- package/dist/cjs/fixtures/1inch.json +1 -1
- package/dist/cjs/src/client.d.ts +5 -4
- package/dist/cjs/src/client.js +55 -16
- package/dist/cjs/src/client.js.map +1 -1
- package/dist/cjs/src/main.d.ts +2 -3
- package/dist/cjs/src/main.js +44 -16
- package/dist/cjs/src/main.js.map +1 -1
- package/dist/cjs/src/types.d.ts +4 -4
- package/dist/mjs/fixtures/1inch.json +1 -1
- package/dist/mjs/src/client.d.ts +5 -4
- package/dist/mjs/src/client.js +25 -12
- package/dist/mjs/src/client.js.map +1 -1
- package/dist/mjs/src/main.d.ts +2 -3
- package/dist/mjs/src/main.js +22 -11
- package/dist/mjs/src/main.js.map +1 -1
- package/dist/mjs/src/types.d.ts +4 -4
- package/package.json +37 -31
package/dist/cjs/src/client.d.ts
CHANGED
|
@@ -1,17 +1,18 @@
|
|
|
1
|
-
import ethscan from '@mycrypto/eth-scan';
|
|
2
|
-
import ethers from 'ethers';
|
|
1
|
+
import * as ethscan from '@mycrypto/eth-scan';
|
|
2
|
+
import * as ethers from 'ethers';
|
|
3
3
|
export interface EthereumWalletClient {
|
|
4
|
+
getChainId(): Promise<bigint>;
|
|
4
5
|
getWeiBalance(walletAddress: string): Promise<bigint>;
|
|
5
6
|
getTokensBalance(walletAddress: string, tokenContractAddresses: string[]): Promise<ethscan.BalanceMap<bigint>>;
|
|
6
7
|
}
|
|
7
|
-
export declare const createEthereumWalletClient: (provider: ethers.
|
|
8
|
+
export declare const createEthereumWalletClient: (provider: ethers.AbstractProvider) => EthereumWalletClient;
|
|
8
9
|
interface Token {
|
|
9
10
|
address: string;
|
|
10
11
|
chainId: number;
|
|
11
12
|
name: string;
|
|
12
13
|
symbol: string;
|
|
13
14
|
decimals: number;
|
|
14
|
-
logoURI: string;
|
|
15
|
+
logoURI: string | null;
|
|
15
16
|
}
|
|
16
17
|
export declare const loadTokenList: () => Promise<Token[]>;
|
|
17
18
|
export {};
|
package/dist/cjs/src/client.js
CHANGED
|
@@ -1,4 +1,27 @@
|
|
|
1
1
|
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
+
}) : function(o, v) {
|
|
16
|
+
o["default"] = v;
|
|
17
|
+
});
|
|
18
|
+
var __importStar = (this && this.__importStar) || function (mod) {
|
|
19
|
+
if (mod && mod.__esModule) return mod;
|
|
20
|
+
var result = {};
|
|
21
|
+
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
|
|
22
|
+
__setModuleDefault(result, mod);
|
|
23
|
+
return result;
|
|
24
|
+
};
|
|
2
25
|
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
3
26
|
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
4
27
|
return new (P || (P = Promise))(function (resolve, reject) {
|
|
@@ -13,23 +36,39 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
|
13
36
|
};
|
|
14
37
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
15
38
|
exports.loadTokenList = exports.createEthereumWalletClient = void 0;
|
|
16
|
-
const
|
|
17
|
-
const mem_1 = __importDefault(require("mem"));
|
|
39
|
+
const ethscan = __importStar(require("@mycrypto/eth-scan"));
|
|
18
40
|
const _1inch_json_1 = __importDefault(require("../fixtures/1inch.json"));
|
|
19
|
-
const createEthereumWalletClient = (provider) =>
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
41
|
+
const createEthereumWalletClient = (provider) => {
|
|
42
|
+
// A custom ethscan provider implementation is needed to map `call` to `send` for ethscan to use the ethers client correctly.
|
|
43
|
+
// This is a temporary solution until the ethscan library is updated to support ethers v6.
|
|
44
|
+
const customProvider = {
|
|
45
|
+
send(method, params) {
|
|
46
|
+
// Type pulled from: https://github.com/MyCryptoHQ/eth-scan/blob/master/src/providers/provider.ts#L32
|
|
47
|
+
const typedParams = params;
|
|
48
|
+
return provider.call({ to: typedParams[0].to, data: typedParams[0].data });
|
|
49
|
+
}
|
|
50
|
+
};
|
|
51
|
+
return {
|
|
52
|
+
getChainId() {
|
|
53
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
54
|
+
return (yield provider.getNetwork()).chainId;
|
|
55
|
+
});
|
|
56
|
+
},
|
|
57
|
+
getWeiBalance(walletAddress) {
|
|
58
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
59
|
+
return (yield provider.getBalance(walletAddress));
|
|
60
|
+
});
|
|
61
|
+
},
|
|
62
|
+
getTokensBalance(walletAddress, tokenContractAddresses) {
|
|
63
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
64
|
+
return ethscan.getTokensBalance(customProvider, walletAddress, tokenContractAddresses);
|
|
65
|
+
});
|
|
66
|
+
},
|
|
67
|
+
};
|
|
68
|
+
};
|
|
31
69
|
exports.createEthereumWalletClient = createEthereumWalletClient;
|
|
32
|
-
|
|
70
|
+
const loadTokenList = () => __awaiter(void 0, void 0, void 0, function* () {
|
|
33
71
|
return _1inch_json_1.default.tokens;
|
|
34
|
-
})
|
|
72
|
+
});
|
|
73
|
+
exports.loadTokenList = loadTokenList;
|
|
35
74
|
//# sourceMappingURL=client.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"client.js","sourceRoot":"","sources":["../../../src/client.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"client.js","sourceRoot":"","sources":["../../../src/client.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,4DAA8C;AAG9C,yEAAoD;AAS7C,MAAM,0BAA0B,GAAG,CAAC,QAAiC,EAAwB,EAAE;IAEpG,6HAA6H;IAC7H,0FAA0F;IAC1F,MAAM,cAAc,GAAwB;QAC1C,IAAI,CAAS,MAAc,EAAE,MAA2B;YAEtD,qGAAqG;YACrG,MAAM,WAAW,GAAG,MAA8C,CAAC;YAEnE,OAAO,QAAQ,CAAC,IAAI,CAAC,EAAC,EAAE,EAAE,WAAW,CAAC,CAAC,CAAC,CAAC,EAAE,EAAE,IAAI,EAAE,WAAW,CAAC,CAAC,CAAC,CAAC,IAAI,EAAC,CAAoB,CAAA;QAC7F,CAAC;KACF,CAAA;IAED,OAAO;QACC,UAAU;;gBACd,OAAO,CAAC,MAAM,QAAQ,CAAC,UAAU,EAAE,CAAC,CAAC,OAAO,CAAC;YAC/C,CAAC;SAAA;QACK,aAAa,CAAC,aAAa;;gBAC/B,OAAO,CAAC,MAAM,QAAQ,CAAC,UAAU,CAAC,aAAa,CAAC,CAAC,CAAC;YACpD,CAAC;SAAA;QACK,gBAAgB,CAAC,aAAa,EAAE,sBAAsB;;gBAC1D,OAAO,OAAO,CAAC,gBAAgB,CAAC,cAAc,EAAE,aAAa,EAAE,sBAAsB,CAAC,CAAC;YACzF,CAAC;SAAA;KACF,CAAC;AACJ,CAAC,CAAC;AAzBW,QAAA,0BAA0B,8BAyBrC;AAWK,MAAM,aAAa,GAAG,GAA2B,EAAE;IACxD,OAAO,qBAAc,CAAC,MAAM,CAAC;AAC/B,CAAC,CAAA,CAAC;AAFW,QAAA,aAAa,iBAExB"}
|
package/dist/cjs/src/main.d.ts
CHANGED
|
@@ -1,7 +1,6 @@
|
|
|
1
|
-
import { LunchMoneyCryptoConnection, LunchMoneyCryptoConnectionContext, LunchMoneyCryptoConnectionConfig } from './types.js';
|
|
1
|
+
import type { LunchMoneyCryptoConnection, LunchMoneyCryptoConnectionContext, LunchMoneyCryptoConnectionConfig } from './types.js';
|
|
2
2
|
import { EthereumWalletClient } from './client.js';
|
|
3
|
-
export {
|
|
4
|
-
export { createEthereumWalletClient, EthereumWalletClient } from './client.js';
|
|
3
|
+
export { createEthereumWalletClient } from './client.js';
|
|
5
4
|
interface LunchMoneyEthereumWalletConnectionConfig extends LunchMoneyCryptoConnectionConfig {
|
|
6
5
|
/** The unique ID of the user's wallet address on the blockchain. */
|
|
7
6
|
walletAddress: string;
|
package/dist/cjs/src/main.js
CHANGED
|
@@ -1,4 +1,27 @@
|
|
|
1
1
|
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
+
}) : function(o, v) {
|
|
16
|
+
o["default"] = v;
|
|
17
|
+
});
|
|
18
|
+
var __importStar = (this && this.__importStar) || function (mod) {
|
|
19
|
+
if (mod && mod.__esModule) return mod;
|
|
20
|
+
var result = {};
|
|
21
|
+
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
|
|
22
|
+
__setModuleDefault(result, mod);
|
|
23
|
+
return result;
|
|
24
|
+
};
|
|
2
25
|
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
3
26
|
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
4
27
|
return new (P || (P = Promise))(function (resolve, reject) {
|
|
@@ -8,13 +31,10 @@ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, ge
|
|
|
8
31
|
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
9
32
|
});
|
|
10
33
|
};
|
|
11
|
-
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
12
|
-
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
13
|
-
};
|
|
14
34
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
15
35
|
exports.LunchMoneyEthereumWalletConnection = exports.createEthereumWalletClient = void 0;
|
|
16
36
|
const client_js_1 = require("./client.js");
|
|
17
|
-
const
|
|
37
|
+
const ethers = __importStar(require("ethers"));
|
|
18
38
|
var client_js_2 = require("./client.js");
|
|
19
39
|
Object.defineProperty(exports, "createEthereumWalletClient", { enumerable: true, get: function () { return client_js_2.createEthereumWalletClient; } });
|
|
20
40
|
/** The minimum balance (in wei) that a token should have in order to be
|
|
@@ -29,19 +49,27 @@ exports.LunchMoneyEthereumWalletConnection = {
|
|
|
29
49
|
getBalances({ walletAddress, negligibleBalanceThreshold = NEGLIGIBLE_BALANCE_THRESHOLD }, { client }) {
|
|
30
50
|
return __awaiter(this, void 0, void 0, function* () {
|
|
31
51
|
const weiBalance = yield client.getWeiBalance(walletAddress);
|
|
32
|
-
|
|
33
|
-
const
|
|
34
|
-
const
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
52
|
+
// Filter out tokens that are not on mainnet
|
|
53
|
+
const chainId = yield client.getChainId();
|
|
54
|
+
const chainFilteredTokensList = (yield (0, client_js_1.loadTokenList)()).filter((t) => BigInt(t.chainId) === BigInt(chainId));
|
|
55
|
+
const map = yield client.getTokensBalance(walletAddress, chainFilteredTokensList.map((t) => t.address));
|
|
56
|
+
const balances = Object.entries(map)
|
|
57
|
+
.map(([address, balance]) => {
|
|
58
|
+
const token = chainFilteredTokensList.find((t) => t.address === address);
|
|
59
|
+
if (!token) {
|
|
60
|
+
throw new Error(`Token ${address} not found in filtered token list for chainId ${chainId}`);
|
|
61
|
+
}
|
|
62
|
+
return {
|
|
63
|
+
asset: token.symbol,
|
|
64
|
+
undivisedAmount: balance,
|
|
65
|
+
decimals: token.decimals,
|
|
66
|
+
};
|
|
41
67
|
})
|
|
42
|
-
.concat({ asset: 'ETH',
|
|
43
|
-
.
|
|
44
|
-
|
|
68
|
+
.concat({ asset: 'ETH', undivisedAmount: weiBalance, decimals: 18 })
|
|
69
|
+
.map(({ asset, undivisedAmount, decimals }) => ({ asset, amount: ethers.formatUnits(undivisedAmount, decimals) }))
|
|
70
|
+
// Normalize the amount to 18 decimal places (for the wei per eth standard) for filtering out negligible balances
|
|
71
|
+
.filter((b) => ethers.parseUnits(b.amount, 18) > negligibleBalanceThreshold)
|
|
72
|
+
.map((b) => ({ asset: b.asset, amount: String(b.amount) }))
|
|
45
73
|
.sort((a, b) => a.asset.localeCompare(b.asset));
|
|
46
74
|
return {
|
|
47
75
|
providerName: 'wallet_ethereum',
|
package/dist/cjs/src/main.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"main.js","sourceRoot":"","sources":["../../../src/main.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"main.js","sourceRoot":"","sources":["../../../src/main.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAMA,2CAAkE;AAClE,+CAAiC;AAEjC,yCAAyD;AAAhD,uHAAA,0BAA0B,OAAA;AAEnC;4CAC4C;AAC5C,MAAM,4BAA4B,GAAG,IAAI,CAAC;AAY7B,QAAA,kCAAkC,GAG3C;IACI,QAAQ,CAAC,MAAM,EAAE,OAAO;;YAC5B,OAAO,IAAI,CAAC,WAAW,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;QAC3C,CAAC;KAAA;IACK,WAAW,CAAC,EAAE,aAAa,EAAE,0BAA0B,GAAG,4BAA4B,EAAE,EAAE,EAAE,MAAM,EAAE;;YACxG,MAAM,UAAU,GAAG,MAAM,MAAM,CAAC,aAAa,CAAC,aAAa,CAAC,CAAC;YAE7D,4CAA4C;YAC5C,MAAM,OAAO,GAAG,MAAM,MAAM,CAAC,UAAU,EAAE,CAAC;YAC1C,MAAM,uBAAuB,GAAG,CAAC,MAAM,IAAA,yBAAa,GAAE,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,MAAM,CAAC,CAAC,CAAC,OAAO,CAAC,KAAK,MAAM,CAAC,OAAO,CAAC,CAAC,CAAC;YAE7G,MAAM,GAAG,GAAG,MAAM,MAAM,CAAC,gBAAgB,CACvC,aAAa,EACb,uBAAuB,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,OAAO,CAAC,CAC9C,CAAC;YAEF,MAAM,QAAQ,GAAG,MAAM,CAAC,OAAO,CAAC,GAAG,CAAC;iBACjC,GAAG,CAAC,CAAC,CAAC,OAAO,EAAE,OAAO,CAAC,EAAE,EAAE;gBAC1B,MAAM,KAAK,GAAG,uBAAuB,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,OAAO,KAAK,OAAO,CAAC,CAAC;gBAEzE,IAAI,CAAC,KAAK,EAAE;oBACV,MAAM,IAAI,KAAK,CAAC,SAAS,OAAO,iDAAiD,OAAO,EAAE,CAAC,CAAC;iBAC7F;gBAED,OAAO;oBACL,KAAK,EAAE,KAAK,CAAC,MAAM;oBACnB,eAAe,EAAE,OAAO;oBACxB,QAAQ,EAAE,KAAK,CAAC,QAAQ;iBACzB,CAAC;YACJ,CAAC,CAAC;iBACD,MAAM,CAAC,EAAE,KAAK,EAAE,KAAK,EAAE,eAAe,EAAE,UAAU,EAAE,QAAQ,EAAE,EAAE,EAAE,CAAC;iBACnE,GAAG,CAAC,CAAC,EAAE,KAAK,EAAE,eAAe,EAAE,QAAQ,EAAE,EAAE,EAAE,CAAC,CAAC,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,CAAC,WAAW,CAAC,eAAe,EAAE,QAAQ,CAAC,EAAE,CAAC,CAAC;gBAClH,iHAAiH;iBAChH,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC,CAAC,MAAM,EAAE,EAAE,CAAC,GAAG,0BAA0B,CAAC;iBAC3E,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,EAAE,KAAK,EAAE,CAAC,CAAC,KAAK,EAAE,MAAM,EAAE,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC;iBAC1D,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,KAAK,CAAC,aAAa,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC;YAElD,OAAO;gBACL,YAAY,EAAE,iBAAiB;gBAC/B,QAAQ;aACT,CAAC;QACJ,CAAC;KAAA;CACF,CAAC"}
|
package/dist/cjs/src/types.d.ts
CHANGED
|
@@ -1,22 +1,22 @@
|
|
|
1
1
|
/**
|
|
2
2
|
* Serializable configuration for the connection
|
|
3
3
|
*/
|
|
4
|
-
export
|
|
4
|
+
export type LunchMoneyCryptoConnectionConfig = {};
|
|
5
5
|
/**
|
|
6
6
|
* Non-serializable injected dependencies for the connection
|
|
7
7
|
*/
|
|
8
|
-
export
|
|
8
|
+
export type LunchMoneyCryptoConnectionContext = {};
|
|
9
9
|
export interface CryptoBalance {
|
|
10
10
|
asset: string;
|
|
11
11
|
amount: string;
|
|
12
12
|
}
|
|
13
13
|
export declare const providerNames: readonly ["coinbase", "coinbase_pro", "kraken", "binance", "wallet_ethereum"];
|
|
14
|
-
export
|
|
14
|
+
export type ProviderName = typeof providerNames[number];
|
|
15
15
|
export interface LunchMoneyCryptoConnectionBalances {
|
|
16
16
|
providerName: ProviderName;
|
|
17
17
|
balances: CryptoBalance[];
|
|
18
18
|
}
|
|
19
|
-
export
|
|
19
|
+
export type LunchMoneyCryptoConnectionInitialization = LunchMoneyCryptoConnectionBalances;
|
|
20
20
|
export interface LunchMoneyCryptoConnection<TConfig extends LunchMoneyCryptoConnectionConfig, TContext extends LunchMoneyCryptoConnectionContext> {
|
|
21
21
|
initiate(config: TConfig, context: TContext): Promise<LunchMoneyCryptoConnectionInitialization>;
|
|
22
22
|
getBalances(config: TConfig, context: TContext): Promise<LunchMoneyCryptoConnectionBalances>;
|