@lombard.finance/sdk 5.0.3 → 5.0.5
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/CHANGELOG.md +28 -0
- package/dist/api-functions/storeNetworkFeeSignature/storeNetworkFeeSignature.d.ts +13 -0
- package/dist/api-functions/storeNetworkFeeSignature/storeNetworkFeeSignature.d.ts.map +1 -1
- package/dist/api.cjs +1 -1
- package/dist/api.js +12 -11
- package/dist/api.js.map +1 -1
- package/dist/btc.cjs +1 -1
- package/dist/btc.js +2 -2
- package/dist/chains/btc/actions/stake/config/evm.d.ts.map +1 -1
- package/dist/chains/evm/EvmActions.d.ts +15 -6
- package/dist/chains/evm/EvmActions.d.ts.map +1 -1
- package/dist/chains/evm/actions/redeem/EvmRedeem.d.ts +15 -8
- package/dist/chains/evm/actions/redeem/EvmRedeem.d.ts.map +1 -1
- package/dist/chains/evm/actions/redeem/factory.d.ts +6 -2
- package/dist/chains/evm/actions/redeem/factory.d.ts.map +1 -1
- package/dist/chains/evm/actions/redeem/types.d.ts +10 -6
- package/dist/chains/evm/actions/redeem/types.d.ts.map +1 -1
- package/dist/chunks/{BtcActions-BE75KQhS.js → BtcActions-BDTnGE1D.js} +235 -216
- package/dist/chunks/{BtcActions-BE75KQhS.js.map → BtcActions-BDTnGE1D.js.map} +1 -1
- package/dist/chunks/BtcActions-DZs5eXTb.cjs +2 -0
- package/dist/chunks/{BtcActions-hLkixDlL.cjs.map → BtcActions-DZs5eXTb.cjs.map} +1 -1
- package/dist/chunks/{EvmActions-DCy8q_l4.js → EvmActions-8VeTiWrl.js} +355 -390
- package/dist/chunks/EvmActions-8VeTiWrl.js.map +1 -0
- package/dist/chunks/EvmActions-CEC3vNtR.cjs +7 -0
- package/dist/chunks/EvmActions-CEC3vNtR.cjs.map +1 -0
- package/dist/chunks/depositStatus-DUXMloTa.cjs +2 -0
- package/dist/chunks/{depositStatus-CeoqUgM5.cjs.map → depositStatus-DUXMloTa.cjs.map} +1 -1
- package/dist/chunks/{depositStatus-CacTFWfJ.js → depositStatus-hmXphYhu.js} +2 -2
- package/dist/chunks/{depositStatus-CacTFWfJ.js.map → depositStatus-hmXphYhu.js.map} +1 -1
- package/dist/chunks/{events-Cu4qfdgE.js → events-22AhTtaL.js} +42 -41
- package/dist/chunks/{events-Cu4qfdgE.js.map → events-22AhTtaL.js.map} +1 -1
- package/dist/chunks/events-CW_OMnKf.cjs +2 -0
- package/dist/chunks/{events-C3tg6XPm.cjs.map → events-CW_OMnKf.cjs.map} +1 -1
- package/dist/chunks/getNetworkFeeSignature-DqKLslZc.cjs +2 -0
- package/dist/chunks/getNetworkFeeSignature-DqKLslZc.cjs.map +1 -0
- package/dist/chunks/getNetworkFeeSignature-FuDJWrMC.js +38 -0
- package/dist/chunks/getNetworkFeeSignature-FuDJWrMC.js.map +1 -0
- package/dist/chunks/statusConstants-Cz77HXnT.cjs +2 -0
- package/dist/chunks/{statusConstants-BPtrxbYC.cjs.map → statusConstants-Cz77HXnT.cjs.map} +1 -1
- package/dist/chunks/{statusConstants-8pqtLXvX.js → statusConstants-DZlImWu7.js} +3 -3
- package/dist/chunks/{statusConstants-8pqtLXvX.js.map → statusConstants-DZlImWu7.js.map} +1 -1
- package/dist/chunks/storeNetworkFeeSignature-BaG3AU8U.cjs +2 -0
- package/dist/chunks/storeNetworkFeeSignature-BaG3AU8U.cjs.map +1 -0
- package/dist/chunks/storeNetworkFeeSignature-sCt4_nHr.js +52 -0
- package/dist/chunks/storeNetworkFeeSignature-sCt4_nHr.js.map +1 -0
- package/dist/common/chains.d.ts +3 -0
- package/dist/common/chains.d.ts.map +1 -1
- package/dist/core.cjs +1 -1
- package/dist/core.js +4 -4
- package/dist/evm.cjs +1 -1
- package/dist/evm.js +2 -2
- package/dist/index.cjs +1 -1
- package/dist/index.d.ts +1 -1
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +264 -263
- package/package.json +1 -1
- package/dist/chunks/BtcActions-hLkixDlL.cjs +0 -2
- package/dist/chunks/EvmActions-DCy8q_l4.js.map +0 -1
- package/dist/chunks/EvmActions-DIkhiG2i.cjs +0 -7
- package/dist/chunks/EvmActions-DIkhiG2i.cjs.map +0 -1
- package/dist/chunks/constants-D1FnS2Z8.js +0 -6
- package/dist/chunks/constants-D1FnS2Z8.js.map +0 -1
- package/dist/chunks/constants-ueShGH9R.cjs +0 -2
- package/dist/chunks/constants-ueShGH9R.cjs.map +0 -1
- package/dist/chunks/depositStatus-CeoqUgM5.cjs +0 -2
- package/dist/chunks/events-C3tg6XPm.cjs +0 -2
- package/dist/chunks/statusConstants-BPtrxbYC.cjs +0 -2
- package/dist/chunks/storeNetworkFeeSignature-Z0NcQyIn.cjs +0 -2
- package/dist/chunks/storeNetworkFeeSignature-Z0NcQyIn.cjs.map +0 -1
- package/dist/chunks/storeNetworkFeeSignature-ZdHcFmfP.js +0 -65
- package/dist/chunks/storeNetworkFeeSignature-ZdHcFmfP.js.map +0 -1
package/CHANGELOG.md
CHANGED
|
@@ -1,3 +1,31 @@
|
|
|
1
|
+
# 5.0.5
|
|
2
|
+
|
|
3
|
+
### Fixed
|
|
4
|
+
|
|
5
|
+
- `sdk.chain.evm.redeem()` (BTC.b → native BTC) no longer triggers a network-fee authorization step. The action burns BTC.b on the EVM source chain and releases native BTC on the Bitcoin network — there is no auto-mint on an EVM destination, so the auto-mint fee model (used by BTC Deposit and EVM Unstake → BTC.b on Ethereum/Sepolia) does not apply. `prepare()` now transitions `IDLE → READY` directly on every source chain, including Ethereum and Sepolia, eliminating the unexpected EIP-712 signing prompt and the `GET /api/v1/claimer/get-user-signature` call that previously fired on those chains.
|
|
6
|
+
|
|
7
|
+
### Deprecated
|
|
8
|
+
|
|
9
|
+
- `IEvmRedeem.authorizeFee()` is now a deprecated **safe no-op** kept for backwards compatibility with consumers that subscribed to the previous status machine. The status never reaches `NEEDS_FEE_AUTHORIZATION`, and calling `authorizeFee()` resolves immediately without touching the wallet, the API, or the action state — so legacy code paths that still invoke it will no longer fail.
|
|
10
|
+
|
|
11
|
+
### Docs
|
|
12
|
+
|
|
13
|
+
- Removed stale JSDoc on `EvmActions.redeem()`, `EvmRedeem` types, and the redeem factory that described a non-existent `LBTC → BTC.b` same-chain unwrap. The actual `LBTC → BTC.b` flow lives in `sdk.chain.evm.unstake()` with `assetOut: AssetId.BTCb`.
|
|
14
|
+
|
|
15
|
+
---
|
|
16
|
+
|
|
17
|
+
# 5.0.4
|
|
18
|
+
|
|
19
|
+
### Fixed
|
|
20
|
+
|
|
21
|
+
- BTC stake fee-auth flow now recovers when the BFF reports that a fee signature already exists for the account (`FeeSignatureAlreadyExistsError`, code 6). Previously this surfaced as a confusing error after the user had already signed. The SDK now refetches the stored signature and continues the workflow. If the BFF reports a duplicate but will not return the existing record, a clearer error message is surfaced instead.
|
|
22
|
+
|
|
23
|
+
### Added
|
|
24
|
+
|
|
25
|
+
- Exported `FeeSignatureAlreadyExistsError` from the package root so consumers can branch on this specific failure mode when calling the underlying fee-auth APIs directly.
|
|
26
|
+
|
|
27
|
+
---
|
|
28
|
+
|
|
1
29
|
# 5.0.3
|
|
2
30
|
|
|
3
31
|
### Fixed
|
|
@@ -1,5 +1,18 @@
|
|
|
1
1
|
import { IEnvParam } from '../../common/parameters';
|
|
2
2
|
export type IStoreNetworkFeeSignatureStatus = 'success';
|
|
3
|
+
/**
|
|
4
|
+
* Thrown when the Lombard API refuses to store a new fee signature because
|
|
5
|
+
* an active one already exists for the user. The caller should re-fetch the
|
|
6
|
+
* existing signature (see `getNetworkFeeSignature`) and proceed with it
|
|
7
|
+
* instead of treating this as a fatal authorization failure.
|
|
8
|
+
*
|
|
9
|
+
* The Lombard API returns this as `{ code: 6, message: "Active signature
|
|
10
|
+
* already exists for this user" }`.
|
|
11
|
+
*/
|
|
12
|
+
export declare class FeeSignatureAlreadyExistsError extends Error {
|
|
13
|
+
readonly code = 6;
|
|
14
|
+
constructor(message?: string);
|
|
15
|
+
}
|
|
3
16
|
export interface IStoreNetworkFeeSignatureParams extends IEnvParam {
|
|
4
17
|
/**
|
|
5
18
|
* signature
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"storeNetworkFeeSignature.d.ts","sourceRoot":"","sources":["../../../src/api-functions/storeNetworkFeeSignature/storeNetworkFeeSignature.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,SAAS,EAAE,MAAM,yBAAyB,CAAC;AAGpD,MAAM,MAAM,+BAA+B,GAAG,SAAS,CAAC;AAMxD,MAAM,WAAW,+BAAgC,SAAQ,SAAS;IAChE;;OAEG;IACH,SAAS,EAAE,MAAM,CAAC;IAClB;;OAEG;IACH,SAAS,EAAE,MAAM,CAAC;IAClB;;OAEG;IACH,OAAO,EAAE,MAAM,CAAC;IAChB;;OAEG;IACH,YAAY,CAAC,EAAE,MAAM,CAAC;CACvB;AAED;;;;;;;;;;GAUG;AACH,wBAAsB,wBAAwB,CAAC,EAC7C,SAAS,EACT,SAAS,EACT,OAAO,EACP,GAAG,EACH,YAAY,GACb,EAAE,+BAA+B,GAAG,OAAO,CAAC,+BAA+B,CAAC,
|
|
1
|
+
{"version":3,"file":"storeNetworkFeeSignature.d.ts","sourceRoot":"","sources":["../../../src/api-functions/storeNetworkFeeSignature/storeNetworkFeeSignature.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,SAAS,EAAE,MAAM,yBAAyB,CAAC;AAGpD,MAAM,MAAM,+BAA+B,GAAG,SAAS,CAAC;AAMxD;;;;;;;;GAQG;AACH,qBAAa,8BAA+B,SAAQ,KAAK;IACvD,QAAQ,CAAC,IAAI,KAAK;gBACN,OAAO,SAAkD;CAItE;AAED,MAAM,WAAW,+BAAgC,SAAQ,SAAS;IAChE;;OAEG;IACH,SAAS,EAAE,MAAM,CAAC;IAClB;;OAEG;IACH,SAAS,EAAE,MAAM,CAAC;IAClB;;OAEG;IACH,OAAO,EAAE,MAAM,CAAC;IAChB;;OAEG;IACH,YAAY,CAAC,EAAE,MAAM,CAAC;CACvB;AAED;;;;;;;;;;GAUG;AACH,wBAAsB,wBAAwB,CAAC,EAC7C,SAAS,EACT,SAAS,EACT,OAAO,EACP,GAAG,EACH,YAAY,GACb,EAAE,+BAA+B,GAAG,OAAO,CAAC,+BAA+B,CAAC,CAmC5E"}
|
package/dist/api.cjs
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const e=require("./chunks/ReferralsClient-B65Nsk21.cjs"),s=require("./chunks/getUserStakeAndBakeSignature-Cwwx89pR.cjs"),
|
|
1
|
+
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const e=require("./chunks/ReferralsClient-B65Nsk21.cjs"),s=require("./chunks/getUserStakeAndBakeSignature-Cwwx89pR.cjs"),i=require("./chunks/get-exchange-ratio-DGztGO7i.cjs"),t=require("./chunks/depositStatus-DUXMloTa.cjs"),r=require("./chunks/getNetworkFeeSignature-DqKLslZc.cjs"),a=require("./chunks/storeNetworkFeeSignature-BaG3AU8U.cjs");exports.ENotarizationStatus=e.ENotarizationStatus;exports.ESessionState=e.ESessionState;exports.PayoutTxStatus=e.PayoutTxStatus;exports.ReferralsClient=e.ReferralsClient;exports.fetchBTCbDeposits=e.fetchBTCbDeposits;exports.fetchDirectDeposits=e.fetchDirectDeposits;exports.fetchUnstakesByAddress=e.fetchUnstakesByAddress;exports.getDepositBtcAddress=e.getDepositBtcAddress;exports.getDepositBtcAddresses=e.getDepositBtcAddresses;exports.getDepositsByAddress=e.getDepositsByAddress;exports.getLuxSeason1Points=e.getLuxSeason1Points;exports.getLuxSeason2Points=e.getLuxSeason2Points;exports.getPointsByAddress=e.getPointsByAddress;exports.getUnstakesByAddress=e.getUnstakesByAddress;exports.storeStakeAndBakeSignature=e.storeStakeAndBakeSignature;exports.SANCTIONED_ADDRESS=s.SANCTIONED_ADDRESS;exports.generateDepositBtcAddress=s.generateDepositBtcAddress;exports.getUserStakeAndBakeSignature=s.getUserStakeAndBakeSignature;exports.getExchangeRatio=i.getExchangeRatio;exports.MIN_CLAIM_AMOUNT_BTC=t.MIN_CLAIM_AMOUNT_BTC;exports.REQUIRED_CONFIRMATIONS=t.REQUIRED_CONFIRMATIONS;exports.calcConfirmations=t.calcConfirmations;exports.depositRequiresAction=t.depositRequiresAction;exports.getConfirmationProgress=t.getConfirmationProgress;exports.getDepositStatus=t.getDepositStatus;exports.getDepositStatusDisplay=t.getDepositStatusDisplay;exports.getLBTCExchangeRate=t.getLBTCExchangeRate;exports.isDepositClaimable=t.isDepositClaimable;exports.isDepositPending=t.isDepositPending;exports.isDepositTerminal=t.isDepositTerminal;exports.setReferral=t.setReferral;exports.getNetworkFeeSignature=r.getNetworkFeeSignature;exports.storeNetworkFeeSignature=a.storeNetworkFeeSignature;
|
|
2
2
|
//# sourceMappingURL=api.cjs.map
|
package/dist/api.js
CHANGED
|
@@ -1,8 +1,9 @@
|
|
|
1
|
-
import { ENotarizationStatus as s, ESessionState as o, PayoutTxStatus as r, ReferralsClient as i, fetchBTCbDeposits as a, fetchDirectDeposits as n, fetchUnstakesByAddress as g, getDepositBtcAddress as
|
|
2
|
-
import { SANCTIONED_ADDRESS as x, generateDepositBtcAddress as
|
|
1
|
+
import { ENotarizationStatus as s, ESessionState as o, PayoutTxStatus as r, ReferralsClient as i, fetchBTCbDeposits as a, fetchDirectDeposits as n, fetchUnstakesByAddress as g, getDepositBtcAddress as p, getDepositBtcAddresses as d, getDepositsByAddress as S, getLuxSeason1Points as D, getLuxSeason2Points as A, getPointsByAddress as f, getUnstakesByAddress as c, storeStakeAndBakeSignature as u } from "./chunks/ReferralsClient-BNwB6wO4.js";
|
|
2
|
+
import { SANCTIONED_ADDRESS as x, generateDepositBtcAddress as m, getUserStakeAndBakeSignature as C } from "./chunks/getUserStakeAndBakeSignature-CQsvL79O.js";
|
|
3
3
|
import { getExchangeRatio as R } from "./chunks/get-exchange-ratio-BvPUfcIQ.js";
|
|
4
|
-
import { MIN_CLAIM_AMOUNT_BTC as l, REQUIRED_CONFIRMATIONS as E, calcConfirmations as T, depositRequiresAction as y, getConfirmationProgress as I, getDepositStatus as P, getDepositStatusDisplay as h, getLBTCExchangeRate as U, isDepositClaimable as _, isDepositPending as L, isDepositTerminal as M, setReferral as O } from "./chunks/depositStatus-
|
|
5
|
-
import { getNetworkFeeSignature as b
|
|
4
|
+
import { MIN_CLAIM_AMOUNT_BTC as l, REQUIRED_CONFIRMATIONS as E, calcConfirmations as T, depositRequiresAction as y, getConfirmationProgress as I, getDepositStatus as P, getDepositStatusDisplay as h, getLBTCExchangeRate as U, isDepositClaimable as _, isDepositPending as L, isDepositTerminal as M, setReferral as O } from "./chunks/depositStatus-hmXphYhu.js";
|
|
5
|
+
import { getNetworkFeeSignature as b } from "./chunks/getNetworkFeeSignature-FuDJWrMC.js";
|
|
6
|
+
import { storeNetworkFeeSignature as q } from "./chunks/storeNetworkFeeSignature-sCt4_nHr.js";
|
|
6
7
|
export {
|
|
7
8
|
s as ENotarizationStatus,
|
|
8
9
|
o as ESessionState,
|
|
@@ -16,10 +17,10 @@ export {
|
|
|
16
17
|
a as fetchBTCbDeposits,
|
|
17
18
|
n as fetchDirectDeposits,
|
|
18
19
|
g as fetchUnstakesByAddress,
|
|
19
|
-
|
|
20
|
+
m as generateDepositBtcAddress,
|
|
20
21
|
I as getConfirmationProgress,
|
|
21
|
-
|
|
22
|
-
|
|
22
|
+
p as getDepositBtcAddress,
|
|
23
|
+
d as getDepositBtcAddresses,
|
|
23
24
|
P as getDepositStatus,
|
|
24
25
|
h as getDepositStatusDisplay,
|
|
25
26
|
S as getDepositsByAddress,
|
|
@@ -28,14 +29,14 @@ export {
|
|
|
28
29
|
D as getLuxSeason1Points,
|
|
29
30
|
A as getLuxSeason2Points,
|
|
30
31
|
b as getNetworkFeeSignature,
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
32
|
+
f as getPointsByAddress,
|
|
33
|
+
c as getUnstakesByAddress,
|
|
34
|
+
C as getUserStakeAndBakeSignature,
|
|
34
35
|
_ as isDepositClaimable,
|
|
35
36
|
L as isDepositPending,
|
|
36
37
|
M as isDepositTerminal,
|
|
37
38
|
O as setReferral,
|
|
38
|
-
|
|
39
|
+
q as storeNetworkFeeSignature,
|
|
39
40
|
u as storeStakeAndBakeSignature
|
|
40
41
|
};
|
|
41
42
|
//# sourceMappingURL=api.js.map
|
package/dist/api.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"api.js","sources":[],"sourcesContent":[],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"api.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;"}
|
package/dist/btc.cjs
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const t=require("./chunks/BtcActions-
|
|
1
|
+
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const t=require("./chunks/BtcActions-DZs5eXTb.cjs"),c=require("./chunks/statusConstants-Cz77HXnT.cjs");exports.BtcActions=t.BtcActions;exports.BtcDeposit=t.BtcDeposit;exports.BtcDepositAndDeploy=t.BtcDepositAndDeploy;exports.BtcStake=t.BtcStake;exports.BtcStakeAndDeploy=t.BtcStakeAndDeploy;exports.btcActions=t.btcActions;exports.btcModule=t.btcModule;exports.BtcActionStatus=c.BtcActionStatus;
|
|
2
2
|
//# sourceMappingURL=btc.cjs.map
|
package/dist/btc.js
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
import { BtcActions as c, BtcDeposit as e, BtcDepositAndDeploy as p, BtcStake as B, BtcStakeAndDeploy as i, btcActions as n, btcModule as s } from "./chunks/BtcActions-
|
|
2
|
-
import { BtcActionStatus as r } from "./chunks/statusConstants-
|
|
1
|
+
import { BtcActions as c, BtcDeposit as e, BtcDepositAndDeploy as p, BtcStake as B, BtcStakeAndDeploy as i, btcActions as n, btcModule as s } from "./chunks/BtcActions-BDTnGE1D.js";
|
|
2
|
+
import { BtcActionStatus as r } from "./chunks/statusConstants-DZlImWu7.js";
|
|
3
3
|
export {
|
|
4
4
|
r as BtcActionStatus,
|
|
5
5
|
c as BtcActions,
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"evm.d.ts","sourceRoot":"","sources":["../../../../../../src/chains/btc/actions/stake/config/evm.ts"],"names":[],"mappings":"AAAA;;;;;;;;;GASG;
|
|
1
|
+
{"version":3,"file":"evm.d.ts","sourceRoot":"","sources":["../../../../../../src/chains/btc/actions/stake/config/evm.ts"],"names":[],"mappings":"AAAA;;;;;;;;;GASG;AAgBH,OAAO,KAAK,EAAE,WAAW,EAAiB,MAAM,SAAS,CAAC;AAmI1D;;;;;;GAMG;AACH,eAAO,MAAM,SAAS,EAAE,WAiDvB,CAAC"}
|
|
@@ -10,7 +10,7 @@
|
|
|
10
10
|
* - deploy: LBTC/BTC.b → DeFi protocols (Veda, Silo)
|
|
11
11
|
* - withdraw: Queue withdrawal from DeFi protocols
|
|
12
12
|
* - cancelWithdraw: Cancel pending withdrawal from DeFi protocols
|
|
13
|
-
* - redeem:
|
|
13
|
+
* - redeem: BTC.b → BTC (cross-chain redemption to Bitcoin)
|
|
14
14
|
*
|
|
15
15
|
* @example
|
|
16
16
|
* ```typescript
|
|
@@ -151,18 +151,27 @@ export declare class EvmActions {
|
|
|
151
151
|
*/
|
|
152
152
|
cancelWithdraw(params: EvmCancelWithdrawParams): IEvmCancelWithdraw;
|
|
153
153
|
/**
|
|
154
|
-
* Redeem
|
|
154
|
+
* Redeem BTC.b to native BTC (cross-chain to Bitcoin)
|
|
155
155
|
*
|
|
156
|
-
*
|
|
157
|
-
*
|
|
156
|
+
* Burns BTC.b on the EVM source chain and releases native BTC to a Bitcoin
|
|
157
|
+
* recipient address. This is the inverse of BTC Deposit. The destination is
|
|
158
|
+
* always the Bitcoin network — for LBTC → BTC.b on the same EVM chain, use
|
|
159
|
+
* {@link unstake} with `assetOut: AssetId.BTCb`.
|
|
158
160
|
*
|
|
159
161
|
* @example
|
|
160
162
|
* ```typescript
|
|
161
163
|
* const redeem = evm.redeem({
|
|
162
|
-
* assetIn: AssetId.
|
|
163
|
-
* assetOut: AssetId.
|
|
164
|
+
* assetIn: AssetId.BTCb,
|
|
165
|
+
* assetOut: AssetId.BTC,
|
|
164
166
|
* sourceChain: Chain.AVALANCHE,
|
|
167
|
+
* destChain: Chain.BITCOIN_MAINNET,
|
|
168
|
+
* });
|
|
169
|
+
*
|
|
170
|
+
* await redeem.prepare({
|
|
171
|
+
* amount: '0.1',
|
|
172
|
+
* recipient: 'bc1q...',
|
|
165
173
|
* });
|
|
174
|
+
* const { txHash } = await redeem.execute();
|
|
166
175
|
* ```
|
|
167
176
|
*/
|
|
168
177
|
redeem(params: EvmRedeemParams): IEvmRedeem;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"EvmActions.d.ts","sourceRoot":"","sources":["../../../src/chains/evm/EvmActions.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAiCG;AAEH,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,oBAAoB,CAAC;AAGxD,OAAO,EAEL,KAAK,eAAe,EACpB,KAAK,UAAU,EAChB,MAAM,kBAAkB,CAAC;AAC1B,OAAO,EAEL,KAAK,gBAAgB,EACrB,KAAK,WAAW,EACjB,MAAM,mBAAmB,CAAC;AAC3B,OAAO,EAEL,KAAK,eAAe,EACpB,KAAK,UAAU,EAChB,MAAM,kBAAkB,CAAC;AAE1B,OAAO,EAEL,KAAK,cAAc,EACnB,KAAK,SAAS,EACf,MAAM,iBAAiB,CAAC;AACzB,OAAO,EAEL,KAAK,gBAAgB,EACrB,KAAK,WAAW,EACjB,MAAM,mBAAmB,CAAC;AAC3B,OAAO,EAGL,KAAK,uBAAuB,EAC5B,KAAK,iBAAiB,EACtB,KAAK,kBAAkB,EACvB,KAAK,YAAY,EAClB,MAAM,oBAAoB,CAAC;AAE5B;;;;;GAKG;AACH,qBAAa,UAAU;IACrB,OAAO,CAAC,QAAQ,CAAC,GAAG,CAAiB;gBAEzB,MAAM,EAAE,aAAa;IAIjC;;;;;;;;;;;;;;;OAeG;IACH,KAAK,CAAC,MAAM,EAAE,cAAc,GAAG,SAAS;IAIxC;;;;;;;;;;;;;;;OAeG;IACH,OAAO,CAAC,MAAM,EAAE,gBAAgB,GAAG,WAAW;IAI9C;;;;;;;;;;;;;;OAcG;IACH,OAAO,CAAC,MAAM,EAAE,gBAAgB,GAAG,WAAW;IAI9C;;;;;;;;;;;;;;OAcG;IACH,MAAM,CAAC,MAAM,EAAE,eAAe,GAAG,UAAU;IAI3C;;;;;;;;;;;;;;;;;;OAkBG;IACH,QAAQ,CAAC,MAAM,EAAE,iBAAiB,GAAG,YAAY;IAIjD;;;;;;;;;;;;;;OAcG;IACH,cAAc,CAAC,MAAM,EAAE,uBAAuB,GAAG,kBAAkB;IAInE
|
|
1
|
+
{"version":3,"file":"EvmActions.d.ts","sourceRoot":"","sources":["../../../src/chains/evm/EvmActions.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAiCG;AAEH,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,oBAAoB,CAAC;AAGxD,OAAO,EAEL,KAAK,eAAe,EACpB,KAAK,UAAU,EAChB,MAAM,kBAAkB,CAAC;AAC1B,OAAO,EAEL,KAAK,gBAAgB,EACrB,KAAK,WAAW,EACjB,MAAM,mBAAmB,CAAC;AAC3B,OAAO,EAEL,KAAK,eAAe,EACpB,KAAK,UAAU,EAChB,MAAM,kBAAkB,CAAC;AAE1B,OAAO,EAEL,KAAK,cAAc,EACnB,KAAK,SAAS,EACf,MAAM,iBAAiB,CAAC;AACzB,OAAO,EAEL,KAAK,gBAAgB,EACrB,KAAK,WAAW,EACjB,MAAM,mBAAmB,CAAC;AAC3B,OAAO,EAGL,KAAK,uBAAuB,EAC5B,KAAK,iBAAiB,EACtB,KAAK,kBAAkB,EACvB,KAAK,YAAY,EAClB,MAAM,oBAAoB,CAAC;AAE5B;;;;;GAKG;AACH,qBAAa,UAAU;IACrB,OAAO,CAAC,QAAQ,CAAC,GAAG,CAAiB;gBAEzB,MAAM,EAAE,aAAa;IAIjC;;;;;;;;;;;;;;;OAeG;IACH,KAAK,CAAC,MAAM,EAAE,cAAc,GAAG,SAAS;IAIxC;;;;;;;;;;;;;;;OAeG;IACH,OAAO,CAAC,MAAM,EAAE,gBAAgB,GAAG,WAAW;IAI9C;;;;;;;;;;;;;;OAcG;IACH,OAAO,CAAC,MAAM,EAAE,gBAAgB,GAAG,WAAW;IAI9C;;;;;;;;;;;;;;OAcG;IACH,MAAM,CAAC,MAAM,EAAE,eAAe,GAAG,UAAU;IAI3C;;;;;;;;;;;;;;;;;;OAkBG;IACH,QAAQ,CAAC,MAAM,EAAE,iBAAiB,GAAG,YAAY;IAIjD;;;;;;;;;;;;;;OAcG;IACH,cAAc,CAAC,MAAM,EAAE,uBAAuB,GAAG,kBAAkB;IAInE;;;;;;;;;;;;;;;;;;;;;;;OAuBG;IACH,MAAM,CAAC,MAAM,EAAE,eAAe,GAAG,UAAU;CAG5C;AAED;;;;;;;GAOG;AACH,wBAAgB,UAAU,CAAC,MAAM,EAAE,aAAa,GAAG,UAAU,CAE5D"}
|
|
@@ -8,15 +8,18 @@
|
|
|
8
8
|
*
|
|
9
9
|
* ## Fee Authorization
|
|
10
10
|
*
|
|
11
|
-
*
|
|
12
|
-
*
|
|
11
|
+
* EVM Redeem does NOT require network fee authorization on any source chain.
|
|
12
|
+
* The destination is the Bitcoin network — there is no auto-mint operation on
|
|
13
|
+
* an EVM destination, so the auto-mint fee model (used by BTC Deposit and
|
|
14
|
+
* EVM Unstake to BTC.b on Ethereum/Sepolia) does not apply here.
|
|
13
15
|
*
|
|
14
|
-
* **Flow
|
|
15
|
-
* IDLE → NEEDS_FEE_AUTHORIZATION → READY → COMPLETED
|
|
16
|
-
*
|
|
17
|
-
* **Flow without fee auth (Base, BSC - subsidized):**
|
|
16
|
+
* **Flow (all source chains):**
|
|
18
17
|
* IDLE → READY → COMPLETED
|
|
19
18
|
*
|
|
19
|
+
* `authorizeFee()` is kept on the action only to preserve the existing public
|
|
20
|
+
* interface; it is a safe no-op and the status will never reach
|
|
21
|
+
* `NEEDS_FEE_AUTHORIZATION`.
|
|
22
|
+
*
|
|
20
23
|
* @module chains/evm/actions/redeem/EvmRedeem
|
|
21
24
|
*/
|
|
22
25
|
import { BaseAction } from '../../../../shared/actions/BaseAction';
|
|
@@ -44,8 +47,12 @@ export declare class EvmRedeem extends BaseAction<RedeemEventMap, EvmOperationSt
|
|
|
44
47
|
/**
|
|
45
48
|
* Authorize the network fee
|
|
46
49
|
*
|
|
47
|
-
*
|
|
48
|
-
*
|
|
50
|
+
* @deprecated EVM Redeem no longer requires fee authorization. The status
|
|
51
|
+
* machine never reaches `NEEDS_FEE_AUTHORIZATION`, so this method is a
|
|
52
|
+
* safe no-op kept only for backwards compatibility with the existing
|
|
53
|
+
* public interface. Calling it on a `READY` (or any other) status will
|
|
54
|
+
* resolve immediately without touching the wallet, the API, or the action
|
|
55
|
+
* state.
|
|
49
56
|
*/
|
|
50
57
|
authorizeFee(): Promise<void>;
|
|
51
58
|
approve(): Promise<void>;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"EvmRedeem.d.ts","sourceRoot":"","sources":["../../../../../src/chains/evm/actions/redeem/EvmRedeem.ts"],"names":[],"mappings":"AAAA
|
|
1
|
+
{"version":3,"file":"EvmRedeem.d.ts","sourceRoot":"","sources":["../../../../../src/chains/evm/actions/redeem/EvmRedeem.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;;;;;;;GAuBG;AAQH,OAAO,EAAE,UAAU,EAAE,MAAM,uCAAuC,CAAC;AACnE,OAAO,EAAE,kBAAkB,EAAE,MAAM,8CAA8C,CAAC;AAClF,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,4BAA4B,CAAC;AAEjE,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,2BAA2B,CAAC;AAMhE,OAAO,EAEL,KAAK,YAAY,EAClB,MAAM,sBAAsB,CAAC;AAE9B,OAAO,KAAK,EACV,eAAe,EACf,sBAAsB,EACtB,UAAU,EACX,MAAM,SAAS,CAAC;AAEjB,qBAAa,SACX,SAAQ,UAAU,CAAC,cAAc,EAAE,kBAAkB,CACrD,YAAW,UAAU;IASnB,OAAO,CAAC,QAAQ,CAAC,GAAG;IACpB,OAAO,CAAC,QAAQ,CAAC,MAAM;IARzB,OAAO,CAAC,OAAO,CAAC,CAAS;IACzB,OAAO,CAAC,UAAU,CAAC,CAAS;IAC5B,OAAO,CAAC,cAAc,CAAS;IAC/B,OAAO,CAAC,OAAO,CAAC,CAAS;IACzB,OAAO,CAAC,QAAQ,CAA6C;gBAG1C,GAAG,EAAE,cAAc,EACnB,MAAM,EAAE,eAAe;IAK1C,IAAI,MAAM,IAAI,MAAM,GAAG,SAAS,CAE/B;IAED,IAAI,SAAS,IAAI,MAAM,GAAG,SAAS,CAElC;IAED,IAAI,aAAa,IAAI,OAAO,CAE3B;IAED,IAAI,MAAM,IAAI,MAAM,GAAG,SAAS,CAE/B;IAED,+CAA+C;IAC/C,IAAI,OAAO,IAAI,YAAY,CAE1B;IAEK,OAAO,CAAC,MAAM,EAAE,sBAAsB,GAAG,OAAO,CAAC,IAAI,CAAC;IAqB5D;;;;;;;;;OASG;IACG,YAAY,IAAI,OAAO,CAAC,IAAI,CAAC;IAM7B,OAAO,IAAI,OAAO,CAAC,IAAI,CAAC;IAYxB,OAAO,IAAI,OAAO,CAAC;QAAE,MAAM,EAAE,MAAM,CAAA;KAAE,CAAC;IAkD5C,OAAO,KAAK,aAAa,GAKxB;CACF"}
|
|
@@ -16,9 +16,13 @@ import type { EvmRedeemParams } from './types';
|
|
|
16
16
|
* ```typescript
|
|
17
17
|
* const sdk = await createLombardSDK({ env: Env.prod, providers: { evm: () => window.ethereum } });
|
|
18
18
|
* const redeem = sdk.chain.evm.redeem({
|
|
19
|
-
*
|
|
19
|
+
* assetIn: AssetId.BTCb,
|
|
20
|
+
* assetOut: AssetId.BTC,
|
|
21
|
+
* sourceChain: Chain.AVALANCHE,
|
|
22
|
+
* destChain: Chain.BITCOIN_MAINNET,
|
|
20
23
|
* });
|
|
21
|
-
* await redeem.prepare({ amount: '0.1' });
|
|
24
|
+
* await redeem.prepare({ amount: '0.1', recipient: 'bc1q...' });
|
|
25
|
+
* await redeem.execute();
|
|
22
26
|
* ```
|
|
23
27
|
*/
|
|
24
28
|
export declare function evmRedeem(config: LombardConfig, params: EvmRedeemParams): EvmRedeem;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"factory.d.ts","sourceRoot":"","sources":["../../../../../src/chains/evm/actions/redeem/factory.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAEH,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,0BAA0B,CAAC;AAC9D,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,4BAA4B,CAAC;AAEjE,OAAO,EAAE,SAAS,EAAE,MAAM,aAAa,CAAC;AACxC,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,SAAS,CAAC;AAE/C
|
|
1
|
+
{"version":3,"file":"factory.d.ts","sourceRoot":"","sources":["../../../../../src/chains/evm/actions/redeem/factory.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAEH,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,0BAA0B,CAAC;AAC9D,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,4BAA4B,CAAC;AAEjE,OAAO,EAAE,SAAS,EAAE,MAAM,aAAa,CAAC;AACxC,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,SAAS,CAAC;AAE/C;;;;;;;;;;;;;;;;;GAiBG;AACH,wBAAgB,SAAS,CACvB,MAAM,EAAE,aAAa,EACrB,MAAM,EAAE,eAAe,GACtB,SAAS,CAGX;AAED;;GAEG;AACH,wBAAgB,eAAe,CAC7B,GAAG,EAAE,cAAc,EACnB,MAAM,EAAE,eAAe,GACtB,SAAS,CAEX"}
|
|
@@ -8,12 +8,11 @@
|
|
|
8
8
|
*
|
|
9
9
|
* ## Fee Authorization
|
|
10
10
|
*
|
|
11
|
-
*
|
|
11
|
+
* EVM Redeem does not require network-fee authorization on any source chain.
|
|
12
|
+
* There is no auto-mint on the Bitcoin destination, so the model used by BTC
|
|
13
|
+
* Deposit and EVM Unstake-to-BTC.b on Ethereum/Sepolia does not apply here.
|
|
12
14
|
*
|
|
13
|
-
* **Flow
|
|
14
|
-
* IDLE → NEEDS_FEE_AUTHORIZATION → READY → COMPLETED
|
|
15
|
-
*
|
|
16
|
-
* **Flow without fee auth (Base, BSC - subsidized):**
|
|
15
|
+
* **Flow (all source chains):**
|
|
17
16
|
* IDLE → READY → COMPLETED
|
|
18
17
|
*
|
|
19
18
|
* @module chains/evm/actions/redeem/types
|
|
@@ -71,7 +70,12 @@ export interface IEvmRedeem extends MonitorableAction {
|
|
|
71
70
|
/** Fee authorization state (for UI display) */
|
|
72
71
|
readonly feeAuth: FeeAuthState;
|
|
73
72
|
prepare(params: EvmRedeemPrepareParams): Promise<void>;
|
|
74
|
-
/**
|
|
73
|
+
/**
|
|
74
|
+
* @deprecated EVM Redeem no longer requires fee authorization. The status
|
|
75
|
+
* machine never reaches `NEEDS_FEE_AUTHORIZATION`; this method is kept for
|
|
76
|
+
* backwards compatibility and is a safe no-op that resolves immediately
|
|
77
|
+
* regardless of the current status.
|
|
78
|
+
*/
|
|
75
79
|
authorizeFee(): Promise<void>;
|
|
76
80
|
approve(): Promise<void>;
|
|
77
81
|
execute(): Promise<{
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../../../src/chains/evm/actions/redeem/types.ts"],"names":[],"mappings":"AAAA
|
|
1
|
+
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../../../src/chains/evm/actions/redeem/types.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;;GAkBG;AAEH,OAAO,KAAK,EACV,OAAO,EACP,KAAK,EACL,UAAU,EACV,gBAAgB,EACjB,MAAM,kBAAkB,CAAC;AAC1B,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,uCAAuC,CAAC;AAC/E,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,8CAA8C,CAAC;AACvF,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,2BAA2B,CAAC;AAC9D,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,sBAAsB,CAAC;AAGzD,OAAO,EAAE,kBAAkB,IAAI,eAAe,EAAE,MAAM,8CAA8C,CAAC;AAErG;;;;GAIG;AACH,MAAM,WAAW,eAAe;IAC9B,0BAA0B;IAC1B,OAAO,EAAE,OAAO,CAAC;IACjB,yBAAyB;IACzB,QAAQ,EAAE,OAAO,CAAC;IAClB,mDAAmD;IACnD,WAAW,EAAE,KAAK,CAAC;IACnB,0CAA0C;IAC1C,SAAS,EAAE,KAAK,CAAC;CAClB;AAED;;GAEG;AACH,MAAM,WAAW,sBAAsB;IACrC,gCAAgC;IAChC,MAAM,EAAE,MAAM,CAAC;IACf,qCAAqC;IACrC,SAAS,EAAE,MAAM,CAAC;CACnB;AAED;;GAEG;AACH,MAAM,WAAW,iBAAkB,SAAQ,gBAAgB,CAAC,kBAAkB,CAAC;IAC7E,MAAM,EAAE,kBAAkB,CAAC;IAC3B,KAAK,EAAE;QACL,SAAS,EAAE,UAAU,CAAC;KACvB,CAAC;IACF,MAAM,CAAC,EAAE,MAAM,CAAC;CACjB;AAED;;GAEG;AACH,MAAM,WAAW,UAAW,SAAQ,iBAAiB;IACnD,QAAQ,CAAC,MAAM,EAAE,kBAAkB,CAAC;IACpC,QAAQ,CAAC,KAAK,EAAE,YAAY,GAAG,IAAI,CAAC;IACpC,QAAQ,CAAC,MAAM,CAAC,EAAE,MAAM,CAAC;IACzB,QAAQ,CAAC,SAAS,CAAC,EAAE,MAAM,CAAC;IAC5B,QAAQ,CAAC,aAAa,EAAE,OAAO,CAAC;IAChC,QAAQ,CAAC,MAAM,CAAC,EAAE,MAAM,CAAC;IAEzB,+CAA+C;IAC/C,QAAQ,CAAC,OAAO,EAAE,YAAY,CAAC;IAE/B,OAAO,CAAC,MAAM,EAAE,sBAAsB,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IACvD;;;;;OAKG;IACH,YAAY,IAAI,OAAO,CAAC,IAAI,CAAC,CAAC;IAC9B,OAAO,IAAI,OAAO,CAAC,IAAI,CAAC,CAAC;IACzB,OAAO,IAAI,OAAO,CAAC;QAAE,MAAM,EAAE,MAAM,CAAA;KAAE,CAAC,CAAC;CACxC"}
|