@metamask/assets-controllers 108.2.0 → 108.4.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/CHANGELOG.md +24 -1
- package/dist/index.cjs +2 -1
- package/dist/index.cjs.map +1 -1
- package/dist/index.d.cts +2 -2
- package/dist/index.d.cts.map +1 -1
- package/dist/index.d.mts +2 -2
- package/dist/index.d.mts.map +1 -1
- package/dist/index.mjs +1 -1
- package/dist/index.mjs.map +1 -1
- package/dist/multicall.cjs +2 -0
- package/dist/multicall.cjs.map +1 -1
- package/dist/multicall.d.cts.map +1 -1
- package/dist/multicall.d.mts.map +1 -1
- package/dist/multicall.mjs +2 -0
- package/dist/multicall.mjs.map +1 -1
- package/dist/token-prices-service/codefi-v2.cjs +1 -0
- package/dist/token-prices-service/codefi-v2.cjs.map +1 -1
- package/dist/token-prices-service/codefi-v2.d.cts +2 -1
- package/dist/token-prices-service/codefi-v2.d.cts.map +1 -1
- package/dist/token-prices-service/codefi-v2.d.mts +2 -1
- package/dist/token-prices-service/codefi-v2.d.mts.map +1 -1
- package/dist/token-prices-service/codefi-v2.mjs +1 -0
- package/dist/token-prices-service/codefi-v2.mjs.map +1 -1
- package/dist/token-service.cjs +46 -1
- package/dist/token-service.cjs.map +1 -1
- package/dist/token-service.d.cts +58 -0
- package/dist/token-service.d.cts.map +1 -1
- package/dist/token-service.d.mts +58 -0
- package/dist/token-service.d.mts.map +1 -1
- package/dist/token-service.mjs +44 -0
- package/dist/token-service.mjs.map +1 -1
- package/package.json +7 -7
package/dist/token-service.d.mts
CHANGED
|
@@ -51,6 +51,57 @@ export type TokenRwaData = {
|
|
|
51
51
|
ticker?: string;
|
|
52
52
|
instrumentType?: string;
|
|
53
53
|
};
|
|
54
|
+
export type RwaMarket = {
|
|
55
|
+
nextOpen?: string;
|
|
56
|
+
nextClose?: string;
|
|
57
|
+
};
|
|
58
|
+
export type RwaTokenData = {
|
|
59
|
+
price: string;
|
|
60
|
+
priceChange: string;
|
|
61
|
+
marketCap: number;
|
|
62
|
+
aggregatedUsdVolume: number;
|
|
63
|
+
active: boolean;
|
|
64
|
+
ticker: string;
|
|
65
|
+
instrumentType: string;
|
|
66
|
+
custodians: string[];
|
|
67
|
+
industry: string[];
|
|
68
|
+
market?: RwaMarket;
|
|
69
|
+
nextPause?: Record<string, unknown>;
|
|
70
|
+
sharesOutstanding?: number;
|
|
71
|
+
restrictedCountries?: string[];
|
|
72
|
+
updatedAt?: string;
|
|
73
|
+
addressType?: string;
|
|
74
|
+
};
|
|
75
|
+
export type RwaToken = {
|
|
76
|
+
id: string;
|
|
77
|
+
assetId: CaipAssetType;
|
|
78
|
+
symbol: string;
|
|
79
|
+
decimals: number;
|
|
80
|
+
name: string;
|
|
81
|
+
rwaData: RwaTokenData;
|
|
82
|
+
};
|
|
83
|
+
export type RwasResponse = {
|
|
84
|
+
data: RwaToken[];
|
|
85
|
+
count: number;
|
|
86
|
+
totalCount: number;
|
|
87
|
+
pageInfo: {
|
|
88
|
+
nextCursor: string | null;
|
|
89
|
+
hasNextPage: boolean;
|
|
90
|
+
};
|
|
91
|
+
};
|
|
92
|
+
export type RwaSortBy = 'price_change_asc' | 'price_change_desc' | 'volume_asc' | 'volume_desc' | 'market_cap_asc' | 'market_cap_desc';
|
|
93
|
+
export type FetchRwasParams = {
|
|
94
|
+
chainIds?: CaipChainId[];
|
|
95
|
+
query?: string;
|
|
96
|
+
sortBy?: RwaSortBy;
|
|
97
|
+
limit?: number;
|
|
98
|
+
after?: string;
|
|
99
|
+
active?: boolean;
|
|
100
|
+
custodian?: 'ondo';
|
|
101
|
+
type?: 'stock' | 'etf';
|
|
102
|
+
industry?: 'industrials' | 'technology' | 'healthcare' | 'consumer discretionary' | 'financials' | 'materials' | 'utilities' | 'energy' | 'real estate';
|
|
103
|
+
[key: string]: string | number | boolean | string[] | undefined;
|
|
104
|
+
};
|
|
54
105
|
export type TokenSecurityFeature = {
|
|
55
106
|
featureId: string;
|
|
56
107
|
type: string;
|
|
@@ -225,6 +276,13 @@ type FetchTokenAssetsOptions = {
|
|
|
225
276
|
* @returns Array of token assets, or empty array if the request failed or no IDs were provided.
|
|
226
277
|
*/
|
|
227
278
|
export declare function fetchTokenAssets(assetIds: CaipAssetType[], { includeAggregators, includeCoingeckoId, includeLabels, includeMarketData, includeOccurrences, includeTokenSecurityData, includeRwaData, }?: FetchTokenAssetsOptions): Promise<TokenAsset[]>;
|
|
279
|
+
/**
|
|
280
|
+
* Fetch real-world asset tokens.
|
|
281
|
+
*
|
|
282
|
+
* @param params - Query params used to filter, sort, and paginate RWAs.
|
|
283
|
+
* @returns The paginated RWA response.
|
|
284
|
+
*/
|
|
285
|
+
export declare function fetchRwas(params?: FetchRwasParams): Promise<RwasResponse>;
|
|
228
286
|
/**
|
|
229
287
|
* Fetch metadata for the token address provided for a given network. This request is cancellable
|
|
230
288
|
* using the abort signal passed in.
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"token-service.d.mts","sourceRoot":"","sources":["../src/token-service.ts"],"names":[],"mappings":"AAMA,OAAO,KAAK,EAAE,aAAa,EAAE,WAAW,EAAE,GAAG,EAAE,wBAAwB;AAIvE,eAAO,MAAM,mBAAmB,qCAAqC,CAAC;AACtE,eAAO,MAAM,+BAA+B,oEACuB,CAAC;AAkCpE;;GAEG;AACH,MAAM,MAAM,cAAc,GACtB,aAAa,GACb,aAAa,GACb,aAAa,GACb,cAAc,CAAC;
|
|
1
|
+
{"version":3,"file":"token-service.d.mts","sourceRoot":"","sources":["../src/token-service.ts"],"names":[],"mappings":"AAMA,OAAO,KAAK,EAAE,aAAa,EAAE,WAAW,EAAE,GAAG,EAAE,wBAAwB;AAIvE,eAAO,MAAM,mBAAmB,qCAAqC,CAAC;AACtE,eAAO,MAAM,+BAA+B,oEACuB,CAAC;AAkCpE;;GAEG;AACH,MAAM,MAAM,cAAc,GACtB,aAAa,GACb,aAAa,GACb,aAAa,GACb,cAAc,CAAC;AA2InB;;;;;;;GAOG;AACH,MAAM,MAAM,yBAAyB,GAAG;IACtC,IAAI,CAAC,EAAE,cAAc,CAAC;IACtB,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,eAAe,CAAC,EAAE,MAAM,CAAC;IACzB,eAAe,CAAC,EAAE,MAAM,CAAC;IACzB,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,aAAa,CAAC,EAAE,MAAM,EAAE,CAAC;IACzB,cAAc,CAAC,EAAE,OAAO,CAAC;IACzB,eAAe,CAAC,EAAE,OAAO,CAAC;IAC1B,wBAAwB,CAAC,EAAE,OAAO,CAAC;IACnC,CAAC,GAAG,EAAE,MAAM,GAAG,MAAM,GAAG,MAAM,GAAG,OAAO,GAAG,MAAM,EAAE,GAAG,SAAS,CAAC;CACjE,CAAC;AAsCF;;;;;;;;;GASG;AACH,wBAAsB,uBAAuB,CAC3C,OAAO,EAAE,GAAG,EACZ,WAAW,EAAE,WAAW,EACxB,EAAE,OAAwB,EAAE;;CAAK,GAChC,OAAO,CAAC,OAAO,CAAC,CAelB;AAED,MAAM,MAAM,YAAY,GAAG;IACzB,MAAM,CAAC,EAAE;QACP,QAAQ,CAAC,EAAE,MAAM,CAAC;QAClB,SAAS,CAAC,EAAE,MAAM,CAAC;KACpB,CAAC;IACF,SAAS,CAAC,EAAE;QACV,KAAK,CAAC,EAAE,MAAM,CAAC;QACf,GAAG,CAAC,EAAE,MAAM,CAAC;KACd,CAAC;IACF,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,cAAc,CAAC,EAAE,MAAM,CAAC;CACzB,CAAC;AAEF,MAAM,MAAM,SAAS,GAAG;IACtB,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,SAAS,CAAC,EAAE,MAAM,CAAC;CACpB,CAAC;AAEF,MAAM,MAAM,YAAY,GAAG;IACzB,KAAK,EAAE,MAAM,CAAC;IACd,WAAW,EAAE,MAAM,CAAC;IACpB,SAAS,EAAE,MAAM,CAAC;IAClB,mBAAmB,EAAE,MAAM,CAAC;IAC5B,MAAM,EAAE,OAAO,CAAC;IAChB,MAAM,EAAE,MAAM,CAAC;IACf,cAAc,EAAE,MAAM,CAAC;IACvB,UAAU,EAAE,MAAM,EAAE,CAAC;IACrB,QAAQ,EAAE,MAAM,EAAE,CAAC;IACnB,MAAM,CAAC,EAAE,SAAS,CAAC;IACnB,SAAS,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;IACpC,iBAAiB,CAAC,EAAE,MAAM,CAAC;IAC3B,mBAAmB,CAAC,EAAE,MAAM,EAAE,CAAC;IAC/B,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,WAAW,CAAC,EAAE,MAAM,CAAC;CACtB,CAAC;AAEF,MAAM,MAAM,QAAQ,GAAG;IACrB,EAAE,EAAE,MAAM,CAAC;IACX,OAAO,EAAE,aAAa,CAAC;IACvB,MAAM,EAAE,MAAM,CAAC;IACf,QAAQ,EAAE,MAAM,CAAC;IACjB,IAAI,EAAE,MAAM,CAAC;IACb,OAAO,EAAE,YAAY,CAAC;CACvB,CAAC;AAEF,MAAM,MAAM,YAAY,GAAG;IACzB,IAAI,EAAE,QAAQ,EAAE,CAAC;IACjB,KAAK,EAAE,MAAM,CAAC;IACd,UAAU,EAAE,MAAM,CAAC;IACnB,QAAQ,EAAE;QACR,UAAU,EAAE,MAAM,GAAG,IAAI,CAAC;QAC1B,WAAW,EAAE,OAAO,CAAC;KACtB,CAAC;CACH,CAAC;AAEF,MAAM,MAAM,SAAS,GACjB,kBAAkB,GAClB,mBAAmB,GACnB,YAAY,GACZ,aAAa,GACb,gBAAgB,GAChB,iBAAiB,CAAC;AAEtB,MAAM,MAAM,eAAe,GAAG;IAC5B,QAAQ,CAAC,EAAE,WAAW,EAAE,CAAC;IACzB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,MAAM,CAAC,EAAE,SAAS,CAAC;IACnB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,MAAM,CAAC,EAAE,OAAO,CAAC;IACjB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,IAAI,CAAC,EAAE,OAAO,GAAG,KAAK,CAAC;IACvB,QAAQ,CAAC,EACL,aAAa,GACb,YAAY,GACZ,YAAY,GACZ,wBAAwB,GACxB,YAAY,GACZ,WAAW,GACX,WAAW,GACX,QAAQ,GACR,aAAa,CAAC;IAClB,CAAC,GAAG,EAAE,MAAM,GAAG,MAAM,GAAG,MAAM,GAAG,OAAO,GAAG,MAAM,EAAE,GAAG,SAAS,CAAC;CACjE,CAAC;AAEF,MAAM,MAAM,oBAAoB,GAAG;IACjC,SAAS,EAAE,MAAM,CAAC;IAClB,IAAI,EAAE,MAAM,CAAC;IACb,WAAW,EAAE,MAAM,CAAC;CACrB,CAAC;AAEF,MAAM,MAAM,mBAAmB,GAAG;IAChC,KAAK,EAAE,MAAM,CAAC;IACd,IAAI,EAAE,MAAM,GAAG,IAAI,CAAC;IACpB,OAAO,EAAE,MAAM,CAAC;IAChB,iBAAiB,EAAE,MAAM,CAAC;CAC3B,CAAC;AAEF,MAAM,MAAM,mBAAmB,GAAG;IAChC,UAAU,EAAE,MAAM,CAAC;IACnB,UAAU,EAAE,MAAM,CAAC;IACnB,QAAQ,EAAE,MAAM,CAAC;IACjB,UAAU,EAAE,MAAM,CAAC;CACpB,CAAC;AAEF,MAAM,MAAM,iBAAiB,GAAG;IAC9B,QAAQ,EAAE,MAAM,CAAC;IACjB,oBAAoB,EAAE,MAAM,GAAG,IAAI,CAAC;IACpC,GAAG,EAAE,MAAM,CAAC;IACZ,IAAI,EAAE,MAAM,GAAG,IAAI,CAAC;CACrB,CAAC;AAEF,MAAM,MAAM,2BAA2B,GAAG;IACxC,MAAM,EAAE,MAAM,CAAC;IACf,UAAU,EAAE,mBAAmB,EAAE,CAAC;IAClC,YAAY,EAAE,MAAM,CAAC;IACrB,cAAc,EAAE,MAAM,GAAG,IAAI,CAAC;IAC9B,kBAAkB,EAAE,MAAM,GAAG,IAAI,CAAC;IAClC,OAAO,EAAE,mBAAmB,EAAE,CAAC;CAChC,CAAC;AAEF,MAAM,MAAM,qBAAqB,GAAG;IAClC,aAAa,EAAE;QACb,QAAQ,EAAE,MAAM,GAAG,IAAI,CAAC;QACxB,WAAW,EAAE,MAAM,GAAG,IAAI,CAAC;QAC3B,iBAAiB,EAAE,MAAM,GAAG,IAAI,CAAC;KAClC,CAAC;CACH,CAAC;AAEF,MAAM,MAAM,iBAAiB,GAAG;IAC9B,UAAU,EAAE,MAAM,CAAC;IACnB,cAAc,EAAE,MAAM,CAAC;IACvB,IAAI,EAAE,iBAAiB,CAAC;IACxB,QAAQ,EAAE,oBAAoB,EAAE,CAAC;IACjC,cAAc,EAAE,2BAA2B,CAAC;IAC5C,QAAQ,EAAE,qBAAqB,CAAC;IAChC,OAAO,EAAE,MAAM,CAAC;CACjB,CAAC;AAEF,MAAM,MAAM,eAAe,GAAG;IAC5B,OAAO,EAAE,aAAa,CAAC;IACvB,IAAI,EAAE,MAAM,CAAC;IACb,MAAM,EAAE,MAAM,CAAC;IACf,QAAQ,EAAE,MAAM,CAAC;IACjB,+DAA+D;IAC/D,OAAO,CAAC,EAAE,YAAY,CAAC;IACvB,8EAA8E;IAC9E,YAAY,CAAC,EAAE,iBAAiB,CAAC;CAClC,CAAC;AAEF,MAAM,MAAM,QAAQ,GAAG;IACrB,WAAW,EAAE,OAAO,CAAC;IACrB,SAAS,EAAE,MAAM,GAAG,IAAI,CAAC;CAC1B,CAAC;AAEF,KAAK,kBAAkB,GAAG;IACxB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,4FAA4F;IAC5F,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,iBAAiB,CAAC,EAAE,OAAO,CAAC;IAC5B,cAAc,CAAC,EAAE,OAAO,CAAC;IACzB,wBAAwB,CAAC,EAAE,OAAO,CAAC;CACpC,CAAC;AAEF;;;;;;;;;;;;GAYG;AACH,wBAAsB,YAAY,CAChC,QAAQ,EAAE,WAAW,EAAE,EACvB,KAAK,EAAE,MAAM,EACb,EACE,KAAU,EACV,KAAK,EACL,iBAAyB,EACzB,cAAqB,EACrB,wBAAwB,GACzB,GAAE,kBAAuB,GACzB,OAAO,CAAC;IACT,KAAK,EAAE,MAAM,CAAC;IACd,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,IAAI,EAAE,eAAe,EAAE,CAAC;IACxB,QAAQ,CAAC,EAAE,QAAQ,CAAC;IACpB,KAAK,CAAC,EAAE,MAAM,CAAC;CAChB,CAAC,CAoCD;AAED;;GAEG;AACH,MAAM,MAAM,aAAa,GAAG;IAC1B,OAAO,EAAE,MAAM,CAAC;IAChB,IAAI,EAAE,MAAM,CAAC;IACb,MAAM,EAAE,MAAM,CAAC;IACf,QAAQ,EAAE,MAAM,CAAC;IACjB,KAAK,EAAE,MAAM,CAAC;IACd,mBAAmB,EAAE,MAAM,CAAC;IAC5B,SAAS,EAAE,MAAM,CAAC;IAClB,cAAc,CAAC,EAAE;QACf,EAAE,CAAC,EAAE,MAAM,CAAC;QACZ,GAAG,CAAC,EAAE,MAAM,CAAC;QACb,GAAG,CAAC,EAAE,MAAM,CAAC;QACb,EAAE,CAAC,EAAE,MAAM,CAAC;QACZ,EAAE,CAAC,EAAE,MAAM,CAAC;QACZ,GAAG,CAAC,EAAE,MAAM,CAAC;KACd,CAAC;IACF,MAAM,CAAC,EAAE,MAAM,EAAE,CAAC;IAClB,+DAA+D;IAC/D,OAAO,CAAC,EAAE,YAAY,CAAC;IACvB,8EAA8E;IAC9E,YAAY,CAAC,EAAE,iBAAiB,CAAC;CAClC,CAAC;AAEF;;;;;;;;;;;GAWG;AACH,wBAAsB,iBAAiB,CACrC,OAAO,EAAE;IAAE,QAAQ,EAAE,WAAW,EAAE,CAAA;CAAE,GAAG,yBAAyB,GAC/D,OAAO,CAAC,aAAa,EAAE,CAAC,CA8B1B;AAED;;GAEG;AACH,MAAM,MAAM,UAAU,GAAG;IACvB,OAAO,EAAE,aAAa,CAAC;IACvB,IAAI,EAAE,MAAM,CAAC;IACb,MAAM,EAAE,MAAM,CAAC;IACf,QAAQ,EAAE,MAAM,CAAC;IACjB,sDAAsD;IACtD,WAAW,CAAC,EAAE,MAAM,EAAE,CAAC;IACvB,mDAAmD;IACnD,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,wCAAwC;IACxC,MAAM,CAAC,EAAE,MAAM,EAAE,CAAC;IAClB,uDAAuD;IACvD,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,2CAA2C;IAC3C,OAAO,CAAC,EAAE,YAAY,CAAC;IACvB,0DAA0D;IAC1D,YAAY,CAAC,EAAE,iBAAiB,CAAC;CAClC,CAAC;AAEF,KAAK,uBAAuB,GAAG;IAC7B,kBAAkB,CAAC,EAAE,OAAO,CAAC;IAC7B,kBAAkB,CAAC,EAAE,OAAO,CAAC;IAC7B,aAAa,CAAC,EAAE,OAAO,CAAC;IACxB,iBAAiB,CAAC,EAAE,OAAO,CAAC;IAC5B,kBAAkB,CAAC,EAAE,OAAO,CAAC;IAC7B,wBAAwB,CAAC,EAAE,OAAO,CAAC;IACnC,cAAc,CAAC,EAAE,OAAO,CAAC;CAC1B,CAAC;AAEF;;;;;;;;;;;;;GAaG;AACH,wBAAsB,gBAAgB,CACpC,QAAQ,EAAE,aAAa,EAAE,EACzB,EACE,kBAAkB,EAClB,kBAAkB,EAClB,aAAa,EACb,iBAAiB,EACjB,kBAAkB,EAClB,wBAAwB,EACxB,cAAc,GACf,GAAE,uBAA4B,GAC9B,OAAO,CAAC,UAAU,EAAE,CAAC,CA2BvB;AAED;;;;;GAKG;AACH,wBAAsB,SAAS,CAC7B,MAAM,GAAE,eAAoB,GAC3B,OAAO,CAAC,YAAY,CAAC,CAEvB;AAED;;;;;;;;;;GAUG;AACH,wBAAsB,kBAAkB,CAAC,OAAO,EAC9C,OAAO,EAAE,GAAG,EACZ,YAAY,EAAE,MAAM,EACpB,WAAW,EAAE,WAAW,EACxB,EAAE,OAAwB,EAAE;;CAAK,GAChC,OAAO,CAAC,OAAO,GAAG,SAAS,CAAC,CAU9B"}
|
package/dist/token-service.mjs
CHANGED
|
@@ -93,6 +93,41 @@ function getTokenAssetsURL(options) {
|
|
|
93
93
|
});
|
|
94
94
|
return `${TOKEN_END_POINT_API}/assets?assetIds=${encodedAssetIds}${queryParams.toString() ? `&${queryParams.toString()}` : ''}`;
|
|
95
95
|
}
|
|
96
|
+
/**
|
|
97
|
+
* Get the RWAs URL for the given query params.
|
|
98
|
+
*
|
|
99
|
+
* @param options - Options for getting RWAs.
|
|
100
|
+
* @returns The RWAs URL.
|
|
101
|
+
*/
|
|
102
|
+
function getRwasURL(options) {
|
|
103
|
+
const { chainIds, query: searchQuery, active, custodian, type, industry, sortBy, limit = 100, after, ...additionalParams } = options;
|
|
104
|
+
const trimmedSearchQuery = searchQuery?.trim();
|
|
105
|
+
const queryParams = new URLSearchParams();
|
|
106
|
+
Object.entries({
|
|
107
|
+
...(chainIds?.length ? { chainIds } : {}),
|
|
108
|
+
...(trimmedSearchQuery && { query: trimmedSearchQuery }),
|
|
109
|
+
...(active === undefined ? {} : { active }),
|
|
110
|
+
...(custodian && { custodian }),
|
|
111
|
+
...(type && { type }),
|
|
112
|
+
...(industry && { industry }),
|
|
113
|
+
...(sortBy && { sortBy }),
|
|
114
|
+
limit,
|
|
115
|
+
...(after && { after }),
|
|
116
|
+
...additionalParams,
|
|
117
|
+
}).forEach(([key, value]) => {
|
|
118
|
+
if (value === undefined || value === '') {
|
|
119
|
+
return;
|
|
120
|
+
}
|
|
121
|
+
if (Array.isArray(value)) {
|
|
122
|
+
if (value.length > 0) {
|
|
123
|
+
queryParams.append(key, value.join(','));
|
|
124
|
+
}
|
|
125
|
+
return;
|
|
126
|
+
}
|
|
127
|
+
queryParams.append(key, String(value));
|
|
128
|
+
});
|
|
129
|
+
return `${TOKEN_END_POINT_API}/v1/rwas?${queryParams.toString()}`;
|
|
130
|
+
}
|
|
96
131
|
/**
|
|
97
132
|
* Get the trending tokens URL for the given networks and search query.
|
|
98
133
|
*
|
|
@@ -265,6 +300,15 @@ export async function fetchTokenAssets(assetIds, { includeAggregators, includeCo
|
|
|
265
300
|
return [];
|
|
266
301
|
}
|
|
267
302
|
}
|
|
303
|
+
/**
|
|
304
|
+
* Fetch real-world asset tokens.
|
|
305
|
+
*
|
|
306
|
+
* @param params - Query params used to filter, sort, and paginate RWAs.
|
|
307
|
+
* @returns The paginated RWA response.
|
|
308
|
+
*/
|
|
309
|
+
export async function fetchRwas(params = {}) {
|
|
310
|
+
return handleFetch(getRwasURL(params), { headers: { accept: '*/*' } });
|
|
311
|
+
}
|
|
268
312
|
/**
|
|
269
313
|
* Fetch metadata for the token address provided for a given network. This request is cancellable
|
|
270
314
|
* using the abort signal passed in.
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"token-service.mjs","sourceRoot":"","sources":["../src/token-service.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n ChainId,\n convertHexToDecimal,\n handleFetch,\n timeoutFetch,\n} from '@metamask/controller-utils';\nimport type { CaipAssetType, CaipChainId, Hex } from '@metamask/utils';\n\nimport { isTokenListSupportedForNetwork } from './assetsUtil';\n\nexport const TOKEN_END_POINT_API = 'https://token.api.cx.metamask.io';\nexport const TOKEN_METADATA_NO_SUPPORT_ERROR =\n 'TokenService Error: Network does not support fetchTokenMetadata';\n\n/**\n * Get the tokens URL for a specific network.\n *\n * @param chainId - The chain ID of the network the tokens requested are on.\n * @returns The tokens URL.\n */\nfunction getTokensURL(chainId: Hex): string {\n const occurrenceFloor =\n chainId === ChainId['linea-mainnet'] ||\n chainId === ChainId['megaeth-mainnet'] ||\n chainId === '0x1079' // Tempo Mainnet\n ? 1\n : 3;\n\n return `${TOKEN_END_POINT_API}/tokens/${convertHexToDecimal(\n chainId,\n )}?occurrenceFloor=${occurrenceFloor}&includeNativeAssets=false&includeTokenFees=false&includeAssetType=false&includeERC20Permit=false&includeStorage=false&includeRwaData=true`;\n}\n\n/**\n * Get the token metadata URL for the given network and token.\n *\n * @param chainId - The chain ID of the network the token is on.\n * @param tokenAddress - The token address.\n * @returns The token metadata URL.\n */\nfunction getTokenMetadataURL(chainId: Hex, tokenAddress: string): string {\n return `${TOKEN_END_POINT_API}/token/${convertHexToDecimal(\n chainId,\n )}?address=${tokenAddress}&includeRwaData=true`;\n}\n\n/**\n * The sort by field for trending tokens.\n */\nexport type SortTrendingBy =\n | 'm5_trending'\n | 'h1_trending'\n | 'h6_trending'\n | 'h24_trending';\n\n/**\n * Get the token search URL for the given networks and search query.\n *\n * @param options - Options for getting token search URL.\n * @param options.chainIds - Array of CAIP format chain IDs (e.g., 'eip155:1', 'solana:5eykt4UsFv8P8NJdTREpY1vzqKqZKvdp').\n * @param options.query - The search query (token name, symbol, or address).\n * @param options.limit - Optional limit for the number of results (defaults to 10).\n * @param options.after - Optional cursor for fetching the next page of results.\n * @param options.includeMarketData - Optional flag to include market data in the results (defaults to false).\n * @param options.includeRwaData - Optional flag to include RWA data in the results (defaults to false).\n * @param options.includeTokenSecurityData - Optional flag to include token security data in the results (defaults to false).\n * @returns The token search URL.\n */\nfunction getTokenSearchURL(options: {\n chainIds: CaipChainId[];\n query: string;\n limit?: number;\n after?: string;\n includeMarketData?: boolean;\n includeRwaData?: boolean;\n includeTokenSecurityData?: boolean;\n}): string {\n const { chainIds, query, limit, after, ...optionalParams } = options;\n const encodedQuery = encodeURIComponent(query);\n const encodedChainIds = chainIds\n .map((id) => encodeURIComponent(id))\n .join(',');\n const queryParams = new URLSearchParams();\n Object.entries(optionalParams).forEach(([key, value]) => {\n if (value !== undefined) {\n queryParams.append(key, String(value));\n }\n });\n\n let numberOfItems;\n if (limit) {\n if (limit <= 50) {\n numberOfItems = limit;\n } else if (query.includes('Ondo') && limit <= 500) {\n // There is an exception on the API side https://github.com/consensys-vertical-apps/va-mmcx-token-api/pull/287\n numberOfItems = limit;\n } else {\n numberOfItems = 50;\n }\n }\n\n return `${TOKEN_END_POINT_API}/tokens/search?networks=${encodedChainIds}&query=${encodedQuery}${numberOfItems ? `&first=${numberOfItems}` : ''}${after ? `&after=${encodeURIComponent(after)}` : ''}&${queryParams.toString()}`;\n}\n\n/**\n * Get the token assets URL for the given asset IDs.\n *\n * @param options - Options for getting token assets.\n * @param options.assetIds - Array of CAIP-19 asset IDs (e.g., ['eip155:1/erc20:0x...', 'solana:5eykt.../slip44:501']).\n * @param options.includeAggregators - Optional flag to include aggregator list in the results (defaults to false).\n * @param options.includeCoingeckoId - Optional flag to include CoinGecko ID in the results (defaults to false).\n * @param options.includeLabels - Optional flag to include labels in the results (defaults to false).\n * @param options.includeMarketData - Optional flag to include market data in the results (defaults to false).\n * @param options.includeOccurrences - Optional flag to include occurrence count in the results (defaults to false).\n * @param options.includeTokenSecurityData - Optional flag to include token security data in the results (defaults to false).\n * @param options.includeRwaData - Optional flag to include RWA data in the results (defaults to false).\n * @returns The token assets URL.\n */\nfunction getTokenAssetsURL(options: {\n assetIds: CaipAssetType[];\n includeAggregators?: boolean;\n includeCoingeckoId?: boolean;\n includeLabels?: boolean;\n includeMarketData?: boolean;\n includeOccurrences?: boolean;\n includeTokenSecurityData?: boolean;\n includeRwaData?: boolean;\n}): string {\n const { assetIds, ...queryOptions } = options;\n const encodedAssetIds = assetIds\n .map((id) => encodeURIComponent(id))\n .join(',');\n const queryParams = new URLSearchParams();\n Object.entries(queryOptions).forEach(([key, value]) => {\n if (value !== undefined) {\n queryParams.append(key, String(value));\n }\n });\n return `${TOKEN_END_POINT_API}/assets?assetIds=${encodedAssetIds}${queryParams.toString() ? `&${queryParams.toString()}` : ''}`;\n}\n\n/**\n * Shared query-parameter type for the v3 trending tokens endpoint.\n *\n * Known parameters are explicitly typed for autocomplete and documentation.\n * The index signature allows new API parameters to pass through without\n * requiring a core release — callers can add any additional key/value and\n * it will be forwarded as a query parameter.\n */\nexport type TrendingTokensQueryParams = {\n sort?: SortTrendingBy;\n minLiquidity?: number;\n minVolume24hUsd?: number;\n maxVolume24hUsd?: number;\n minMarketCap?: number;\n maxMarketCap?: number;\n excludeLabels?: string[];\n includeRwaData?: boolean;\n usePriceApiData?: boolean;\n includeTokenSecurityData?: boolean;\n [key: string]: string | number | boolean | string[] | undefined;\n};\n\n/**\n * Get the trending tokens URL for the given networks and search query.\n *\n * @param options - Options bag: `chainIds` (required) plus any query params.\n * @returns The trending tokens URL.\n */\nfunction getTrendingTokensURL(\n options: { chainIds: CaipChainId[] } & TrendingTokensQueryParams,\n): string {\n const encodedChainIds = options.chainIds\n .map((id) => encodeURIComponent(id))\n .join(',');\n const queryParams = new URLSearchParams();\n const { chainIds, excludeLabels, ...rest } = options;\n Object.entries(rest).forEach(([key, value]) => {\n if (value !== undefined) {\n queryParams.append(key, String(value));\n }\n });\n\n // Handle excludeLabels separately to avoid encoding the commas\n // The API expects: excludeLabels=stable_coin,blue_chip (not %2C)\n const excludeLabelsParam =\n excludeLabels !== undefined && excludeLabels.length > 0\n ? `&excludeLabels=${excludeLabels.join(',')}`\n : '';\n\n return `${TOKEN_END_POINT_API}/v3/tokens/trending?chainIds=${encodedChainIds}${queryParams.toString() ? `&${queryParams.toString()}` : ''}${excludeLabelsParam}`;\n}\n\nconst tenSecondsInMilliseconds = 10_000;\n\n// Token list averages 1.6 MB in size\n// timeoutFetch by default has a 500ms timeout, which will almost always timeout given the response size.\nconst defaultTimeout = tenSecondsInMilliseconds;\n\n/**\n * Fetch the list of token metadata for a given network. This request is cancellable using the\n * abort signal passed in.\n *\n * @param chainId - The chain ID of the network the requested tokens are on.\n * @param abortSignal - The abort signal used to cancel the request if necessary.\n * @param options - Additional fetch options.\n * @param options.timeout - The fetch timeout.\n * @returns The token list, or `undefined` if the request was cancelled.\n */\nexport async function fetchTokenListByChainId(\n chainId: Hex,\n abortSignal: AbortSignal,\n { timeout = defaultTimeout } = {},\n): Promise<unknown> {\n const tokenURL = getTokensURL(chainId);\n const response = await queryApi(tokenURL, abortSignal, timeout);\n if (response) {\n const result = await parseJsonResponse(response);\n if (Array.isArray(result) && chainId === ChainId['linea-mainnet']) {\n return result.filter(\n (elm) =>\n Boolean(elm.aggregators.includes('lineaTeam')) ||\n elm.aggregators.length >= 3,\n );\n }\n return result;\n }\n return undefined;\n}\n\nexport type TokenRwaData = {\n market?: {\n nextOpen?: string;\n nextClose?: string;\n };\n nextPause?: {\n start?: string;\n end?: string;\n };\n ticker?: string;\n instrumentType?: string;\n};\n\nexport type TokenSecurityFeature = {\n featureId: string;\n type: string;\n description: string;\n};\n\nexport type TokenSecurityHolder = {\n label: string;\n name: string | null;\n address: string;\n holdingPercentage: number;\n};\n\nexport type TokenSecurityMarket = {\n marketType: string;\n marketName: string;\n pairName: string;\n reserveUSD: number;\n};\n\nexport type TokenSecurityFees = {\n transfer: number;\n transferFeeMaxAmount: number | null;\n buy: number;\n sell: number | null;\n};\n\nexport type TokenSecurityFinancialStats = {\n supply: number;\n topHolders: TokenSecurityHolder[];\n holdersCount: number;\n tradeVolume24h: number | null;\n lockedLiquidityPct: number | null;\n markets: TokenSecurityMarket[];\n};\n\nexport type TokenSecurityMetadata = {\n externalLinks: {\n homepage: string | null;\n twitterPage: string | null;\n telegramChannelId: string | null;\n };\n};\n\nexport type TokenSecurityData = {\n resultType: string;\n maliciousScore: string;\n fees: TokenSecurityFees;\n features: TokenSecurityFeature[];\n financialStats: TokenSecurityFinancialStats;\n metadata: TokenSecurityMetadata;\n created: string;\n};\n\nexport type TokenSearchItem = {\n assetId: CaipAssetType;\n name: string;\n symbol: string;\n decimals: number;\n /** Optional RWA data for tokens when includeRwaData is true */\n rwaData?: TokenRwaData;\n /** Optional security data for tokens when includeTokenSecurityData is true */\n securityData?: TokenSecurityData;\n};\n\nexport type PageInfo = {\n hasNextPage: boolean;\n endCursor: string | null;\n};\n\ntype SearchTokenOptions = {\n limit?: number;\n /** Cursor returned by a previous response's `pageInfo.endCursor` to fetch the next page. */\n after?: string;\n includeMarketData?: boolean;\n includeRwaData?: boolean;\n includeTokenSecurityData?: boolean;\n};\n\n/**\n * Search for tokens across one or more networks by query string using CAIP format chain IDs.\n *\n * @param chainIds - Array of CAIP format chain IDs (e.g., ['eip155:1', 'eip155:137', 'solana:5eykt4UsFv8P8NJdTREpY1vzqKqZKvdp']).\n * @param query - The search query (token name, symbol, or address).\n * @param options - Additional fetch options.\n * @param options.limit - The maximum number of results to return.\n * @param options.after - Cursor from a previous response's `pageInfo.endCursor` to fetch the next page.\n * @param options.includeMarketData - Optional flag to include market data in the results (defaults to false).\n * @param options.includeRwaData - Optional flag to include RWA data in the results (defaults to false).\n * @param options.includeTokenSecurityData - Optional flag to include token security data in the results (defaults to false).\n * @returns Object containing count, totalCount, data array, optional pageInfo for pagination, and an optional error message if the request failed.\n */\nexport async function searchTokens(\n chainIds: CaipChainId[],\n query: string,\n {\n limit = 10,\n after,\n includeMarketData = false,\n includeRwaData = true,\n includeTokenSecurityData,\n }: SearchTokenOptions = {},\n): Promise<{\n count: number;\n totalCount?: number;\n data: TokenSearchItem[];\n pageInfo?: PageInfo;\n error?: string;\n}> {\n const tokenSearchURL = getTokenSearchURL({\n chainIds,\n query,\n limit,\n after,\n includeMarketData,\n includeRwaData,\n includeTokenSecurityData,\n });\n\n try {\n const result: {\n count: number;\n totalCount?: number;\n data: TokenSearchItem[];\n pageInfo?: PageInfo;\n } = await handleFetch(tokenSearchURL);\n\n if (result && typeof result === 'object' && Array.isArray(result.data)) {\n return {\n count: result.count ?? result.data.length,\n ...(result.totalCount !== undefined && {\n totalCount: result.totalCount,\n }),\n data: result.data,\n ...(result.pageInfo !== undefined && { pageInfo: result.pageInfo }),\n };\n }\n\n // Handle non-expected responses\n return { count: 0, data: [], error: 'Unexpected API response format' };\n } catch (error) {\n const errorMessage = error instanceof Error ? error.message : String(error);\n return { count: 0, data: [], error: errorMessage };\n }\n}\n\n/**\n * The trending asset type.\n */\nexport type TrendingAsset = {\n assetId: string;\n name: string;\n symbol: string;\n decimals: number;\n price: string;\n aggregatedUsdVolume: number;\n marketCap: number;\n priceChangePct?: {\n m5?: string;\n m15?: string;\n m30?: string;\n h1?: string;\n h6?: string;\n h24?: string;\n };\n labels?: string[];\n /** Optional RWA data for tokens when includeRwaData is true */\n rwaData?: TokenRwaData;\n /** Optional security data for tokens when includeTokenSecurityData is true */\n securityData?: TokenSecurityData;\n};\n\n/**\n * Get the trending tokens for the given chains.\n *\n * Accepts all known query parameters plus any additional ones via the\n * index signature on {@link TrendingTokensQueryParams}. New API parameters\n * can be passed without updating this function.\n *\n * @param options - Options bag: `chainIds` (required) plus any query params\n * supported by the v3 trending endpoint.\n * @returns The trending tokens.\n * @throws Will throw if the request fails.\n */\nexport async function getTrendingTokens(\n options: { chainIds: CaipChainId[] } & TrendingTokensQueryParams,\n): Promise<TrendingAsset[]> {\n const { chainIds, ...rest } = options;\n\n if (chainIds.length === 0) {\n console.error('No chains provided');\n return [];\n }\n\n const trendingTokensURL = getTrendingTokensURL({\n chainIds,\n ...rest,\n includeRwaData: rest.includeRwaData ?? true,\n usePriceApiData: rest.usePriceApiData ?? true,\n });\n\n try {\n const result = await handleFetch(trendingTokensURL);\n\n // Validate that the API returned an array\n if (Array.isArray(result)) {\n return result;\n }\n\n // Handle non-expected responses\n console.error('Trending tokens API returned non-array response:', result);\n return [];\n } catch (error) {\n console.error('Trending tokens request failed:', error);\n return [];\n }\n}\n\n/**\n * The token asset type returned by the /assets endpoint.\n */\nexport type TokenAsset = {\n assetId: CaipAssetType;\n name: string;\n symbol: string;\n decimals: number;\n /** Aggregator list when includeAggregators is true */\n aggregators?: string[];\n /** CoinGecko ID when includeCoingeckoId is true */\n coingeckoId?: string;\n /** Labels when includeLabels is true */\n labels?: string[];\n /** Occurrence count when includeOccurrences is true */\n occurrences?: number;\n /** RWA data when includeRwaData is true */\n rwaData?: TokenRwaData;\n /** Security data when includeTokenSecurityData is true */\n securityData?: TokenSecurityData;\n};\n\ntype FetchTokenAssetsOptions = {\n includeAggregators?: boolean;\n includeCoingeckoId?: boolean;\n includeLabels?: boolean;\n includeMarketData?: boolean;\n includeOccurrences?: boolean;\n includeTokenSecurityData?: boolean;\n includeRwaData?: boolean;\n};\n\n/**\n * Fetch asset metadata for the given CAIP-19 asset IDs.\n *\n * @param assetIds - Array of CAIP-19 asset IDs (e.g., ['eip155:1/erc20:0x...', 'solana:5eykt.../slip44:501']).\n * @param options - Additional fetch options.\n * @param options.includeAggregators - Optional flag to include aggregator list in the results (defaults to false).\n * @param options.includeCoingeckoId - Optional flag to include CoinGecko ID in the results (defaults to false).\n * @param options.includeLabels - Optional flag to include labels in the results (defaults to false).\n * @param options.includeMarketData - Optional flag to include market data in the results (defaults to false).\n * @param options.includeOccurrences - Optional flag to include occurrence count in the results (defaults to false).\n * @param options.includeTokenSecurityData - Optional flag to include token security data in the results (defaults to false).\n * @param options.includeRwaData - Optional flag to include RWA data in the results (defaults to false).\n * @returns Array of token assets, or empty array if the request failed or no IDs were provided.\n */\nexport async function fetchTokenAssets(\n assetIds: CaipAssetType[],\n {\n includeAggregators,\n includeCoingeckoId,\n includeLabels,\n includeMarketData,\n includeOccurrences,\n includeTokenSecurityData,\n includeRwaData,\n }: FetchTokenAssetsOptions = {},\n): Promise<TokenAsset[]> {\n if (assetIds.length === 0) {\n return [];\n }\n\n const tokenAssetsURL = getTokenAssetsURL({\n assetIds,\n includeAggregators,\n includeCoingeckoId,\n includeLabels,\n includeMarketData,\n includeOccurrences,\n includeTokenSecurityData,\n includeRwaData,\n });\n\n try {\n const result = await handleFetch(tokenAssetsURL);\n\n if (Array.isArray(result)) {\n return result;\n }\n\n return [];\n } catch {\n return [];\n }\n}\n\n/**\n * Fetch metadata for the token address provided for a given network. This request is cancellable\n * using the abort signal passed in.\n *\n * @param chainId - The chain ID of the network the token is on.\n * @param tokenAddress - The address of the token to fetch metadata for.\n * @param abortSignal - The abort signal used to cancel the request if necessary.\n * @param options - Additional fetch options.\n * @param options.timeout - The fetch timeout.\n * @returns The token metadata, or `undefined` if the request was either aborted or failed.\n */\nexport async function fetchTokenMetadata<TReturn>(\n chainId: Hex,\n tokenAddress: string,\n abortSignal: AbortSignal,\n { timeout = defaultTimeout } = {},\n): Promise<TReturn | undefined> {\n if (!isTokenListSupportedForNetwork(chainId)) {\n throw new Error(TOKEN_METADATA_NO_SUPPORT_ERROR);\n }\n const tokenMetadataURL = getTokenMetadataURL(chainId, tokenAddress);\n const response = await queryApi(tokenMetadataURL, abortSignal, timeout);\n if (response) {\n return parseJsonResponse(response) as Promise<TReturn>;\n }\n return undefined;\n}\n\n/**\n * Perform fetch request against the api.\n *\n * @param apiURL - The URL of the API to fetch.\n * @param abortSignal - The abort signal used to cancel the request if necessary.\n * @param timeout - The fetch timeout.\n * @returns Promise resolving request response.\n */\nasync function queryApi(\n apiURL: string,\n abortSignal: AbortSignal,\n timeout: number,\n): Promise<Response | undefined> {\n const fetchOptions: RequestInit = {\n referrer: apiURL,\n referrerPolicy: 'no-referrer-when-downgrade',\n method: 'GET',\n mode: 'cors',\n signal: abortSignal,\n cache: 'default',\n headers: {\n 'Content-Type': 'application/json',\n },\n };\n try {\n return await timeoutFetch(apiURL, fetchOptions, timeout);\n } catch (error) {\n if (error instanceof Error && error.name === 'AbortError') {\n console.log('Request is aborted');\n }\n }\n return undefined;\n}\n\n/**\n * Parse an API response and return the response JSON data.\n *\n * @param apiResponse - The API response to parse.\n * @returns The response JSON data.\n * @throws Will throw if the response includes an error.\n */\nasync function parseJsonResponse(apiResponse: Response): Promise<unknown> {\n const responseObj = await apiResponse.json();\n // api may return errors as json without setting an error http status code\n if (responseObj?.error) {\n throw new Error(`TokenService Error: ${responseObj.error}`);\n }\n return responseObj;\n}\n"]}
|
|
1
|
+
{"version":3,"file":"token-service.mjs","sourceRoot":"","sources":["../src/token-service.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n ChainId,\n convertHexToDecimal,\n handleFetch,\n timeoutFetch,\n} from '@metamask/controller-utils';\nimport type { CaipAssetType, CaipChainId, Hex } from '@metamask/utils';\n\nimport { isTokenListSupportedForNetwork } from './assetsUtil';\n\nexport const TOKEN_END_POINT_API = 'https://token.api.cx.metamask.io';\nexport const TOKEN_METADATA_NO_SUPPORT_ERROR =\n 'TokenService Error: Network does not support fetchTokenMetadata';\n\n/**\n * Get the tokens URL for a specific network.\n *\n * @param chainId - The chain ID of the network the tokens requested are on.\n * @returns The tokens URL.\n */\nfunction getTokensURL(chainId: Hex): string {\n const occurrenceFloor =\n chainId === ChainId['linea-mainnet'] ||\n chainId === ChainId['megaeth-mainnet'] ||\n chainId === '0x1079' // Tempo Mainnet\n ? 1\n : 3;\n\n return `${TOKEN_END_POINT_API}/tokens/${convertHexToDecimal(\n chainId,\n )}?occurrenceFloor=${occurrenceFloor}&includeNativeAssets=false&includeTokenFees=false&includeAssetType=false&includeERC20Permit=false&includeStorage=false&includeRwaData=true`;\n}\n\n/**\n * Get the token metadata URL for the given network and token.\n *\n * @param chainId - The chain ID of the network the token is on.\n * @param tokenAddress - The token address.\n * @returns The token metadata URL.\n */\nfunction getTokenMetadataURL(chainId: Hex, tokenAddress: string): string {\n return `${TOKEN_END_POINT_API}/token/${convertHexToDecimal(\n chainId,\n )}?address=${tokenAddress}&includeRwaData=true`;\n}\n\n/**\n * The sort by field for trending tokens.\n */\nexport type SortTrendingBy =\n | 'm5_trending'\n | 'h1_trending'\n | 'h6_trending'\n | 'h24_trending';\n\n/**\n * Get the token search URL for the given networks and search query.\n *\n * @param options - Options for getting token search URL.\n * @param options.chainIds - Array of CAIP format chain IDs (e.g., 'eip155:1', 'solana:5eykt4UsFv8P8NJdTREpY1vzqKqZKvdp').\n * @param options.query - The search query (token name, symbol, or address).\n * @param options.limit - Optional limit for the number of results (defaults to 10).\n * @param options.after - Optional cursor for fetching the next page of results.\n * @param options.includeMarketData - Optional flag to include market data in the results (defaults to false).\n * @param options.includeRwaData - Optional flag to include RWA data in the results (defaults to false).\n * @param options.includeTokenSecurityData - Optional flag to include token security data in the results (defaults to false).\n * @returns The token search URL.\n */\nfunction getTokenSearchURL(options: {\n chainIds: CaipChainId[];\n query: string;\n limit?: number;\n after?: string;\n includeMarketData?: boolean;\n includeRwaData?: boolean;\n includeTokenSecurityData?: boolean;\n}): string {\n const { chainIds, query, limit, after, ...optionalParams } = options;\n const encodedQuery = encodeURIComponent(query);\n const encodedChainIds = chainIds\n .map((id) => encodeURIComponent(id))\n .join(',');\n const queryParams = new URLSearchParams();\n Object.entries(optionalParams).forEach(([key, value]) => {\n if (value !== undefined) {\n queryParams.append(key, String(value));\n }\n });\n\n let numberOfItems;\n if (limit) {\n if (limit <= 50) {\n numberOfItems = limit;\n } else if (query.includes('Ondo') && limit <= 500) {\n // There is an exception on the API side https://github.com/consensys-vertical-apps/va-mmcx-token-api/pull/287\n numberOfItems = limit;\n } else {\n numberOfItems = 50;\n }\n }\n\n return `${TOKEN_END_POINT_API}/tokens/search?networks=${encodedChainIds}&query=${encodedQuery}${numberOfItems ? `&first=${numberOfItems}` : ''}${after ? `&after=${encodeURIComponent(after)}` : ''}&${queryParams.toString()}`;\n}\n\n/**\n * Get the token assets URL for the given asset IDs.\n *\n * @param options - Options for getting token assets.\n * @param options.assetIds - Array of CAIP-19 asset IDs (e.g., ['eip155:1/erc20:0x...', 'solana:5eykt.../slip44:501']).\n * @param options.includeAggregators - Optional flag to include aggregator list in the results (defaults to false).\n * @param options.includeCoingeckoId - Optional flag to include CoinGecko ID in the results (defaults to false).\n * @param options.includeLabels - Optional flag to include labels in the results (defaults to false).\n * @param options.includeMarketData - Optional flag to include market data in the results (defaults to false).\n * @param options.includeOccurrences - Optional flag to include occurrence count in the results (defaults to false).\n * @param options.includeTokenSecurityData - Optional flag to include token security data in the results (defaults to false).\n * @param options.includeRwaData - Optional flag to include RWA data in the results (defaults to false).\n * @returns The token assets URL.\n */\nfunction getTokenAssetsURL(options: {\n assetIds: CaipAssetType[];\n includeAggregators?: boolean;\n includeCoingeckoId?: boolean;\n includeLabels?: boolean;\n includeMarketData?: boolean;\n includeOccurrences?: boolean;\n includeTokenSecurityData?: boolean;\n includeRwaData?: boolean;\n}): string {\n const { assetIds, ...queryOptions } = options;\n const encodedAssetIds = assetIds\n .map((id) => encodeURIComponent(id))\n .join(',');\n const queryParams = new URLSearchParams();\n Object.entries(queryOptions).forEach(([key, value]) => {\n if (value !== undefined) {\n queryParams.append(key, String(value));\n }\n });\n return `${TOKEN_END_POINT_API}/assets?assetIds=${encodedAssetIds}${queryParams.toString() ? `&${queryParams.toString()}` : ''}`;\n}\n\n/**\n * Get the RWAs URL for the given query params.\n *\n * @param options - Options for getting RWAs.\n * @returns The RWAs URL.\n */\nfunction getRwasURL(options: FetchRwasParams): string {\n const {\n chainIds,\n query: searchQuery,\n active,\n custodian,\n type,\n industry,\n sortBy,\n limit = 100,\n after,\n ...additionalParams\n } = options;\n const trimmedSearchQuery = searchQuery?.trim();\n const queryParams = new URLSearchParams();\n\n Object.entries({\n ...(chainIds?.length ? { chainIds } : {}),\n ...(trimmedSearchQuery && { query: trimmedSearchQuery }),\n ...(active === undefined ? {} : { active }),\n ...(custodian && { custodian }),\n ...(type && { type }),\n ...(industry && { industry }),\n ...(sortBy && { sortBy }),\n limit,\n ...(after && { after }),\n ...additionalParams,\n }).forEach(([key, value]) => {\n if (value === undefined || value === '') {\n return;\n }\n\n if (Array.isArray(value)) {\n if (value.length > 0) {\n queryParams.append(key, value.join(','));\n }\n return;\n }\n\n queryParams.append(key, String(value));\n });\n\n return `${TOKEN_END_POINT_API}/v1/rwas?${queryParams.toString()}`;\n}\n\n/**\n * Shared query-parameter type for the v3 trending tokens endpoint.\n *\n * Known parameters are explicitly typed for autocomplete and documentation.\n * The index signature allows new API parameters to pass through without\n * requiring a core release — callers can add any additional key/value and\n * it will be forwarded as a query parameter.\n */\nexport type TrendingTokensQueryParams = {\n sort?: SortTrendingBy;\n minLiquidity?: number;\n minVolume24hUsd?: number;\n maxVolume24hUsd?: number;\n minMarketCap?: number;\n maxMarketCap?: number;\n excludeLabels?: string[];\n includeRwaData?: boolean;\n usePriceApiData?: boolean;\n includeTokenSecurityData?: boolean;\n [key: string]: string | number | boolean | string[] | undefined;\n};\n\n/**\n * Get the trending tokens URL for the given networks and search query.\n *\n * @param options - Options bag: `chainIds` (required) plus any query params.\n * @returns The trending tokens URL.\n */\nfunction getTrendingTokensURL(\n options: { chainIds: CaipChainId[] } & TrendingTokensQueryParams,\n): string {\n const encodedChainIds = options.chainIds\n .map((id) => encodeURIComponent(id))\n .join(',');\n const queryParams = new URLSearchParams();\n const { chainIds, excludeLabels, ...rest } = options;\n Object.entries(rest).forEach(([key, value]) => {\n if (value !== undefined) {\n queryParams.append(key, String(value));\n }\n });\n\n // Handle excludeLabels separately to avoid encoding the commas\n // The API expects: excludeLabels=stable_coin,blue_chip (not %2C)\n const excludeLabelsParam =\n excludeLabels !== undefined && excludeLabels.length > 0\n ? `&excludeLabels=${excludeLabels.join(',')}`\n : '';\n\n return `${TOKEN_END_POINT_API}/v3/tokens/trending?chainIds=${encodedChainIds}${queryParams.toString() ? `&${queryParams.toString()}` : ''}${excludeLabelsParam}`;\n}\n\nconst tenSecondsInMilliseconds = 10_000;\n\n// Token list averages 1.6 MB in size\n// timeoutFetch by default has a 500ms timeout, which will almost always timeout given the response size.\nconst defaultTimeout = tenSecondsInMilliseconds;\n\n/**\n * Fetch the list of token metadata for a given network. This request is cancellable using the\n * abort signal passed in.\n *\n * @param chainId - The chain ID of the network the requested tokens are on.\n * @param abortSignal - The abort signal used to cancel the request if necessary.\n * @param options - Additional fetch options.\n * @param options.timeout - The fetch timeout.\n * @returns The token list, or `undefined` if the request was cancelled.\n */\nexport async function fetchTokenListByChainId(\n chainId: Hex,\n abortSignal: AbortSignal,\n { timeout = defaultTimeout } = {},\n): Promise<unknown> {\n const tokenURL = getTokensURL(chainId);\n const response = await queryApi(tokenURL, abortSignal, timeout);\n if (response) {\n const result = await parseJsonResponse(response);\n if (Array.isArray(result) && chainId === ChainId['linea-mainnet']) {\n return result.filter(\n (elm) =>\n Boolean(elm.aggregators.includes('lineaTeam')) ||\n elm.aggregators.length >= 3,\n );\n }\n return result;\n }\n return undefined;\n}\n\nexport type TokenRwaData = {\n market?: {\n nextOpen?: string;\n nextClose?: string;\n };\n nextPause?: {\n start?: string;\n end?: string;\n };\n ticker?: string;\n instrumentType?: string;\n};\n\nexport type RwaMarket = {\n nextOpen?: string;\n nextClose?: string;\n};\n\nexport type RwaTokenData = {\n price: string;\n priceChange: string;\n marketCap: number;\n aggregatedUsdVolume: number;\n active: boolean;\n ticker: string;\n instrumentType: string;\n custodians: string[];\n industry: string[];\n market?: RwaMarket;\n nextPause?: Record<string, unknown>;\n sharesOutstanding?: number;\n restrictedCountries?: string[];\n updatedAt?: string;\n addressType?: string;\n};\n\nexport type RwaToken = {\n id: string;\n assetId: CaipAssetType;\n symbol: string;\n decimals: number;\n name: string;\n rwaData: RwaTokenData;\n};\n\nexport type RwasResponse = {\n data: RwaToken[];\n count: number;\n totalCount: number;\n pageInfo: {\n nextCursor: string | null;\n hasNextPage: boolean;\n };\n};\n\nexport type RwaSortBy =\n | 'price_change_asc'\n | 'price_change_desc'\n | 'volume_asc'\n | 'volume_desc'\n | 'market_cap_asc'\n | 'market_cap_desc';\n\nexport type FetchRwasParams = {\n chainIds?: CaipChainId[];\n query?: string;\n sortBy?: RwaSortBy;\n limit?: number;\n after?: string;\n active?: boolean;\n custodian?: 'ondo';\n type?: 'stock' | 'etf';\n industry?:\n | 'industrials'\n | 'technology'\n | 'healthcare'\n | 'consumer discretionary'\n | 'financials'\n | 'materials'\n | 'utilities'\n | 'energy'\n | 'real estate';\n [key: string]: string | number | boolean | string[] | undefined;\n};\n\nexport type TokenSecurityFeature = {\n featureId: string;\n type: string;\n description: string;\n};\n\nexport type TokenSecurityHolder = {\n label: string;\n name: string | null;\n address: string;\n holdingPercentage: number;\n};\n\nexport type TokenSecurityMarket = {\n marketType: string;\n marketName: string;\n pairName: string;\n reserveUSD: number;\n};\n\nexport type TokenSecurityFees = {\n transfer: number;\n transferFeeMaxAmount: number | null;\n buy: number;\n sell: number | null;\n};\n\nexport type TokenSecurityFinancialStats = {\n supply: number;\n topHolders: TokenSecurityHolder[];\n holdersCount: number;\n tradeVolume24h: number | null;\n lockedLiquidityPct: number | null;\n markets: TokenSecurityMarket[];\n};\n\nexport type TokenSecurityMetadata = {\n externalLinks: {\n homepage: string | null;\n twitterPage: string | null;\n telegramChannelId: string | null;\n };\n};\n\nexport type TokenSecurityData = {\n resultType: string;\n maliciousScore: string;\n fees: TokenSecurityFees;\n features: TokenSecurityFeature[];\n financialStats: TokenSecurityFinancialStats;\n metadata: TokenSecurityMetadata;\n created: string;\n};\n\nexport type TokenSearchItem = {\n assetId: CaipAssetType;\n name: string;\n symbol: string;\n decimals: number;\n /** Optional RWA data for tokens when includeRwaData is true */\n rwaData?: TokenRwaData;\n /** Optional security data for tokens when includeTokenSecurityData is true */\n securityData?: TokenSecurityData;\n};\n\nexport type PageInfo = {\n hasNextPage: boolean;\n endCursor: string | null;\n};\n\ntype SearchTokenOptions = {\n limit?: number;\n /** Cursor returned by a previous response's `pageInfo.endCursor` to fetch the next page. */\n after?: string;\n includeMarketData?: boolean;\n includeRwaData?: boolean;\n includeTokenSecurityData?: boolean;\n};\n\n/**\n * Search for tokens across one or more networks by query string using CAIP format chain IDs.\n *\n * @param chainIds - Array of CAIP format chain IDs (e.g., ['eip155:1', 'eip155:137', 'solana:5eykt4UsFv8P8NJdTREpY1vzqKqZKvdp']).\n * @param query - The search query (token name, symbol, or address).\n * @param options - Additional fetch options.\n * @param options.limit - The maximum number of results to return.\n * @param options.after - Cursor from a previous response's `pageInfo.endCursor` to fetch the next page.\n * @param options.includeMarketData - Optional flag to include market data in the results (defaults to false).\n * @param options.includeRwaData - Optional flag to include RWA data in the results (defaults to false).\n * @param options.includeTokenSecurityData - Optional flag to include token security data in the results (defaults to false).\n * @returns Object containing count, totalCount, data array, optional pageInfo for pagination, and an optional error message if the request failed.\n */\nexport async function searchTokens(\n chainIds: CaipChainId[],\n query: string,\n {\n limit = 10,\n after,\n includeMarketData = false,\n includeRwaData = true,\n includeTokenSecurityData,\n }: SearchTokenOptions = {},\n): Promise<{\n count: number;\n totalCount?: number;\n data: TokenSearchItem[];\n pageInfo?: PageInfo;\n error?: string;\n}> {\n const tokenSearchURL = getTokenSearchURL({\n chainIds,\n query,\n limit,\n after,\n includeMarketData,\n includeRwaData,\n includeTokenSecurityData,\n });\n\n try {\n const result: {\n count: number;\n totalCount?: number;\n data: TokenSearchItem[];\n pageInfo?: PageInfo;\n } = await handleFetch(tokenSearchURL);\n\n if (result && typeof result === 'object' && Array.isArray(result.data)) {\n return {\n count: result.count ?? result.data.length,\n ...(result.totalCount !== undefined && {\n totalCount: result.totalCount,\n }),\n data: result.data,\n ...(result.pageInfo !== undefined && { pageInfo: result.pageInfo }),\n };\n }\n\n // Handle non-expected responses\n return { count: 0, data: [], error: 'Unexpected API response format' };\n } catch (error) {\n const errorMessage = error instanceof Error ? error.message : String(error);\n return { count: 0, data: [], error: errorMessage };\n }\n}\n\n/**\n * The trending asset type.\n */\nexport type TrendingAsset = {\n assetId: string;\n name: string;\n symbol: string;\n decimals: number;\n price: string;\n aggregatedUsdVolume: number;\n marketCap: number;\n priceChangePct?: {\n m5?: string;\n m15?: string;\n m30?: string;\n h1?: string;\n h6?: string;\n h24?: string;\n };\n labels?: string[];\n /** Optional RWA data for tokens when includeRwaData is true */\n rwaData?: TokenRwaData;\n /** Optional security data for tokens when includeTokenSecurityData is true */\n securityData?: TokenSecurityData;\n};\n\n/**\n * Get the trending tokens for the given chains.\n *\n * Accepts all known query parameters plus any additional ones via the\n * index signature on {@link TrendingTokensQueryParams}. New API parameters\n * can be passed without updating this function.\n *\n * @param options - Options bag: `chainIds` (required) plus any query params\n * supported by the v3 trending endpoint.\n * @returns The trending tokens.\n * @throws Will throw if the request fails.\n */\nexport async function getTrendingTokens(\n options: { chainIds: CaipChainId[] } & TrendingTokensQueryParams,\n): Promise<TrendingAsset[]> {\n const { chainIds, ...rest } = options;\n\n if (chainIds.length === 0) {\n console.error('No chains provided');\n return [];\n }\n\n const trendingTokensURL = getTrendingTokensURL({\n chainIds,\n ...rest,\n includeRwaData: rest.includeRwaData ?? true,\n usePriceApiData: rest.usePriceApiData ?? true,\n });\n\n try {\n const result = await handleFetch(trendingTokensURL);\n\n // Validate that the API returned an array\n if (Array.isArray(result)) {\n return result;\n }\n\n // Handle non-expected responses\n console.error('Trending tokens API returned non-array response:', result);\n return [];\n } catch (error) {\n console.error('Trending tokens request failed:', error);\n return [];\n }\n}\n\n/**\n * The token asset type returned by the /assets endpoint.\n */\nexport type TokenAsset = {\n assetId: CaipAssetType;\n name: string;\n symbol: string;\n decimals: number;\n /** Aggregator list when includeAggregators is true */\n aggregators?: string[];\n /** CoinGecko ID when includeCoingeckoId is true */\n coingeckoId?: string;\n /** Labels when includeLabels is true */\n labels?: string[];\n /** Occurrence count when includeOccurrences is true */\n occurrences?: number;\n /** RWA data when includeRwaData is true */\n rwaData?: TokenRwaData;\n /** Security data when includeTokenSecurityData is true */\n securityData?: TokenSecurityData;\n};\n\ntype FetchTokenAssetsOptions = {\n includeAggregators?: boolean;\n includeCoingeckoId?: boolean;\n includeLabels?: boolean;\n includeMarketData?: boolean;\n includeOccurrences?: boolean;\n includeTokenSecurityData?: boolean;\n includeRwaData?: boolean;\n};\n\n/**\n * Fetch asset metadata for the given CAIP-19 asset IDs.\n *\n * @param assetIds - Array of CAIP-19 asset IDs (e.g., ['eip155:1/erc20:0x...', 'solana:5eykt.../slip44:501']).\n * @param options - Additional fetch options.\n * @param options.includeAggregators - Optional flag to include aggregator list in the results (defaults to false).\n * @param options.includeCoingeckoId - Optional flag to include CoinGecko ID in the results (defaults to false).\n * @param options.includeLabels - Optional flag to include labels in the results (defaults to false).\n * @param options.includeMarketData - Optional flag to include market data in the results (defaults to false).\n * @param options.includeOccurrences - Optional flag to include occurrence count in the results (defaults to false).\n * @param options.includeTokenSecurityData - Optional flag to include token security data in the results (defaults to false).\n * @param options.includeRwaData - Optional flag to include RWA data in the results (defaults to false).\n * @returns Array of token assets, or empty array if the request failed or no IDs were provided.\n */\nexport async function fetchTokenAssets(\n assetIds: CaipAssetType[],\n {\n includeAggregators,\n includeCoingeckoId,\n includeLabels,\n includeMarketData,\n includeOccurrences,\n includeTokenSecurityData,\n includeRwaData,\n }: FetchTokenAssetsOptions = {},\n): Promise<TokenAsset[]> {\n if (assetIds.length === 0) {\n return [];\n }\n\n const tokenAssetsURL = getTokenAssetsURL({\n assetIds,\n includeAggregators,\n includeCoingeckoId,\n includeLabels,\n includeMarketData,\n includeOccurrences,\n includeTokenSecurityData,\n includeRwaData,\n });\n\n try {\n const result = await handleFetch(tokenAssetsURL);\n\n if (Array.isArray(result)) {\n return result;\n }\n\n return [];\n } catch {\n return [];\n }\n}\n\n/**\n * Fetch real-world asset tokens.\n *\n * @param params - Query params used to filter, sort, and paginate RWAs.\n * @returns The paginated RWA response.\n */\nexport async function fetchRwas(\n params: FetchRwasParams = {},\n): Promise<RwasResponse> {\n return handleFetch(getRwasURL(params), { headers: { accept: '*/*' } });\n}\n\n/**\n * Fetch metadata for the token address provided for a given network. This request is cancellable\n * using the abort signal passed in.\n *\n * @param chainId - The chain ID of the network the token is on.\n * @param tokenAddress - The address of the token to fetch metadata for.\n * @param abortSignal - The abort signal used to cancel the request if necessary.\n * @param options - Additional fetch options.\n * @param options.timeout - The fetch timeout.\n * @returns The token metadata, or `undefined` if the request was either aborted or failed.\n */\nexport async function fetchTokenMetadata<TReturn>(\n chainId: Hex,\n tokenAddress: string,\n abortSignal: AbortSignal,\n { timeout = defaultTimeout } = {},\n): Promise<TReturn | undefined> {\n if (!isTokenListSupportedForNetwork(chainId)) {\n throw new Error(TOKEN_METADATA_NO_SUPPORT_ERROR);\n }\n const tokenMetadataURL = getTokenMetadataURL(chainId, tokenAddress);\n const response = await queryApi(tokenMetadataURL, abortSignal, timeout);\n if (response) {\n return parseJsonResponse(response) as Promise<TReturn>;\n }\n return undefined;\n}\n\n/**\n * Perform fetch request against the api.\n *\n * @param apiURL - The URL of the API to fetch.\n * @param abortSignal - The abort signal used to cancel the request if necessary.\n * @param timeout - The fetch timeout.\n * @returns Promise resolving request response.\n */\nasync function queryApi(\n apiURL: string,\n abortSignal: AbortSignal,\n timeout: number,\n): Promise<Response | undefined> {\n const fetchOptions: RequestInit = {\n referrer: apiURL,\n referrerPolicy: 'no-referrer-when-downgrade',\n method: 'GET',\n mode: 'cors',\n signal: abortSignal,\n cache: 'default',\n headers: {\n 'Content-Type': 'application/json',\n },\n };\n try {\n return await timeoutFetch(apiURL, fetchOptions, timeout);\n } catch (error) {\n if (error instanceof Error && error.name === 'AbortError') {\n console.log('Request is aborted');\n }\n }\n return undefined;\n}\n\n/**\n * Parse an API response and return the response JSON data.\n *\n * @param apiResponse - The API response to parse.\n * @returns The response JSON data.\n * @throws Will throw if the response includes an error.\n */\nasync function parseJsonResponse(apiResponse: Response): Promise<unknown> {\n const responseObj = await apiResponse.json();\n // api may return errors as json without setting an error http status code\n if (responseObj?.error) {\n throw new Error(`TokenService Error: ${responseObj.error}`);\n }\n return responseObj;\n}\n"]}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@metamask/assets-controllers",
|
|
3
|
-
"version": "108.
|
|
3
|
+
"version": "108.4.0",
|
|
4
4
|
"description": "Controllers which manage interactions involving ERC-20, ERC-721, and ERC-1155 tokens (including NFTs)",
|
|
5
5
|
"keywords": [
|
|
6
6
|
"Ethereum",
|
|
@@ -60,26 +60,26 @@
|
|
|
60
60
|
"@ethersproject/contracts": "^5.7.0",
|
|
61
61
|
"@ethersproject/providers": "^5.7.0",
|
|
62
62
|
"@metamask/abi-utils": "^2.0.3",
|
|
63
|
-
"@metamask/account-tree-controller": "^7.
|
|
64
|
-
"@metamask/accounts-controller": "^38.1.
|
|
63
|
+
"@metamask/account-tree-controller": "^7.5.0",
|
|
64
|
+
"@metamask/accounts-controller": "^38.1.2",
|
|
65
65
|
"@metamask/approval-controller": "^9.0.1",
|
|
66
66
|
"@metamask/base-controller": "^9.1.0",
|
|
67
67
|
"@metamask/contract-metadata": "^2.4.0",
|
|
68
68
|
"@metamask/controller-utils": "^12.1.0",
|
|
69
|
-
"@metamask/core-backend": "^6.3.
|
|
69
|
+
"@metamask/core-backend": "^6.3.1",
|
|
70
70
|
"@metamask/eth-query": "^4.0.0",
|
|
71
71
|
"@metamask/keyring-api": "^23.1.0",
|
|
72
|
-
"@metamask/keyring-controller": "^
|
|
72
|
+
"@metamask/keyring-controller": "^26.0.0",
|
|
73
73
|
"@metamask/messenger": "^1.2.0",
|
|
74
74
|
"@metamask/metamask-eth-abis": "^3.1.1",
|
|
75
|
-
"@metamask/multichain-account-service": "^10.0.
|
|
75
|
+
"@metamask/multichain-account-service": "^10.0.1",
|
|
76
76
|
"@metamask/network-controller": "^32.0.0",
|
|
77
77
|
"@metamask/network-enablement-controller": "^5.2.0",
|
|
78
78
|
"@metamask/permission-controller": "^13.1.1",
|
|
79
79
|
"@metamask/phishing-controller": "^17.2.0",
|
|
80
80
|
"@metamask/polling-controller": "^16.0.6",
|
|
81
81
|
"@metamask/preferences-controller": "^23.1.0",
|
|
82
|
-
"@metamask/profile-sync-controller": "^28.1.
|
|
82
|
+
"@metamask/profile-sync-controller": "^28.1.1",
|
|
83
83
|
"@metamask/rpc-errors": "^7.0.2",
|
|
84
84
|
"@metamask/snaps-controllers": "^19.0.0",
|
|
85
85
|
"@metamask/snaps-sdk": "^11.0.0",
|