@bitgo-beta/sdk-coin-rune 1.0.1-alpha.7 → 1.0.1-alpha.9
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 +18 -0
- package/dist/src/lib/utils.d.ts +34 -0
- package/dist/src/lib/utils.d.ts.map +1 -1
- package/dist/src/lib/utils.js +64 -19
- package/dist/src/register.js +2 -2
- package/package.json +7 -7
package/CHANGELOG.md
ADDED
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
# Change Log
|
|
2
|
+
|
|
3
|
+
All notable changes to this project will be documented in this file.
|
|
4
|
+
See [Conventional Commits](https://conventionalcommits.org) for commit guidelines.
|
|
5
|
+
|
|
6
|
+
## [1.1.2](https://github.com/BitGo/BitGoJS/compare/@bitgo/sdk-coin-rune@1.1.1...@bitgo/sdk-coin-rune@1.1.2) (2024-11-08)
|
|
7
|
+
|
|
8
|
+
**Note:** Version bump only for package @bitgo/sdk-coin-rune
|
|
9
|
+
|
|
10
|
+
## [1.1.1](https://github.com/BitGo/BitGoJS/compare/@bitgo/sdk-coin-rune@1.1.0...@bitgo/sdk-coin-rune@1.1.1) (2024-11-07)
|
|
11
|
+
|
|
12
|
+
**Note:** Version bump only for package @bitgo/sdk-coin-rune
|
|
13
|
+
|
|
14
|
+
# 1.1.0 (2024-11-01)
|
|
15
|
+
|
|
16
|
+
### Features
|
|
17
|
+
|
|
18
|
+
- **sdk-coin-rune:** new coin generation ([64775ca](https://github.com/BitGo/BitGoJS/commit/64775caefc425df17f893fe1a5ae26d21adc7b6b))
|
package/dist/src/lib/utils.d.ts
CHANGED
|
@@ -1,4 +1,5 @@
|
|
|
1
1
|
/// <reference types="node" />
|
|
2
|
+
/// <reference types="node" />
|
|
2
3
|
import { Coin } from '@cosmjs/stargate';
|
|
3
4
|
import { CosmosLikeTransaction, CosmosUtils, FeeData } from '@bitgo-beta/abstract-cosmos';
|
|
4
5
|
import { MessageData } from './iface';
|
|
@@ -10,6 +11,39 @@ export declare class RuneUtils extends CosmosUtils {
|
|
|
10
11
|
getSendMessageDataFromDecodedTx(decodedTx: DecodedTxRaw): MessageData[];
|
|
11
12
|
/** @inheritdoc */
|
|
12
13
|
isValidAddress(address: string | Buffer): boolean;
|
|
14
|
+
/**
|
|
15
|
+
* Validates a decoded address in `Buffer` form by encoding it and
|
|
16
|
+
* checking if the encoded version is valid
|
|
17
|
+
*
|
|
18
|
+
* @param address - The decoded address as a `Buffer`.
|
|
19
|
+
* @returns `true` if the encoded address is valid, `false` otherwise.
|
|
20
|
+
*/
|
|
21
|
+
private isValidDecodedAddress;
|
|
22
|
+
/**
|
|
23
|
+
* Validates an encoded address string against network-specific criteria.
|
|
24
|
+
*
|
|
25
|
+
* @param address - The encoded address as a `string`.
|
|
26
|
+
* @returns `true` if the address meets network-specific validation criteria, `false` otherwise.
|
|
27
|
+
*/
|
|
28
|
+
private isValidEncodedAddress;
|
|
29
|
+
/**
|
|
30
|
+
* Encodes a given address `Buffer` into a bech32 string format, based on the current network type.
|
|
31
|
+
* Primarily serves as a utility to convert a `Buffer`-type address to a bech32 encoded string
|
|
32
|
+
*
|
|
33
|
+
* @param address - The address to be encoded, provided as a `Buffer`.
|
|
34
|
+
* @returns A bech32-encoded string representing the address.
|
|
35
|
+
* @throws Error - Throws an error if encoding fails
|
|
36
|
+
*/
|
|
37
|
+
getEncodedAddress(address: Buffer): string;
|
|
38
|
+
/**
|
|
39
|
+
* Decodes a bech32-encoded address string back into a `Buffer`.
|
|
40
|
+
* Primarily serves as a utility to convert a string-type address into its binary representation,
|
|
41
|
+
*
|
|
42
|
+
* @param address - The bech32-encoded address as a `string`.
|
|
43
|
+
* @returns The decoded address as a `Buffer`.
|
|
44
|
+
* @throws Error - Throws an error if decoding fails
|
|
45
|
+
*/
|
|
46
|
+
getDecodedAddress(address: string): Buffer;
|
|
13
47
|
/** @inheritdoc */
|
|
14
48
|
isValidValidatorAddress(address: string): boolean;
|
|
15
49
|
/** @inheritdoc */
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"utils.d.ts","sourceRoot":"","sources":["../../../src/lib/utils.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"utils.d.ts","sourceRoot":"","sources":["../../../src/lib/utils.ts"],"names":[],"mappings":";;AACA,OAAO,EAAE,IAAI,EAAE,MAAM,kBAAkB,CAAC;AAGxC,OAAO,EAAE,qBAAqB,EAAE,WAAW,EAAE,OAAO,EAAE,MAAM,6BAA6B,CAAC;AAC1F,OAAO,EAAE,WAAW,EAAE,MAAM,SAAS,CAAC;AAEtC,OAAO,EAAE,WAAW,EAAE,MAAM,qBAAqB,CAAC;AAClD,OAAO,EAAE,YAAY,EAAE,MAAM,uBAAuB,CAAC;AAIrD,qBAAa,SAAU,SAAQ,WAAW;IACxC,OAAO,CAAC,WAAW,CAAc;gBACrB,WAAW,GAAE,WAAiC;IAK1D,+BAA+B,CAAC,SAAS,EAAE,YAAY,GAAG,WAAW,EAAE;IAcvE,kBAAkB;IAClB,cAAc,CAAC,OAAO,EAAE,MAAM,GAAG,MAAM,GAAG,OAAO;IAajD;;;;;;OAMG;IACH,OAAO,CAAC,qBAAqB;IAK7B;;;;;OAKG;IACH,OAAO,CAAC,qBAAqB;IAO7B;;;;;;;OAOG;IACH,iBAAiB,CAAC,OAAO,EAAE,MAAM,GAAG,MAAM;IAU1C;;;;;;;OAOG;IACH,iBAAiB,CAAC,OAAO,EAAE,MAAM,GAAG,MAAM;IAQ1C,kBAAkB;IAClB,uBAAuB,CAAC,OAAO,EAAE,MAAM,GAAG,OAAO;IAOjD,kBAAkB;IAClB,cAAc,CAAC,MAAM,EAAE,IAAI,GAAG,IAAI;IAelC,6BAA6B,CAAC,QAAQ,EAAE,WAAW,EAAE,GAAG,WAAW,EAAE;IA0BrE,iBAAiB,CACf,QAAQ,EAAE,MAAM,EAChB,QAAQ,EAAE,WAAW,EAAE,EACvB,SAAS,EAAE,OAAO,EAClB,SAAS,CAAC,EAAE,MAAM,EAClB,IAAI,CAAC,EAAE,MAAM,GACZ,qBAAqB;IAaxB,gBAAgB;CAGjB;AAED,QAAA,MAAM,SAAS,WAAkB,CAAC;AAElC,eAAe,SAAS,CAAC"}
|
package/dist/src/lib/utils.js
CHANGED
|
@@ -44,12 +44,8 @@ class RuneUtils extends abstract_cosmos_1.CosmosUtils {
|
|
|
44
44
|
const value = this.registry.decode(message);
|
|
45
45
|
return {
|
|
46
46
|
value: {
|
|
47
|
-
fromAddress: this.
|
|
48
|
-
|
|
49
|
-
: bech32.encode(constants_1.MAINNET_ADDRESS_PREFIX, value.fromAddress),
|
|
50
|
-
toAddress: this.networkType === statics_1.NetworkType.TESTNET
|
|
51
|
-
? bech32.encode(constants_1.TESTNET_ADDRESS_PREFIX, value.toAddress)
|
|
52
|
-
: bech32.encode(constants_1.MAINNET_ADDRESS_PREFIX, value.toAddress),
|
|
47
|
+
fromAddress: this.getEncodedAddress(value.fromAddress),
|
|
48
|
+
toAddress: this.getEncodedAddress(value.toAddress),
|
|
53
49
|
amount: value.amount,
|
|
54
50
|
},
|
|
55
51
|
typeUrl: message.typeUrl,
|
|
@@ -58,23 +54,72 @@ class RuneUtils extends abstract_cosmos_1.CosmosUtils {
|
|
|
58
54
|
}
|
|
59
55
|
/** @inheritdoc */
|
|
60
56
|
isValidAddress(address) {
|
|
61
|
-
if (address === undefined) {
|
|
57
|
+
if (address === undefined || address === null) {
|
|
62
58
|
return false;
|
|
63
59
|
}
|
|
64
|
-
if (
|
|
65
|
-
|
|
60
|
+
if (address instanceof Uint8Array) {
|
|
61
|
+
return this.isValidDecodedAddress(address);
|
|
62
|
+
}
|
|
63
|
+
if (typeof address === 'string') {
|
|
64
|
+
return this.isValidEncodedAddress(address);
|
|
65
|
+
}
|
|
66
|
+
return false;
|
|
67
|
+
}
|
|
68
|
+
/**
|
|
69
|
+
* Validates a decoded address in `Buffer` form by encoding it and
|
|
70
|
+
* checking if the encoded version is valid
|
|
71
|
+
*
|
|
72
|
+
* @param address - The decoded address as a `Buffer`.
|
|
73
|
+
* @returns `true` if the encoded address is valid, `false` otherwise.
|
|
74
|
+
*/
|
|
75
|
+
isValidDecodedAddress(address) {
|
|
76
|
+
const encodedAddress = this.getEncodedAddress(address);
|
|
77
|
+
return this.isValidEncodedAddress(encodedAddress);
|
|
78
|
+
}
|
|
79
|
+
/**
|
|
80
|
+
* Validates an encoded address string against network-specific criteria.
|
|
81
|
+
*
|
|
82
|
+
* @param address - The encoded address as a `string`.
|
|
83
|
+
* @returns `true` if the address meets network-specific validation criteria, `false` otherwise.
|
|
84
|
+
*/
|
|
85
|
+
isValidEncodedAddress(address) {
|
|
86
|
+
if (this.networkType === statics_1.NetworkType.TESTNET) {
|
|
87
|
+
return this.isValidCosmosLikeAddressWithMemoId(address, constants.testnetAccountAddressRegex);
|
|
88
|
+
}
|
|
89
|
+
return this.isValidCosmosLikeAddressWithMemoId(address, constants.mainnetAccountAddressRegex);
|
|
90
|
+
}
|
|
91
|
+
/**
|
|
92
|
+
* Encodes a given address `Buffer` into a bech32 string format, based on the current network type.
|
|
93
|
+
* Primarily serves as a utility to convert a `Buffer`-type address to a bech32 encoded string
|
|
94
|
+
*
|
|
95
|
+
* @param address - The address to be encoded, provided as a `Buffer`.
|
|
96
|
+
* @returns A bech32-encoded string representing the address.
|
|
97
|
+
* @throws Error - Throws an error if encoding fails
|
|
98
|
+
*/
|
|
99
|
+
getEncodedAddress(address) {
|
|
100
|
+
try {
|
|
101
|
+
return this.networkType === statics_1.NetworkType.TESTNET
|
|
66
102
|
? bech32.encode(constants_1.TESTNET_ADDRESS_PREFIX, address)
|
|
67
103
|
: bech32.encode(constants_1.MAINNET_ADDRESS_PREFIX, address);
|
|
68
|
-
if (this.networkType === statics_1.NetworkType.TESTNET) {
|
|
69
|
-
return this.isValidCosmosLikeAddressWithMemoId(encodedAddress, constants.testnetAccountAddressRegex);
|
|
70
|
-
}
|
|
71
|
-
return this.isValidCosmosLikeAddressWithMemoId(encodedAddress, constants.mainnetAccountAddressRegex);
|
|
72
104
|
}
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
105
|
+
catch (error) {
|
|
106
|
+
throw new Error(`Failed to encode address: ${error instanceof Error ? error.message : String(error)}`);
|
|
107
|
+
}
|
|
108
|
+
}
|
|
109
|
+
/**
|
|
110
|
+
* Decodes a bech32-encoded address string back into a `Buffer`.
|
|
111
|
+
* Primarily serves as a utility to convert a string-type address into its binary representation,
|
|
112
|
+
*
|
|
113
|
+
* @param address - The bech32-encoded address as a `string`.
|
|
114
|
+
* @returns The decoded address as a `Buffer`.
|
|
115
|
+
* @throws Error - Throws an error if decoding fails
|
|
116
|
+
*/
|
|
117
|
+
getDecodedAddress(address) {
|
|
118
|
+
try {
|
|
119
|
+
return bech32.decode(address).data;
|
|
120
|
+
}
|
|
121
|
+
catch (error) {
|
|
122
|
+
throw new Error(`Failed to decode address: ${error instanceof Error ? error.message : String(error)}`);
|
|
78
123
|
}
|
|
79
124
|
}
|
|
80
125
|
/** @inheritdoc */
|
|
@@ -136,4 +181,4 @@ class RuneUtils extends abstract_cosmos_1.CosmosUtils {
|
|
|
136
181
|
exports.RuneUtils = RuneUtils;
|
|
137
182
|
const runeUtils = new RuneUtils();
|
|
138
183
|
exports.default = runeUtils;
|
|
139
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"utils.js","sourceRoot":"","sources":["../../../src/lib/utils.ts"],"names":[],"mappings":"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","sourcesContent":["import { InvalidTransactionError } from '@bitgo-beta/sdk-core';\nimport { Coin } from '@cosmjs/stargate';\nimport BigNumber from 'bignumber.js';\n\nimport { CosmosLikeTransaction, CosmosUtils, FeeData } from '@bitgo-beta/abstract-cosmos';\nimport { MessageData } from './iface';\nimport * as constants from './constants';\nimport { NetworkType } from '@bitgo-beta/statics';\nimport { DecodedTxRaw } from '@cosmjs/proto-signing';\nimport { MAINNET_ADDRESS_PREFIX, TESTNET_ADDRESS_PREFIX } from './constants';\nconst bech32 = require('bech32-buffer');\n\nexport class RuneUtils extends CosmosUtils {\n  private networkType: NetworkType;\n  constructor(networkType: NetworkType = NetworkType.MAINNET) {\n    super();\n    this.networkType = networkType;\n  }\n\n  getSendMessageDataFromDecodedTx(decodedTx: DecodedTxRaw): MessageData[] {\n    return decodedTx.body.messages.map((message) => {\n      const value = this.registry.decode(message);\n      return {\n        value: {\n          fromAddress:\n            this.networkType === NetworkType.TESTNET\n              ? bech32.encode(TESTNET_ADDRESS_PREFIX, value.fromAddress)\n              : bech32.encode(MAINNET_ADDRESS_PREFIX, value.fromAddress),\n          toAddress:\n            this.networkType === NetworkType.TESTNET\n              ? bech32.encode(TESTNET_ADDRESS_PREFIX, value.toAddress)\n              : bech32.encode(MAINNET_ADDRESS_PREFIX, value.toAddress),\n          amount: value.amount,\n        },\n        typeUrl: message.typeUrl,\n      };\n    });\n  }\n\n  /** @inheritdoc */\n  isValidAddress(address: string | Buffer): boolean {\n    if (address === undefined) {\n      return false;\n    }\n    if (typeof address !== 'string') {\n      const encodedAddress =\n        this.networkType === NetworkType.TESTNET\n          ? bech32.encode(TESTNET_ADDRESS_PREFIX, address)\n          : bech32.encode(MAINNET_ADDRESS_PREFIX, address);\n      if (this.networkType === NetworkType.TESTNET) {\n        return this.isValidCosmosLikeAddressWithMemoId(encodedAddress, constants.testnetAccountAddressRegex);\n      }\n      return this.isValidCosmosLikeAddressWithMemoId(encodedAddress, constants.mainnetAccountAddressRegex);\n    } else {\n      if (this.networkType === NetworkType.TESTNET) {\n        return this.isValidCosmosLikeAddressWithMemoId(address, constants.testnetAccountAddressRegex);\n      }\n      return this.isValidCosmosLikeAddressWithMemoId(address, constants.mainnetAccountAddressRegex);\n    }\n  }\n\n  /** @inheritdoc */\n  isValidValidatorAddress(address: string): boolean {\n    if (this.networkType === NetworkType.TESTNET) {\n      return this.isValidBech32AddressMatchingRegex(address, constants.testnetValidatorAddressRegex);\n    }\n    return this.isValidBech32AddressMatchingRegex(address, constants.mainnetValidatorAddressRegex);\n  }\n\n  /** @inheritdoc */\n  validateAmount(amount: Coin): void {\n    const amountBig = BigNumber(amount.amount);\n    if (amountBig.isLessThanOrEqualTo(0)) {\n      throw new InvalidTransactionError('transactionBuilder: validateAmount: Invalid amount: ' + amount.amount);\n    }\n    if (\n      (this.networkType === NetworkType.TESTNET &&\n        !constants.testnetValidDenoms.find((denom) => denom === amount.denom)) ||\n      (this.networkType === NetworkType.MAINNET &&\n        !constants.mainnetValidDenoms.find((denom) => denom === amount.denom))\n    ) {\n      throw new InvalidTransactionError('transactionBuilder: validateAmount: Invalid denom: ' + amount.denom);\n    }\n  }\n\n  convertMessageAddressToBuffer(messages: MessageData[]): MessageData[] {\n    return messages.map((message) => {\n      if ('fromAddress' in message.value && 'toAddress' in message.value) {\n        const sendMessage = message.value;\n\n        const decodedFrom =\n          typeof sendMessage.fromAddress === 'string'\n            ? bech32.decode(sendMessage.fromAddress).data\n            : sendMessage.fromAddress;\n        const decodedTo =\n          typeof sendMessage.toAddress === 'string' ? bech32.decode(sendMessage.toAddress).data : sendMessage.toAddress;\n\n        return {\n          ...message,\n          value: {\n            ...sendMessage,\n            fromAddress: decodedFrom,\n            toAddress: decodedTo,\n          },\n        };\n      }\n\n      return message;\n    });\n  }\n\n  createTransaction(\n    sequence: number,\n    messages: MessageData[],\n    gasBudget: FeeData,\n    publicKey?: string,\n    memo?: string\n  ): CosmosLikeTransaction {\n    messages = this.convertMessageAddressToBuffer(messages);\n    const cosmosLikeTxn = {\n      sequence: sequence,\n      sendMessages: messages,\n      gasBudget: gasBudget,\n      publicKey: publicKey,\n      memo: memo,\n    };\n    this.validateTransaction(cosmosLikeTxn);\n    return cosmosLikeTxn;\n  }\n\n  getNetworkPrefix() {\n    return this.networkType === NetworkType.TESTNET ? TESTNET_ADDRESS_PREFIX : MAINNET_ADDRESS_PREFIX;\n  }\n}\n\nconst runeUtils = new RuneUtils();\n\nexport default runeUtils;\n"]}
|
|
184
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"utils.js","sourceRoot":"","sources":["../../../src/lib/utils.ts"],"names":[],"mappings":"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","sourcesContent":["import { InvalidTransactionError } from '@bitgo-beta/sdk-core';\nimport { Coin } from '@cosmjs/stargate';\nimport BigNumber from 'bignumber.js';\n\nimport { CosmosLikeTransaction, CosmosUtils, FeeData } from '@bitgo-beta/abstract-cosmos';\nimport { MessageData } from './iface';\nimport * as constants from './constants';\nimport { NetworkType } from '@bitgo-beta/statics';\nimport { DecodedTxRaw } from '@cosmjs/proto-signing';\nimport { MAINNET_ADDRESS_PREFIX, TESTNET_ADDRESS_PREFIX } from './constants';\nconst bech32 = require('bech32-buffer');\n\nexport class RuneUtils extends CosmosUtils {\n  private networkType: NetworkType;\n  constructor(networkType: NetworkType = NetworkType.MAINNET) {\n    super();\n    this.networkType = networkType;\n  }\n\n  getSendMessageDataFromDecodedTx(decodedTx: DecodedTxRaw): MessageData[] {\n    return decodedTx.body.messages.map((message) => {\n      const value = this.registry.decode(message);\n      return {\n        value: {\n          fromAddress: this.getEncodedAddress(value.fromAddress),\n          toAddress: this.getEncodedAddress(value.toAddress),\n          amount: value.amount,\n        },\n        typeUrl: message.typeUrl,\n      };\n    });\n  }\n\n  /** @inheritdoc */\n  isValidAddress(address: string | Buffer): boolean {\n    if (address === undefined || address === null) {\n      return false;\n    }\n    if (address instanceof Uint8Array) {\n      return this.isValidDecodedAddress(address);\n    }\n    if (typeof address === 'string') {\n      return this.isValidEncodedAddress(address);\n    }\n    return false;\n  }\n\n  /**\n   * Validates a decoded address in `Buffer` form by encoding it and\n   * checking if the encoded version is valid\n   *\n   * @param address - The decoded address as a `Buffer`.\n   * @returns `true` if the encoded address is valid, `false` otherwise.\n   */\n  private isValidDecodedAddress(address: Buffer): boolean {\n    const encodedAddress = this.getEncodedAddress(address);\n    return this.isValidEncodedAddress(encodedAddress);\n  }\n\n  /**\n   * Validates an encoded address string against network-specific criteria.\n   *\n   * @param address - The encoded address as a `string`.\n   * @returns `true` if the address meets network-specific validation criteria, `false` otherwise.\n   */\n  private isValidEncodedAddress(address: string): boolean {\n    if (this.networkType === NetworkType.TESTNET) {\n      return this.isValidCosmosLikeAddressWithMemoId(address, constants.testnetAccountAddressRegex);\n    }\n    return this.isValidCosmosLikeAddressWithMemoId(address, constants.mainnetAccountAddressRegex);\n  }\n\n  /**\n   * Encodes a given address `Buffer` into a bech32 string format, based on the current network type.\n   * Primarily serves as a utility to convert a `Buffer`-type address to a bech32 encoded string\n   *\n   * @param address - The address to be encoded, provided as a `Buffer`.\n   * @returns A bech32-encoded string representing the address.\n   * @throws Error - Throws an error if encoding fails\n   */\n  getEncodedAddress(address: Buffer): string {\n    try {\n      return this.networkType === NetworkType.TESTNET\n        ? bech32.encode(TESTNET_ADDRESS_PREFIX, address)\n        : bech32.encode(MAINNET_ADDRESS_PREFIX, address);\n    } catch (error) {\n      throw new Error(`Failed to encode address: ${error instanceof Error ? error.message : String(error)}`);\n    }\n  }\n\n  /**\n   * Decodes a bech32-encoded address string back into a `Buffer`.\n   * Primarily serves as a utility to convert a string-type address into its binary representation,\n   *\n   * @param address - The bech32-encoded address as a `string`.\n   * @returns The decoded address as a `Buffer`.\n   * @throws Error - Throws an error if decoding fails\n   */\n  getDecodedAddress(address: string): Buffer {\n    try {\n      return bech32.decode(address).data;\n    } catch (error) {\n      throw new Error(`Failed to decode address: ${error instanceof Error ? error.message : String(error)}`);\n    }\n  }\n\n  /** @inheritdoc */\n  isValidValidatorAddress(address: string): boolean {\n    if (this.networkType === NetworkType.TESTNET) {\n      return this.isValidBech32AddressMatchingRegex(address, constants.testnetValidatorAddressRegex);\n    }\n    return this.isValidBech32AddressMatchingRegex(address, constants.mainnetValidatorAddressRegex);\n  }\n\n  /** @inheritdoc */\n  validateAmount(amount: Coin): void {\n    const amountBig = BigNumber(amount.amount);\n    if (amountBig.isLessThanOrEqualTo(0)) {\n      throw new InvalidTransactionError('transactionBuilder: validateAmount: Invalid amount: ' + amount.amount);\n    }\n    if (\n      (this.networkType === NetworkType.TESTNET &&\n        !constants.testnetValidDenoms.find((denom) => denom === amount.denom)) ||\n      (this.networkType === NetworkType.MAINNET &&\n        !constants.mainnetValidDenoms.find((denom) => denom === amount.denom))\n    ) {\n      throw new InvalidTransactionError('transactionBuilder: validateAmount: Invalid denom: ' + amount.denom);\n    }\n  }\n\n  convertMessageAddressToBuffer(messages: MessageData[]): MessageData[] {\n    return messages.map((message) => {\n      if ('fromAddress' in message.value && 'toAddress' in message.value) {\n        const sendMessage = message.value;\n\n        const decodedFrom =\n          typeof sendMessage.fromAddress === 'string'\n            ? bech32.decode(sendMessage.fromAddress).data\n            : sendMessage.fromAddress;\n        const decodedTo =\n          typeof sendMessage.toAddress === 'string' ? bech32.decode(sendMessage.toAddress).data : sendMessage.toAddress;\n\n        return {\n          ...message,\n          value: {\n            ...sendMessage,\n            fromAddress: decodedFrom,\n            toAddress: decodedTo,\n          },\n        };\n      }\n\n      return message;\n    });\n  }\n\n  createTransaction(\n    sequence: number,\n    messages: MessageData[],\n    gasBudget: FeeData,\n    publicKey?: string,\n    memo?: string\n  ): CosmosLikeTransaction {\n    messages = this.convertMessageAddressToBuffer(messages);\n    const cosmosLikeTxn = {\n      sequence: sequence,\n      sendMessages: messages,\n      gasBudget: gasBudget,\n      publicKey: publicKey,\n      memo: memo,\n    };\n    this.validateTransaction(cosmosLikeTxn);\n    return cosmosLikeTxn;\n  }\n\n  getNetworkPrefix() {\n    return this.networkType === NetworkType.TESTNET ? TESTNET_ADDRESS_PREFIX : MAINNET_ADDRESS_PREFIX;\n  }\n}\n\nconst runeUtils = new RuneUtils();\n\nexport default runeUtils;\n"]}
|
package/dist/src/register.js
CHANGED
|
@@ -5,7 +5,7 @@ const rune_1 = require("./rune");
|
|
|
5
5
|
const trune_1 = require("./trune");
|
|
6
6
|
const register = (sdk) => {
|
|
7
7
|
sdk.register('thorchain:rune', rune_1.Rune.createInstance);
|
|
8
|
-
sdk.register('
|
|
8
|
+
sdk.register('tthorchain:rune', trune_1.Trune.createInstance);
|
|
9
9
|
};
|
|
10
10
|
exports.register = register;
|
|
11
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
11
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVnaXN0ZXIuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvcmVnaXN0ZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBQ0EsaUNBQThCO0FBQzlCLG1DQUFnQztBQUV6QixNQUFNLFFBQVEsR0FBRyxDQUFDLEdBQWMsRUFBUSxFQUFFO0lBQy9DLEdBQUcsQ0FBQyxRQUFRLENBQUMsZ0JBQWdCLEVBQUUsV0FBSSxDQUFDLGNBQWMsQ0FBQyxDQUFDO0lBQ3BELEdBQUcsQ0FBQyxRQUFRLENBQUMsaUJBQWlCLEVBQUUsYUFBSyxDQUFDLGNBQWMsQ0FBQyxDQUFDO0FBQ3hELENBQUMsQ0FBQztBQUhXLFFBQUEsUUFBUSxZQUduQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEJpdEdvQmFzZSB9IGZyb20gJ0BiaXRnby1iZXRhL3Nkay1jb3JlJztcbmltcG9ydCB7IFJ1bmUgfSBmcm9tICcuL3J1bmUnO1xuaW1wb3J0IHsgVHJ1bmUgfSBmcm9tICcuL3RydW5lJztcblxuZXhwb3J0IGNvbnN0IHJlZ2lzdGVyID0gKHNkazogQml0R29CYXNlKTogdm9pZCA9PiB7XG4gIHNkay5yZWdpc3RlcigndGhvcmNoYWluOnJ1bmUnLCBSdW5lLmNyZWF0ZUluc3RhbmNlKTtcbiAgc2RrLnJlZ2lzdGVyKCd0dGhvcmNoYWluOnJ1bmUnLCBUcnVuZS5jcmVhdGVJbnN0YW5jZSk7XG59O1xuIl19
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@bitgo-beta/sdk-coin-rune",
|
|
3
|
-
"version": "1.0.1-alpha.
|
|
3
|
+
"version": "1.0.1-alpha.9",
|
|
4
4
|
"description": "BitGo SDK coin library for Thorchain",
|
|
5
5
|
"main": "./dist/src/index.js",
|
|
6
6
|
"types": "./dist/src/index.d.ts",
|
|
@@ -40,9 +40,9 @@
|
|
|
40
40
|
]
|
|
41
41
|
},
|
|
42
42
|
"dependencies": {
|
|
43
|
-
"@bitgo-beta/abstract-cosmos": "1.0.0-alpha.
|
|
44
|
-
"@bitgo-beta/sdk-core": "2.4.1-alpha.
|
|
45
|
-
"@bitgo-beta/statics": "10.0.1-alpha.
|
|
43
|
+
"@bitgo-beta/abstract-cosmos": "1.0.0-alpha.180",
|
|
44
|
+
"@bitgo-beta/sdk-core": "2.4.1-alpha.231",
|
|
45
|
+
"@bitgo-beta/statics": "10.0.1-alpha.231",
|
|
46
46
|
"@cosmjs/amino": "^0.29.5",
|
|
47
47
|
"@cosmjs/encoding": "^0.29.5",
|
|
48
48
|
"@cosmjs/proto-signing": "^0.29.5",
|
|
@@ -52,8 +52,8 @@
|
|
|
52
52
|
"lodash": "^4.17.21"
|
|
53
53
|
},
|
|
54
54
|
"devDependencies": {
|
|
55
|
-
"@bitgo-beta/sdk-api": "1.6.1-alpha.
|
|
56
|
-
"@bitgo-beta/sdk-test": "^8.0.
|
|
55
|
+
"@bitgo-beta/sdk-api": "1.6.1-alpha.231",
|
|
56
|
+
"@bitgo-beta/sdk-test": "^8.0.50"
|
|
57
57
|
},
|
|
58
|
-
"gitHead": "
|
|
58
|
+
"gitHead": "a9cbef1b9e8e4e325ba9609f3f773e289ce943e3"
|
|
59
59
|
}
|