@chain-registry/utils 0.6.3 → 0.7.2
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 -0
- package/README.md +3 -0
- package/main/registry.js +5 -5
- package/main/utils.js +39 -39
- package/module/registry.js +5 -5
- package/module/utils.js +39 -39
- package/package.json +4 -4
- package/types/index.d.ts +2 -56
- package/types/registry.d.ts +45 -0
- package/types/utils.d.ts +56 -0
package/CHANGELOG.md
CHANGED
|
@@ -3,6 +3,30 @@
|
|
|
3
3
|
All notable changes to this project will be documented in this file.
|
|
4
4
|
See [Conventional Commits](https://conventionalcommits.org) for commit guidelines.
|
|
5
5
|
|
|
6
|
+
## [0.7.2](https://github.com/cosmology-tech/chain-registry/compare/@chain-registry/utils@0.7.1...@chain-registry/utils@0.7.2) (2022-09-08)
|
|
7
|
+
|
|
8
|
+
**Note:** Version bump only for package @chain-registry/utils
|
|
9
|
+
|
|
10
|
+
|
|
11
|
+
|
|
12
|
+
|
|
13
|
+
|
|
14
|
+
## [0.7.1](https://github.com/cosmology-tech/chain-registry/compare/@chain-registry/utils@0.7.0...@chain-registry/utils@0.7.1) (2022-09-07)
|
|
15
|
+
|
|
16
|
+
**Note:** Version bump only for package @chain-registry/utils
|
|
17
|
+
|
|
18
|
+
|
|
19
|
+
|
|
20
|
+
|
|
21
|
+
|
|
22
|
+
# [0.7.0](https://github.com/cosmology-tech/chain-registry/compare/@chain-registry/utils@0.6.3...@chain-registry/utils@0.7.0) (2022-09-06)
|
|
23
|
+
|
|
24
|
+
**Note:** Version bump only for package @chain-registry/utils
|
|
25
|
+
|
|
26
|
+
|
|
27
|
+
|
|
28
|
+
|
|
29
|
+
|
|
6
30
|
## [0.6.3](https://github.com/cosmology-tech/chain-registry/compare/@chain-registry/utils@0.6.2...@chain-registry/utils@0.6.3) (2022-08-31)
|
|
7
31
|
|
|
8
32
|
**Note:** Version bump only for package @chain-registry/utils
|
package/README.md
CHANGED
package/main/registry.js
CHANGED
|
@@ -55,8 +55,8 @@ var ChainInfo = /*#__PURE__*/function () {
|
|
|
55
55
|
this._chain = this.registry.getChain(this.chain_name);
|
|
56
56
|
|
|
57
57
|
var supportedChains = this._ibc_data.reduce(function (m, v) {
|
|
58
|
-
if (!m.includes(v
|
|
59
|
-
if (!m.includes(v
|
|
58
|
+
if (!m.includes(v.chain_1.chain_name)) m.push(v.chain_1.chain_name);
|
|
59
|
+
if (!m.includes(v.chain_2.chain_name)) m.push(v.chain_2.chain_name);
|
|
60
60
|
return m;
|
|
61
61
|
}, []);
|
|
62
62
|
|
|
@@ -150,7 +150,7 @@ var ChainRegistry = /*#__PURE__*/function () {
|
|
|
150
150
|
key: "getChainIbcData",
|
|
151
151
|
value: function getChainIbcData(chainName) {
|
|
152
152
|
return this._ibc_data.filter(function (info) {
|
|
153
|
-
return info
|
|
153
|
+
return info.chain_1.chain_name === chainName || info.chain_2.chain_name === chainName;
|
|
154
154
|
});
|
|
155
155
|
}
|
|
156
156
|
}, {
|
|
@@ -207,7 +207,7 @@ var ChainRegistry = /*#__PURE__*/function () {
|
|
|
207
207
|
key: "upsertIbcData",
|
|
208
208
|
value: function upsertIbcData(data) {
|
|
209
209
|
var found = this._ibc_data.find(function (info) {
|
|
210
|
-
return info
|
|
210
|
+
return info.chain_1.chain_name === data.chain_1.chain_name && info.chain_2.chain_name === data.chain_2.chain_name;
|
|
211
211
|
});
|
|
212
212
|
|
|
213
213
|
if (!found) {
|
|
@@ -217,7 +217,7 @@ var ChainRegistry = /*#__PURE__*/function () {
|
|
|
217
217
|
}
|
|
218
218
|
|
|
219
219
|
this._ibc_data = this._ibc_data.map(function (info) {
|
|
220
|
-
if (info
|
|
220
|
+
if (info.chain_1.chain_name === data.chain_1.chain_name && info.chain_2.chain_name === data.chain_2.chain_name) {
|
|
221
221
|
return data;
|
|
222
222
|
} else {
|
|
223
223
|
return info;
|
package/main/utils.js
CHANGED
|
@@ -49,7 +49,7 @@ exports.ibcDenom = ibcDenom;
|
|
|
49
49
|
|
|
50
50
|
var findInfo = function findInfo(ibc, to, from) {
|
|
51
51
|
return ibc.find(function (i) {
|
|
52
|
-
return i
|
|
52
|
+
return i.chain_1.chain_name === from && i.chain_2.chain_name === to;
|
|
53
53
|
});
|
|
54
54
|
};
|
|
55
55
|
|
|
@@ -61,7 +61,7 @@ exports.getIbcInfo = getIbcInfo;
|
|
|
61
61
|
|
|
62
62
|
var getTransferChannel = function getTransferChannel(info) {
|
|
63
63
|
return info.channels.find(function (channel) {
|
|
64
|
-
return channel
|
|
64
|
+
return channel.chain_1.port_id === 'transfer' && channel.chain_2.port_id === 'transfer';
|
|
65
65
|
});
|
|
66
66
|
};
|
|
67
67
|
|
|
@@ -69,7 +69,7 @@ exports.getTransferChannel = getTransferChannel;
|
|
|
69
69
|
|
|
70
70
|
var getNonTransferChannel = function getNonTransferChannel(info) {
|
|
71
71
|
return info.channels.find(function (channel) {
|
|
72
|
-
return channel
|
|
72
|
+
return channel.chain_1.port_id !== 'transfer' && channel.chain_2.port_id === 'transfer' || channel.chain_1.port_id === 'transfer' && channel.chain_2.port_id !== 'transfer';
|
|
73
73
|
});
|
|
74
74
|
};
|
|
75
75
|
|
|
@@ -77,7 +77,7 @@ exports.getNonTransferChannel = getNonTransferChannel;
|
|
|
77
77
|
|
|
78
78
|
var getWasmChannel = function getWasmChannel(info) {
|
|
79
79
|
return info.channels.find(function (channel) {
|
|
80
|
-
return channel
|
|
80
|
+
return channel.chain_1.port_id.startsWith('wasm.') && channel.chain_2.port_id === 'transfer' || channel.chain_1.port_id === 'transfer' && channel.chain_2.port_id.startsWith('wasm');
|
|
81
81
|
});
|
|
82
82
|
};
|
|
83
83
|
|
|
@@ -95,10 +95,10 @@ var getIbcDenomByBase = function getIbcDenomByBase(ibc, chain, counterparty, ass
|
|
|
95
95
|
|
|
96
96
|
var channelInfo;
|
|
97
97
|
|
|
98
|
-
if (ibcInfo
|
|
99
|
-
channelInfo = channel
|
|
98
|
+
if (ibcInfo.chain_1.chain_name === chain) {
|
|
99
|
+
channelInfo = channel.chain_1;
|
|
100
100
|
} else {
|
|
101
|
-
channelInfo = channel
|
|
101
|
+
channelInfo = channel.chain_2;
|
|
102
102
|
}
|
|
103
103
|
|
|
104
104
|
var assetList = assets.find(function (_ref) {
|
|
@@ -143,8 +143,8 @@ var getIbcDenomByBase = function getIbcDenomByBase(ibc, chain, counterparty, ass
|
|
|
143
143
|
// channelId: assetInfo.ibc.source_channel
|
|
144
144
|
// },
|
|
145
145
|
// {
|
|
146
|
-
// portId: channelInfo
|
|
147
|
-
// channelId: channelInfo
|
|
146
|
+
// portId: channelInfo.port_id,
|
|
147
|
+
// channelId: channelInfo.channel_id
|
|
148
148
|
// }
|
|
149
149
|
// ],
|
|
150
150
|
// base
|
|
@@ -153,8 +153,8 @@ var getIbcDenomByBase = function getIbcDenomByBase(ibc, chain, counterparty, ass
|
|
|
153
153
|
|
|
154
154
|
|
|
155
155
|
return ibcDenom([{
|
|
156
|
-
portId: channelInfo
|
|
157
|
-
channelId: channelInfo
|
|
156
|
+
portId: channelInfo.port_id,
|
|
157
|
+
channelId: channelInfo.channel_id
|
|
158
158
|
}], base);
|
|
159
159
|
}
|
|
160
160
|
};
|
|
@@ -173,10 +173,10 @@ var getIbcDenomByBaseForCw20 = function getIbcDenomByBaseForCw20(ibc, chain, cou
|
|
|
173
173
|
|
|
174
174
|
var channelInfo;
|
|
175
175
|
|
|
176
|
-
if (ibcInfo
|
|
177
|
-
channelInfo = channel
|
|
176
|
+
if (ibcInfo.chain_1.chain_name === chain) {
|
|
177
|
+
channelInfo = channel.chain_1;
|
|
178
178
|
} else {
|
|
179
|
-
channelInfo = channel
|
|
179
|
+
channelInfo = channel.chain_2;
|
|
180
180
|
}
|
|
181
181
|
|
|
182
182
|
var assetInfo = assets.find(function (_ref2) {
|
|
@@ -189,8 +189,8 @@ var getIbcDenomByBaseForCw20 = function getIbcDenomByBaseForCw20(ibc, chain, cou
|
|
|
189
189
|
}
|
|
190
190
|
|
|
191
191
|
return ibcDenom([{
|
|
192
|
-
portId: channelInfo
|
|
193
|
-
channelId: channelInfo
|
|
192
|
+
portId: channelInfo.port_id,
|
|
193
|
+
channelId: channelInfo.channel_id
|
|
194
194
|
}], base);
|
|
195
195
|
}
|
|
196
196
|
};
|
|
@@ -199,12 +199,12 @@ exports.getIbcDenomByBaseForCw20 = getIbcDenomByBaseForCw20;
|
|
|
199
199
|
|
|
200
200
|
var getIbcAssets = function getIbcAssets(chainName, ibc, assets) {
|
|
201
201
|
var chainIbcInfo = ibc.filter(function (i) {
|
|
202
|
-
return i
|
|
202
|
+
return i.chain_1.chain_name === chainName || i.chain_2.chain_name === chainName;
|
|
203
203
|
});
|
|
204
204
|
var ibcAssetLists = chainIbcInfo.map(function (ibcInfo) {
|
|
205
|
-
var counterpartyIs = ibcInfo
|
|
206
|
-
var chainIs = ibcInfo
|
|
207
|
-
var counterparty = ibcInfo[counterpartyIs]
|
|
205
|
+
var counterpartyIs = ibcInfo.chain_1.chain_name === chainName ? 'chain_2' : 'chain_1';
|
|
206
|
+
var chainIs = ibcInfo.chain_1.chain_name === chainName ? 'chain_1' : 'chain_2';
|
|
207
|
+
var counterparty = ibcInfo[counterpartyIs].chain_name;
|
|
208
208
|
var counterpartyIbc = ibcInfo[counterpartyIs];
|
|
209
209
|
var chainIbc = ibcInfo[chainIs];
|
|
210
210
|
var counterpartyAssets = assets.find(function (a) {
|
|
@@ -246,23 +246,23 @@ var getIbcAssets = function getIbcAssets(chainName, ibc, assets) {
|
|
|
246
246
|
};
|
|
247
247
|
}).filter(Boolean);
|
|
248
248
|
var hash = ibcAssetLists.reduce(function (m, v) {
|
|
249
|
-
m[v.chain
|
|
249
|
+
m[v.chain.chain_name] = m[v.chain.chain_name] || [];
|
|
250
250
|
var assets = v.assets.map(function (asset) {
|
|
251
251
|
return _objectSpread(_objectSpread({}, asset), {}, {
|
|
252
252
|
traces: [{
|
|
253
253
|
type: 'ibc',
|
|
254
254
|
counterparty: {
|
|
255
255
|
// source_channel
|
|
256
|
-
channel: v.counterparty
|
|
256
|
+
channel: v.counterparty.channel_id,
|
|
257
257
|
// source_denom
|
|
258
258
|
denom: asset.denom_units[0].aliases[0],
|
|
259
|
-
chain_name: v.counterparty
|
|
259
|
+
chain_name: v.counterparty.chain_name // port: v.counterparty.port_id
|
|
260
260
|
|
|
261
261
|
},
|
|
262
262
|
chain: {
|
|
263
263
|
// dst_denom
|
|
264
|
-
channel: v.chain
|
|
265
|
-
// port: v.chain
|
|
264
|
+
channel: v.chain.channel_id // chain_name: v.chain.chain_name,
|
|
265
|
+
// port: v.chain.port_id
|
|
266
266
|
|
|
267
267
|
}
|
|
268
268
|
}]
|
|
@@ -273,7 +273,7 @@ var getIbcAssets = function getIbcAssets(chainName, ibc, assets) {
|
|
|
273
273
|
assets: assets
|
|
274
274
|
});
|
|
275
275
|
|
|
276
|
-
m[v.chain
|
|
276
|
+
m[v.chain.chain_name].push(obj);
|
|
277
277
|
return m;
|
|
278
278
|
}, {});
|
|
279
279
|
return Object.keys(hash).map(function (chain) {
|
|
@@ -290,12 +290,12 @@ exports.getIbcAssets = getIbcAssets;
|
|
|
290
290
|
|
|
291
291
|
var getCw20Assets = function getCw20Assets(chainName, ibc, assets) {
|
|
292
292
|
var chainIbcInfo = ibc.filter(function (i) {
|
|
293
|
-
return i
|
|
293
|
+
return i.chain_1.chain_name === chainName || i.chain_2.chain_name === chainName;
|
|
294
294
|
});
|
|
295
295
|
var cw20AssetLists = chainIbcInfo.map(function (ibcInfo) {
|
|
296
|
-
var counterpartyIs = ibcInfo
|
|
297
|
-
var chainIs = ibcInfo
|
|
298
|
-
var counterparty = ibcInfo[counterpartyIs]
|
|
296
|
+
var counterpartyIs = ibcInfo.chain_1.chain_name === chainName ? 'chain_2' : 'chain_1';
|
|
297
|
+
var chainIs = ibcInfo.chain_1.chain_name === chainName ? 'chain_1' : 'chain_2';
|
|
298
|
+
var counterparty = ibcInfo[counterpartyIs].chain_name;
|
|
299
299
|
var counterpartyIbc = ibcInfo[counterpartyIs];
|
|
300
300
|
var chainIbc = ibcInfo[chainIs];
|
|
301
301
|
var counterpartyAssets = assets.find(function (a) {
|
|
@@ -334,9 +334,9 @@ var getCw20Assets = function getCw20Assets(chainName, ibc, assets) {
|
|
|
334
334
|
|
|
335
335
|
if (!channel) {
|
|
336
336
|
// console.warn(
|
|
337
|
-
// chainIbc
|
|
337
|
+
// chainIbc.chain_name,
|
|
338
338
|
// '<>',
|
|
339
|
-
// counterpartyIbc
|
|
339
|
+
// counterpartyIbc.chain_name,
|
|
340
340
|
// 'MISSING cw20 IBC info'
|
|
341
341
|
// );
|
|
342
342
|
return;
|
|
@@ -349,23 +349,23 @@ var getCw20Assets = function getCw20Assets(chainName, ibc, assets) {
|
|
|
349
349
|
};
|
|
350
350
|
}).filter(Boolean);
|
|
351
351
|
var hash = cw20AssetLists.reduce(function (m, v) {
|
|
352
|
-
m[v.chain
|
|
352
|
+
m[v.chain.chain_name] = m[v.chain.chain_name] || [];
|
|
353
353
|
var assets = v.assets.map(function (asset) {
|
|
354
354
|
return _objectSpread(_objectSpread({}, asset), {}, {
|
|
355
355
|
traces: [{
|
|
356
356
|
type: 'ibc',
|
|
357
357
|
counterparty: {
|
|
358
|
-
port: v.counterparty
|
|
358
|
+
port: v.counterparty.port_id,
|
|
359
359
|
// source_channel
|
|
360
|
-
channel: v.counterparty
|
|
360
|
+
channel: v.counterparty.channel_id,
|
|
361
361
|
// source_denom
|
|
362
362
|
denom: asset.denom_units[0].aliases[0],
|
|
363
|
-
chain_name: v.counterparty
|
|
363
|
+
chain_name: v.counterparty.chain_name
|
|
364
364
|
},
|
|
365
365
|
chain: {
|
|
366
366
|
// dst_denom
|
|
367
|
-
port: v.chain
|
|
368
|
-
channel: v.chain
|
|
367
|
+
port: v.chain.port_id,
|
|
368
|
+
channel: v.chain.channel_id // chain_name: v.chain.chain_name,
|
|
369
369
|
|
|
370
370
|
}
|
|
371
371
|
}]
|
|
@@ -376,7 +376,7 @@ var getCw20Assets = function getCw20Assets(chainName, ibc, assets) {
|
|
|
376
376
|
assets: assets
|
|
377
377
|
});
|
|
378
378
|
|
|
379
|
-
m[v.chain
|
|
379
|
+
m[v.chain.chain_name].push(obj);
|
|
380
380
|
return m;
|
|
381
381
|
}, {});
|
|
382
382
|
return Object.keys(hash).map(function (chain) {
|
package/module/registry.js
CHANGED
|
@@ -38,8 +38,8 @@ export class ChainInfo {
|
|
|
38
38
|
this._chain = this.registry.getChain(this.chain_name);
|
|
39
39
|
|
|
40
40
|
const supportedChains = this._ibc_data.reduce((m, v) => {
|
|
41
|
-
if (!m.includes(v
|
|
42
|
-
if (!m.includes(v
|
|
41
|
+
if (!m.includes(v.chain_1.chain_name)) m.push(v.chain_1.chain_name);
|
|
42
|
+
if (!m.includes(v.chain_2.chain_name)) m.push(v.chain_2.chain_name);
|
|
43
43
|
return m;
|
|
44
44
|
}, []);
|
|
45
45
|
|
|
@@ -112,7 +112,7 @@ export class ChainRegistry {
|
|
|
112
112
|
}
|
|
113
113
|
|
|
114
114
|
getChainIbcData(chainName) {
|
|
115
|
-
return this._ibc_data.filter(info => info
|
|
115
|
+
return this._ibc_data.filter(info => info.chain_1.chain_name === chainName || info.chain_2.chain_name === chainName);
|
|
116
116
|
}
|
|
117
117
|
|
|
118
118
|
getChainInfo(chainName) {
|
|
@@ -164,7 +164,7 @@ export class ChainRegistry {
|
|
|
164
164
|
|
|
165
165
|
upsertIbcData(data) {
|
|
166
166
|
const found = this._ibc_data.find(info => {
|
|
167
|
-
return info
|
|
167
|
+
return info.chain_1.chain_name === data.chain_1.chain_name && info.chain_2.chain_name === data.chain_2.chain_name;
|
|
168
168
|
});
|
|
169
169
|
|
|
170
170
|
if (!found) {
|
|
@@ -174,7 +174,7 @@ export class ChainRegistry {
|
|
|
174
174
|
}
|
|
175
175
|
|
|
176
176
|
this._ibc_data = this._ibc_data.map(info => {
|
|
177
|
-
if (info
|
|
177
|
+
if (info.chain_1.chain_name === data.chain_1.chain_name && info.chain_2.chain_name === data.chain_2.chain_name) {
|
|
178
178
|
return data;
|
|
179
179
|
} else {
|
|
180
180
|
return info;
|
package/module/utils.js
CHANGED
|
@@ -17,19 +17,19 @@ export const ibcDenom = (paths, coinMinimalDenom) => {
|
|
|
17
17
|
return 'ibc/' + Buffer.from(new Uint8Array(new sha256().update(Buffer.from(denom)).digest())).toString('hex').toUpperCase();
|
|
18
18
|
};
|
|
19
19
|
|
|
20
|
-
const findInfo = (ibc, to, from) => ibc.find(i => i
|
|
20
|
+
const findInfo = (ibc, to, from) => ibc.find(i => i.chain_1.chain_name === from && i.chain_2.chain_name === to);
|
|
21
21
|
|
|
22
22
|
export const getIbcInfo = (ibc, chain, counterparty) => {
|
|
23
23
|
return findInfo(ibc, chain, counterparty) || findInfo(ibc, counterparty, chain);
|
|
24
24
|
};
|
|
25
25
|
export const getTransferChannel = info => {
|
|
26
|
-
return info.channels.find(channel => channel
|
|
26
|
+
return info.channels.find(channel => channel.chain_1.port_id === 'transfer' && channel.chain_2.port_id === 'transfer');
|
|
27
27
|
};
|
|
28
28
|
export const getNonTransferChannel = info => {
|
|
29
|
-
return info.channels.find(channel => channel
|
|
29
|
+
return info.channels.find(channel => channel.chain_1.port_id !== 'transfer' && channel.chain_2.port_id === 'transfer' || channel.chain_1.port_id === 'transfer' && channel.chain_2.port_id !== 'transfer');
|
|
30
30
|
};
|
|
31
31
|
export const getWasmChannel = info => {
|
|
32
|
-
return info.channels.find(channel => channel
|
|
32
|
+
return info.channels.find(channel => channel.chain_1.port_id.startsWith('wasm.') && channel.chain_2.port_id === 'transfer' || channel.chain_1.port_id === 'transfer' && channel.chain_2.port_id.startsWith('wasm'));
|
|
33
33
|
};
|
|
34
34
|
export const getIbcDenomByBase = (ibc, chain, counterparty, assets, base) => {
|
|
35
35
|
const ibcInfo = getIbcInfo(ibc, chain, counterparty);
|
|
@@ -43,10 +43,10 @@ export const getIbcDenomByBase = (ibc, chain, counterparty, assets, base) => {
|
|
|
43
43
|
|
|
44
44
|
let channelInfo;
|
|
45
45
|
|
|
46
|
-
if (ibcInfo
|
|
47
|
-
channelInfo = channel
|
|
46
|
+
if (ibcInfo.chain_1.chain_name === chain) {
|
|
47
|
+
channelInfo = channel.chain_1;
|
|
48
48
|
} else {
|
|
49
|
-
channelInfo = channel
|
|
49
|
+
channelInfo = channel.chain_2;
|
|
50
50
|
}
|
|
51
51
|
|
|
52
52
|
const assetList = assets.find(({
|
|
@@ -90,8 +90,8 @@ export const getIbcDenomByBase = (ibc, chain, counterparty, assets, base) => {
|
|
|
90
90
|
// channelId: assetInfo.ibc.source_channel
|
|
91
91
|
// },
|
|
92
92
|
// {
|
|
93
|
-
// portId: channelInfo
|
|
94
|
-
// channelId: channelInfo
|
|
93
|
+
// portId: channelInfo.port_id,
|
|
94
|
+
// channelId: channelInfo.channel_id
|
|
95
95
|
// }
|
|
96
96
|
// ],
|
|
97
97
|
// base
|
|
@@ -100,8 +100,8 @@ export const getIbcDenomByBase = (ibc, chain, counterparty, assets, base) => {
|
|
|
100
100
|
|
|
101
101
|
|
|
102
102
|
return ibcDenom([{
|
|
103
|
-
portId: channelInfo
|
|
104
|
-
channelId: channelInfo
|
|
103
|
+
portId: channelInfo.port_id,
|
|
104
|
+
channelId: channelInfo.channel_id
|
|
105
105
|
}], base);
|
|
106
106
|
}
|
|
107
107
|
};
|
|
@@ -117,10 +117,10 @@ export const getIbcDenomByBaseForCw20 = (ibc, chain, counterparty, assets, base)
|
|
|
117
117
|
|
|
118
118
|
let channelInfo;
|
|
119
119
|
|
|
120
|
-
if (ibcInfo
|
|
121
|
-
channelInfo = channel
|
|
120
|
+
if (ibcInfo.chain_1.chain_name === chain) {
|
|
121
|
+
channelInfo = channel.chain_1;
|
|
122
122
|
} else {
|
|
123
|
-
channelInfo = channel
|
|
123
|
+
channelInfo = channel.chain_2;
|
|
124
124
|
}
|
|
125
125
|
|
|
126
126
|
const assetInfo = assets.find(({
|
|
@@ -132,19 +132,19 @@ export const getIbcDenomByBaseForCw20 = (ibc, chain, counterparty, assets, base)
|
|
|
132
132
|
}
|
|
133
133
|
|
|
134
134
|
return ibcDenom([{
|
|
135
|
-
portId: channelInfo
|
|
136
|
-
channelId: channelInfo
|
|
135
|
+
portId: channelInfo.port_id,
|
|
136
|
+
channelId: channelInfo.channel_id
|
|
137
137
|
}], base);
|
|
138
138
|
}
|
|
139
139
|
};
|
|
140
140
|
export const getIbcAssets = (chainName, ibc, assets) => {
|
|
141
141
|
const chainIbcInfo = ibc.filter(i => {
|
|
142
|
-
return i
|
|
142
|
+
return i.chain_1.chain_name === chainName || i.chain_2.chain_name === chainName;
|
|
143
143
|
});
|
|
144
144
|
const ibcAssetLists = chainIbcInfo.map(ibcInfo => {
|
|
145
|
-
const counterpartyIs = ibcInfo
|
|
146
|
-
const chainIs = ibcInfo
|
|
147
|
-
const counterparty = ibcInfo[counterpartyIs]
|
|
145
|
+
const counterpartyIs = ibcInfo.chain_1.chain_name === chainName ? 'chain_2' : 'chain_1';
|
|
146
|
+
const chainIs = ibcInfo.chain_1.chain_name === chainName ? 'chain_1' : 'chain_2';
|
|
147
|
+
const counterparty = ibcInfo[counterpartyIs].chain_name;
|
|
148
148
|
const counterpartyIbc = ibcInfo[counterpartyIs];
|
|
149
149
|
const chainIbc = ibcInfo[chainIs];
|
|
150
150
|
const counterpartyAssets = assets.find(a => {
|
|
@@ -184,23 +184,23 @@ export const getIbcAssets = (chainName, ibc, assets) => {
|
|
|
184
184
|
};
|
|
185
185
|
}).filter(Boolean);
|
|
186
186
|
const hash = ibcAssetLists.reduce((m, v) => {
|
|
187
|
-
m[v.chain
|
|
187
|
+
m[v.chain.chain_name] = m[v.chain.chain_name] || [];
|
|
188
188
|
const assets = v.assets.map(asset => {
|
|
189
189
|
return _objectSpread(_objectSpread({}, asset), {}, {
|
|
190
190
|
traces: [{
|
|
191
191
|
type: 'ibc',
|
|
192
192
|
counterparty: {
|
|
193
193
|
// source_channel
|
|
194
|
-
channel: v.counterparty
|
|
194
|
+
channel: v.counterparty.channel_id,
|
|
195
195
|
// source_denom
|
|
196
196
|
denom: asset.denom_units[0].aliases[0],
|
|
197
|
-
chain_name: v.counterparty
|
|
197
|
+
chain_name: v.counterparty.chain_name // port: v.counterparty.port_id
|
|
198
198
|
|
|
199
199
|
},
|
|
200
200
|
chain: {
|
|
201
201
|
// dst_denom
|
|
202
|
-
channel: v.chain
|
|
203
|
-
// port: v.chain
|
|
202
|
+
channel: v.chain.channel_id // chain_name: v.chain.chain_name,
|
|
203
|
+
// port: v.chain.port_id
|
|
204
204
|
|
|
205
205
|
}
|
|
206
206
|
}]
|
|
@@ -211,7 +211,7 @@ export const getIbcAssets = (chainName, ibc, assets) => {
|
|
|
211
211
|
assets
|
|
212
212
|
});
|
|
213
213
|
|
|
214
|
-
m[v.chain
|
|
214
|
+
m[v.chain.chain_name].push(obj);
|
|
215
215
|
return m;
|
|
216
216
|
}, {});
|
|
217
217
|
return Object.keys(hash).map(chain => {
|
|
@@ -225,12 +225,12 @@ export const getIbcAssets = (chainName, ibc, assets) => {
|
|
|
225
225
|
};
|
|
226
226
|
export const getCw20Assets = (chainName, ibc, assets) => {
|
|
227
227
|
const chainIbcInfo = ibc.filter(i => {
|
|
228
|
-
return i
|
|
228
|
+
return i.chain_1.chain_name === chainName || i.chain_2.chain_name === chainName;
|
|
229
229
|
});
|
|
230
230
|
const cw20AssetLists = chainIbcInfo.map(ibcInfo => {
|
|
231
|
-
const counterpartyIs = ibcInfo
|
|
232
|
-
const chainIs = ibcInfo
|
|
233
|
-
const counterparty = ibcInfo[counterpartyIs]
|
|
231
|
+
const counterpartyIs = ibcInfo.chain_1.chain_name === chainName ? 'chain_2' : 'chain_1';
|
|
232
|
+
const chainIs = ibcInfo.chain_1.chain_name === chainName ? 'chain_1' : 'chain_2';
|
|
233
|
+
const counterparty = ibcInfo[counterpartyIs].chain_name;
|
|
234
234
|
const counterpartyIbc = ibcInfo[counterpartyIs];
|
|
235
235
|
const chainIbc = ibcInfo[chainIs];
|
|
236
236
|
const counterpartyAssets = assets.find(a => {
|
|
@@ -267,9 +267,9 @@ export const getCw20Assets = (chainName, ibc, assets) => {
|
|
|
267
267
|
|
|
268
268
|
if (!channel) {
|
|
269
269
|
// console.warn(
|
|
270
|
-
// chainIbc
|
|
270
|
+
// chainIbc.chain_name,
|
|
271
271
|
// '<>',
|
|
272
|
-
// counterpartyIbc
|
|
272
|
+
// counterpartyIbc.chain_name,
|
|
273
273
|
// 'MISSING cw20 IBC info'
|
|
274
274
|
// );
|
|
275
275
|
return;
|
|
@@ -282,23 +282,23 @@ export const getCw20Assets = (chainName, ibc, assets) => {
|
|
|
282
282
|
};
|
|
283
283
|
}).filter(Boolean);
|
|
284
284
|
const hash = cw20AssetLists.reduce((m, v) => {
|
|
285
|
-
m[v.chain
|
|
285
|
+
m[v.chain.chain_name] = m[v.chain.chain_name] || [];
|
|
286
286
|
const assets = v.assets.map(asset => {
|
|
287
287
|
return _objectSpread(_objectSpread({}, asset), {}, {
|
|
288
288
|
traces: [{
|
|
289
289
|
type: 'ibc',
|
|
290
290
|
counterparty: {
|
|
291
|
-
port: v.counterparty
|
|
291
|
+
port: v.counterparty.port_id,
|
|
292
292
|
// source_channel
|
|
293
|
-
channel: v.counterparty
|
|
293
|
+
channel: v.counterparty.channel_id,
|
|
294
294
|
// source_denom
|
|
295
295
|
denom: asset.denom_units[0].aliases[0],
|
|
296
|
-
chain_name: v.counterparty
|
|
296
|
+
chain_name: v.counterparty.chain_name
|
|
297
297
|
},
|
|
298
298
|
chain: {
|
|
299
299
|
// dst_denom
|
|
300
|
-
port: v.chain
|
|
301
|
-
channel: v.chain
|
|
300
|
+
port: v.chain.port_id,
|
|
301
|
+
channel: v.chain.channel_id // chain_name: v.chain.chain_name,
|
|
302
302
|
|
|
303
303
|
}
|
|
304
304
|
}]
|
|
@@ -309,7 +309,7 @@ export const getCw20Assets = (chainName, ibc, assets) => {
|
|
|
309
309
|
assets
|
|
310
310
|
});
|
|
311
311
|
|
|
312
|
-
m[v.chain
|
|
312
|
+
m[v.chain.chain_name].push(obj);
|
|
313
313
|
return m;
|
|
314
314
|
}, {});
|
|
315
315
|
return Object.keys(hash).map(chain => {
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@chain-registry/utils",
|
|
3
|
-
"version": "0.
|
|
3
|
+
"version": "0.7.2",
|
|
4
4
|
"description": "Chain Registry Utils",
|
|
5
5
|
"author": "Dan Lynch <pyramation@gmail.com>",
|
|
6
6
|
"homepage": "https://github.com/cosmology-tech/chain-registry",
|
|
@@ -63,7 +63,6 @@
|
|
|
63
63
|
"babel-jest": "28.1.1",
|
|
64
64
|
"babel-watch": "^7.0.0",
|
|
65
65
|
"cross-env": "^7.0.2",
|
|
66
|
-
"cross-fetch": "^3.1.5",
|
|
67
66
|
"eslint": "8.20.0",
|
|
68
67
|
"eslint-config-prettier": "^8.5.0",
|
|
69
68
|
"eslint-plugin-prettier": "^4.0.0",
|
|
@@ -78,9 +77,10 @@
|
|
|
78
77
|
},
|
|
79
78
|
"dependencies": {
|
|
80
79
|
"@babel/runtime": "^7.18.3",
|
|
81
|
-
"@chain-registry/types": "^0.
|
|
80
|
+
"@chain-registry/types": "^0.7.1",
|
|
82
81
|
"bfs-path": "^1.0.2",
|
|
82
|
+
"cross-fetch": "^3.1.5",
|
|
83
83
|
"sha.js": "^2.4.11"
|
|
84
84
|
},
|
|
85
|
-
"gitHead": "
|
|
85
|
+
"gitHead": "bff7e354c6383e548bf51bd932af9ad4cb1a0214"
|
|
86
86
|
}
|
package/types/index.d.ts
CHANGED
|
@@ -1,56 +1,2 @@
|
|
|
1
|
-
|
|
2
|
-
export
|
|
3
|
-
portId: string;
|
|
4
|
-
channelId: string;
|
|
5
|
-
}[], coinMinimalDenom: string) => string;
|
|
6
|
-
export declare const getIbcInfo: (ibc: IBCInfo[], chain: string, counterparty: string) => IBCInfo;
|
|
7
|
-
export declare const getTransferChannel: (info: IBCInfo) => {
|
|
8
|
-
'chain-1': {
|
|
9
|
-
'channel-id': string;
|
|
10
|
-
'port-id': string;
|
|
11
|
-
};
|
|
12
|
-
'chain-2': {
|
|
13
|
-
'channel-id': string;
|
|
14
|
-
'port-id': string;
|
|
15
|
-
};
|
|
16
|
-
ordering: string;
|
|
17
|
-
version: string;
|
|
18
|
-
tags: object;
|
|
19
|
-
};
|
|
20
|
-
export declare const getNonTransferChannel: (info: IBCInfo) => {
|
|
21
|
-
'chain-1': {
|
|
22
|
-
'channel-id': string;
|
|
23
|
-
'port-id': string;
|
|
24
|
-
};
|
|
25
|
-
'chain-2': {
|
|
26
|
-
'channel-id': string;
|
|
27
|
-
'port-id': string;
|
|
28
|
-
};
|
|
29
|
-
ordering: string;
|
|
30
|
-
version: string;
|
|
31
|
-
tags: object;
|
|
32
|
-
};
|
|
33
|
-
export declare const getWasmChannel: (info: IBCInfo) => {
|
|
34
|
-
'chain-1': {
|
|
35
|
-
'channel-id': string;
|
|
36
|
-
'port-id': string;
|
|
37
|
-
};
|
|
38
|
-
'chain-2': {
|
|
39
|
-
'channel-id': string;
|
|
40
|
-
'port-id': string;
|
|
41
|
-
};
|
|
42
|
-
ordering: string;
|
|
43
|
-
version: string;
|
|
44
|
-
tags: object;
|
|
45
|
-
};
|
|
46
|
-
export declare const getIbcDenomByBase: (ibc: IBCInfo[], chain: string, counterparty: string, assets: AssetList[], base: string) => string;
|
|
47
|
-
export declare const getIbcDenomByBaseForCw20: (ibc: IBCInfo[], chain: string, counterparty: string, assets: AssetList[], base: string) => string;
|
|
48
|
-
export declare const getIbcAssets: (chainName: string, ibc: IBCInfo[], assets: AssetList[]) => {
|
|
49
|
-
chain_name: string;
|
|
50
|
-
assets: any;
|
|
51
|
-
}[];
|
|
52
|
-
export declare const getCw20Assets: (chainName: string, ibc: IBCInfo[], assets: AssetList[]) => {
|
|
53
|
-
chain_name: string;
|
|
54
|
-
assets: any;
|
|
55
|
-
}[];
|
|
56
|
-
export declare const getAssetLists: (chainName: string, ibc: IBCInfo[], assets: AssetList[]) => any[];
|
|
1
|
+
export * from './registry';
|
|
2
|
+
export * from './utils';
|
|
@@ -0,0 +1,45 @@
|
|
|
1
|
+
import { AssetList, Chain, IBCInfo } from '@chain-registry/types';
|
|
2
|
+
export interface ChainRegistryOptions {
|
|
3
|
+
assetLists?: AssetList[];
|
|
4
|
+
chains?: Chain[];
|
|
5
|
+
ibcData?: IBCInfo[];
|
|
6
|
+
urls?: string[];
|
|
7
|
+
}
|
|
8
|
+
export interface ChainInfoOptions {
|
|
9
|
+
chain_name: string;
|
|
10
|
+
registry: ChainRegistry;
|
|
11
|
+
}
|
|
12
|
+
export declare class ChainInfo {
|
|
13
|
+
chain_name: string;
|
|
14
|
+
registry: ChainRegistry;
|
|
15
|
+
protected _asset_list: AssetList;
|
|
16
|
+
protected _asset_lists: AssetList[];
|
|
17
|
+
protected _chain: Chain;
|
|
18
|
+
protected _ibc_data: IBCInfo[];
|
|
19
|
+
constructor(options: ChainInfoOptions);
|
|
20
|
+
refresh(): void;
|
|
21
|
+
nativeAssetLists(): AssetList;
|
|
22
|
+
chain(): Chain;
|
|
23
|
+
assetLists(): any[];
|
|
24
|
+
}
|
|
25
|
+
export declare class ChainRegistry {
|
|
26
|
+
protected _asset_lists: AssetList[];
|
|
27
|
+
protected _chains: Chain[];
|
|
28
|
+
protected _ibc_data: IBCInfo[];
|
|
29
|
+
urls: string[];
|
|
30
|
+
constructor(options?: ChainRegistryOptions);
|
|
31
|
+
assetLists(): AssetList[];
|
|
32
|
+
getChainAssetList(chainName: string): AssetList;
|
|
33
|
+
getGeneratedAssetLists(chainName: string): AssetList[];
|
|
34
|
+
chains(): Chain[];
|
|
35
|
+
getChain(chainName: string): Chain;
|
|
36
|
+
ibcData(): IBCInfo[];
|
|
37
|
+
getChainIbcData(chainName: string): IBCInfo[];
|
|
38
|
+
getChainInfo(chainName: string): ChainInfo;
|
|
39
|
+
upsertChain(data: Chain): void;
|
|
40
|
+
updateAssetList(data: AssetList): void;
|
|
41
|
+
upsertIbcData(data: IBCInfo): void;
|
|
42
|
+
update(data: Chain | AssetList | IBCInfo): void;
|
|
43
|
+
fetch(url: any): Promise<void>;
|
|
44
|
+
fetchUrls(): Promise<void[]>;
|
|
45
|
+
}
|
package/types/utils.d.ts
ADDED
|
@@ -0,0 +1,56 @@
|
|
|
1
|
+
import { AssetList, IBCInfo } from '@chain-registry/types';
|
|
2
|
+
export declare const ibcDenom: (paths: {
|
|
3
|
+
portId: string;
|
|
4
|
+
channelId: string;
|
|
5
|
+
}[], coinMinimalDenom: string) => string;
|
|
6
|
+
export declare const getIbcInfo: (ibc: IBCInfo[], chain: string, counterparty: string) => IBCInfo;
|
|
7
|
+
export declare const getTransferChannel: (info: IBCInfo) => {
|
|
8
|
+
chain_1: {
|
|
9
|
+
channel_id: string;
|
|
10
|
+
port_id: string;
|
|
11
|
+
};
|
|
12
|
+
chain_2: {
|
|
13
|
+
channel_id: string;
|
|
14
|
+
port_id: string;
|
|
15
|
+
};
|
|
16
|
+
ordering: string;
|
|
17
|
+
version: string;
|
|
18
|
+
tags?: object;
|
|
19
|
+
};
|
|
20
|
+
export declare const getNonTransferChannel: (info: IBCInfo) => {
|
|
21
|
+
chain_1: {
|
|
22
|
+
channel_id: string;
|
|
23
|
+
port_id: string;
|
|
24
|
+
};
|
|
25
|
+
chain_2: {
|
|
26
|
+
channel_id: string;
|
|
27
|
+
port_id: string;
|
|
28
|
+
};
|
|
29
|
+
ordering: string;
|
|
30
|
+
version: string;
|
|
31
|
+
tags?: object;
|
|
32
|
+
};
|
|
33
|
+
export declare const getWasmChannel: (info: IBCInfo) => {
|
|
34
|
+
chain_1: {
|
|
35
|
+
channel_id: string;
|
|
36
|
+
port_id: string;
|
|
37
|
+
};
|
|
38
|
+
chain_2: {
|
|
39
|
+
channel_id: string;
|
|
40
|
+
port_id: string;
|
|
41
|
+
};
|
|
42
|
+
ordering: string;
|
|
43
|
+
version: string;
|
|
44
|
+
tags?: object;
|
|
45
|
+
};
|
|
46
|
+
export declare const getIbcDenomByBase: (ibc: IBCInfo[], chain: string, counterparty: string, assets: AssetList[], base: string) => string;
|
|
47
|
+
export declare const getIbcDenomByBaseForCw20: (ibc: IBCInfo[], chain: string, counterparty: string, assets: AssetList[], base: string) => string;
|
|
48
|
+
export declare const getIbcAssets: (chainName: string, ibc: IBCInfo[], assets: AssetList[]) => {
|
|
49
|
+
chain_name: string;
|
|
50
|
+
assets: any;
|
|
51
|
+
}[];
|
|
52
|
+
export declare const getCw20Assets: (chainName: string, ibc: IBCInfo[], assets: AssetList[]) => {
|
|
53
|
+
chain_name: string;
|
|
54
|
+
assets: any;
|
|
55
|
+
}[];
|
|
56
|
+
export declare const getAssetLists: (chainName: string, ibc: IBCInfo[], assets: AssetList[]) => any[];
|