@heliofi/common 0.2.181-alpha.1 → 0.2.181-alpha.3
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/src/domain/model/blockchain/constants/BlockchainEngineToBlockchain.d.ts +2 -2
- package/dist/src/domain/model/blockchain/constants/BlockchainEngineToBlockchain.js +1 -1
- package/dist/src/domain/model/blockchain/constants/BlockchainEngineToBlockchain.js.map +1 -1
- package/dist/src/domain/model/blockchain/constants/BlockchainEngineToBlockchain.spec.js +1 -1
- package/dist/src/domain/model/blockchain/constants/BlockchainEngineToBlockchain.spec.js.map +1 -1
- package/dist/src/domain/model/blockchain/constants/BlockchainSymbol.d.ts +3 -3
- package/dist/src/domain/model/blockchain/constants/BlockchainSymbol.js +1 -1
- package/dist/src/domain/model/blockchain/constants/BlockchainSymbol.js.map +1 -1
- package/dist/src/domain/model/blockchain/constants/BlockchainToBlockchainEngine.d.ts +2 -2
- package/dist/src/domain/model/blockchain/constants/BlockchainToBlockchainEngine.js +1 -1
- package/dist/src/domain/model/blockchain/constants/BlockchainToBlockchainEngine.js.map +1 -1
- package/dist/src/domain/model/privateRpc/entities/PrivateRpcUsageUi.enum.d.ts +2 -1
- package/dist/src/domain/model/privateRpc/entities/PrivateRpcUsageUi.enum.js +1 -0
- package/dist/src/domain/model/privateRpc/entities/PrivateRpcUsageUi.enum.js.map +1 -1
- package/dist/src/domain/services/PublicKeyService.d.ts +1 -0
- package/dist/src/domain/services/PublicKeyService.js +12 -0
- package/dist/src/domain/services/PublicKeyService.js.map +1 -1
- package/dist/tsconfig.tsbuildinfo +1 -1
- package/package.json +3 -2
|
@@ -1,3 +1,3 @@
|
|
|
1
1
|
import { BlockchainEngineType } from '../../blockchainEngine';
|
|
2
|
-
import { BlockchainSymbol
|
|
3
|
-
export declare const blockchainEngineToBlockchainMap: Map<BlockchainEngineType, BlockchainSymbol
|
|
2
|
+
import { BlockchainSymbol } from './BlockchainSymbol';
|
|
3
|
+
export declare const blockchainEngineToBlockchainMap: Map<BlockchainEngineType, BlockchainSymbol>;
|
|
@@ -7,6 +7,6 @@ exports.blockchainEngineToBlockchainMap = new Map([
|
|
|
7
7
|
[blockchainEngine_1.BlockchainEngineType.SOL, BlockchainSymbol_1.BlockchainSymbol.SOL],
|
|
8
8
|
[blockchainEngine_1.BlockchainEngineType.EVM, BlockchainSymbol_1.BlockchainSymbol.POLYGON],
|
|
9
9
|
[blockchainEngine_1.BlockchainEngineType.BTC, BlockchainSymbol_1.BlockchainSymbol.BITCOIN],
|
|
10
|
-
[blockchainEngine_1.BlockchainEngineType.TRON, BlockchainSymbol_1.
|
|
10
|
+
[blockchainEngine_1.BlockchainEngineType.TRON, BlockchainSymbol_1.BlockchainSymbol.TRON],
|
|
11
11
|
]);
|
|
12
12
|
//# sourceMappingURL=BlockchainEngineToBlockchain.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"BlockchainEngineToBlockchain.js","sourceRoot":"","sources":["../../../../../../src/domain/model/blockchain/constants/BlockchainEngineToBlockchain.ts"],"names":[],"mappings":";;;AAAA,6DAA8D;AAC9D,
|
|
1
|
+
{"version":3,"file":"BlockchainEngineToBlockchain.js","sourceRoot":"","sources":["../../../../../../src/domain/model/blockchain/constants/BlockchainEngineToBlockchain.ts"],"names":[],"mappings":";;;AAAA,6DAA8D;AAC9D,yDAAsD;AAEzC,QAAA,+BAA+B,GAAG,IAAI,GAAG,CAGpD;IACA,CAAC,uCAAoB,CAAC,GAAG,EAAE,mCAAgB,CAAC,GAAG,CAAC;IAChD,CAAC,uCAAoB,CAAC,GAAG,EAAE,mCAAgB,CAAC,OAAO,CAAC;IACpD,CAAC,uCAAoB,CAAC,GAAG,EAAE,mCAAgB,CAAC,OAAO,CAAC;IACpD,CAAC,uCAAoB,CAAC,IAAI,EAAE,mCAAgB,CAAC,IAAI,CAAC;CACnD,CAAC,CAAC"}
|
|
@@ -8,7 +8,7 @@ describe('BlockchainEngineToBlockchain', () => {
|
|
|
8
8
|
[blockchainEngine_1.BlockchainEngineType.EVM]: BlockchainSymbol_1.BlockchainSymbol.POLYGON,
|
|
9
9
|
[blockchainEngine_1.BlockchainEngineType.SOL]: BlockchainSymbol_1.BlockchainSymbol.SOL,
|
|
10
10
|
[blockchainEngine_1.BlockchainEngineType.BTC]: BlockchainSymbol_1.BlockchainSymbol.BITCOIN,
|
|
11
|
-
[blockchainEngine_1.BlockchainEngineType.TRON]: BlockchainSymbol_1.
|
|
11
|
+
[blockchainEngine_1.BlockchainEngineType.TRON]: BlockchainSymbol_1.BlockchainSymbol.TRON,
|
|
12
12
|
};
|
|
13
13
|
it.each(Object.entries(cases))('should have all blockchain engines', (engineType, symbol) => {
|
|
14
14
|
expect(BlockchainEngineToBlockchain_1.blockchainEngineToBlockchainMap.get(engineType)).toBe(symbol);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"BlockchainEngineToBlockchain.spec.js","sourceRoot":"","sources":["../../../../../../src/domain/model/blockchain/constants/BlockchainEngineToBlockchain.spec.ts"],"names":[],"mappings":";;AAAA,
|
|
1
|
+
{"version":3,"file":"BlockchainEngineToBlockchain.spec.js","sourceRoot":"","sources":["../../../../../../src/domain/model/blockchain/constants/BlockchainEngineToBlockchain.spec.ts"],"names":[],"mappings":";;AAAA,yDAAsD;AACtD,iFAAiF;AACjF,6DAA8D;AAE9D,QAAQ,CAAC,8BAA8B,EAAE,GAAG,EAAE;IAE5C,MAAM,KAAK,GAAmD;QAC5D,CAAC,uCAAoB,CAAC,GAAG,CAAC,EAAE,mCAAgB,CAAC,OAAO;QACpD,CAAC,uCAAoB,CAAC,GAAG,CAAC,EAAE,mCAAgB,CAAC,GAAG;QAChD,CAAC,uCAAoB,CAAC,GAAG,CAAC,EAAE,mCAAgB,CAAC,OAAO;QACpD,CAAC,uCAAoB,CAAC,IAAI,CAAC,EAAE,mCAAgB,CAAC,IAAI;KACnD,CAAC;IAEF,EAAE,CAAC,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,CAC5B,oCAAoC,EACpC,CAAC,UAAU,EAAE,MAAM,EAAE,EAAE;QACrB,MAAM,CACJ,8DAA+B,CAAC,GAAG,CAAC,UAAkC,CAAC,CACxE,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;IACjB,CAAC,CACF,CAAC;AACJ,CAAC,CAAC,CAAC"}
|
|
@@ -5,11 +5,11 @@ export declare enum BlockchainSymbol {
|
|
|
5
5
|
BASE = "BASE",
|
|
6
6
|
BITCOIN = "BITCOIN",
|
|
7
7
|
ARBITRUM = "ARBITRUM",
|
|
8
|
-
BSC = "BSC"
|
|
8
|
+
BSC = "BSC",
|
|
9
|
+
TRON = "TRON"
|
|
9
10
|
}
|
|
10
11
|
export declare enum DepositBlockchainSymbol {
|
|
11
12
|
ABSTRACT = "ABSTRACT",
|
|
12
13
|
HYPERLIQUID = "HYPERLIQUID",
|
|
13
|
-
PLASMA = "PLASMA"
|
|
14
|
-
TRON = "TRON"
|
|
14
|
+
PLASMA = "PLASMA"
|
|
15
15
|
}
|
|
@@ -10,12 +10,12 @@ var BlockchainSymbol;
|
|
|
10
10
|
BlockchainSymbol["BITCOIN"] = "BITCOIN";
|
|
11
11
|
BlockchainSymbol["ARBITRUM"] = "ARBITRUM";
|
|
12
12
|
BlockchainSymbol["BSC"] = "BSC";
|
|
13
|
+
BlockchainSymbol["TRON"] = "TRON";
|
|
13
14
|
})(BlockchainSymbol || (exports.BlockchainSymbol = BlockchainSymbol = {}));
|
|
14
15
|
var DepositBlockchainSymbol;
|
|
15
16
|
(function (DepositBlockchainSymbol) {
|
|
16
17
|
DepositBlockchainSymbol["ABSTRACT"] = "ABSTRACT";
|
|
17
18
|
DepositBlockchainSymbol["HYPERLIQUID"] = "HYPERLIQUID";
|
|
18
19
|
DepositBlockchainSymbol["PLASMA"] = "PLASMA";
|
|
19
|
-
DepositBlockchainSymbol["TRON"] = "TRON";
|
|
20
20
|
})(DepositBlockchainSymbol || (exports.DepositBlockchainSymbol = DepositBlockchainSymbol = {}));
|
|
21
21
|
//# sourceMappingURL=BlockchainSymbol.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"BlockchainSymbol.js","sourceRoot":"","sources":["../../../../../../src/domain/model/blockchain/constants/BlockchainSymbol.ts"],"names":[],"mappings":";;;AAAA,IAAY,
|
|
1
|
+
{"version":3,"file":"BlockchainSymbol.js","sourceRoot":"","sources":["../../../../../../src/domain/model/blockchain/constants/BlockchainSymbol.ts"],"names":[],"mappings":";;;AAAA,IAAY,gBASX;AATD,WAAY,gBAAgB;IAC1B,+BAAW,CAAA;IACX,+BAAW,CAAA;IACX,uCAAmB,CAAA;IACnB,iCAAa,CAAA;IACb,uCAAmB,CAAA;IACnB,yCAAqB,CAAA;IACrB,+BAAW,CAAA;IACX,iCAAa,CAAA;AACf,CAAC,EATW,gBAAgB,gCAAhB,gBAAgB,QAS3B;AAGD,IAAY,uBAIX;AAJD,WAAY,uBAAuB;IACjC,gDAAqB,CAAA;IACrB,sDAA2B,CAAA;IAC3B,4CAAiB,CAAA;AACnB,CAAC,EAJW,uBAAuB,uCAAvB,uBAAuB,QAIlC"}
|
|
@@ -1,3 +1,3 @@
|
|
|
1
1
|
import { BlockchainEngineType } from '../../blockchainEngine';
|
|
2
|
-
import { BlockchainSymbol
|
|
3
|
-
export declare const blockchainToBlockchainEngineMap: Map<BlockchainSymbol
|
|
2
|
+
import { BlockchainSymbol } from './BlockchainSymbol';
|
|
3
|
+
export declare const blockchainToBlockchainEngineMap: Map<BlockchainSymbol, BlockchainEngineType>;
|
|
@@ -9,6 +9,6 @@ exports.blockchainToBlockchainEngineMap = new Map([
|
|
|
9
9
|
[BlockchainSymbol_1.BlockchainSymbol.POLYGON, blockchainEngine_1.BlockchainEngineType.EVM],
|
|
10
10
|
[BlockchainSymbol_1.BlockchainSymbol.BASE, blockchainEngine_1.BlockchainEngineType.EVM],
|
|
11
11
|
[BlockchainSymbol_1.BlockchainSymbol.BITCOIN, blockchainEngine_1.BlockchainEngineType.BTC],
|
|
12
|
-
[BlockchainSymbol_1.
|
|
12
|
+
[BlockchainSymbol_1.BlockchainSymbol.TRON, blockchainEngine_1.BlockchainEngineType.TRON],
|
|
13
13
|
]);
|
|
14
14
|
//# sourceMappingURL=BlockchainToBlockchainEngine.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"BlockchainToBlockchainEngine.js","sourceRoot":"","sources":["../../../../../../src/domain/model/blockchain/constants/BlockchainToBlockchainEngine.ts"],"names":[],"mappings":";;;AAAA,6DAA8D;AAC9D,
|
|
1
|
+
{"version":3,"file":"BlockchainToBlockchainEngine.js","sourceRoot":"","sources":["../../../../../../src/domain/model/blockchain/constants/BlockchainToBlockchainEngine.ts"],"names":[],"mappings":";;;AAAA,6DAA8D;AAC9D,yDAAsD;AAEzC,QAAA,+BAA+B,GAAG,IAAI,GAAG,CAGpD;IACA,CAAC,mCAAgB,CAAC,GAAG,EAAE,uCAAoB,CAAC,GAAG,CAAC;IAChD,CAAC,mCAAgB,CAAC,GAAG,EAAE,uCAAoB,CAAC,GAAG,CAAC;IAChD,CAAC,mCAAgB,CAAC,OAAO,EAAE,uCAAoB,CAAC,GAAG,CAAC;IACpD,CAAC,mCAAgB,CAAC,IAAI,EAAE,uCAAoB,CAAC,GAAG,CAAC;IACjD,CAAC,mCAAgB,CAAC,OAAO,EAAE,uCAAoB,CAAC,GAAG,CAAC;IACpD,CAAC,mCAAgB,CAAC,IAAI,EAAE,uCAAoB,CAAC,IAAI,CAAC;CACnD,CAAC,CAAC"}
|
|
@@ -11,5 +11,6 @@ export declare enum PrivateRpcUsageUI {
|
|
|
11
11
|
DEPOSITS_EVM_HYPERLIQUID = "EVM Hyperliquid Deposits RPC",
|
|
12
12
|
DEPOSITS_EVM_PLASMA = "EVM Plasma Deposits RPC",
|
|
13
13
|
DEPOSITS_BITCOIN = "Bitcoin Deposits RPC",
|
|
14
|
-
DEPOSITS_SOL = "Solana Deposits RPC"
|
|
14
|
+
DEPOSITS_SOL = "Solana Deposits RPC",
|
|
15
|
+
DEPOSITS_TRON = "Tron Deposits RPC"
|
|
15
16
|
}
|
|
@@ -16,5 +16,6 @@ var PrivateRpcUsageUI;
|
|
|
16
16
|
PrivateRpcUsageUI["DEPOSITS_EVM_PLASMA"] = "EVM Plasma Deposits RPC";
|
|
17
17
|
PrivateRpcUsageUI["DEPOSITS_BITCOIN"] = "Bitcoin Deposits RPC";
|
|
18
18
|
PrivateRpcUsageUI["DEPOSITS_SOL"] = "Solana Deposits RPC";
|
|
19
|
+
PrivateRpcUsageUI["DEPOSITS_TRON"] = "Tron Deposits RPC";
|
|
19
20
|
})(PrivateRpcUsageUI || (exports.PrivateRpcUsageUI = PrivateRpcUsageUI = {}));
|
|
20
21
|
//# sourceMappingURL=PrivateRpcUsageUi.enum.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"PrivateRpcUsageUi.enum.js","sourceRoot":"","sources":["../../../../../../src/domain/model/privateRpc/entities/PrivateRpcUsageUi.enum.ts"],"names":[],"mappings":";;;AAAA,IAAY,
|
|
1
|
+
{"version":3,"file":"PrivateRpcUsageUi.enum.js","sourceRoot":"","sources":["../../../../../../src/domain/model/privateRpc/entities/PrivateRpcUsageUi.enum.ts"],"names":[],"mappings":";;;AAAA,IAAY,iBAeX;AAfD,WAAY,iBAAiB;IAC3B,6EAAwD,CAAA;IACxD,gDAA2B,CAAA;IAC3B,8EAAyD,CAAA;IACzD,mEAA8C,CAAA;IAC9C,gEAA2C,CAAA;IAC3C,sEAAiD,CAAA;IACjD,wEAAmD,CAAA;IACnD,8DAAyC,CAAA;IACzC,wEAAmD,CAAA;IACnD,8EAAyD,CAAA;IACzD,oEAA+C,CAAA;IAC/C,8DAAyC,CAAA;IACzC,yDAAoC,CAAA;IACpC,wDAAmC,CAAA;AACrC,CAAC,EAfW,iBAAiB,iCAAjB,iBAAiB,QAe5B"}
|
|
@@ -3,5 +3,6 @@ export declare class PublicKeyService {
|
|
|
3
3
|
static validateAnyBlockchainAddress(address: string, generalNetwork?: GeneralNetwork): boolean;
|
|
4
4
|
static validateSolAddress(address: string): boolean;
|
|
5
5
|
static validateEvmAddress(address: string): boolean;
|
|
6
|
+
static validateTronAddress(address: string): boolean;
|
|
6
7
|
static validateBTCAddress(address: string, generalNetwork: GeneralNetwork): boolean;
|
|
7
8
|
}
|
|
@@ -27,6 +27,7 @@ exports.PublicKeyService = void 0;
|
|
|
27
27
|
const web3_js_1 = require("@solana/web3.js");
|
|
28
28
|
const bitcoinjs = __importStar(require("bitcoinjs-lib"));
|
|
29
29
|
const js_sha3_1 = require("js-sha3");
|
|
30
|
+
const tronweb_1 = require("tronweb");
|
|
30
31
|
const constants_1 = require("../constants");
|
|
31
32
|
class PublicKeyService {
|
|
32
33
|
static validateAnyBlockchainAddress(address, generalNetwork) {
|
|
@@ -36,6 +37,9 @@ class PublicKeyService {
|
|
|
36
37
|
if (this.validateEvmAddress(address)) {
|
|
37
38
|
return true;
|
|
38
39
|
}
|
|
40
|
+
if (this.validateTronAddress(address)) {
|
|
41
|
+
return true;
|
|
42
|
+
}
|
|
39
43
|
if (generalNetwork && this.validateBTCAddress(address, generalNetwork)) {
|
|
40
44
|
return true;
|
|
41
45
|
}
|
|
@@ -69,6 +73,14 @@ class PublicKeyService {
|
|
|
69
73
|
}
|
|
70
74
|
return true;
|
|
71
75
|
}
|
|
76
|
+
static validateTronAddress(address) {
|
|
77
|
+
try {
|
|
78
|
+
return tronweb_1.TronWeb.isAddress(address);
|
|
79
|
+
}
|
|
80
|
+
catch (error) {
|
|
81
|
+
return false;
|
|
82
|
+
}
|
|
83
|
+
}
|
|
72
84
|
static validateBTCAddress(address, generalNetwork) {
|
|
73
85
|
const network = generalNetwork === constants_1.GeneralNetwork.MAINNET
|
|
74
86
|
? bitcoinjs.networks.bitcoin
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"PublicKeyService.js","sourceRoot":"","sources":["../../../../src/domain/services/PublicKeyService.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,6CAA4C;AAC5C,yDAA2C;AAC3C,qCAAoC;AACpC,4CAA8C;AAE9C,MAAa,gBAAgB;IAC3B,MAAM,CAAC,4BAA4B,CACjC,OAAe,EACf,cAA+B;QAE/B,IAAI,IAAI,CAAC,kBAAkB,CAAC,OAAO,CAAC,EAAE,CAAC;YACrC,OAAO,IAAI,CAAC;QACd,CAAC;QACD,IAAI,IAAI,CAAC,kBAAkB,CAAC,OAAO,CAAC,EAAE,CAAC;YACrC,OAAO,IAAI,CAAC;QACd,CAAC;QACD,IAAI,cAAc,IAAI,IAAI,CAAC,kBAAkB,CAAC,OAAO,EAAE,cAAc,CAAC,EAAE,CAAC;YACvE,OAAO,IAAI,CAAC;QACd,CAAC;QACD,OAAO,KAAK,CAAC;IACf,CAAC;IAED,MAAM,CAAC,kBAAkB,CAAC,OAAe;QACvC,IAAI,CAAC;YACH,MAAM,EAAE,GAAG,IAAI,mBAAS,CAAC,OAAO,CAAC,CAAC;YAClC,OAAO,EAAE,IAAI,IAAI,CAAC;QACpB,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,OAAO,KAAK,CAAC;QACf,CAAC;IACH,CAAC;IAED,MAAM,CAAC,kBAAkB,CAAC,OAAe;QACvC,MAAM,UAAU,GAAG,qBAAqB,CAAC;QACzC,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,OAAO,CAAC;YAAE,OAAO,KAAK,CAAC;QAE5C,IAAI,OAAO,KAAK,OAAO,CAAC,WAAW,EAAE,EAAE,CAAC;YACtC,OAAO,IAAI,CAAC;QACd,CAAC;QAID,MAAM,oBAAoB,GAAG,OAAO,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;QAC9C,MAAM,WAAW,GAAG,IAAA,mBAAS,EAAC,oBAAoB,CAAC,WAAW,EAAE,CAAC,CAAC;QAElE,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,EAAE,EAAE,CAAC,EAAE,EAAE,CAAC;YAC5B,MAAM,IAAI,GAAG,oBAAoB,CAAC,CAAC,CAAC,CAAC;YACrC,MAAM,QAAQ,GAAG,WAAW,CAAC,CAAC,CAAC,CAAC;YAEhC,IACE,CAAC,QAAQ,CAAC,QAAQ,EAAE,EAAE,CAAC,GAAG,CAAC,IAAI,IAAI,CAAC,WAAW,EAAE,KAAK,IAAI,CAAC;gBAC3D,CAAC,QAAQ,CAAC,QAAQ,EAAE,EAAE,CAAC,IAAI,CAAC,IAAI,IAAI,CAAC,WAAW,EAAE,KAAK,IAAI,CAAC,EAC5D,CAAC;gBACD,OAAO,KAAK,CAAC;YACf,CAAC;QACH,CAAC;QAED,OAAO,IAAI,CAAC;IACd,CAAC;IAQD,MAAM,CAAC,kBAAkB,CACvB,OAAe,EACf,cAA8B;QAE9B,MAAM,OAAO,GACX,cAAc,KAAK,0BAAc,CAAC,OAAO;YACvC,CAAC,CAAC,SAAS,CAAC,QAAQ,CAAC,OAAO;YAC5B,CAAC,CAAC,SAAS,CAAC,QAAQ,CAAC,OAAO,CAAC;QACjC,IAAI,CAAC;YACH,SAAS,CAAC,OAAO,CAAC,cAAc,CAAC,OAAO,EAAE,OAAO,CAAC,CAAC;YACnD,OAAO,IAAI,CAAC;QACd,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,OAAO,KAAK,CAAC;QACf,CAAC;IACH,CAAC;CACF;
|
|
1
|
+
{"version":3,"file":"PublicKeyService.js","sourceRoot":"","sources":["../../../../src/domain/services/PublicKeyService.ts"],"names":[],"mappings":"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"}
|