@ledgerhq/live-common 31.6.0 → 31.7.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/lib/account/helpers.d.ts.map +1 -1
- package/lib/account/helpers.js +0 -5
- package/lib/account/helpers.js.map +1 -1
- package/lib/bot/engine.d.ts.map +1 -1
- package/lib/bot/engine.js +6 -0
- package/lib/bot/engine.js.map +1 -1
- package/lib/config/defaultConfig.js +1 -1
- package/lib/config/defaultConfig.js.map +1 -1
- package/lib/cross.d.ts +6 -1
- package/lib/cross.d.ts.map +1 -1
- package/lib/cross.js +12 -2
- package/lib/cross.js.map +1 -1
- package/lib/cross.test.js +7 -0
- package/lib/cross.test.js.map +1 -1
- package/lib/exchange/swap/api/v5/__tests__/fetchCurrencyFrom.spec.js +3 -2
- package/lib/exchange/swap/api/v5/__tests__/fetchCurrencyFrom.spec.js.map +1 -1
- package/lib/exchange/swap/api/v5/__tests__/fetchCurrencyTo.spec.js +5 -4
- package/lib/exchange/swap/api/v5/__tests__/fetchCurrencyTo.spec.js.map +1 -1
- package/lib/exchange/swap/api/v5/fetchCurrencyFrom.d.ts +1 -1
- package/lib/exchange/swap/api/v5/fetchCurrencyFrom.d.ts.map +1 -1
- package/lib/exchange/swap/api/v5/fetchCurrencyFrom.js +5 -3
- package/lib/exchange/swap/api/v5/fetchCurrencyFrom.js.map +1 -1
- package/lib/exchange/swap/api/v5/fetchCurrencyTo.d.ts +2 -2
- package/lib/exchange/swap/api/v5/fetchCurrencyTo.d.ts.map +1 -1
- package/lib/exchange/swap/api/v5/fetchCurrencyTo.js +7 -5
- package/lib/exchange/swap/api/v5/fetchCurrencyTo.js.map +1 -1
- package/lib/exchange/swap/api/v5/fetchRates.d.ts +10 -0
- package/lib/exchange/swap/api/v5/fetchRates.d.ts.map +1 -0
- package/lib/exchange/swap/api/v5/fetchRates.js +53 -0
- package/lib/exchange/swap/api/v5/fetchRates.js.map +1 -0
- package/lib/exchange/swap/completeExchange.d.ts.map +1 -1
- package/lib/exchange/swap/completeExchange.js +2 -1
- package/lib/exchange/swap/completeExchange.js.map +1 -1
- package/lib/exchange/swap/hooks/v5/useFetchCurrencyFrom.d.ts +13 -0
- package/lib/exchange/swap/hooks/v5/useFetchCurrencyFrom.d.ts.map +1 -0
- package/lib/exchange/swap/hooks/v5/useFetchCurrencyFrom.js +21 -0
- package/lib/exchange/swap/hooks/v5/useFetchCurrencyFrom.js.map +1 -0
- package/lib/exchange/swap/hooks/v5/useFetchCurrencyTo.d.ts +13 -0
- package/lib/exchange/swap/hooks/v5/useFetchCurrencyTo.d.ts.map +1 -0
- package/lib/exchange/swap/hooks/v5/useFetchCurrencyTo.js +25 -0
- package/lib/exchange/swap/hooks/v5/useFetchCurrencyTo.js.map +1 -0
- package/lib/exchange/swap/hooks/v5/useFetchRates.d.ts +18 -0
- package/lib/exchange/swap/hooks/v5/useFetchRates.d.ts.map +1 -0
- package/lib/exchange/swap/hooks/v5/useFetchRates.js +28 -0
- package/lib/exchange/swap/hooks/v5/useFetchRates.js.map +1 -0
- package/lib/exchange/swap/types.d.ts +24 -0
- package/lib/exchange/swap/types.d.ts.map +1 -1
- package/lib/exchange/swap/utils/flattenV5CurrenciesToAndFrom.d.ts +4 -0
- package/lib/exchange/swap/utils/flattenV5CurrenciesToAndFrom.d.ts.map +1 -0
- package/lib/exchange/swap/utils/flattenV5CurrenciesToAndFrom.js +9 -0
- package/lib/exchange/swap/utils/flattenV5CurrenciesToAndFrom.js.map +1 -0
- package/lib/exchange/swap/webApp/index.d.ts +2 -0
- package/lib/exchange/swap/webApp/index.d.ts.map +1 -0
- package/lib/exchange/swap/webApp/index.js +18 -0
- package/lib/exchange/swap/webApp/index.js.map +1 -0
- package/lib/exchange/swap/webApp/utils.d.ts +31 -0
- package/lib/exchange/swap/webApp/utils.d.ts.map +1 -0
- package/lib/exchange/swap/webApp/utils.js +43 -0
- package/lib/exchange/swap/webApp/utils.js.map +1 -0
- package/lib/families/cosmos/account.js +8 -8
- package/lib/families/cosmos/account.js.map +1 -1
- package/lib/families/cosmos/api/Cosmos.d.ts +4 -0
- package/lib/families/cosmos/api/Cosmos.d.ts.map +1 -1
- package/lib/families/cosmos/api/Cosmos.js +3 -1
- package/lib/families/cosmos/api/Cosmos.js.map +1 -1
- package/lib/families/cosmos/banner.test.js +1 -0
- package/lib/families/cosmos/banner.test.js.map +1 -1
- package/lib/families/cosmos/chain/Osmosis.d.ts.map +1 -1
- package/lib/families/cosmos/chain/Osmosis.js +0 -2
- package/lib/families/cosmos/chain/Osmosis.js.map +1 -1
- package/lib/families/cosmos/chain/cosmosBase.d.ts +0 -2
- package/lib/families/cosmos/chain/cosmosBase.d.ts.map +1 -1
- package/lib/families/cosmos/chain/cosmosBase.js +0 -2
- package/lib/families/cosmos/chain/cosmosBase.js.map +1 -1
- package/lib/families/cosmos/datasets/cosmos.d.ts.map +1 -1
- package/lib/families/cosmos/datasets/cosmos.js +15 -13
- package/lib/families/cosmos/datasets/cosmos.js.map +1 -1
- package/lib/families/cosmos/js-synchronisation.d.ts.map +1 -1
- package/lib/families/cosmos/js-synchronisation.js +2 -1
- package/lib/families/cosmos/js-synchronisation.js.map +1 -1
- package/lib/families/cosmos/js-synchronisation.unit.test.js +1 -0
- package/lib/families/cosmos/js-synchronisation.unit.test.js.map +1 -1
- package/lib/families/cosmos/mock.d.ts.map +1 -1
- package/lib/families/cosmos/mock.js +6 -0
- package/lib/families/cosmos/mock.js.map +1 -1
- package/lib/families/cosmos/serialization.d.ts.map +1 -1
- package/lib/families/cosmos/serialization.js +4 -2
- package/lib/families/cosmos/serialization.js.map +1 -1
- package/lib/families/cosmos/specs.d.ts +45 -33
- package/lib/families/cosmos/specs.d.ts.map +1 -1
- package/lib/families/cosmos/specs.js +102 -41
- package/lib/families/cosmos/specs.js.map +1 -1
- package/lib/families/cosmos/types.d.ts +2 -0
- package/lib/families/cosmos/types.d.ts.map +1 -1
- package/lib/families/elrond/specs.d.ts.map +1 -1
- package/lib/families/elrond/specs.js.map +1 -1
- package/lib/families/polkadot/bridge/mock.d.ts.map +1 -1
- package/lib/families/polkadot/bridge/mock.js +105 -102
- package/lib/families/polkadot/bridge/mock.js.map +1 -1
- package/lib/generated/specs.d.ts +44 -33
- package/lib/generated/specs.d.ts.map +1 -1
- package/lib/hooks/useAPI.d.ts +20 -0
- package/lib/hooks/useAPI.d.ts.map +1 -0
- package/lib/hooks/useAPI.js +62 -0
- package/lib/hooks/useAPI.js.map +1 -0
- package/lib/mock/account.d.ts.map +1 -1
- package/lib/mock/account.js +1 -0
- package/lib/mock/account.js.map +1 -1
- package/lib-es/account/helpers.d.ts.map +1 -1
- package/lib-es/account/helpers.js +0 -5
- package/lib-es/account/helpers.js.map +1 -1
- package/lib-es/bot/engine.d.ts.map +1 -1
- package/lib-es/bot/engine.js +6 -0
- package/lib-es/bot/engine.js.map +1 -1
- package/lib-es/config/defaultConfig.js +1 -1
- package/lib-es/config/defaultConfig.js.map +1 -1
- package/lib-es/cross.d.ts +6 -1
- package/lib-es/cross.d.ts.map +1 -1
- package/lib-es/cross.js +12 -2
- package/lib-es/cross.js.map +1 -1
- package/lib-es/cross.test.js +7 -0
- package/lib-es/cross.test.js.map +1 -1
- package/lib-es/exchange/swap/api/v5/__tests__/fetchCurrencyFrom.spec.js +3 -2
- package/lib-es/exchange/swap/api/v5/__tests__/fetchCurrencyFrom.spec.js.map +1 -1
- package/lib-es/exchange/swap/api/v5/__tests__/fetchCurrencyTo.spec.js +5 -4
- package/lib-es/exchange/swap/api/v5/__tests__/fetchCurrencyTo.spec.js.map +1 -1
- package/lib-es/exchange/swap/api/v5/fetchCurrencyFrom.d.ts +1 -1
- package/lib-es/exchange/swap/api/v5/fetchCurrencyFrom.d.ts.map +1 -1
- package/lib-es/exchange/swap/api/v5/fetchCurrencyFrom.js +5 -3
- package/lib-es/exchange/swap/api/v5/fetchCurrencyFrom.js.map +1 -1
- package/lib-es/exchange/swap/api/v5/fetchCurrencyTo.d.ts +2 -2
- package/lib-es/exchange/swap/api/v5/fetchCurrencyTo.d.ts.map +1 -1
- package/lib-es/exchange/swap/api/v5/fetchCurrencyTo.js +7 -5
- package/lib-es/exchange/swap/api/v5/fetchCurrencyTo.js.map +1 -1
- package/lib-es/exchange/swap/api/v5/fetchRates.d.ts +10 -0
- package/lib-es/exchange/swap/api/v5/fetchRates.d.ts.map +1 -0
- package/lib-es/exchange/swap/api/v5/fetchRates.js +46 -0
- package/lib-es/exchange/swap/api/v5/fetchRates.js.map +1 -0
- package/lib-es/exchange/swap/completeExchange.d.ts.map +1 -1
- package/lib-es/exchange/swap/completeExchange.js +2 -1
- package/lib-es/exchange/swap/completeExchange.js.map +1 -1
- package/lib-es/exchange/swap/hooks/v5/useFetchCurrencyFrom.d.ts +13 -0
- package/lib-es/exchange/swap/hooks/v5/useFetchCurrencyFrom.d.ts.map +1 -0
- package/lib-es/exchange/swap/hooks/v5/useFetchCurrencyFrom.js +17 -0
- package/lib-es/exchange/swap/hooks/v5/useFetchCurrencyFrom.js.map +1 -0
- package/lib-es/exchange/swap/hooks/v5/useFetchCurrencyTo.d.ts +13 -0
- package/lib-es/exchange/swap/hooks/v5/useFetchCurrencyTo.d.ts.map +1 -0
- package/lib-es/exchange/swap/hooks/v5/useFetchCurrencyTo.js +21 -0
- package/lib-es/exchange/swap/hooks/v5/useFetchCurrencyTo.js.map +1 -0
- package/lib-es/exchange/swap/hooks/v5/useFetchRates.d.ts +18 -0
- package/lib-es/exchange/swap/hooks/v5/useFetchRates.d.ts.map +1 -0
- package/lib-es/exchange/swap/hooks/v5/useFetchRates.js +24 -0
- package/lib-es/exchange/swap/hooks/v5/useFetchRates.js.map +1 -0
- package/lib-es/exchange/swap/types.d.ts +24 -0
- package/lib-es/exchange/swap/types.d.ts.map +1 -1
- package/lib-es/exchange/swap/utils/flattenV5CurrenciesToAndFrom.d.ts +4 -0
- package/lib-es/exchange/swap/utils/flattenV5CurrenciesToAndFrom.d.ts.map +1 -0
- package/lib-es/exchange/swap/utils/flattenV5CurrenciesToAndFrom.js +5 -0
- package/lib-es/exchange/swap/utils/flattenV5CurrenciesToAndFrom.js.map +1 -0
- package/lib-es/exchange/swap/webApp/index.d.ts +2 -0
- package/lib-es/exchange/swap/webApp/index.d.ts.map +1 -0
- package/lib-es/exchange/swap/webApp/index.js +2 -0
- package/lib-es/exchange/swap/webApp/index.js.map +1 -0
- package/lib-es/exchange/swap/webApp/utils.d.ts +31 -0
- package/lib-es/exchange/swap/webApp/utils.d.ts.map +1 -0
- package/lib-es/exchange/swap/webApp/utils.js +38 -0
- package/lib-es/exchange/swap/webApp/utils.js.map +1 -0
- package/lib-es/families/cosmos/account.js +8 -8
- package/lib-es/families/cosmos/account.js.map +1 -1
- package/lib-es/families/cosmos/api/Cosmos.d.ts +4 -0
- package/lib-es/families/cosmos/api/Cosmos.d.ts.map +1 -1
- package/lib-es/families/cosmos/api/Cosmos.js +3 -1
- package/lib-es/families/cosmos/api/Cosmos.js.map +1 -1
- package/lib-es/families/cosmos/banner.test.js +1 -0
- package/lib-es/families/cosmos/banner.test.js.map +1 -1
- package/lib-es/families/cosmos/chain/Osmosis.d.ts.map +1 -1
- package/lib-es/families/cosmos/chain/Osmosis.js +0 -2
- package/lib-es/families/cosmos/chain/Osmosis.js.map +1 -1
- package/lib-es/families/cosmos/chain/cosmosBase.d.ts +0 -2
- package/lib-es/families/cosmos/chain/cosmosBase.d.ts.map +1 -1
- package/lib-es/families/cosmos/chain/cosmosBase.js +0 -2
- package/lib-es/families/cosmos/chain/cosmosBase.js.map +1 -1
- package/lib-es/families/cosmos/datasets/cosmos.d.ts.map +1 -1
- package/lib-es/families/cosmos/datasets/cosmos.js +15 -13
- package/lib-es/families/cosmos/datasets/cosmos.js.map +1 -1
- package/lib-es/families/cosmos/js-synchronisation.d.ts.map +1 -1
- package/lib-es/families/cosmos/js-synchronisation.js +2 -1
- package/lib-es/families/cosmos/js-synchronisation.js.map +1 -1
- package/lib-es/families/cosmos/js-synchronisation.unit.test.js +1 -0
- package/lib-es/families/cosmos/js-synchronisation.unit.test.js.map +1 -1
- package/lib-es/families/cosmos/mock.d.ts.map +1 -1
- package/lib-es/families/cosmos/mock.js +6 -0
- package/lib-es/families/cosmos/mock.js.map +1 -1
- package/lib-es/families/cosmos/serialization.d.ts.map +1 -1
- package/lib-es/families/cosmos/serialization.js +4 -2
- package/lib-es/families/cosmos/serialization.js.map +1 -1
- package/lib-es/families/cosmos/specs.d.ts +45 -33
- package/lib-es/families/cosmos/specs.d.ts.map +1 -1
- package/lib-es/families/cosmos/specs.js +102 -41
- package/lib-es/families/cosmos/specs.js.map +1 -1
- package/lib-es/families/cosmos/types.d.ts +2 -0
- package/lib-es/families/cosmos/types.d.ts.map +1 -1
- package/lib-es/families/elrond/specs.d.ts.map +1 -1
- package/lib-es/families/elrond/specs.js.map +1 -1
- package/lib-es/families/polkadot/bridge/mock.d.ts.map +1 -1
- package/lib-es/families/polkadot/bridge/mock.js +106 -103
- package/lib-es/families/polkadot/bridge/mock.js.map +1 -1
- package/lib-es/generated/specs.d.ts +44 -33
- package/lib-es/generated/specs.d.ts.map +1 -1
- package/lib-es/hooks/useAPI.d.ts +20 -0
- package/lib-es/hooks/useAPI.d.ts.map +1 -0
- package/lib-es/hooks/useAPI.js +58 -0
- package/lib-es/hooks/useAPI.js.map +1 -0
- package/lib-es/mock/account.d.ts.map +1 -1
- package/lib-es/mock/account.js +1 -0
- package/lib-es/mock/account.js.map +1 -1
- package/package.json +12 -12
- package/src/__snapshots__/cross.test.ts.snap +2 -0
- package/src/account/helpers.ts +0 -6
- package/src/bot/engine.ts +6 -0
- package/src/config/defaultConfig.ts +1 -1
- package/src/cross.test.ts +7 -0
- package/src/cross.ts +26 -2
- package/src/exchange/swap/api/v5/__tests__/fetchCurrencyFrom.spec.ts +3 -2
- package/src/exchange/swap/api/v5/__tests__/fetchCurrencyTo.spec.ts +5 -4
- package/src/exchange/swap/api/v5/fetchCurrencyFrom.ts +5 -3
- package/src/exchange/swap/api/v5/fetchCurrencyTo.ts +8 -5
- package/src/exchange/swap/api/v5/fetchRates.ts +48 -0
- package/src/exchange/swap/completeExchange.ts +2 -1
- package/src/exchange/swap/hooks/v5/useFetchCurrencyFrom.ts +23 -0
- package/src/exchange/swap/hooks/v5/useFetchCurrencyTo.ts +28 -0
- package/src/exchange/swap/hooks/v5/useFetchRates.ts +41 -0
- package/src/exchange/swap/types.ts +29 -0
- package/src/exchange/swap/utils/flattenV5CurrenciesToAndFrom.ts +7 -0
- package/src/exchange/swap/webApp/index.ts +1 -0
- package/src/exchange/swap/webApp/utils.ts +41 -0
- package/src/families/cosmos/account.ts +8 -8
- package/src/families/cosmos/api/Cosmos.ts +21 -10
- package/src/families/cosmos/banner.test.ts +1 -0
- package/src/families/cosmos/chain/Osmosis.ts +0 -2
- package/src/families/cosmos/chain/cosmosBase.ts +0 -3
- package/src/families/cosmos/datasets/__snapshots__/coreum.integration.test.ts.snap +0 -3
- package/src/families/cosmos/datasets/__snapshots__/cosmos.integration.test.ts.snap +259 -354
- package/src/families/cosmos/datasets/__snapshots__/onomy.integration.test.ts.snap +1 -235
- package/src/families/cosmos/datasets/cosmos.ts +15 -13
- package/src/families/cosmos/js-synchronisation.ts +11 -2
- package/src/families/cosmos/js-synchronisation.unit.test.ts +1 -0
- package/src/families/cosmos/mock.ts +6 -0
- package/src/families/cosmos/serialization.ts +4 -0
- package/src/families/cosmos/specs.ts +113 -54
- package/src/families/cosmos/types.ts +2 -0
- package/src/families/elrond/specs.ts +0 -1
- package/src/families/polkadot/bridge/mock.ts +109 -103
- package/src/hooks/useAPI.ts +81 -0
- package/src/mock/account.ts +1 -0
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
type AsyncFn<T, P = undefined> = P extends undefined ? () => Promise<T> : (props: P) => Promise<T>;
|
|
2
|
+
type UseAsyncReturn<T> = {
|
|
3
|
+
data: T | undefined;
|
|
4
|
+
isLoading: boolean;
|
|
5
|
+
error: Error | undefined;
|
|
6
|
+
refetch: () => void;
|
|
7
|
+
};
|
|
8
|
+
export type ApiOptions<T> = {
|
|
9
|
+
enabled?: boolean;
|
|
10
|
+
staleTimeout?: number;
|
|
11
|
+
onSuccess?(data: T): void;
|
|
12
|
+
onError?(error: unknown): void;
|
|
13
|
+
};
|
|
14
|
+
type Props<T, P> = ApiOptions<T> & {
|
|
15
|
+
queryFn: AsyncFn<T, P>;
|
|
16
|
+
queryProps?: P;
|
|
17
|
+
};
|
|
18
|
+
export declare function useAPI<T, P extends Record<PropertyKey, unknown> | undefined>({ queryFn, queryProps, enabled, staleTimeout, onSuccess, onError, }: Props<T, P>): UseAsyncReturn<T>;
|
|
19
|
+
export {};
|
|
20
|
+
//# sourceMappingURL=useAPI.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"useAPI.d.ts","sourceRoot":"","sources":["../../src/hooks/useAPI.ts"],"names":[],"mappings":"AAEA,KAAK,OAAO,CAAC,CAAC,EAAE,CAAC,GAAG,SAAS,IAAI,CAAC,SAAS,SAAS,GAAG,MAAM,OAAO,CAAC,CAAC,CAAC,GAAG,CAAC,KAAK,EAAE,CAAC,KAAK,OAAO,CAAC,CAAC,CAAC,CAAC;AAEnG,KAAK,cAAc,CAAC,CAAC,IAAI;IACvB,IAAI,EAAE,CAAC,GAAG,SAAS,CAAC;IACpB,SAAS,EAAE,OAAO,CAAC;IACnB,KAAK,EAAE,KAAK,GAAG,SAAS,CAAC;IACzB,OAAO,EAAE,MAAM,IAAI,CAAC;CACrB,CAAC;AAEF,MAAM,MAAM,UAAU,CAAC,CAAC,IAAI;IAC1B,OAAO,CAAC,EAAE,OAAO,CAAC;IAClB,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,SAAS,CAAC,CAAC,IAAI,EAAE,CAAC,GAAG,IAAI,CAAC;IAC1B,OAAO,CAAC,CAAC,KAAK,EAAE,OAAO,GAAG,IAAI,CAAC;CAChC,CAAC;AAEF,KAAK,KAAK,CAAC,CAAC,EAAE,CAAC,IAAI,UAAU,CAAC,CAAC,CAAC,GAAG;IACjC,OAAO,EAAE,OAAO,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;IACvB,UAAU,CAAC,EAAE,CAAC,CAAC;CAChB,CAAC;AAIF,wBAAgB,MAAM,CAAC,CAAC,EAAE,CAAC,SAAS,MAAM,CAAC,WAAW,EAAE,OAAO,CAAC,GAAG,SAAS,EAAE,EAC5E,OAAO,EACP,UAAe,EACf,OAAc,EACd,YAAmB,EACnB,SAAS,EACT,OAAO,GACR,EAAE,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,GAAG,cAAc,CAAC,CAAC,CAAC,CAgDjC"}
|
|
@@ -0,0 +1,58 @@
|
|
|
1
|
+
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
2
|
+
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
3
|
+
return new (P || (P = Promise))(function (resolve, reject) {
|
|
4
|
+
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
5
|
+
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
6
|
+
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
7
|
+
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
8
|
+
});
|
|
9
|
+
};
|
|
10
|
+
import { useState, useEffect, useCallback } from "react";
|
|
11
|
+
const apiCache = {};
|
|
12
|
+
export function useAPI({ queryFn, queryProps = {}, enabled = true, staleTimeout = 5000, onSuccess, onError, }) {
|
|
13
|
+
const [isLoading, setIsLoading] = useState(false);
|
|
14
|
+
const [data, setData] = useState(undefined);
|
|
15
|
+
const [error, setError] = useState(undefined);
|
|
16
|
+
const cacheKey = queryFn.name + JSON.stringify(queryProps);
|
|
17
|
+
const fetch = useCallback(() => __awaiter(this, void 0, void 0, function* () {
|
|
18
|
+
setIsLoading(true);
|
|
19
|
+
setData(undefined);
|
|
20
|
+
setError(undefined);
|
|
21
|
+
try {
|
|
22
|
+
const res = yield queryFn(Object.assign({}, queryProps));
|
|
23
|
+
setData(res);
|
|
24
|
+
setIsLoading(false);
|
|
25
|
+
apiCache[cacheKey] = { data: res, timestamp: new Date().getTime() };
|
|
26
|
+
onSuccess === null || onSuccess === void 0 ? void 0 : onSuccess(res);
|
|
27
|
+
}
|
|
28
|
+
catch (e) {
|
|
29
|
+
if (e instanceof Error) {
|
|
30
|
+
setError(e);
|
|
31
|
+
onError === null || onError === void 0 ? void 0 : onError(e);
|
|
32
|
+
}
|
|
33
|
+
}
|
|
34
|
+
finally {
|
|
35
|
+
setIsLoading(false);
|
|
36
|
+
}
|
|
37
|
+
}), [cacheKey, onError, onSuccess, queryFn, queryProps]);
|
|
38
|
+
const execute = useCallback(() => {
|
|
39
|
+
if (enabled) {
|
|
40
|
+
const cachedItem = apiCache[cacheKey];
|
|
41
|
+
if (cachedItem && new Date().getTime() - cachedItem.timestamp < staleTimeout) {
|
|
42
|
+
// The cached item is still fresh, so we use it
|
|
43
|
+
setData(cachedItem.data);
|
|
44
|
+
onSuccess === null || onSuccess === void 0 ? void 0 : onSuccess(cachedItem.data);
|
|
45
|
+
setIsLoading(false);
|
|
46
|
+
}
|
|
47
|
+
else {
|
|
48
|
+
// The cached item is stale or doesn't exist, so we fetch fresh data
|
|
49
|
+
fetch();
|
|
50
|
+
}
|
|
51
|
+
}
|
|
52
|
+
}, [cacheKey, staleTimeout, enabled, fetch, onSuccess]);
|
|
53
|
+
useEffect(() => {
|
|
54
|
+
execute();
|
|
55
|
+
}, [execute]);
|
|
56
|
+
return { data, isLoading, error, refetch: execute };
|
|
57
|
+
}
|
|
58
|
+
//# sourceMappingURL=useAPI.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"useAPI.js","sourceRoot":"","sources":["../../src/hooks/useAPI.ts"],"names":[],"mappings":";;;;;;;;;AAAA,OAAO,EAAE,QAAQ,EAAE,SAAS,EAAE,WAAW,EAAE,MAAM,OAAO,CAAC;AAuBzD,MAAM,QAAQ,GAAG,EAAE,CAAC;AAEpB,MAAM,UAAU,MAAM,CAAwD,EAC5E,OAAO,EACP,UAAU,GAAG,EAAE,EACf,OAAO,GAAG,IAAI,EACd,YAAY,GAAG,IAAI,EACnB,SAAS,EACT,OAAO,GACK;IACZ,MAAM,CAAC,SAAS,EAAE,YAAY,CAAC,GAAG,QAAQ,CAAC,KAAK,CAAC,CAAC;IAClD,MAAM,CAAC,IAAI,EAAE,OAAO,CAAC,GAAG,QAAQ,CAAgB,SAAS,CAAC,CAAC;IAC3D,MAAM,CAAC,KAAK,EAAE,QAAQ,CAAC,GAAG,QAAQ,CAAoB,SAAS,CAAC,CAAC;IAEjE,MAAM,QAAQ,GAAG,OAAO,CAAC,IAAI,GAAG,IAAI,CAAC,SAAS,CAAC,UAAU,CAAC,CAAC;IAE3D,MAAM,KAAK,GAAG,WAAW,CAAC,GAAS,EAAE;QACnC,YAAY,CAAC,IAAI,CAAC,CAAC;QACnB,OAAO,CAAC,SAAS,CAAC,CAAC;QACnB,QAAQ,CAAC,SAAS,CAAC,CAAC;QAEpB,IAAI;YACF,MAAM,GAAG,GAAG,MAAM,OAAO,mBAAM,UAAU,EAAG,CAAC;YAC7C,OAAO,CAAC,GAAG,CAAC,CAAC;YACb,YAAY,CAAC,KAAK,CAAC,CAAC;YACpB,QAAQ,CAAC,QAAQ,CAAC,GAAG,EAAE,IAAI,EAAE,GAAG,EAAE,SAAS,EAAE,IAAI,IAAI,EAAE,CAAC,OAAO,EAAE,EAAE,CAAC;YACpE,SAAS,aAAT,SAAS,uBAAT,SAAS,CAAG,GAAG,CAAC,CAAC;SAClB;QAAC,OAAO,CAAU,EAAE;YACnB,IAAI,CAAC,YAAY,KAAK,EAAE;gBACtB,QAAQ,CAAC,CAAC,CAAC,CAAC;gBACZ,OAAO,aAAP,OAAO,uBAAP,OAAO,CAAG,CAAC,CAAC,CAAC;aACd;SACF;gBAAS;YACR,YAAY,CAAC,KAAK,CAAC,CAAC;SACrB;IACH,CAAC,CAAA,EAAE,CAAC,QAAQ,EAAE,OAAO,EAAE,SAAS,EAAE,OAAO,EAAE,UAAU,CAAC,CAAC,CAAC;IAExD,MAAM,OAAO,GAAG,WAAW,CAAC,GAAG,EAAE;QAC/B,IAAI,OAAO,EAAE;YACX,MAAM,UAAU,GAAG,QAAQ,CAAC,QAAQ,CAAC,CAAC;YACtC,IAAI,UAAU,IAAI,IAAI,IAAI,EAAE,CAAC,OAAO,EAAE,GAAG,UAAU,CAAC,SAAS,GAAG,YAAY,EAAE;gBAC5E,+CAA+C;gBAC/C,OAAO,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC;gBACzB,SAAS,aAAT,SAAS,uBAAT,SAAS,CAAG,UAAU,CAAC,IAAI,CAAC,CAAC;gBAC7B,YAAY,CAAC,KAAK,CAAC,CAAC;aACrB;iBAAM;gBACL,oEAAoE;gBACpE,KAAK,EAAE,CAAC;aACT;SACF;IACH,CAAC,EAAE,CAAC,QAAQ,EAAE,YAAY,EAAE,OAAO,EAAE,KAAK,EAAE,SAAS,CAAC,CAAC,CAAC;IAExD,SAAS,CAAC,GAAG,EAAE;QACb,OAAO,EAAE,CAAC;IACZ,CAAC,EAAE,CAAC,OAAO,CAAC,CAAC,CAAC;IAEd,OAAO,EAAE,IAAI,EAAE,SAAS,EAAE,KAAK,EAAE,OAAO,EAAE,OAAO,EAAE,CAAC;AACtD,CAAC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"account.d.ts","sourceRoot":"","sources":["../../src/mock/account.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,sBAAsB,CAAC;AACpD,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,wCAAwC,CAAC;AAgBhF;;GAEG;AACH,wBAAgB,4BAA4B,CAC1C,OAAO,EAAE,OAAO,EAChB,KAAK,EAAE,MAAM,EACb,IAAI,EAAE,MAAM,GAAG,MAAM,GACpB,OAAO,CAcT;AAED,wBAAgB,UAAU,CAAC,EAAE,EAAE,MAAM,GAAG,MAAM,EAAE,IAAI,GAAE,iBAAsB,GAAG,OAAO,
|
|
1
|
+
{"version":3,"file":"account.d.ts","sourceRoot":"","sources":["../../src/mock/account.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,sBAAsB,CAAC;AACpD,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,wCAAwC,CAAC;AAgBhF;;GAEG;AACH,wBAAgB,4BAA4B,CAC1C,OAAO,EAAE,OAAO,EAChB,KAAK,EAAE,MAAM,EACb,IAAI,EAAE,MAAM,GAAG,MAAM,GACpB,OAAO,CAcT;AAED,wBAAgB,UAAU,CAAC,EAAE,EAAE,MAAM,GAAG,MAAM,EAAE,IAAI,GAAE,iBAAsB,GAAG,OAAO,CAwJrF"}
|
package/lib-es/mock/account.js
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"account.js","sourceRoot":"","sources":["../../src/mock/account.ts"],"names":[],"mappings":"AAAA,OAAO,MAAM,MAAM,QAAQ,CAAC;AAC5B,OAAO,EAAE,SAAS,EAAE,MAAM,cAAc,CAAC;AAIzC,OAAO,EACL,UAAU,IAAI,gBAAgB,EAC9B,YAAY,EACZ,gBAAgB,GACjB,MAAM,wCAAwC,CAAC;AAChD,OAAO,EAAE,gBAAgB,EAAE,MAAM,WAAW,CAAC;AAC7C,OAAO,aAAa,MAAM,mBAAmB,CAAC;AAM9C,OAAO,EAAkB,YAAY,EAAE,MAAM,2BAA2B,CAAC;AAGzE;;GAEG;AACH,MAAM,UAAU,4BAA4B,CAC1C,OAAgB,EAChB,KAAa,EACb,IAAqB;IAErB,MAAM,GAAG,GAAG,IAAI,MAAM,CAAC,IAAI,CAAC,CAAC;IAC7B,MAAM,IAAI,qBAAiB,OAAO,CAAE,CAAC;IACrC,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC,KAAK,CAAC;SAC3B,IAAI,CAAC,IAAI,CAAC;SACV,MAAM,CAAC,GAAG,CAAC,EAAE;QACZ,MAAM,EAAE,GAAG,YAAY,CAAC,IAAI,EAAE,IAAI,EAAE,GAAG,EAAE,GAAG,CAAC,CAAC;QAC9C,OAAO,GAAG,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC;IACxB,CAAC,EAAE,IAAI,CAAC,UAAU,CAAC,CAAC;IACtB,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC,OAAO,GAAG,gBAAgB,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;IACzE,MAAM,kBAAkB,GAAG,aAAa,CAAC,OAAO,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC;IAC9D,MAAM,eAAe,GAAG,kBAAkB,IAAI,kBAAkB,CAAC,eAAe,CAAC;IACjF,IAAI,eAAe;QAAE,eAAe,CAAC,IAAI,CAAC,CAAC;IAC3C,OAAO,IAAI,CAAC;AACd,CAAC;AAED,MAAM,UAAU,UAAU,CAAC,EAAmB,EAAE,OAA0B,EAAE;IAC1E,OAAO,gBAAgB,CACrB,EAAE,EACF,IAAI,EACJ,CAAC,OAAgB,EAAE,QAAwB,EAAE,OAAe,EAAE,EAAE;QAC9D,QAAQ,QAAQ,CAAC,MAAM,EAAE;YACvB,KAAK,QAAQ;gBACV,OAAyB,CAAC,eAAe,GAAG;oBAC3C,0BAA0B;oBAC1B,WAAW,EAAE,EAAE;oBACf,aAAa,EAAE,EAAE;oBACjB,UAAU,EAAE,EAAE;oBACd,gBAAgB,EAAE,IAAI,SAAS,CAAC,CAAC,CAAC;oBAClC,qBAAqB,EAAE,IAAI,SAAS,CAAC,CAAC,CAAC;oBACvC,gBAAgB,EAAE,IAAI,SAAS,CAAC,CAAC,CAAC;oBAClC,eAAe,EAAE,OAAO;
|
|
1
|
+
{"version":3,"file":"account.js","sourceRoot":"","sources":["../../src/mock/account.ts"],"names":[],"mappings":"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"}
|
package/package.json
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@ledgerhq/live-common",
|
|
3
3
|
"description": "Common ground for the Ledger Live apps",
|
|
4
|
-
"version": "31.
|
|
4
|
+
"version": "31.7.0",
|
|
5
5
|
"repository": {
|
|
6
6
|
"type": "git",
|
|
7
7
|
"url": "https://github.com/LedgerHQ/ledger-live.git"
|
|
@@ -131,8 +131,8 @@
|
|
|
131
131
|
"@keplr-wallet/proto-types": "^0.10.4",
|
|
132
132
|
"@ledgerhq/compressjs": "github:LedgerHQ/compressjs#d9e8e4d994923e0ea76a32b97289bcccfe71b82e",
|
|
133
133
|
"@ledgerhq/live-app-sdk": "^0.8.1",
|
|
134
|
-
"@ledgerhq/wallet-api-core": "^1.0
|
|
135
|
-
"@ledgerhq/wallet-api-server": "^1.1.
|
|
134
|
+
"@ledgerhq/wallet-api-core": "^1.1.0",
|
|
135
|
+
"@ledgerhq/wallet-api-server": "^1.1.2",
|
|
136
136
|
"@solana/spl-token": "^0.3.7",
|
|
137
137
|
"@solana/web3.js": "1.77.3",
|
|
138
138
|
"@stacks/network": "1.2.2",
|
|
@@ -223,19 +223,19 @@
|
|
|
223
223
|
"varuint-bitcoin": "1.1.2",
|
|
224
224
|
"winston": "^3.4.0",
|
|
225
225
|
"xstate": "^4.30.2",
|
|
226
|
-
"@ledgerhq/coin-algorand": "^0.3.
|
|
227
|
-
"@ledgerhq/coin-evm": "^0.6.
|
|
228
|
-
"@ledgerhq/coin-framework": "^0.5.
|
|
229
|
-
"@ledgerhq/coin-polkadot": "^0.4.
|
|
230
|
-
"@ledgerhq/cryptoassets": "^9.12.
|
|
226
|
+
"@ledgerhq/coin-algorand": "^0.3.1",
|
|
227
|
+
"@ledgerhq/coin-evm": "^0.6.1",
|
|
228
|
+
"@ledgerhq/coin-framework": "^0.5.3",
|
|
229
|
+
"@ledgerhq/coin-polkadot": "^0.4.1",
|
|
230
|
+
"@ledgerhq/cryptoassets": "^9.12.1",
|
|
231
231
|
"@ledgerhq/devices": "^8.0.7",
|
|
232
|
-
"@ledgerhq/domain-service": "^1.1.
|
|
232
|
+
"@ledgerhq/domain-service": "^1.1.10",
|
|
233
233
|
"@ledgerhq/errors": "^6.14.0",
|
|
234
|
-
"@ledgerhq/evm-tools": "^1.0.
|
|
234
|
+
"@ledgerhq/evm-tools": "^1.0.6",
|
|
235
235
|
"@ledgerhq/hw-app-algorand": "^6.27.19",
|
|
236
236
|
"@ledgerhq/hw-app-btc": "^10.0.8",
|
|
237
237
|
"@ledgerhq/hw-app-cosmos": "^6.28.5",
|
|
238
|
-
"@ledgerhq/hw-app-eth": "^6.34.
|
|
238
|
+
"@ledgerhq/hw-app-eth": "^6.34.5",
|
|
239
239
|
"@ledgerhq/hw-app-exchange": "^0.2.3",
|
|
240
240
|
"@ledgerhq/hw-app-near": "^6.27.14",
|
|
241
241
|
"@ledgerhq/hw-app-polkadot": "^6.27.19",
|
|
@@ -256,7 +256,7 @@
|
|
|
256
256
|
"devDependencies": {
|
|
257
257
|
"@svgr/core": "^5.5.0",
|
|
258
258
|
"@testing-library/react": "12",
|
|
259
|
-
"@testing-library/react-hooks": "^
|
|
259
|
+
"@testing-library/react-hooks": "^8.0.0",
|
|
260
260
|
"@types/bn.js": "^5.1.1",
|
|
261
261
|
"@types/bs58": "^4.0.1",
|
|
262
262
|
"@types/cbor": "^6.0.0",
|
package/src/account/helpers.ts
CHANGED
|
@@ -63,12 +63,6 @@ export {
|
|
|
63
63
|
};
|
|
64
64
|
|
|
65
65
|
export const isAccountEmpty = (a: AccountLike): boolean => {
|
|
66
|
-
// FIXME LIVE-5966 why do we need this? also this shouldn't be implemented here / this part must be removed back to the coin specifics
|
|
67
|
-
if (a.type === "Account" && a.currency.family === "tron") {
|
|
68
|
-
const tronAcc = a as TronAccount;
|
|
69
|
-
return tronAcc.tronResources && tronAcc.tronResources.bandwidth.freeLimit.eq(0);
|
|
70
|
-
}
|
|
71
|
-
|
|
72
66
|
return commonIsAccountEmpty(a);
|
|
73
67
|
};
|
|
74
68
|
|
package/src/bot/engine.ts
CHANGED
|
@@ -603,6 +603,9 @@ export async function runOnAccount<T extends Transaction>({
|
|
|
603
603
|
const testBefore = now();
|
|
604
604
|
const timeOut = mutation.testTimeout || spec.testTimeout || 5 * 60 * 1000;
|
|
605
605
|
const step = account => {
|
|
606
|
+
if (spec.skipOperationHistory) {
|
|
607
|
+
return optimisticOperation;
|
|
608
|
+
}
|
|
606
609
|
const timedOut = now() - testBefore > timeOut;
|
|
607
610
|
const operation = account.operations.find(o => o.id === optimisticOperation.id);
|
|
608
611
|
|
|
@@ -663,6 +666,9 @@ export async function runOnAccount<T extends Transaction>({
|
|
|
663
666
|
log("bot", "remaining time to test destination: " + (newTimeOut / 1000).toFixed(0) + "s");
|
|
664
667
|
const sendingOperation = operation;
|
|
665
668
|
const step = account => {
|
|
669
|
+
if (spec.skipOperationHistory) {
|
|
670
|
+
return sendingOperation;
|
|
671
|
+
}
|
|
666
672
|
const timedOut = now() - ntestBefore > newTimeOut;
|
|
667
673
|
let operation;
|
|
668
674
|
try {
|
|
@@ -32,7 +32,7 @@ const defaultConfig = {
|
|
|
32
32
|
minGasPrice: 0.025,
|
|
33
33
|
},
|
|
34
34
|
persistence: {
|
|
35
|
-
lcd: "https://rest
|
|
35
|
+
lcd: "https://rest.core.persistence.one",
|
|
36
36
|
minGasPrice: 0.025,
|
|
37
37
|
ledgerValidator: "persistencevaloper1fgklp9hemczlwtqp9jqzq3xahh38hznxatty38",
|
|
38
38
|
},
|
package/src/cross.test.ts
CHANGED
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
import { genAccount } from "@ledgerhq/coin-framework/mocks/account";
|
|
2
2
|
import { getDerivationModesForCurrency } from "@ledgerhq/coin-framework/derivation";
|
|
3
|
+
import { DeviceModelId } from "@ledgerhq/devices";
|
|
3
4
|
import { listCryptoCurrencies, setSupportedCurrencies } from "./currencies";
|
|
4
5
|
import { accountDataToAccount, accountToAccountData, encode, decode } from "./cross";
|
|
5
6
|
import { Account } from "@ledgerhq/types-live";
|
|
@@ -38,11 +39,15 @@ test("encode/decode", () => {
|
|
|
38
39
|
},
|
|
39
40
|
exporterName: "test你好👋",
|
|
40
41
|
exporterVersion: "0.0.0",
|
|
42
|
+
modelId: DeviceModelId.nanoX,
|
|
43
|
+
modelIdList: [DeviceModelId.nanoX],
|
|
41
44
|
};
|
|
42
45
|
const exp = decode(encode(data));
|
|
43
46
|
expect(exp.meta.exporterName).toEqual(data.exporterName);
|
|
44
47
|
expect(exp.accounts.length).toEqual(data.accounts.length);
|
|
45
48
|
expect(exp.accounts).toMatchObject(data.accounts.map(accountToAccountData));
|
|
49
|
+
expect(exp.meta.modelId).toEqual("nanoX");
|
|
50
|
+
expect(exp.meta.modelIdList).toEqual(["nanoX"]);
|
|
46
51
|
});
|
|
47
52
|
test("encode/decode", () => {
|
|
48
53
|
const accounts = Array(3)
|
|
@@ -101,5 +106,7 @@ test("encode/decode", () => {
|
|
|
101
106
|
},
|
|
102
107
|
blacklistedTokenIds: ["tokenid3"],
|
|
103
108
|
});
|
|
109
|
+
expect(res.meta.modelId).toBeUndefined();
|
|
110
|
+
expect(res.meta.modelIdList).toBeUndefined();
|
|
104
111
|
expect(res).toMatchSnapshot();
|
|
105
112
|
});
|
package/src/cross.ts
CHANGED
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
// cross helps dealing with cross-project feature like export/import & cross project conversions
|
|
2
2
|
import { BigNumber } from "bignumber.js";
|
|
3
3
|
import compressjs from "@ledgerhq/compressjs";
|
|
4
|
+
import type { DeviceModelId } from "@ledgerhq/devices";
|
|
4
5
|
import {
|
|
5
6
|
runDerivationScheme,
|
|
6
7
|
getDerivationScheme,
|
|
@@ -43,11 +44,15 @@ export type DataIn = {
|
|
|
43
44
|
exporterName: string;
|
|
44
45
|
// the version of the exporter. e.g. the desktop app version
|
|
45
46
|
exporterVersion: string;
|
|
47
|
+
modelId?: DeviceModelId;
|
|
48
|
+
modelIdList?: DeviceModelId[];
|
|
46
49
|
};
|
|
47
50
|
|
|
48
51
|
type Meta = {
|
|
49
52
|
exporterName: string;
|
|
50
53
|
exporterVersion: string;
|
|
54
|
+
modelId?: DeviceModelId;
|
|
55
|
+
modelIdList?: DeviceModelId[];
|
|
51
56
|
};
|
|
52
57
|
|
|
53
58
|
export type Result = {
|
|
@@ -56,7 +61,14 @@ export type Result = {
|
|
|
56
61
|
meta: Meta;
|
|
57
62
|
};
|
|
58
63
|
|
|
59
|
-
export function encode({
|
|
64
|
+
export function encode({
|
|
65
|
+
accounts,
|
|
66
|
+
settings,
|
|
67
|
+
exporterName,
|
|
68
|
+
exporterVersion,
|
|
69
|
+
modelId,
|
|
70
|
+
modelIdList,
|
|
71
|
+
}: DataIn): string {
|
|
60
72
|
return Buffer.from(
|
|
61
73
|
compressjs.Bzip2.compressFile(
|
|
62
74
|
Buffer.from(
|
|
@@ -64,6 +76,8 @@ export function encode({ accounts, settings, exporterName, exporterVersion }: Da
|
|
|
64
76
|
meta: {
|
|
65
77
|
exporterName,
|
|
66
78
|
exporterVersion,
|
|
79
|
+
modelId,
|
|
80
|
+
modelIdList,
|
|
67
81
|
},
|
|
68
82
|
accounts: accounts.map(accountToAccountData),
|
|
69
83
|
settings,
|
|
@@ -78,7 +92,7 @@ const asResultMeta = (unsafe: Record<string, any>): Meta => {
|
|
|
78
92
|
throw new Error("invalid meta data");
|
|
79
93
|
}
|
|
80
94
|
|
|
81
|
-
const { exporterName, exporterVersion } = unsafe;
|
|
95
|
+
const { exporterName, exporterVersion, modelId, modelIdList } = unsafe;
|
|
82
96
|
|
|
83
97
|
if (typeof exporterName !== "string") {
|
|
84
98
|
throw new Error("invalid meta.exporterName");
|
|
@@ -88,9 +102,19 @@ const asResultMeta = (unsafe: Record<string, any>): Meta => {
|
|
|
88
102
|
throw new Error("invalid meta.exporterVersion");
|
|
89
103
|
}
|
|
90
104
|
|
|
105
|
+
if (modelId && typeof modelId !== "string") {
|
|
106
|
+
throw new Error("invalid meta.modelId");
|
|
107
|
+
}
|
|
108
|
+
|
|
109
|
+
if (modelIdList && modelIdList.some(id => typeof id !== "string")) {
|
|
110
|
+
throw new Error("invalid meta.modelIdList");
|
|
111
|
+
}
|
|
112
|
+
|
|
91
113
|
return {
|
|
92
114
|
exporterName,
|
|
93
115
|
exporterVersion,
|
|
116
|
+
modelId,
|
|
117
|
+
modelIdList,
|
|
94
118
|
};
|
|
95
119
|
};
|
|
96
120
|
|
|
@@ -2,6 +2,7 @@ import network from "@ledgerhq/live-network/network";
|
|
|
2
2
|
import { fetchCurrencyFrom } from "../fetchCurrencyFrom";
|
|
3
3
|
import { fetchCurrencyFromMock } from "../__mocks__/fetchCurrencyFrom.mocks";
|
|
4
4
|
import { DEFAULT_SWAP_TIMEOUT_MS } from "../../../const/timeout";
|
|
5
|
+
import { flattenV5CurrenciesToAndFrom } from "../../../utils/flattenV5CurrenciesToAndFrom";
|
|
5
6
|
|
|
6
7
|
jest.mock("@ledgerhq/live-network/network");
|
|
7
8
|
|
|
@@ -16,11 +17,11 @@ describe("fetchCurrencyFrom", () => {
|
|
|
16
17
|
currencyTo: "bitcoin",
|
|
17
18
|
});
|
|
18
19
|
|
|
19
|
-
expect(result).toStrictEqual(fetchCurrencyFromMock);
|
|
20
|
+
expect(result).toStrictEqual(flattenV5CurrenciesToAndFrom(fetchCurrencyFromMock));
|
|
20
21
|
expect(network as jest.Mock).toHaveBeenCalledWith({
|
|
21
22
|
method: "GET",
|
|
22
23
|
timeout: DEFAULT_SWAP_TIMEOUT_MS,
|
|
23
|
-
url: "https://swap-stg.ledger.com/v5/currencies/from?providers-whitelist=changelly%2Ccic%2Coneinch&additional-coins-flag=false&
|
|
24
|
+
url: "https://swap-stg.ledger.com/v5/currencies/from?providers-whitelist=changelly%2Ccic%2Coneinch&additional-coins-flag=false¤cy-to=bitcoin",
|
|
24
25
|
});
|
|
25
26
|
});
|
|
26
27
|
});
|
|
@@ -4,6 +4,7 @@ import { fetchCurrencyTo } from "../fetchCurrencyTo";
|
|
|
4
4
|
import { fetchCurrencyToMock } from "../__mocks__/fetchCurrencyTo.mocks";
|
|
5
5
|
import { DEFAULT_SWAP_TIMEOUT_MS } from "../../../const/timeout";
|
|
6
6
|
import { LedgerAPI4xx } from "@ledgerhq/errors";
|
|
7
|
+
import { flattenV5CurrenciesToAndFrom } from "../../../utils/flattenV5CurrenciesToAndFrom";
|
|
7
8
|
|
|
8
9
|
jest.mock("@ledgerhq/live-network/network");
|
|
9
10
|
|
|
@@ -17,14 +18,14 @@ describe("fetchCurrencyFrom", () => {
|
|
|
17
18
|
|
|
18
19
|
const result = await fetchCurrencyTo({
|
|
19
20
|
providers: ["changelly", "cic", "oneinch"],
|
|
20
|
-
|
|
21
|
+
currencyFromId: "bitcoin",
|
|
21
22
|
});
|
|
22
23
|
|
|
23
|
-
expect(result).toStrictEqual(fetchCurrencyToMock);
|
|
24
|
+
expect(result).toStrictEqual(flattenV5CurrenciesToAndFrom(fetchCurrencyToMock));
|
|
24
25
|
expect(mockNetwork).toHaveBeenCalledWith({
|
|
25
26
|
method: "GET",
|
|
26
27
|
timeout: DEFAULT_SWAP_TIMEOUT_MS,
|
|
27
|
-
url: "https://swap-stg.ledger.com/v5/currencies/to?providers-whitelist=changelly%2Ccic%2Coneinch&additional-coins-flag=false&
|
|
28
|
+
url: "https://swap-stg.ledger.com/v5/currencies/to?providers-whitelist=changelly%2Ccic%2Coneinch&additional-coins-flag=false¤cy-from=bitcoin",
|
|
28
29
|
});
|
|
29
30
|
});
|
|
30
31
|
|
|
@@ -34,7 +35,7 @@ describe("fetchCurrencyFrom", () => {
|
|
|
34
35
|
try {
|
|
35
36
|
await fetchCurrencyTo({
|
|
36
37
|
providers: ["changelly", "cic", "oneinch"],
|
|
37
|
-
|
|
38
|
+
currencyFromId: "bitcoin",
|
|
38
39
|
});
|
|
39
40
|
} catch (e) {
|
|
40
41
|
expect(e).toBeInstanceOf(LedgerAPI4xx);
|
|
@@ -2,6 +2,8 @@ import network from "@ledgerhq/live-network/network";
|
|
|
2
2
|
import { isIntegrationTestEnv } from "../../utils/isIntegrationTestEnv";
|
|
3
3
|
import { getEnv } from "@ledgerhq/live-env";
|
|
4
4
|
import { DEFAULT_SWAP_TIMEOUT_MS } from "../../const/timeout";
|
|
5
|
+
import { flattenV5CurrenciesToAndFrom } from "../../utils/flattenV5CurrenciesToAndFrom";
|
|
6
|
+
import { fetchCurrencyFromMock } from "./__mocks__/fetchCurrencyFrom.mocks";
|
|
5
7
|
|
|
6
8
|
type Props = {
|
|
7
9
|
providers: Array<string>;
|
|
@@ -21,13 +23,13 @@ export async function fetchCurrencyFrom({
|
|
|
21
23
|
currencyTo,
|
|
22
24
|
additionalCoinsFlag = false,
|
|
23
25
|
}: Props) {
|
|
24
|
-
if (isIntegrationTestEnv()) return
|
|
26
|
+
if (isIntegrationTestEnv()) return flattenV5CurrenciesToAndFrom(fetchCurrencyFromMock);
|
|
25
27
|
|
|
26
28
|
const url = new URL(`${getEnv("SWAP_API_BASE_V5")}/currencies/from`);
|
|
27
29
|
url.searchParams.append("providers-whitelist", providers.join(","));
|
|
28
30
|
url.searchParams.append("additional-coins-flag", additionalCoinsFlag.toString());
|
|
29
31
|
if (currencyTo) {
|
|
30
|
-
url.searchParams.append("
|
|
32
|
+
url.searchParams.append("currency-to", currencyTo);
|
|
31
33
|
}
|
|
32
34
|
|
|
33
35
|
try {
|
|
@@ -36,7 +38,7 @@ export async function fetchCurrencyFrom({
|
|
|
36
38
|
url: url.toString(),
|
|
37
39
|
timeout: DEFAULT_SWAP_TIMEOUT_MS,
|
|
38
40
|
});
|
|
39
|
-
return data;
|
|
41
|
+
return flattenV5CurrenciesToAndFrom(data);
|
|
40
42
|
} catch (e) {
|
|
41
43
|
throw Error("Something went wrong in fetchCurrencyFrom call");
|
|
42
44
|
}
|
|
@@ -5,9 +5,10 @@ import { isIntegrationTestEnv } from "../../utils/isIntegrationTestEnv";
|
|
|
5
5
|
import { DEFAULT_SWAP_TIMEOUT_MS } from "../../const/timeout";
|
|
6
6
|
import axios from "axios";
|
|
7
7
|
import { LedgerAPI4xx } from "@ledgerhq/errors";
|
|
8
|
+
import { flattenV5CurrenciesToAndFrom } from "../../utils/flattenV5CurrenciesToAndFrom";
|
|
8
9
|
|
|
9
10
|
type Props = {
|
|
10
|
-
|
|
11
|
+
currencyFromId?: string;
|
|
11
12
|
providers: string[];
|
|
12
13
|
additionalCoinsFlag?: boolean;
|
|
13
14
|
};
|
|
@@ -21,17 +22,19 @@ type CurrencyGroup = {
|
|
|
21
22
|
};
|
|
22
23
|
|
|
23
24
|
export async function fetchCurrencyTo({
|
|
24
|
-
|
|
25
|
+
currencyFromId,
|
|
25
26
|
providers,
|
|
26
27
|
additionalCoinsFlag = false,
|
|
27
28
|
}: Props) {
|
|
28
|
-
if (isIntegrationTestEnv())
|
|
29
|
+
if (isIntegrationTestEnv()) {
|
|
30
|
+
return Promise.resolve(flattenV5CurrenciesToAndFrom(fetchCurrencyToMock));
|
|
31
|
+
}
|
|
29
32
|
|
|
30
33
|
const url = new URL(`${getEnv("SWAP_API_BASE_V5")}/currencies/to`);
|
|
31
34
|
|
|
32
35
|
url.searchParams.append("providers-whitelist", providers.join(","));
|
|
33
36
|
url.searchParams.append("additional-coins-flag", additionalCoinsFlag.toString());
|
|
34
|
-
url.searchParams.append("
|
|
37
|
+
url.searchParams.append("currency-from", currencyFromId!);
|
|
35
38
|
|
|
36
39
|
try {
|
|
37
40
|
const { data } = await network<ResponseData>({
|
|
@@ -39,7 +42,7 @@ export async function fetchCurrencyTo({
|
|
|
39
42
|
url: url.toString(),
|
|
40
43
|
timeout: DEFAULT_SWAP_TIMEOUT_MS,
|
|
41
44
|
});
|
|
42
|
-
return data;
|
|
45
|
+
return flattenV5CurrenciesToAndFrom(data);
|
|
43
46
|
} catch (e: unknown) {
|
|
44
47
|
if (axios.isAxiosError(e)) {
|
|
45
48
|
if (e.code === "ECONNABORTED") {
|
|
@@ -0,0 +1,48 @@
|
|
|
1
|
+
import network from "@ledgerhq/live-network/network";
|
|
2
|
+
import { DEFAULT_SWAP_TIMEOUT_MS } from "../../const/timeout";
|
|
3
|
+
import axios from "axios";
|
|
4
|
+
import { LedgerAPI4xx } from "@ledgerhq/errors";
|
|
5
|
+
import { getEnv } from "@ledgerhq/live-env";
|
|
6
|
+
import { ExchangeRateV5Response } from "../../types";
|
|
7
|
+
|
|
8
|
+
type Props = {
|
|
9
|
+
providers: Array<string>;
|
|
10
|
+
currencyFrom?: string;
|
|
11
|
+
toCurrencyId?: string;
|
|
12
|
+
fromCurrencyAmount: string;
|
|
13
|
+
};
|
|
14
|
+
|
|
15
|
+
export async function fetchRates({
|
|
16
|
+
providers,
|
|
17
|
+
currencyFrom,
|
|
18
|
+
toCurrencyId,
|
|
19
|
+
fromCurrencyAmount,
|
|
20
|
+
}: Props) {
|
|
21
|
+
const url = new URL(`${getEnv("SWAP_API_BASE_V5")}/rate`);
|
|
22
|
+
const requestBody = {
|
|
23
|
+
from: currencyFrom,
|
|
24
|
+
to: toCurrencyId,
|
|
25
|
+
amountFrom: fromCurrencyAmount, // not sure why amountFrom thinks it can be undefined here
|
|
26
|
+
providers,
|
|
27
|
+
};
|
|
28
|
+
|
|
29
|
+
try {
|
|
30
|
+
const { data } = await network<ExchangeRateV5Response[]>({
|
|
31
|
+
method: "POST",
|
|
32
|
+
url: url.toString(),
|
|
33
|
+
timeout: DEFAULT_SWAP_TIMEOUT_MS,
|
|
34
|
+
data: requestBody,
|
|
35
|
+
});
|
|
36
|
+
return data.filter(d => d.status === "success");
|
|
37
|
+
} catch (e: unknown) {
|
|
38
|
+
if (axios.isAxiosError(e)) {
|
|
39
|
+
if (e.code === "ECONNABORTED") {
|
|
40
|
+
// TODO: LIVE-8901 (handle request timeout)
|
|
41
|
+
}
|
|
42
|
+
}
|
|
43
|
+
if (e instanceof LedgerAPI4xx) {
|
|
44
|
+
// TODO: LIVE-8901 (handle 4xx)
|
|
45
|
+
}
|
|
46
|
+
throw e;
|
|
47
|
+
}
|
|
48
|
+
}
|
|
@@ -73,6 +73,7 @@ const completeExchange = (
|
|
|
73
73
|
const payoutAccount = getMainAccount(toAccount, toParentAccount);
|
|
74
74
|
const accountBridge = getAccountBridge(refundAccount);
|
|
75
75
|
const mainPayoutCurrency = getAccountCurrency(payoutAccount);
|
|
76
|
+
const payoutCurrency = getAccountCurrency(toAccount);
|
|
76
77
|
const refundCurrency = getAccountCurrency(fromAccount);
|
|
77
78
|
const mainRefundCurrency = getAccountCurrency(refundAccount);
|
|
78
79
|
if (mainPayoutCurrency.type !== "CryptoCurrency")
|
|
@@ -126,7 +127,7 @@ const completeExchange = (
|
|
|
126
127
|
if (unsubscribed) return;
|
|
127
128
|
|
|
128
129
|
const { config: payoutAddressConfig, signature: payoutAddressConfigSignature } =
|
|
129
|
-
getCurrencyExchangeConfig(
|
|
130
|
+
getCurrencyExchangeConfig(payoutCurrency);
|
|
130
131
|
|
|
131
132
|
try {
|
|
132
133
|
currentStep = "CHECK_PAYOUT_ADDRESS";
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
import { getAvailableProviders } from "../..";
|
|
2
|
+
import { useAPI } from "../../../../hooks/useAPI";
|
|
3
|
+
import { fetchCurrencyFrom } from "../../api/v5/fetchCurrencyFrom";
|
|
4
|
+
|
|
5
|
+
type Props = {
|
|
6
|
+
currencyTo?: string;
|
|
7
|
+
additionalCoinsFlag?: boolean;
|
|
8
|
+
enabled?: boolean;
|
|
9
|
+
};
|
|
10
|
+
|
|
11
|
+
export function useFetchCurrencyFrom({ currencyTo, additionalCoinsFlag, enabled }: Props) {
|
|
12
|
+
return useAPI({
|
|
13
|
+
queryFn: fetchCurrencyFrom,
|
|
14
|
+
queryProps: {
|
|
15
|
+
providers: getAvailableProviders(),
|
|
16
|
+
currencyTo,
|
|
17
|
+
additionalCoinsFlag,
|
|
18
|
+
},
|
|
19
|
+
// assume a currency list for the given props won't change during a users session.
|
|
20
|
+
staleTimeout: Infinity,
|
|
21
|
+
enabled,
|
|
22
|
+
});
|
|
23
|
+
}
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
import { AccountLike } from "@ledgerhq/types-live";
|
|
2
|
+
import { getAccountCurrency } from "@ledgerhq/coin-framework/account/helpers";
|
|
3
|
+
|
|
4
|
+
import { fetchCurrencyTo } from "../../api/v5";
|
|
5
|
+
import { getAvailableProviders } from "../..";
|
|
6
|
+
import { useAPI } from "../../../../hooks/useAPI";
|
|
7
|
+
|
|
8
|
+
type Props = {
|
|
9
|
+
fromCurrencyAccount: AccountLike | undefined;
|
|
10
|
+
additionalCoinsFlag?: boolean;
|
|
11
|
+
};
|
|
12
|
+
|
|
13
|
+
export function useFetchCurrencyTo({ fromCurrencyAccount, additionalCoinsFlag }: Props) {
|
|
14
|
+
const currencyFromId = fromCurrencyAccount
|
|
15
|
+
? getAccountCurrency(fromCurrencyAccount).id
|
|
16
|
+
: undefined;
|
|
17
|
+
return useAPI({
|
|
18
|
+
queryFn: fetchCurrencyTo,
|
|
19
|
+
queryProps: {
|
|
20
|
+
providers: getAvailableProviders(),
|
|
21
|
+
currencyFromId,
|
|
22
|
+
additionalCoinsFlag,
|
|
23
|
+
},
|
|
24
|
+
// assume a currency list for the given props won't change during a users session.
|
|
25
|
+
staleTimeout: Infinity,
|
|
26
|
+
enabled: !!currencyFromId,
|
|
27
|
+
});
|
|
28
|
+
}
|
|
@@ -0,0 +1,41 @@
|
|
|
1
|
+
import { getAvailableProviders } from "../..";
|
|
2
|
+
import { AccountLike } from "@ledgerhq/types-live";
|
|
3
|
+
import { getAccountCurrency, getAccountUnit } from "@ledgerhq/coin-framework/account/helpers";
|
|
4
|
+
import { CryptoOrTokenCurrency } from "@ledgerhq/types-cryptoassets";
|
|
5
|
+
import BigNumber from "bignumber.js";
|
|
6
|
+
import { formatCurrencyUnit } from "@ledgerhq/coin-framework/currencies/formatCurrencyUnit";
|
|
7
|
+
import { fetchRates } from "../../api/v5/fetchRates";
|
|
8
|
+
import { useAPI } from "../../../../hooks/useAPI";
|
|
9
|
+
import { ExchangeRateV5Response } from "../../types";
|
|
10
|
+
|
|
11
|
+
type Props = {
|
|
12
|
+
fromCurrencyAccount: AccountLike | undefined;
|
|
13
|
+
toCurrency: CryptoOrTokenCurrency | undefined;
|
|
14
|
+
fromCurrencyAmount: BigNumber;
|
|
15
|
+
onSuccess?(data: ExchangeRateV5Response[]): void;
|
|
16
|
+
};
|
|
17
|
+
|
|
18
|
+
export function useFetchRates({
|
|
19
|
+
fromCurrencyAccount,
|
|
20
|
+
toCurrency,
|
|
21
|
+
fromCurrencyAmount,
|
|
22
|
+
onSuccess,
|
|
23
|
+
}: Props) {
|
|
24
|
+
const currencyFrom = fromCurrencyAccount ? getAccountCurrency(fromCurrencyAccount).id : undefined;
|
|
25
|
+
const unit = fromCurrencyAccount ? getAccountUnit(fromCurrencyAccount) : undefined;
|
|
26
|
+
|
|
27
|
+
const formattedCurrencyAmount = (unit && formatCurrencyUnit(unit, fromCurrencyAmount)) ?? "0";
|
|
28
|
+
|
|
29
|
+
const toCurrencyId = toCurrency?.id;
|
|
30
|
+
return useAPI({
|
|
31
|
+
queryFn: fetchRates,
|
|
32
|
+
queryProps: {
|
|
33
|
+
providers: getAvailableProviders(),
|
|
34
|
+
currencyFrom,
|
|
35
|
+
toCurrencyId,
|
|
36
|
+
fromCurrencyAmount: formattedCurrencyAmount,
|
|
37
|
+
},
|
|
38
|
+
enabled: !!toCurrencyId && !!currencyFrom && fromCurrencyAmount.gt(0),
|
|
39
|
+
onSuccess,
|
|
40
|
+
});
|
|
41
|
+
}
|