four-flap-meme-sdk 1.4.91 → 1.4.93
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/dist/index.d.ts +2 -0
- package/dist/index.js +24 -0
- package/dist/xlayer/aa-account.d.ts +240 -0
- package/dist/xlayer/aa-account.js +510 -0
- package/dist/xlayer/bundle.d.ts +93 -0
- package/dist/xlayer/bundle.js +472 -0
- package/dist/xlayer/bundler.d.ts +111 -0
- package/dist/xlayer/bundler.js +162 -0
- package/dist/xlayer/constants.d.ts +75 -0
- package/dist/xlayer/constants.js +145 -0
- package/dist/xlayer/dex.d.ts +132 -0
- package/dist/xlayer/dex.js +335 -0
- package/dist/xlayer/examples/bundle-buy-sell.d.ts +11 -0
- package/dist/xlayer/examples/bundle-buy-sell.js +194 -0
- package/dist/xlayer/index.d.ts +75 -0
- package/dist/xlayer/index.js +130 -0
- package/dist/xlayer/portal-ops.d.ts +152 -0
- package/dist/xlayer/portal-ops.js +239 -0
- package/dist/xlayer/types.d.ts +298 -0
- package/dist/xlayer/types.js +6 -0
- package/dist/xlayer/volume.d.ts +65 -0
- package/dist/xlayer/volume.js +235 -0
- package/package.json +1 -1
package/dist/index.d.ts
CHANGED
|
@@ -52,3 +52,5 @@ export { quoteV2, quoteV3, quote, getTokenToNativeQuote, getNativeToTokenQuote,
|
|
|
52
52
|
export { submitDirectToRpc, submitDirectToRpcSequential, // ✅ 新增:顺序广播并等待确认(用于多跳)
|
|
53
53
|
submitDirectToRpcParallel, type DirectSubmitConfig, type DirectSubmitResult, type DirectTxResult } from './contracts/tm-bundle-merkle/submit.js';
|
|
54
54
|
export { directV2BatchBuy, directV2BatchSell, directV3BatchBuy, directV3BatchSell, getRouterAddress, DIRECT_ROUTERS, type DirectV2BuyParams, type DirectV2SellParams, type DirectV3BuyParams, type DirectV3SellParams, type DirectRouterResult, type DirectRouterSignConfig, type DexKey, type RouterVersion, } from './dex/index.js';
|
|
55
|
+
export * as XLayer from './xlayer/index.js';
|
|
56
|
+
export { bundleBuy as xlayerBundleBuy, bundleSell as xlayerBundleSell, bundleBuySell as xlayerBundleBuySell, createBundleExecutor as xlayerCreateBundleExecutor, BundleExecutor as XLayerBundleExecutor, makeVolume as xlayerMakeVolume, singleRoundVolume as xlayerSingleRoundVolume, createVolumeExecutor as xlayerCreateVolumeExecutor, VolumeExecutor as XLayerVolumeExecutor, createDexExecutor as xlayerCreateDexExecutor, createDexQuery as xlayerCreateDexQuery, quoteOkbToToken as xlayerQuoteOkbToToken, quoteTokenToOkb as xlayerQuoteTokenToOkb, DexExecutor as XLayerDexExecutor, DexQuery as XLayerDexQuery, createAAAccountManager as xlayerCreateAAAccountManager, predictSender as xlayerPredictSender, createWallet as xlayerCreateWallet, AAAccountManager as XLayerAAAccountManager, generateAAWallets as xlayerGenerateAAWallets, generateAAWalletsFromMnemonic as xlayerGenerateAAWalletsFromMnemonic, predictSendersFromPrivateKeys as xlayerPredictSendersFromPrivateKeys, createBundlerClient as xlayerCreateBundlerClient, BundlerClient as XLayerBundlerClient, createPortalQuery as xlayerCreatePortalQuery, PortalQuery as XLayerPortalQuery, encodeBuyCall as xlayerEncodeBuyCall, encodeSellCall as xlayerEncodeSellCall, encodeApproveCall as xlayerEncodeApproveCall, parseOkb as xlayerParseOkb, formatOkb as xlayerFormatOkb, XLAYER_CHAIN_ID, FLAP_PORTAL as XLAYER_FLAP_PORTAL, ENTRYPOINT_V06 as XLAYER_ENTRYPOINT, SIMPLE_ACCOUNT_FACTORY as XLAYER_FACTORY, PARTICLE_BUNDLER_URL as XLAYER_BUNDLER_URL, WOKB as XLAYER_WOKB, POTATOSWAP_V2_ROUTER as XLAYER_POTATOSWAP_ROUTER, type XLayerConfig, type BundleBuyParams as XLayerBundleBuyParams, type BundleSellParams as XLayerBundleSellParams, type BundleBuySellParams as XLayerBundleBuySellParams, type VolumeParams as XLayerVolumeParams, type BundleBuyResult as XLayerBundleBuyResult, type BundleSellResult as XLayerBundleSellResult, type BundleBuySellResult as XLayerBundleBuySellResult, type VolumeResult as XLayerVolumeResult, type HandleOpsResult as XLayerHandleOpsResult, type AAAccount as XLayerAAAccount, type UserOperation as XLayerUserOperation, type GeneratedAAWallet as XLayerGeneratedAAWallet, type GenerateAAWalletsParams as XLayerGenerateAAWalletsParams, type GenerateAAWalletsResult as XLayerGenerateAAWalletsResult, } from './xlayer/index.js';
|
package/dist/index.js
CHANGED
|
@@ -2,6 +2,7 @@
|
|
|
2
2
|
// 公共 ABI(统一管理)
|
|
3
3
|
// ============================================================================
|
|
4
4
|
export * as Abis from './abis/index.js';
|
|
5
|
+
// export * as Sol from './sol/index.js';
|
|
5
6
|
export { ERC20_ABI, ERC20_BALANCE_ABI, ERC20_ALLOWANCE_ABI, MULTICALL3_ABI, V2_ROUTER_ABI, V2_ROUTER_QUOTE_ABI, V3_ROUTER02_ABI, V3_ROUTER_LEGACY_ABI, V3_QUOTER_ABI, V2_FACTORY_ABI, V2_PAIR_ABI, V3_FACTORY_ABI, V3_POOL_ABI, FLAP_PORTAL_ABI, TM2_ABI, HELPER3_ABI, } from './abis/common.js';
|
|
6
7
|
// ============================================================================
|
|
7
8
|
// 公共常量(统一管理)
|
|
@@ -95,3 +96,26 @@ directV3BatchBuy, directV3BatchSell,
|
|
|
95
96
|
getRouterAddress,
|
|
96
97
|
// 常量
|
|
97
98
|
DIRECT_ROUTERS, } from './dex/index.js';
|
|
99
|
+
// ============================================================
|
|
100
|
+
// ✅ XLayer SDK(ERC-4337 AA 钱包模式)
|
|
101
|
+
// ============================================================
|
|
102
|
+
export * as XLayer from './xlayer/index.js';
|
|
103
|
+
export {
|
|
104
|
+
// 捆绑交易
|
|
105
|
+
bundleBuy as xlayerBundleBuy, bundleSell as xlayerBundleSell, bundleBuySell as xlayerBundleBuySell, createBundleExecutor as xlayerCreateBundleExecutor, BundleExecutor as XLayerBundleExecutor,
|
|
106
|
+
// 刷量
|
|
107
|
+
makeVolume as xlayerMakeVolume, singleRoundVolume as xlayerSingleRoundVolume, createVolumeExecutor as xlayerCreateVolumeExecutor, VolumeExecutor as XLayerVolumeExecutor,
|
|
108
|
+
// DEX 交易
|
|
109
|
+
createDexExecutor as xlayerCreateDexExecutor, createDexQuery as xlayerCreateDexQuery, quoteOkbToToken as xlayerQuoteOkbToToken, quoteTokenToOkb as xlayerQuoteTokenToOkb, DexExecutor as XLayerDexExecutor, DexQuery as XLayerDexQuery,
|
|
110
|
+
// AA 账户管理
|
|
111
|
+
createAAAccountManager as xlayerCreateAAAccountManager, predictSender as xlayerPredictSender, createWallet as xlayerCreateWallet, AAAccountManager as XLayerAAAccountManager,
|
|
112
|
+
// 批量生成钱包工具
|
|
113
|
+
generateAAWallets as xlayerGenerateAAWallets, generateAAWalletsFromMnemonic as xlayerGenerateAAWalletsFromMnemonic, predictSendersFromPrivateKeys as xlayerPredictSendersFromPrivateKeys,
|
|
114
|
+
// Bundler 客户端
|
|
115
|
+
createBundlerClient as xlayerCreateBundlerClient, BundlerClient as XLayerBundlerClient,
|
|
116
|
+
// Portal 操作
|
|
117
|
+
createPortalQuery as xlayerCreatePortalQuery, PortalQuery as XLayerPortalQuery, encodeBuyCall as xlayerEncodeBuyCall, encodeSellCall as xlayerEncodeSellCall, encodeApproveCall as xlayerEncodeApproveCall,
|
|
118
|
+
// 工具函数
|
|
119
|
+
parseOkb as xlayerParseOkb, formatOkb as xlayerFormatOkb,
|
|
120
|
+
// 常量
|
|
121
|
+
XLAYER_CHAIN_ID, FLAP_PORTAL as XLAYER_FLAP_PORTAL, ENTRYPOINT_V06 as XLAYER_ENTRYPOINT, SIMPLE_ACCOUNT_FACTORY as XLAYER_FACTORY, PARTICLE_BUNDLER_URL as XLAYER_BUNDLER_URL, WOKB as XLAYER_WOKB, POTATOSWAP_V2_ROUTER as XLAYER_POTATOSWAP_ROUTER, } from './xlayer/index.js';
|
|
@@ -0,0 +1,240 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* XLayer AA 账户管理器
|
|
3
|
+
*
|
|
4
|
+
* 核心功能:
|
|
5
|
+
* - AA 账户(Sender)地址预测和部署
|
|
6
|
+
* - UserOperation 构建和签名
|
|
7
|
+
* - 余额管理和资金充值
|
|
8
|
+
* - initCode 生成
|
|
9
|
+
*/
|
|
10
|
+
import { ethers, JsonRpcProvider, Wallet, Contract } from 'ethers';
|
|
11
|
+
import type { UserOperation, SignedUserOp, AAAccount, XLayerConfig } from './types.js';
|
|
12
|
+
import { BundlerClient } from './bundler.js';
|
|
13
|
+
/**
|
|
14
|
+
* AA 账户管理器
|
|
15
|
+
*
|
|
16
|
+
* 管理 ERC-4337 SimpleAccount:
|
|
17
|
+
* - 地址预测(无需部署即可知道地址)
|
|
18
|
+
* - UserOp 构建和签名
|
|
19
|
+
* - Gas 估算和 Prefund 计算
|
|
20
|
+
* - 支持 Paymaster(免 Gas)
|
|
21
|
+
*/
|
|
22
|
+
export declare class AAAccountManager {
|
|
23
|
+
private provider;
|
|
24
|
+
private chainId;
|
|
25
|
+
private factory;
|
|
26
|
+
private entryPoint;
|
|
27
|
+
private factoryAddress;
|
|
28
|
+
private entryPointAddress;
|
|
29
|
+
private salt;
|
|
30
|
+
private bundler;
|
|
31
|
+
private paymaster?;
|
|
32
|
+
private paymasterData?;
|
|
33
|
+
private gasLimitMultiplier;
|
|
34
|
+
constructor(config?: XLayerConfig);
|
|
35
|
+
/**
|
|
36
|
+
* 获取 Provider
|
|
37
|
+
*/
|
|
38
|
+
getProvider(): JsonRpcProvider;
|
|
39
|
+
/**
|
|
40
|
+
* 获取 EntryPoint 合约
|
|
41
|
+
*/
|
|
42
|
+
getEntryPoint(): Contract;
|
|
43
|
+
/**
|
|
44
|
+
* 获取 EntryPoint 地址
|
|
45
|
+
*/
|
|
46
|
+
getEntryPointAddress(): string;
|
|
47
|
+
/**
|
|
48
|
+
* 获取 Bundler 客户端
|
|
49
|
+
*/
|
|
50
|
+
getBundler(): BundlerClient;
|
|
51
|
+
/**
|
|
52
|
+
* 获取当前 Fee Data
|
|
53
|
+
*/
|
|
54
|
+
getFeeData(): Promise<ethers.FeeData>;
|
|
55
|
+
/**
|
|
56
|
+
* 预测 AA Sender 地址
|
|
57
|
+
*
|
|
58
|
+
* @param ownerAddress Owner EOA 地址
|
|
59
|
+
* @param salt 可选的 salt 覆盖
|
|
60
|
+
* @returns 预测的 Sender 地址
|
|
61
|
+
*/
|
|
62
|
+
predictSenderAddress(ownerAddress: string, salt?: bigint): Promise<string>;
|
|
63
|
+
/**
|
|
64
|
+
* 获取完整的 AA 账户信息
|
|
65
|
+
*/
|
|
66
|
+
getAccountInfo(ownerAddress: string, salt?: bigint): Promise<AAAccount>;
|
|
67
|
+
/**
|
|
68
|
+
* 生成 initCode(用于在 UserOp 中部署账户)
|
|
69
|
+
*/
|
|
70
|
+
generateInitCode(ownerAddress: string, salt?: bigint): string;
|
|
71
|
+
/**
|
|
72
|
+
* 构建 paymasterAndData
|
|
73
|
+
*/
|
|
74
|
+
private buildPaymasterAndData;
|
|
75
|
+
/**
|
|
76
|
+
* 构建未签名的 UserOperation(使用 Bundler 估算 Gas)
|
|
77
|
+
*/
|
|
78
|
+
buildUserOpWithBundlerEstimate(params: {
|
|
79
|
+
ownerWallet: Wallet;
|
|
80
|
+
sender: string;
|
|
81
|
+
callData: string;
|
|
82
|
+
nonce: bigint;
|
|
83
|
+
initCode?: string;
|
|
84
|
+
}): Promise<{
|
|
85
|
+
userOp: UserOperation;
|
|
86
|
+
prefundWei: bigint;
|
|
87
|
+
}>;
|
|
88
|
+
/**
|
|
89
|
+
* 构建未签名的 UserOperation(本地估算 Gas,不依赖 Bundler)
|
|
90
|
+
*
|
|
91
|
+
* 适用于无法通过 Bundler 估算的场景(如尚未授权的 sell 操作)
|
|
92
|
+
*/
|
|
93
|
+
buildUserOpWithLocalEstimate(params: {
|
|
94
|
+
ownerWallet: Wallet;
|
|
95
|
+
sender: string;
|
|
96
|
+
callData: string;
|
|
97
|
+
nonce: bigint;
|
|
98
|
+
initCode?: string;
|
|
99
|
+
callGasLimit?: bigint;
|
|
100
|
+
}): Promise<{
|
|
101
|
+
userOp: UserOperation;
|
|
102
|
+
prefundWei: bigint;
|
|
103
|
+
}>;
|
|
104
|
+
/**
|
|
105
|
+
* 签名 UserOperation
|
|
106
|
+
*/
|
|
107
|
+
signUserOp(userOp: UserOperation, ownerWallet: Wallet): Promise<SignedUserOp>;
|
|
108
|
+
/**
|
|
109
|
+
* 构建并签名 UserOperation(完整流程)
|
|
110
|
+
*/
|
|
111
|
+
buildAndSignUserOp(params: {
|
|
112
|
+
ownerWallet: Wallet;
|
|
113
|
+
callData: string;
|
|
114
|
+
value?: bigint;
|
|
115
|
+
useBundlerEstimate?: boolean;
|
|
116
|
+
callGasLimit?: bigint;
|
|
117
|
+
}): Promise<SignedUserOp>;
|
|
118
|
+
/**
|
|
119
|
+
* 确保 Sender 有足够的 OKB 余额
|
|
120
|
+
*
|
|
121
|
+
* @param ownerWallet Owner 钱包(用于转账)
|
|
122
|
+
* @param sender Sender 地址
|
|
123
|
+
* @param requiredWei 所需余额(wei)
|
|
124
|
+
* @param tag 日志标签
|
|
125
|
+
* @returns 是否进行了转账
|
|
126
|
+
*/
|
|
127
|
+
ensureSenderBalance(ownerWallet: Wallet, sender: string, requiredWei: bigint, tag?: string): Promise<{
|
|
128
|
+
funded: boolean;
|
|
129
|
+
txHash?: string;
|
|
130
|
+
}>;
|
|
131
|
+
/**
|
|
132
|
+
* 批量获取多个 owner 的 AA 账户信息
|
|
133
|
+
*/
|
|
134
|
+
getMultipleAccountInfo(ownerAddresses: string[]): Promise<AAAccount[]>;
|
|
135
|
+
}
|
|
136
|
+
/**
|
|
137
|
+
* 编码 SimpleAccount.execute 调用
|
|
138
|
+
*/
|
|
139
|
+
export declare function encodeExecute(dest: string, value: bigint, data: string): string;
|
|
140
|
+
/**
|
|
141
|
+
* 编码 SimpleAccount.executeBatch 调用
|
|
142
|
+
*/
|
|
143
|
+
export declare function encodeExecuteBatch(dests: string[], values: bigint[], datas: string[]): string;
|
|
144
|
+
/**
|
|
145
|
+
* 创建 AA 账户管理器
|
|
146
|
+
*/
|
|
147
|
+
export declare function createAAAccountManager(config?: XLayerConfig): AAAccountManager;
|
|
148
|
+
/**
|
|
149
|
+
* 快速预测 Sender 地址
|
|
150
|
+
*/
|
|
151
|
+
export declare function predictSender(ownerAddress: string, config?: XLayerConfig): Promise<string>;
|
|
152
|
+
/**
|
|
153
|
+
* 从私钥创建连接了 Provider 的 Wallet
|
|
154
|
+
*/
|
|
155
|
+
export declare function createWallet(privateKey: string, config?: XLayerConfig): Wallet;
|
|
156
|
+
/**
|
|
157
|
+
* 生成的钱包信息(包含 AA 地址)
|
|
158
|
+
*/
|
|
159
|
+
export interface GeneratedAAWallet {
|
|
160
|
+
/** 索引 */
|
|
161
|
+
index: number;
|
|
162
|
+
/** Owner EOA 地址 */
|
|
163
|
+
owner: string;
|
|
164
|
+
/** Owner 私钥 */
|
|
165
|
+
privateKey: string;
|
|
166
|
+
/** AA Sender 地址(预测) */
|
|
167
|
+
sender: string;
|
|
168
|
+
/** 助记词(仅当使用 generateAAWalletsFromMnemonic 时) */
|
|
169
|
+
mnemonic?: string;
|
|
170
|
+
/** 派生路径(仅当使用 generateAAWalletsFromMnemonic 时) */
|
|
171
|
+
derivationPath?: string;
|
|
172
|
+
}
|
|
173
|
+
/**
|
|
174
|
+
* 批量生成钱包参数
|
|
175
|
+
*/
|
|
176
|
+
export interface GenerateAAWalletsParams {
|
|
177
|
+
/** 生成数量 */
|
|
178
|
+
count: number;
|
|
179
|
+
/** 配置 */
|
|
180
|
+
config?: XLayerConfig;
|
|
181
|
+
}
|
|
182
|
+
/**
|
|
183
|
+
* 批量生成钱包结果
|
|
184
|
+
*/
|
|
185
|
+
export interface GenerateAAWalletsResult {
|
|
186
|
+
/** 生成的钱包列表 */
|
|
187
|
+
wallets: GeneratedAAWallet[];
|
|
188
|
+
/** 所有 owner 地址 */
|
|
189
|
+
owners: string[];
|
|
190
|
+
/** 所有私钥 */
|
|
191
|
+
privateKeys: string[];
|
|
192
|
+
/** 所有 AA sender 地址 */
|
|
193
|
+
senders: string[];
|
|
194
|
+
/** 格式化输出(方便复制) */
|
|
195
|
+
formatted: string;
|
|
196
|
+
}
|
|
197
|
+
/**
|
|
198
|
+
* 批量生成随机钱包并预测 AA 地址
|
|
199
|
+
*
|
|
200
|
+
* @param params 生成参数
|
|
201
|
+
* @returns 钱包列表和汇总信息
|
|
202
|
+
*
|
|
203
|
+
* @example
|
|
204
|
+
* ```typescript
|
|
205
|
+
* const result = await generateAAWallets({ count: 5 });
|
|
206
|
+
*
|
|
207
|
+
* console.log(result.formatted);
|
|
208
|
+
* // 输出:
|
|
209
|
+
* // === XLayer AA Wallets ===
|
|
210
|
+
* // #1
|
|
211
|
+
* // Owner: 0x1234...
|
|
212
|
+
* // Sender: 0xabcd...
|
|
213
|
+
* // Key: 0x...
|
|
214
|
+
* // ...
|
|
215
|
+
*
|
|
216
|
+
* // 直接使用私钥列表
|
|
217
|
+
* await bundleBuy({
|
|
218
|
+
* tokenAddress: '0x...',
|
|
219
|
+
* privateKeys: result.privateKeys,
|
|
220
|
+
* buyAmounts: ['0.01', '0.01', '0.01', '0.01', '0.01'],
|
|
221
|
+
* });
|
|
222
|
+
* ```
|
|
223
|
+
*/
|
|
224
|
+
export declare function generateAAWallets(params: GenerateAAWalletsParams): Promise<GenerateAAWalletsResult>;
|
|
225
|
+
/**
|
|
226
|
+
* 从助记词批量派生钱包并预测 AA 地址
|
|
227
|
+
*
|
|
228
|
+
* @param mnemonic 助记词
|
|
229
|
+
* @param count 派生数量
|
|
230
|
+
* @param startIndex 起始索引(默认 0)
|
|
231
|
+
* @param config 配置
|
|
232
|
+
*/
|
|
233
|
+
export declare function generateAAWalletsFromMnemonic(mnemonic: string, count: number, startIndex?: number, config?: XLayerConfig): Promise<GenerateAAWalletsResult>;
|
|
234
|
+
/**
|
|
235
|
+
* 从私钥列表预测 AA 地址
|
|
236
|
+
*
|
|
237
|
+
* @param privateKeys 私钥列表
|
|
238
|
+
* @param config 配置
|
|
239
|
+
*/
|
|
240
|
+
export declare function predictSendersFromPrivateKeys(privateKeys: string[], config?: XLayerConfig): Promise<GenerateAAWalletsResult>;
|