@pendle/sdk-boros 1.0.11-strategies → 1.0.12-cross-deposit-1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/addresses.d.ts +11 -1
- package/dist/addresses.js +23 -1
- package/dist/addresses.js.map +1 -1
- package/dist/backend/secrettune/BorosCoreSDK.d.ts +165 -21
- package/dist/backend/secrettune/BorosCoreSDK.js +72 -6
- package/dist/backend/secrettune/BorosCoreSDK.js.map +1 -1
- package/dist/backend/secrettune/BorosSendTxsBotSDK.d.ts +4 -3
- package/dist/backend/secrettune/BorosSendTxsBotSDK.js.map +1 -1
- package/dist/backend/secrettune/PendleV2SDK.d.ts +2281 -0
- package/dist/backend/secrettune/PendleV2SDK.js +970 -0
- package/dist/backend/secrettune/PendleV2SDK.js.map +1 -0
- package/dist/backend/secrettune/module.d.ts +6 -0
- package/dist/backend/secrettune/module.js +25 -0
- package/dist/backend/secrettune/module.js.map +1 -1
- package/dist/common/chainId.d.ts +12 -0
- package/dist/common/chainId.js +17 -0
- package/dist/common/chainId.js.map +1 -0
- package/dist/contracts/abis/viemAbiDepositBoxFactory.d.ts +75 -0
- package/dist/contracts/abis/viemAbiDepositBoxFactory.js +103 -0
- package/dist/contracts/abis/viemAbiDepositBoxFactory.js.map +1 -0
- package/dist/contracts/abis/viemAbiRouter.d.ts +1983 -0
- package/dist/contracts/abis/viemAbiRouter.js +2549 -0
- package/dist/contracts/abis/viemAbiRouter.js.map +1 -0
- package/dist/contracts/contracts.factory.d.ts +8 -2
- package/dist/contracts/contracts.factory.js +16 -4
- package/dist/contracts/contracts.factory.js.map +1 -1
- package/dist/contracts/deposit-box-factory.d.ts +86 -0
- package/dist/contracts/deposit-box-factory.js +16 -0
- package/dist/contracts/deposit-box-factory.js.map +1 -0
- package/dist/contracts/erc20.d.ts +158 -0
- package/dist/contracts/erc20.js +52 -0
- package/dist/contracts/erc20.js.map +1 -0
- package/dist/contracts/router.d.ts +1987 -0
- package/dist/contracts/router.js +12 -0
- package/dist/contracts/router.js.map +1 -0
- package/dist/entities/crossChainDeposit/AggregatorHelper.d.ts +109 -0
- package/dist/entities/crossChainDeposit/AggregatorHelper.js +26 -0
- package/dist/entities/crossChainDeposit/AggregatorHelper.js.map +1 -0
- package/dist/entities/crossChainDeposit/AggregatorHelperErrors.d.ts +80 -0
- package/dist/entities/crossChainDeposit/AggregatorHelperErrors.js +116 -0
- package/dist/entities/crossChainDeposit/AggregatorHelperErrors.js.map +1 -0
- package/dist/entities/crossChainDeposit/Depositor.d.ts +31 -0
- package/dist/entities/crossChainDeposit/Depositor.js +64 -0
- package/dist/entities/crossChainDeposit/Depositor.js.map +1 -0
- package/dist/entities/crossChainDeposit/aggregators/Boros/index.d.ts +36 -0
- package/dist/entities/crossChainDeposit/aggregators/Boros/index.js +191 -0
- package/dist/entities/crossChainDeposit/aggregators/Boros/index.js.map +1 -0
- package/dist/entities/crossChainDeposit/aggregators/Boros/types.d.ts +10 -0
- package/dist/entities/crossChainDeposit/aggregators/Boros/types.js.map +1 -0
- package/dist/entities/crossChainDeposit/aggregators/Lifi/index.d.ts +39 -0
- package/dist/entities/crossChainDeposit/aggregators/Lifi/index.js +159 -0
- package/dist/entities/crossChainDeposit/aggregators/Lifi/index.js.map +1 -0
- package/dist/entities/crossChainDeposit/aggregators/Lifi/types.d.ts +186 -0
- package/dist/entities/crossChainDeposit/aggregators/Lifi/types.js +28 -0
- package/dist/entities/crossChainDeposit/aggregators/Lifi/types.js.map +1 -0
- package/dist/entities/crossChainDeposit/aggregators/Pendle/index.d.ts +38 -0
- package/dist/entities/crossChainDeposit/aggregators/Pendle/index.js +171 -0
- package/dist/entities/crossChainDeposit/aggregators/Pendle/index.js.map +1 -0
- package/dist/entities/crossChainDeposit/helpers/TokenHelper.d.ts +23 -0
- package/dist/entities/crossChainDeposit/helpers/TokenHelper.js +67 -0
- package/dist/entities/crossChainDeposit/helpers/TokenHelper.js.map +1 -0
- package/dist/entities/crossChainDeposit/helpers/utils.d.ts +4 -0
- package/dist/entities/crossChainDeposit/helpers/utils.js +25 -0
- package/dist/entities/crossChainDeposit/helpers/utils.js.map +1 -0
- package/dist/entities/crossChainDeposit/index.d.ts +2 -0
- package/dist/entities/{Calculator → crossChainDeposit}/index.js +2 -6
- package/dist/entities/crossChainDeposit/index.js.map +1 -0
- package/dist/entities/index.d.ts +2 -1
- package/dist/entities/index.js +2 -1
- package/dist/entities/index.js.map +1 -1
- package/dist/entities/token/Token.d.ts +31 -0
- package/dist/entities/token/Token.js +61 -0
- package/dist/entities/token/Token.js.map +1 -0
- package/dist/entities/token/index.d.ts +1 -0
- package/dist/entities/token/index.js +18 -0
- package/dist/entities/token/index.js.map +1 -0
- package/dist/errors/PendleSdkError.d.ts +7 -0
- package/dist/errors/PendleSdkError.js +15 -0
- package/dist/errors/PendleSdkError.js.map +1 -0
- package/dist/types/common.d.ts +16 -0
- package/dist/utils/signing/index.d.ts +1 -1
- package/dist/utils/signing/index.js +2 -1
- package/dist/utils/signing/index.js.map +1 -1
- package/dist/utils/signing/sensitive.d.ts +2 -1
- package/dist/utils/signing/sensitive.js +29 -0
- package/dist/utils/signing/sensitive.js.map +1 -1
- package/package.json +1 -1
- package/dist/entities/Calculator/exchangeFees.d.ts +0 -47
- package/dist/entities/Calculator/exchangeFees.js +0 -93
- package/dist/entities/Calculator/exchangeFees.js.map +0 -1
- package/dist/entities/Calculator/index.d.ts +0 -6
- package/dist/entities/Calculator/index.js.map +0 -1
- package/dist/entities/Calculator/marginCalculator.d.ts +0 -10
- package/dist/entities/Calculator/marginCalculator.js +0 -67
- package/dist/entities/Calculator/marginCalculator.js.map +0 -1
- package/dist/entities/Calculator/strategyApr.d.ts +0 -30
- package/dist/entities/Calculator/strategyApr.js +0 -94
- package/dist/entities/Calculator/strategyApr.js.map +0 -1
- package/dist/entities/Calculator/strategyExecution.d.ts +0 -28
- package/dist/entities/Calculator/strategyExecution.js +0 -130
- package/dist/entities/Calculator/strategyExecution.js.map +0 -1
- package/dist/entities/Calculator/strategyFinder.d.ts +0 -11
- package/dist/entities/Calculator/strategyFinder.js +0 -162
- package/dist/entities/Calculator/strategyFinder.js.map +0 -1
- package/dist/entities/Calculator/types.d.ts +0 -84
- package/dist/entities/Calculator/types.js.map +0 -1
- /package/dist/entities/{Calculator → crossChainDeposit/aggregators/Boros}/types.js +0 -0
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
import { Hex, PublicClient } from 'viem';
|
|
2
|
+
import { PendleSwapResponse } from '../../../../backend/secrettune/PendleV2SDK';
|
|
3
|
+
import { BorosCoreSdk, PendleV2Sdk } from '../../../../backend/secrettune/module';
|
|
4
|
+
import { DepositBoxFactoryContract } from '../../../../contracts/deposit-box-factory';
|
|
5
|
+
import { AggregatorChain, AggregatorHelper, AggregatorName, AggregatorResult, AggregatorRoute, AggregatorRouteStatus, AggregatorSwapData, AggregatorTransferData, QuoteDepositParams } from '../../AggregatorHelper';
|
|
6
|
+
import { TokenHelper, TokenLookupTable } from '../../helpers/TokenHelper';
|
|
7
|
+
export declare class PendleSwapResult implements AggregatorResult {
|
|
8
|
+
routes: AggregatorRoute[];
|
|
9
|
+
private rawResult;
|
|
10
|
+
private req;
|
|
11
|
+
private helper;
|
|
12
|
+
constructor(params: {
|
|
13
|
+
req: QuoteDepositParams;
|
|
14
|
+
res: PendleSwapResponse;
|
|
15
|
+
tokenLookupTable: TokenLookupTable;
|
|
16
|
+
helper: PendleSwapHelper;
|
|
17
|
+
});
|
|
18
|
+
getAggregatorName(): AggregatorName;
|
|
19
|
+
selectRoute(): PendleSwapResponse | undefined;
|
|
20
|
+
getRouteData(): Promise<{
|
|
21
|
+
transferData: AggregatorTransferData;
|
|
22
|
+
swapData: AggregatorSwapData;
|
|
23
|
+
}>;
|
|
24
|
+
}
|
|
25
|
+
export declare class PendleSwapHelper implements AggregatorHelper {
|
|
26
|
+
private readonly pendleV2Sdk;
|
|
27
|
+
private readonly coreSdk;
|
|
28
|
+
private readonly publicClient;
|
|
29
|
+
private readonly tokenHelper;
|
|
30
|
+
private readonly depositBoxFactoryContract;
|
|
31
|
+
aggregatorName: AggregatorName;
|
|
32
|
+
constructor(pendleV2Sdk: PendleV2Sdk, coreSdk: BorosCoreSdk, publicClient: PublicClient, tokenHelper: TokenHelper, depositBoxFactoryContract: DepositBoxFactoryContract);
|
|
33
|
+
getChains(): Promise<AggregatorChain[]>;
|
|
34
|
+
getTokenLookupTable(): Promise<TokenLookupTable>;
|
|
35
|
+
getRouteStatus(txHash: Hex): Promise<AggregatorRouteStatus>;
|
|
36
|
+
quoteDeposit(params: QuoteDepositParams): Promise<PendleSwapResult>;
|
|
37
|
+
prepareTransferCall(params: QuoteDepositParams): Promise<AggregatorTransferData>;
|
|
38
|
+
}
|
|
@@ -0,0 +1,171 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
3
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
4
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
5
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
6
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
7
|
+
};
|
|
8
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
9
|
+
exports.PendleSwapHelper = exports.PendleSwapResult = void 0;
|
|
10
|
+
const viem_1 = require("viem");
|
|
11
|
+
const chains_1 = require("viem/chains");
|
|
12
|
+
const addresses_1 = require("../../../../addresses");
|
|
13
|
+
const cacheDecorators_1 = require("../../../../common/cacheDecorators");
|
|
14
|
+
const constants_1 = require("../../../../multicall/constants");
|
|
15
|
+
const Token_1 = require("../../../token/Token");
|
|
16
|
+
const AggregatorHelper_1 = require("../../AggregatorHelper");
|
|
17
|
+
const AggregatorHelperErrors_1 = require("../../AggregatorHelperErrors");
|
|
18
|
+
const utils_1 = require("../../helpers/utils");
|
|
19
|
+
class PendleSwapResult {
|
|
20
|
+
routes = [];
|
|
21
|
+
rawResult;
|
|
22
|
+
req;
|
|
23
|
+
helper;
|
|
24
|
+
constructor(params) {
|
|
25
|
+
const { req, res, tokenLookupTable, helper } = params;
|
|
26
|
+
this.helper = helper;
|
|
27
|
+
this.req = req;
|
|
28
|
+
const fromToken = tokenLookupTable.lookup(chains_1.arbitrum.id, req.fromToken, true);
|
|
29
|
+
const toToken = tokenLookupTable.lookup(chains_1.arbitrum.id, req.toToken, true);
|
|
30
|
+
this.routes = [
|
|
31
|
+
{
|
|
32
|
+
id: 'pendle',
|
|
33
|
+
inputTokenAmount: new Token_1.TokenAmount(fromToken, BigInt(req.fromAmount)),
|
|
34
|
+
outputTokenAmount: new Token_1.TokenAmount(toToken, BigInt(res.data.amountOut)),
|
|
35
|
+
minOutputTokenAmount: new Token_1.TokenAmount(toToken, BigInt(res.data.amountOut)).slipDown(req.slippage),
|
|
36
|
+
steps: [
|
|
37
|
+
{
|
|
38
|
+
fromTokenAmount: new Token_1.TokenAmount(fromToken, BigInt(req.fromAmount)),
|
|
39
|
+
toTokenAmount: new Token_1.TokenAmount(toToken, BigInt(res.data.amountOut)),
|
|
40
|
+
executionDuration: 0.25,
|
|
41
|
+
feeCosts: [],
|
|
42
|
+
gasCosts: [],
|
|
43
|
+
tool: {
|
|
44
|
+
key: 'pendle',
|
|
45
|
+
name: 'Pendle Swap',
|
|
46
|
+
logoURI: 'https://storage.googleapis.com/prod-pendle-bucket-a/images/assets/pro/ea33e392-1876-46a5-b7ce-c8434b5a7e71.svg',
|
|
47
|
+
},
|
|
48
|
+
},
|
|
49
|
+
],
|
|
50
|
+
},
|
|
51
|
+
];
|
|
52
|
+
this.rawResult = res;
|
|
53
|
+
}
|
|
54
|
+
getAggregatorName() {
|
|
55
|
+
return AggregatorHelper_1.AggregatorName.PENDLE;
|
|
56
|
+
}
|
|
57
|
+
selectRoute() {
|
|
58
|
+
return this.rawResult;
|
|
59
|
+
}
|
|
60
|
+
async getRouteData() {
|
|
61
|
+
const transferData = await this.helper.prepareTransferCall(this.req);
|
|
62
|
+
return {
|
|
63
|
+
transferData,
|
|
64
|
+
swapData: {
|
|
65
|
+
tokenSpent: this.req.fromToken,
|
|
66
|
+
amountSpent: BigInt(this.req.fromAmount),
|
|
67
|
+
extRouter: (0, addresses_1.toAddress)(this.rawResult.tx.to),
|
|
68
|
+
extCalldata: this.rawResult.tx.data,
|
|
69
|
+
},
|
|
70
|
+
};
|
|
71
|
+
}
|
|
72
|
+
}
|
|
73
|
+
exports.PendleSwapResult = PendleSwapResult;
|
|
74
|
+
class PendleSwapHelper {
|
|
75
|
+
pendleV2Sdk;
|
|
76
|
+
coreSdk;
|
|
77
|
+
publicClient;
|
|
78
|
+
tokenHelper;
|
|
79
|
+
depositBoxFactoryContract;
|
|
80
|
+
aggregatorName = AggregatorHelper_1.AggregatorName.PENDLE;
|
|
81
|
+
constructor(pendleV2Sdk, coreSdk, publicClient, tokenHelper, depositBoxFactoryContract) {
|
|
82
|
+
this.pendleV2Sdk = pendleV2Sdk;
|
|
83
|
+
this.coreSdk = coreSdk;
|
|
84
|
+
this.publicClient = publicClient;
|
|
85
|
+
this.tokenHelper = tokenHelper;
|
|
86
|
+
this.depositBoxFactoryContract = depositBoxFactoryContract;
|
|
87
|
+
}
|
|
88
|
+
async getChains() {
|
|
89
|
+
return [
|
|
90
|
+
{
|
|
91
|
+
chainId: chains_1.arbitrum.id,
|
|
92
|
+
name: 'Arbitrum',
|
|
93
|
+
key: 'arbitrum',
|
|
94
|
+
coin: 'ETH',
|
|
95
|
+
logoURI: 'https://raw.githubusercontent.com/lifinance/types/main/src/assets/icons/chains/arbitrum.svg',
|
|
96
|
+
},
|
|
97
|
+
];
|
|
98
|
+
}
|
|
99
|
+
async getTokenLookupTable() {
|
|
100
|
+
return this.tokenHelper.getTokenLookupTable();
|
|
101
|
+
}
|
|
102
|
+
async getRouteStatus(txHash) {
|
|
103
|
+
try {
|
|
104
|
+
const receipt = await this.publicClient.getTransactionReceipt({ hash: txHash });
|
|
105
|
+
return receipt.status === 'success' ? AggregatorHelper_1.AggregatorRouteStatus.DONE : AggregatorHelper_1.AggregatorRouteStatus.FAILED;
|
|
106
|
+
}
|
|
107
|
+
catch (error) {
|
|
108
|
+
if (error instanceof viem_1.TransactionReceiptNotFoundError) {
|
|
109
|
+
return AggregatorHelper_1.AggregatorRouteStatus.NOT_FOUND;
|
|
110
|
+
}
|
|
111
|
+
throw (0, AggregatorHelperErrors_1.classifyAggregatorError)(AggregatorHelper_1.AggregatorName.PENDLE, error, [500, 502, 503, 504], 'getRouteStatus', txHash, () => undefined);
|
|
112
|
+
}
|
|
113
|
+
}
|
|
114
|
+
async quoteDeposit(params) {
|
|
115
|
+
const { box } = await this.depositBoxFactoryContract.computeDepositBox(params.fromAddress, params.boxId);
|
|
116
|
+
const req = {
|
|
117
|
+
receiver: box,
|
|
118
|
+
inputs: [
|
|
119
|
+
{
|
|
120
|
+
token: params.fromToken,
|
|
121
|
+
amount: params.fromAmount.toString(),
|
|
122
|
+
},
|
|
123
|
+
],
|
|
124
|
+
tokenOut: params.toToken,
|
|
125
|
+
slippage: params.slippage,
|
|
126
|
+
aggregators: 'kyberswap,okx',
|
|
127
|
+
};
|
|
128
|
+
(0, utils_1.ensureDepositBoxAddress)(params.fromAddress, params.boxId, req.receiver);
|
|
129
|
+
try {
|
|
130
|
+
const [{ data }, tokenLookupTable] = await Promise.all([
|
|
131
|
+
this.pendleV2Sdk.sdk.sdkControllerPendleSwapV2(chains_1.arbitrum.id, req),
|
|
132
|
+
this.getTokenLookupTable(),
|
|
133
|
+
]);
|
|
134
|
+
return new PendleSwapResult({ req: params, res: data, tokenLookupTable, helper: this });
|
|
135
|
+
}
|
|
136
|
+
catch (error) {
|
|
137
|
+
throw (0, AggregatorHelperErrors_1.classifyAggregatorError)(AggregatorHelper_1.AggregatorName.PENDLE, error, [500, 502, 503, 504], 'quote', req, () => undefined);
|
|
138
|
+
}
|
|
139
|
+
}
|
|
140
|
+
async prepareTransferCall(params) {
|
|
141
|
+
try {
|
|
142
|
+
const { data } = await this.coreSdk.depositBox.depositBoxControllerPrepareTransferToBox({
|
|
143
|
+
chainId: chains_1.arbitrum.id,
|
|
144
|
+
token: params.fromToken,
|
|
145
|
+
amount: params.fromAmount.toString(),
|
|
146
|
+
root: params.fromAddress,
|
|
147
|
+
boxId: params.boxId,
|
|
148
|
+
});
|
|
149
|
+
return {
|
|
150
|
+
aggregatorName: AggregatorHelper_1.AggregatorName.BOROS,
|
|
151
|
+
approvalAddress: viem_1.zeroAddress,
|
|
152
|
+
chainId: chains_1.arbitrum.id,
|
|
153
|
+
calldata: data.calldata,
|
|
154
|
+
value: BigInt(data.value),
|
|
155
|
+
from: params.fromAddress,
|
|
156
|
+
to: (0, addresses_1.toAddress)(data.to),
|
|
157
|
+
};
|
|
158
|
+
}
|
|
159
|
+
catch (error) {
|
|
160
|
+
throw (0, AggregatorHelperErrors_1.classifyAggregatorError)(AggregatorHelper_1.AggregatorName.BOROS, error, [500, 502, 503, 504], 'prepareTransferCall', params, () => undefined);
|
|
161
|
+
}
|
|
162
|
+
}
|
|
163
|
+
}
|
|
164
|
+
exports.PendleSwapHelper = PendleSwapHelper;
|
|
165
|
+
__decorate([
|
|
166
|
+
(0, cacheDecorators_1.GlobalCache)({
|
|
167
|
+
generateLookupKey: () => 'PendleSwapHelper.getTokenLookupTable',
|
|
168
|
+
ttl_ms: constants_1.MILLISECONDS_IN_A_MINUTE * 10,
|
|
169
|
+
})
|
|
170
|
+
], PendleSwapHelper.prototype, "getTokenLookupTable", null);
|
|
171
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../src/entities/crossChainDeposit/aggregators/Pendle/index.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
import { Address } from 'viem';
|
|
2
|
+
import { Token } from '../..';
|
|
3
|
+
import { BorosCoreSdk } from '../../../backend/secrettune/module';
|
|
4
|
+
import { ChainId } from '../../../common/chainId';
|
|
5
|
+
import { TokenId } from '../../../types';
|
|
6
|
+
export declare class TokenHelper {
|
|
7
|
+
private readonly borosCoreSdk;
|
|
8
|
+
constructor(borosCoreSdk: BorosCoreSdk);
|
|
9
|
+
getTokens(params?: {
|
|
10
|
+
dstTokenId?: TokenId;
|
|
11
|
+
srcChainId?: ChainId;
|
|
12
|
+
}): Promise<Token[]>;
|
|
13
|
+
getTokenLookupTable(params?: {
|
|
14
|
+
dstTokenId?: TokenId;
|
|
15
|
+
}): Promise<TokenLookupTable>;
|
|
16
|
+
}
|
|
17
|
+
export declare class TokenLookupTable {
|
|
18
|
+
private readonly tokens;
|
|
19
|
+
private readonly tokenMap;
|
|
20
|
+
constructor(tokens: Token[]);
|
|
21
|
+
lookup(chainId: ChainId, tokenAddress: Address, checked?: false): Token | undefined;
|
|
22
|
+
lookup(chainId: ChainId, tokenAddress: Address, checked: true): Token;
|
|
23
|
+
}
|
|
@@ -0,0 +1,67 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
3
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
4
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
5
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
6
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
7
|
+
};
|
|
8
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
9
|
+
exports.TokenLookupTable = exports.TokenHelper = void 0;
|
|
10
|
+
const __1 = require("../..");
|
|
11
|
+
const cacheDecorators_1 = require("../../../common/cacheDecorators");
|
|
12
|
+
const constants_1 = require("../../../multicall/constants");
|
|
13
|
+
class TokenHelper {
|
|
14
|
+
borosCoreSdk;
|
|
15
|
+
constructor(borosCoreSdk) {
|
|
16
|
+
this.borosCoreSdk = borosCoreSdk;
|
|
17
|
+
}
|
|
18
|
+
async getTokens(params) {
|
|
19
|
+
const { dstTokenId, srcChainId } = params ?? {};
|
|
20
|
+
const { data } = await this.borosCoreSdk.depositBox.depositBoxControllerGetAssets();
|
|
21
|
+
const filterSrcChainId = srcChainId == null ? () => true : (asset) => asset.chainId === srcChainId;
|
|
22
|
+
const filterDstTokenId = dstTokenId == null
|
|
23
|
+
? () => true
|
|
24
|
+
: (() => {
|
|
25
|
+
const isExclusiveTokenId = data.assets.some((asset) => asset.dstTokenId === dstTokenId);
|
|
26
|
+
return isExclusiveTokenId
|
|
27
|
+
? (asset) => asset.dstTokenId === dstTokenId
|
|
28
|
+
: (asset) => asset.dstTokenId == null;
|
|
29
|
+
})();
|
|
30
|
+
return data.assets
|
|
31
|
+
.filter(filterSrcChainId)
|
|
32
|
+
.filter(filterDstTokenId)
|
|
33
|
+
.map((asset) => __1.Token.createFromBorosCore(asset));
|
|
34
|
+
}
|
|
35
|
+
async getTokenLookupTable(params) {
|
|
36
|
+
const tokens = await this.getTokens(params);
|
|
37
|
+
return new TokenLookupTable(tokens);
|
|
38
|
+
}
|
|
39
|
+
}
|
|
40
|
+
exports.TokenHelper = TokenHelper;
|
|
41
|
+
__decorate([
|
|
42
|
+
(0, cacheDecorators_1.GlobalCache)({
|
|
43
|
+
generateLookupKey: (_, [params]) => `TokenHelper.getTokens.${params?.dstTokenId}.${params?.srcChainId}`,
|
|
44
|
+
ttl_ms: constants_1.MILLISECONDS_IN_A_MINUTE * 10,
|
|
45
|
+
})
|
|
46
|
+
], TokenHelper.prototype, "getTokens", null);
|
|
47
|
+
class TokenLookupTable {
|
|
48
|
+
tokens;
|
|
49
|
+
tokenMap;
|
|
50
|
+
constructor(tokens) {
|
|
51
|
+
this.tokens = tokens;
|
|
52
|
+
this.tokenMap = new Map();
|
|
53
|
+
for (const token of tokens) {
|
|
54
|
+
this.tokenMap.set(`${token.chainId}-${token.address}`, token);
|
|
55
|
+
}
|
|
56
|
+
}
|
|
57
|
+
lookup(chainId, tokenAddress, checked) {
|
|
58
|
+
const key = `${chainId}-${tokenAddress}`;
|
|
59
|
+
const res = this.tokenMap.get(key);
|
|
60
|
+
if (checked && res == null) {
|
|
61
|
+
throw new Error(`Cannot find token ${tokenAddress} in the lookup table`);
|
|
62
|
+
}
|
|
63
|
+
return res;
|
|
64
|
+
}
|
|
65
|
+
}
|
|
66
|
+
exports.TokenLookupTable = TokenLookupTable;
|
|
67
|
+
//# sourceMappingURL=TokenHelper.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"TokenHelper.js","sourceRoot":"","sources":["../../../../src/entities/crossChainDeposit/helpers/TokenHelper.ts"],"names":[],"mappings":";;;;;;;;;AACA,6BAA8B;AAE9B,qEAA8D;AAE9D,4DAAwE;AAGxE,MAAa,WAAW;IACO;IAA7B,YAA6B,YAA0B;QAA1B,iBAAY,GAAZ,YAAY,CAAc;IAAG,CAAC;IAMrD,AAAN,KAAK,CAAC,SAAS,CAAC,MAAuD;QACrE,MAAM,EAAE,UAAU,EAAE,UAAU,EAAE,GAAG,MAAM,IAAI,EAAE,CAAC;QAChD,MAAM,EAAE,IAAI,EAAE,GAAG,MAAM,IAAI,CAAC,YAAY,CAAC,UAAU,CAAC,6BAA6B,EAAE,CAAC;QAEpF,MAAM,gBAAgB,GACpB,UAAU,IAAI,IAAI,CAAC,CAAC,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,KAA0B,EAAE,EAAE,CAAC,KAAK,CAAC,OAAO,KAAK,UAAU,CAAC;QACjG,MAAM,gBAAgB,GACpB,UAAU,IAAI,IAAI;YAChB,CAAC,CAAC,GAAG,EAAE,CAAC,IAAI;YACZ,CAAC,CAAC,CAAC,GAAG,EAAE;gBACJ,MAAM,kBAAkB,GAAG,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,UAAU,KAAK,UAAU,CAAC,CAAC;gBACxF,OAAO,kBAAkB;oBACvB,CAAC,CAAC,CAAC,KAA8B,EAAE,EAAE,CAAC,KAAK,CAAC,UAAU,KAAK,UAAU;oBACrE,CAAC,CAAC,CAAC,KAA8B,EAAE,EAAE,CAAC,KAAK,CAAC,UAAU,IAAI,IAAI,CAAC;YACnE,CAAC,CAAC,EAAE,CAAC;QAEX,OAAO,IAAI,CAAC,MAAM;aACf,MAAM,CAAC,gBAAgB,CAAC;aACxB,MAAM,CAAC,gBAAgB,CAAC;aACxB,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,SAAK,CAAC,mBAAmB,CAAC,KAAK,CAAC,CAAC,CAAC;IACtD,CAAC;IAED,KAAK,CAAC,mBAAmB,CAAC,MAAiC;QACzD,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC;QAC5C,OAAO,IAAI,gBAAgB,CAAC,MAAM,CAAC,CAAC;IACtC,CAAC;CACF;AAjCD,kCAiCC;AA1BO;IAJL,IAAA,6BAAW,EAA2B;QACrC,iBAAiB,EAAE,CAAC,CAAC,EAAE,CAAC,MAAM,CAAC,EAAE,EAAE,CAAC,yBAAyB,MAAM,EAAE,UAAU,IAAI,MAAM,EAAE,UAAU,EAAE;QACvG,MAAM,EAAE,oCAAwB,GAAG,EAAE;KACtC,CAAC;4CAqBD;AAQH,MAAa,gBAAgB;IAGE;IAFZ,QAAQ,CAAsC;IAE/D,YAA6B,MAAe;QAAf,WAAM,GAAN,MAAM,CAAS;QAC1C,IAAI,CAAC,QAAQ,GAAG,IAAI,GAAG,EAAkC,CAAC;QAC1D,KAAK,MAAM,KAAK,IAAI,MAAM,EAAE,CAAC;YAC3B,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,GAAG,KAAK,CAAC,OAAkB,IAAI,KAAK,CAAC,OAAO,EAAE,EAAE,KAAK,CAAC,CAAC;QAC3E,CAAC;IACH,CAAC;IAID,MAAM,CAAC,OAAgB,EAAE,YAAqB,EAAE,OAAiB;QAC/D,MAAM,GAAG,GAA4B,GAAG,OAAO,IAAI,YAAY,EAAE,CAAC;QAClE,MAAM,GAAG,GAAG,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;QACnC,IAAI,OAAO,IAAI,GAAG,IAAI,IAAI,EAAE,CAAC;YAC3B,MAAM,IAAI,KAAK,CAAC,qBAAqB,YAAY,sBAAsB,CAAC,CAAC;QAC3E,CAAC;QACD,OAAO,GAAG,CAAC;IACb,CAAC;CACF;AApBD,4CAoBC"}
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
import { Address, Hex } from 'viem';
|
|
2
|
+
export declare function computeDepositBoxAddress(root: Address, boxId: number): `0x${string}`;
|
|
3
|
+
export declare function ensureDepositBoxAddress(root: Address, boxId: number, box?: string): void;
|
|
4
|
+
export declare function ensureCalldataHasBoxAddress(calldata: Hex, box: Address): void;
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.computeDepositBoxAddress = computeDepositBoxAddress;
|
|
4
|
+
exports.ensureDepositBoxAddress = ensureDepositBoxAddress;
|
|
5
|
+
exports.ensureCalldataHasBoxAddress = ensureCalldataHasBoxAddress;
|
|
6
|
+
const viem_1 = require("viem");
|
|
7
|
+
const addresses_1 = require("../../../addresses");
|
|
8
|
+
function computeDepositBoxAddress(root, boxId) {
|
|
9
|
+
const bytecodeHash = (0, addresses_1.getDepositBoxCodeHash)();
|
|
10
|
+
const depositBoxFactoryAddress = (0, addresses_1.getDepositBoxFactoryAddress)();
|
|
11
|
+
const salt = (0, viem_1.keccak256)((0, viem_1.encodeAbiParameters)((0, viem_1.parseAbiParameters)('address, uint32'), [root, boxId]));
|
|
12
|
+
return (0, viem_1.getCreate2Address)({ from: depositBoxFactoryAddress, salt, bytecodeHash });
|
|
13
|
+
}
|
|
14
|
+
function ensureDepositBoxAddress(root, boxId, box) {
|
|
15
|
+
if (box == null || box.toLowerCase() !== (0, addresses_1.toAddress)(computeDepositBoxAddress(root, boxId))) {
|
|
16
|
+
throw new Error(`Deposit box address mismatch: root=${root}, boxId=${boxId}, box=${box}`);
|
|
17
|
+
}
|
|
18
|
+
}
|
|
19
|
+
function ensureCalldataHasBoxAddress(calldata, box) {
|
|
20
|
+
const normalizedBox = (0, addresses_1.toAddress)(box).slice(2);
|
|
21
|
+
if (!calldata.includes(normalizedBox)) {
|
|
22
|
+
throw new Error(`Calldata does not contain box address: box=${box}, calldata=${calldata}`);
|
|
23
|
+
}
|
|
24
|
+
}
|
|
25
|
+
//# sourceMappingURL=utils.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"utils.js","sourceRoot":"","sources":["../../../../src/entities/crossChainDeposit/helpers/utils.ts"],"names":[],"mappings":";;AAGA,4DAKC;AAED,0DAIC;AAED,kEAMC;AAtBD,+BAA2G;AAC3G,kDAAmG;AAEnG,SAAgB,wBAAwB,CAAC,IAAa,EAAE,KAAa;IACnE,MAAM,YAAY,GAAG,IAAA,iCAAqB,GAAE,CAAC;IAC7C,MAAM,wBAAwB,GAAG,IAAA,uCAA2B,GAAE,CAAC;IAC/D,MAAM,IAAI,GAAG,IAAA,gBAAS,EAAC,IAAA,0BAAmB,EAAC,IAAA,yBAAkB,EAAC,iBAAiB,CAAC,EAAE,CAAC,IAAI,EAAE,KAAK,CAAC,CAAC,CAAC,CAAC;IAClG,OAAO,IAAA,wBAAiB,EAAC,EAAE,IAAI,EAAE,wBAAwB,EAAE,IAAI,EAAE,YAAY,EAAE,CAAC,CAAC;AACnF,CAAC;AAED,SAAgB,uBAAuB,CAAC,IAAa,EAAE,KAAa,EAAE,GAAY;IAChF,IAAI,GAAG,IAAI,IAAI,IAAI,GAAG,CAAC,WAAW,EAAE,KAAK,IAAA,qBAAS,EAAC,wBAAwB,CAAC,IAAI,EAAE,KAAK,CAAC,CAAC,EAAE,CAAC;QAC1F,MAAM,IAAI,KAAK,CAAC,sCAAsC,IAAI,WAAW,KAAK,SAAS,GAAG,EAAE,CAAC,CAAC;IAC5F,CAAC;AACH,CAAC;AAED,SAAgB,2BAA2B,CAAC,QAAa,EAAE,GAAY;IACrE,MAAM,aAAa,GAAG,IAAA,qBAAS,EAAC,GAAG,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;IAE9C,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,aAAa,CAAC,EAAE,CAAC;QACtC,MAAM,IAAI,KAAK,CAAC,8CAA8C,GAAG,cAAc,QAAQ,EAAE,CAAC,CAAC;IAC7F,CAAC;AACH,CAAC"}
|
|
@@ -14,10 +14,6 @@ var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
|
14
14
|
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
15
15
|
};
|
|
16
16
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
|
-
__exportStar(require("./
|
|
18
|
-
__exportStar(require("./
|
|
19
|
-
__exportStar(require("./strategyExecution"), exports);
|
|
20
|
-
__exportStar(require("./strategyApr"), exports);
|
|
21
|
-
__exportStar(require("./exchangeFees"), exports);
|
|
22
|
-
__exportStar(require("./marginCalculator"), exports);
|
|
17
|
+
__exportStar(require("./Depositor"), exports);
|
|
18
|
+
__exportStar(require("./AggregatorHelper"), exports);
|
|
23
19
|
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/entities/crossChainDeposit/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,8CAA4B;AAC5B,qDAAmC"}
|
package/dist/entities/index.d.ts
CHANGED
package/dist/entities/index.js
CHANGED
|
@@ -24,5 +24,6 @@ __exportStar(require("./multiTokenMerkleDistributor"), exports);
|
|
|
24
24
|
__exportStar(require("./wrappedEth"), exports);
|
|
25
25
|
__exportStar(require("./subaccount"), exports);
|
|
26
26
|
__exportStar(require("./vePendle"), exports);
|
|
27
|
-
__exportStar(require("./
|
|
27
|
+
__exportStar(require("./crossChainDeposit"), exports);
|
|
28
|
+
__exportStar(require("./token"), exports);
|
|
28
29
|
//# sourceMappingURL=index.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/entities/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,0CAAwB;AACxB,2CAAyB;AACzB,6CAA2B;AAC3B,wCAAsB;AACtB,+CAA6B;AAC7B,gDAA8B;AAC9B,gEAA8C;AAC9C,+CAA6B;AAC7B,+CAA6B;AAC7B,6CAA2B;AAC3B
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/entities/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,0CAAwB;AACxB,2CAAyB;AACzB,6CAA2B;AAC3B,wCAAsB;AACtB,+CAA6B;AAC7B,gDAA8B;AAC9B,gEAA8C;AAC9C,+CAA6B;AAC7B,+CAA6B;AAC7B,6CAA2B;AAC3B,sDAAoC;AACpC,0CAAwB"}
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
import { Address, PublicClient } from 'viem';
|
|
2
|
+
import { AssetResponse } from '../../backend/secrettune/BorosCoreSDK';
|
|
3
|
+
import { LifiTokenResponse } from '../crossChainDeposit/aggregators/Lifi/types';
|
|
4
|
+
export declare class Token {
|
|
5
|
+
readonly chainId: number;
|
|
6
|
+
readonly address: Address;
|
|
7
|
+
readonly decimals: number;
|
|
8
|
+
readonly symbol: string;
|
|
9
|
+
readonly name: string;
|
|
10
|
+
readonly logoURI?: string | undefined;
|
|
11
|
+
readonly priceUSD?: number | undefined;
|
|
12
|
+
constructor(chainId: number, address: Address, decimals: number, symbol: string, name: string, logoURI?: string | undefined, priceUSD?: number | undefined);
|
|
13
|
+
static createFromLifi(token: LifiTokenResponse): Token;
|
|
14
|
+
static createFromBorosCore(token: AssetResponse & {
|
|
15
|
+
chainId?: number;
|
|
16
|
+
}): Token;
|
|
17
|
+
balanceOf(address: Address, params: {
|
|
18
|
+
client: PublicClient;
|
|
19
|
+
}): Promise<TokenAmount>;
|
|
20
|
+
allowance(address: Address, spender: Address, params: {
|
|
21
|
+
client: PublicClient;
|
|
22
|
+
}): Promise<TokenAmount>;
|
|
23
|
+
}
|
|
24
|
+
export declare class TokenAmount {
|
|
25
|
+
readonly token: Token;
|
|
26
|
+
readonly amount: bigint;
|
|
27
|
+
constructor(token: Token, amount: bigint);
|
|
28
|
+
static createFromLifi(token: LifiTokenResponse, amount: string): TokenAmount;
|
|
29
|
+
static createFromBorosCore(token: AssetResponse, amount: string): TokenAmount;
|
|
30
|
+
slipDown(slippage: number): TokenAmount;
|
|
31
|
+
}
|
|
@@ -0,0 +1,61 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.TokenAmount = exports.Token = void 0;
|
|
4
|
+
const boros_offchain_math_1 = require("@pendle/boros-offchain-math");
|
|
5
|
+
const chains_1 = require("viem/chains");
|
|
6
|
+
const addresses_1 = require("../../addresses");
|
|
7
|
+
const erc20_1 = require("../../contracts/erc20");
|
|
8
|
+
class Token {
|
|
9
|
+
chainId;
|
|
10
|
+
address;
|
|
11
|
+
decimals;
|
|
12
|
+
symbol;
|
|
13
|
+
name;
|
|
14
|
+
logoURI;
|
|
15
|
+
priceUSD;
|
|
16
|
+
constructor(chainId, address, decimals, symbol, name, logoURI, priceUSD) {
|
|
17
|
+
this.chainId = chainId;
|
|
18
|
+
this.address = address;
|
|
19
|
+
this.decimals = decimals;
|
|
20
|
+
this.symbol = symbol;
|
|
21
|
+
this.name = name;
|
|
22
|
+
this.logoURI = logoURI;
|
|
23
|
+
this.priceUSD = priceUSD;
|
|
24
|
+
}
|
|
25
|
+
static createFromLifi(token) {
|
|
26
|
+
return new Token(token.chainId, token.address, token.decimals, token.symbol, token.name, token.logoURI, token.priceUSD != null ? Number(token.priceUSD) : undefined);
|
|
27
|
+
}
|
|
28
|
+
static createFromBorosCore(token) {
|
|
29
|
+
return new Token(token?.chainId ?? chains_1.arbitrum.id, (0, addresses_1.toAddress)(token.address), token.decimals, token.symbol, token.name, token.metadata.icon, Number(token.usdPrice));
|
|
30
|
+
}
|
|
31
|
+
async balanceOf(address, params) {
|
|
32
|
+
const erc20 = erc20_1.ERC20.create(this.address, { client: params.client, multicall: undefined });
|
|
33
|
+
const balance = await erc20.balanceOf(address);
|
|
34
|
+
return new TokenAmount(this, balance);
|
|
35
|
+
}
|
|
36
|
+
async allowance(address, spender, params) {
|
|
37
|
+
const erc20 = erc20_1.ERC20.create(this.address, { client: params.client, multicall: undefined });
|
|
38
|
+
const allowance = await erc20.allowance(address, spender);
|
|
39
|
+
return new TokenAmount(this, allowance);
|
|
40
|
+
}
|
|
41
|
+
}
|
|
42
|
+
exports.Token = Token;
|
|
43
|
+
class TokenAmount {
|
|
44
|
+
token;
|
|
45
|
+
amount;
|
|
46
|
+
constructor(token, amount) {
|
|
47
|
+
this.token = token;
|
|
48
|
+
this.amount = amount;
|
|
49
|
+
}
|
|
50
|
+
static createFromLifi(token, amount) {
|
|
51
|
+
return new TokenAmount(Token.createFromLifi(token), BigInt(amount));
|
|
52
|
+
}
|
|
53
|
+
static createFromBorosCore(token, amount) {
|
|
54
|
+
return new TokenAmount(Token.createFromBorosCore(token), BigInt(amount));
|
|
55
|
+
}
|
|
56
|
+
slipDown(slippage) {
|
|
57
|
+
return new TokenAmount(this.token, boros_offchain_math_1.FixedX18.fromRawValue(this.amount).mulDown(boros_offchain_math_1.FixedX18.fromNumber(1 - slippage)).value);
|
|
58
|
+
}
|
|
59
|
+
}
|
|
60
|
+
exports.TokenAmount = TokenAmount;
|
|
61
|
+
//# sourceMappingURL=Token.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Token.js","sourceRoot":"","sources":["../../../src/entities/token/Token.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export * from './Token';
|
|
@@ -0,0 +1,18 @@
|
|
|
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 __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
14
|
+
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
15
|
+
};
|
|
16
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
|
+
__exportStar(require("./Token"), exports);
|
|
18
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/entities/token/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,0CAAwB"}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.PendleSdkError = void 0;
|
|
4
|
+
class PendleSdkError extends Error {
|
|
5
|
+
cause;
|
|
6
|
+
constructor(message, params) {
|
|
7
|
+
super(message, params);
|
|
8
|
+
const cause = params?.cause;
|
|
9
|
+
if (!this.cause && cause)
|
|
10
|
+
this.cause = cause;
|
|
11
|
+
Object.setPrototypeOf(this, this.constructor.prototype);
|
|
12
|
+
}
|
|
13
|
+
}
|
|
14
|
+
exports.PendleSdkError = PendleSdkError;
|
|
15
|
+
//# sourceMappingURL=PendleSdkError.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"PendleSdkError.js","sourceRoot":"","sources":["../../src/errors/PendleSdkError.ts"],"names":[],"mappings":";;;AAaA,MAAa,cAAe,SAAQ,KAAK;IAM9B,KAAK,CAAW;IAEzB,YAAY,OAAe,EAAE,MAA6B;QACxD,KAAK,CAAC,OAAO,EAAE,MAAM,CAAC,CAAC;QAEvB,MAAM,KAAK,GAAG,MAAM,EAAE,KAAK,CAAC;QAC5B,IAAI,CAAC,IAAI,CAAC,KAAK,IAAI,KAAK;YAAE,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QAI7C,MAAM,CAAC,cAAc,CAAC,IAAI,EAAE,IAAI,CAAC,WAAW,CAAC,SAAS,CAAC,CAAC;IAC1D,CAAC;CACF;AAlBD,wCAkBC"}
|
package/dist/types/common.d.ts
CHANGED
|
@@ -66,6 +66,22 @@ export type ApproveAgentMessage = {
|
|
|
66
66
|
expiry: bigint;
|
|
67
67
|
nonce: bigint;
|
|
68
68
|
};
|
|
69
|
+
export type DepositFromBoxMessage = {
|
|
70
|
+
root: Address;
|
|
71
|
+
boxId: number;
|
|
72
|
+
tokenSpent: Address;
|
|
73
|
+
maxAmountSpent: bigint;
|
|
74
|
+
accountId: number;
|
|
75
|
+
tokenId: number;
|
|
76
|
+
marketId: number;
|
|
77
|
+
minDepositAmount: bigint;
|
|
78
|
+
payTreasuryAmount: bigint;
|
|
79
|
+
swapExtRouter: Address;
|
|
80
|
+
swapApprove: Address;
|
|
81
|
+
swapCalldata: Hex;
|
|
82
|
+
expiry: bigint;
|
|
83
|
+
salt: bigint;
|
|
84
|
+
};
|
|
69
85
|
export type SetAccManagerStruct = {
|
|
70
86
|
root: Address;
|
|
71
87
|
accountId: number;
|
|
@@ -1,3 +1,3 @@
|
|
|
1
1
|
export { bulkSignWithAgent, bulkSignWithAgentV2, getAgentSignature, signCancelStopOrderRequest, signCancelStopOrderV2Request, signStopOrderRequest, signUpdateSettings, signWithAgent, type SignedAgentExecution, } from './agent';
|
|
2
2
|
export { hashStopOrderRequest } from './common';
|
|
3
|
-
export { signApproveAgentMessage, signSetAccManagerMessage } from './sensitive';
|
|
3
|
+
export { signApproveAgentMessage, signDepositFromBoxMessage, signSetAccManagerMessage, } from './sensitive';
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.signSetAccManagerMessage = exports.signApproveAgentMessage = exports.hashStopOrderRequest = exports.signWithAgent = exports.signUpdateSettings = exports.signStopOrderRequest = exports.signCancelStopOrderV2Request = exports.signCancelStopOrderRequest = exports.getAgentSignature = exports.bulkSignWithAgentV2 = exports.bulkSignWithAgent = void 0;
|
|
3
|
+
exports.signSetAccManagerMessage = exports.signDepositFromBoxMessage = exports.signApproveAgentMessage = exports.hashStopOrderRequest = exports.signWithAgent = exports.signUpdateSettings = exports.signStopOrderRequest = exports.signCancelStopOrderV2Request = exports.signCancelStopOrderRequest = exports.getAgentSignature = exports.bulkSignWithAgentV2 = exports.bulkSignWithAgent = void 0;
|
|
4
4
|
var agent_1 = require("./agent");
|
|
5
5
|
Object.defineProperty(exports, "bulkSignWithAgent", { enumerable: true, get: function () { return agent_1.bulkSignWithAgent; } });
|
|
6
6
|
Object.defineProperty(exports, "bulkSignWithAgentV2", { enumerable: true, get: function () { return agent_1.bulkSignWithAgentV2; } });
|
|
@@ -14,5 +14,6 @@ var common_1 = require("./common");
|
|
|
14
14
|
Object.defineProperty(exports, "hashStopOrderRequest", { enumerable: true, get: function () { return common_1.hashStopOrderRequest; } });
|
|
15
15
|
var sensitive_1 = require("./sensitive");
|
|
16
16
|
Object.defineProperty(exports, "signApproveAgentMessage", { enumerable: true, get: function () { return sensitive_1.signApproveAgentMessage; } });
|
|
17
|
+
Object.defineProperty(exports, "signDepositFromBoxMessage", { enumerable: true, get: function () { return sensitive_1.signDepositFromBoxMessage; } });
|
|
17
18
|
Object.defineProperty(exports, "signSetAccManagerMessage", { enumerable: true, get: function () { return sensitive_1.signSetAccManagerMessage; } });
|
|
18
19
|
//# sourceMappingURL=index.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/utils/signing/index.ts"],"names":[],"mappings":";;;AAAA,iCAUiB;AATf,0GAAA,iBAAiB,OAAA;AACjB,4GAAA,mBAAmB,OAAA;AACnB,0GAAA,iBAAiB,OAAA;AACjB,mHAAA,0BAA0B,OAAA;AAC1B,qHAAA,4BAA4B,OAAA;AAC5B,6GAAA,oBAAoB,OAAA;AACpB,2GAAA,kBAAkB,OAAA;AAClB,sGAAA,aAAa,OAAA;AAGf,mCAAgD;AAAvC,8GAAA,oBAAoB,OAAA;AAC7B,
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/utils/signing/index.ts"],"names":[],"mappings":";;;AAAA,iCAUiB;AATf,0GAAA,iBAAiB,OAAA;AACjB,4GAAA,mBAAmB,OAAA;AACnB,0GAAA,iBAAiB,OAAA;AACjB,mHAAA,0BAA0B,OAAA;AAC1B,qHAAA,4BAA4B,OAAA;AAC5B,6GAAA,oBAAoB,OAAA;AACpB,2GAAA,kBAAkB,OAAA;AAClB,sGAAA,aAAa,OAAA;AAGf,mCAAgD;AAAvC,8GAAA,oBAAoB,OAAA;AAC7B,yCAIqB;AAHnB,oHAAA,uBAAuB,OAAA;AACvB,sHAAA,yBAAyB,OAAA;AACzB,qHAAA,wBAAwB,OAAA"}
|
|
@@ -1,4 +1,5 @@
|
|
|
1
1
|
import { WalletClient } from 'viem';
|
|
2
|
-
import { ApproveAgentMessage, SetAccManagerStruct } from '../../types';
|
|
2
|
+
import { ApproveAgentMessage, DepositFromBoxMessage, SetAccManagerStruct } from '../../types';
|
|
3
3
|
export declare function signSetAccManagerMessage(wallet: WalletClient, message: SetAccManagerStruct): Promise<`0x${string}`>;
|
|
4
4
|
export declare function signApproveAgentMessage(wallet: WalletClient, message: ApproveAgentMessage): Promise<`0x${string}`>;
|
|
5
|
+
export declare function signDepositFromBoxMessage(wallet: WalletClient, message: DepositFromBoxMessage): Promise<`0x${string}`>;
|