@cityofzion/bs-neo3 1.0.3 → 1.1.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/dist/BSNeo3.d.ts CHANGED
@@ -1,8 +1,8 @@
1
1
  import { BlockchainDataService, BlockchainService, BSClaimable, Account, ExchangeDataService, BDSClaimable, Token, BSWithNameService, Network, TransferParam, BSCalculableFee, NftDataService, BSWithNft, AccountWithDerivationPath, BSWithExplorerService, ExplorerService, BSWithLedger } from '@cityofzion/blockchain-service';
2
2
  import Transport from '@ledgerhq/hw-transport';
3
- import { AvailableNetworkIds } from './BSNeo3Helper';
3
+ import { BSNeo3NetworkId } from './BSNeo3Helper';
4
4
  import { NeonDappKitLedgerServiceNeo3 } from './NeonDappKitLedgerServiceNeo3';
5
- export declare class BSNeo3<BSCustomName extends string = string> implements BlockchainService<BSCustomName, AvailableNetworkIds>, BSClaimable, BSWithNameService, BSCalculableFee, BSWithNft, BSWithExplorerService, BSWithLedger {
5
+ export declare class BSNeo3<BSCustomName extends string = string> implements BlockchainService<BSCustomName, BSNeo3NetworkId>, BSClaimable, BSWithNameService, BSCalculableFee, BSWithNft, BSWithExplorerService, BSWithLedger {
6
6
  #private;
7
7
  blockchainName: BSCustomName;
8
8
  derivationPath: string;
@@ -15,9 +15,9 @@ export declare class BSNeo3<BSCustomName extends string = string> implements Blo
15
15
  ledgerService: NeonDappKitLedgerServiceNeo3;
16
16
  exchangeDataService: ExchangeDataService;
17
17
  explorerService: ExplorerService;
18
- network: Network<AvailableNetworkIds>;
19
- constructor(blockchainName: BSCustomName, network?: Network<AvailableNetworkIds>, getLedgerTransport?: (account: Account) => Promise<Transport>);
20
- setNetwork(network: Network<AvailableNetworkIds>): void;
18
+ network: Network<BSNeo3NetworkId>;
19
+ constructor(blockchainName: BSCustomName, network?: Network<BSNeo3NetworkId>, getLedgerTransport?: (account: Account) => Promise<Transport>);
20
+ setNetwork(network: Network<BSNeo3NetworkId>): void;
21
21
  validateAddress(address: string): boolean;
22
22
  validateEncrypted(encryptedKey: string): boolean;
23
23
  validateKey(key: string): boolean;
package/dist/BSNeo3.js CHANGED
@@ -22,7 +22,6 @@ const bs_asteroid_sdk_1 = require("@cityofzion/bs-asteroid-sdk");
22
22
  const BSNeo3Helper_1 = require("./BSNeo3Helper");
23
23
  const NeonDappKitLedgerServiceNeo3_1 = require("./NeonDappKitLedgerServiceNeo3");
24
24
  const DoraBDSNeo3_1 = require("./DoraBDSNeo3");
25
- const RpcBDSNeo3_1 = require("./RpcBDSNeo3");
26
25
  const FlamingoEDSNeo3_1 = require("./FlamingoEDSNeo3");
27
26
  const GhostMarketNDSNeo3_1 = require("./GhostMarketNDSNeo3");
28
27
  const DoraESNeo3_1 = require("./DoraESNeo3");
@@ -38,15 +37,10 @@ class BSNeo3 {
38
37
  setNetwork(network) {
39
38
  __classPrivateFieldGet(this, _BSNeo3_instances, "m", _BSNeo3_setTokens).call(this, network);
40
39
  this.network = network;
41
- if (DoraBDSNeo3_1.DoraBDSNeo3.SUPPORTED_NETWORKS.includes(network.id)) {
42
- this.blockchainDataService = new DoraBDSNeo3_1.DoraBDSNeo3(network, this.feeToken, this.claimToken, this.tokens);
43
- }
44
- else {
45
- this.blockchainDataService = new RpcBDSNeo3_1.RPCBDSNeo3(network, this.feeToken, this.claimToken, this.tokens);
46
- }
47
- this.exchangeDataService = new FlamingoEDSNeo3_1.FlamingoEDSNeo3(network.id, this.tokens);
40
+ this.blockchainDataService = new DoraBDSNeo3_1.DoraBDSNeo3(network, this.feeToken, this.claimToken, this.tokens);
41
+ this.exchangeDataService = new FlamingoEDSNeo3_1.FlamingoEDSNeo3(network);
48
42
  this.nftDataService = new GhostMarketNDSNeo3_1.GhostMarketNDSNeo3(network);
49
- this.explorerService = new DoraESNeo3_1.DoraESNeo3(network.id);
43
+ this.explorerService = new DoraESNeo3_1.DoraESNeo3(network);
50
44
  }
51
45
  validateAddress(address) {
52
46
  return neon_js_1.wallet.isAddress(address, 53);
@@ -1,21 +1,23 @@
1
- import { Network } from '@cityofzion/blockchain-service';
2
- export type AvailableNetworkIds = 'mainnet' | 'testnet' | (string & {});
1
+ import { Network, NetworkId } from '@cityofzion/blockchain-service';
2
+ export type BSNeo3NetworkId = NetworkId<'mainnet' | 'testnet'>;
3
3
  export declare class BSNeo3Helper {
4
4
  #private;
5
- static MAINNET_NETWORK_IDS: AvailableNetworkIds[];
6
- static TESTNET_NETWORK_IDS: AvailableNetworkIds[];
7
- static ALL_NETWORK_IDS: AvailableNetworkIds[];
8
- static MAINNET_NETWORKS: Network<AvailableNetworkIds>[];
9
- static TESTNET_NETWORKS: Network<AvailableNetworkIds>[];
10
- static ALL_NETWORKS: Network<AvailableNetworkIds>[];
11
- static DEFAULT_NETWORK: Network<AvailableNetworkIds>;
5
+ static MAINNET_NETWORK_IDS: BSNeo3NetworkId[];
6
+ static TESTNET_NETWORK_IDS: BSNeo3NetworkId[];
7
+ static ALL_NETWORK_IDS: BSNeo3NetworkId[];
8
+ static MAINNET_NETWORKS: Network<BSNeo3NetworkId>[];
9
+ static TESTNET_NETWORKS: Network<BSNeo3NetworkId>[];
10
+ static ALL_NETWORKS: Network<BSNeo3NetworkId>[];
11
+ static DEFAULT_NETWORK: Network<BSNeo3NetworkId>;
12
12
  static NEO_NS_HASH: string;
13
13
  static DERIVATION_PATH: string;
14
- static getTokens(network: Network<AvailableNetworkIds>): {
14
+ static getTokens(network: Network<BSNeo3NetworkId>): {
15
15
  symbol: string;
16
16
  name: string;
17
17
  hash: string;
18
18
  decimals: number;
19
19
  }[];
20
- static getRpcList(network: Network<AvailableNetworkIds>): string[];
20
+ static getRpcList(network: Network<BSNeo3NetworkId>): string[];
21
+ static isMainnet(network: Network<BSNeo3NetworkId>): boolean;
22
+ static isCustomNet(network: Network<BSNeo3NetworkId>): boolean;
21
23
  }
@@ -22,6 +22,12 @@ class BSNeo3Helper {
22
22
  var _b;
23
23
  return (_b = __classPrivateFieldGet(this, _a, "f", _BSNeo3Helper_RPC_LIST_BY_NETWORK_ID)[network.id]) !== null && _b !== void 0 ? _b : [];
24
24
  }
25
+ static isMainnet(network) {
26
+ return this.MAINNET_NETWORK_IDS.includes(network.id);
27
+ }
28
+ static isCustomNet(network) {
29
+ return !this.ALL_NETWORK_IDS.includes(network.id);
30
+ }
25
31
  }
26
32
  exports.BSNeo3Helper = BSNeo3Helper;
27
33
  _a = BSNeo3Helper;
@@ -1,9 +1,8 @@
1
1
  import { BalanceResponse, ContractResponse, TransactionsByAddressParams, TransactionsByAddressResponse, TransactionResponse, Network, Token } from '@cityofzion/blockchain-service';
2
2
  import { RPCBDSNeo3 } from './RpcBDSNeo3';
3
- import { AvailableNetworkIds } from './BSNeo3Helper';
3
+ import { BSNeo3NetworkId } from './BSNeo3Helper';
4
4
  export declare class DoraBDSNeo3 extends RPCBDSNeo3 {
5
- static SUPPORTED_NETWORKS: AvailableNetworkIds[];
6
- constructor(network: Network<AvailableNetworkIds>, feeToken: Token, claimToken: Token, tokens: Token[]);
5
+ constructor(network: Network<BSNeo3NetworkId>, feeToken: Token, claimToken: Token, tokens: Token[]);
7
6
  getTransaction(hash: string): Promise<TransactionResponse>;
8
7
  getTransactionsByAddress({ address, page, }: TransactionsByAddressParams): Promise<TransactionsByAddressResponse>;
9
8
  getContract(contractHash: string): Promise<ContractResponse>;
@@ -13,6 +13,7 @@ exports.DoraBDSNeo3 = void 0;
13
13
  const neon_js_1 = require("@cityofzion/neon-js");
14
14
  const api_1 = require("@cityofzion/dora-ts/dist/api");
15
15
  const RpcBDSNeo3_1 = require("./RpcBDSNeo3");
16
+ const BSNeo3Helper_1 = require("./BSNeo3Helper");
16
17
  const NeoRest = new api_1.NeoRESTApi({
17
18
  doraUrl: 'https://dora.coz.io',
18
19
  endpoint: '/api/v2/neo3',
@@ -22,8 +23,14 @@ class DoraBDSNeo3 extends RpcBDSNeo3_1.RPCBDSNeo3 {
22
23
  super(network, feeToken, claimToken, tokens);
23
24
  }
24
25
  getTransaction(hash) {
26
+ const _super = Object.create(null, {
27
+ getTransaction: { get: () => super.getTransaction }
28
+ });
25
29
  var _a, _b;
26
30
  return __awaiter(this, void 0, void 0, function* () {
31
+ if (BSNeo3Helper_1.BSNeo3Helper.isCustomNet(this._network)) {
32
+ return yield _super.getTransaction.call(this, hash);
33
+ }
27
34
  try {
28
35
  const data = yield NeoRest.transaction(hash, this._network.id);
29
36
  return {
@@ -43,7 +50,13 @@ class DoraBDSNeo3 extends RpcBDSNeo3_1.RPCBDSNeo3 {
43
50
  });
44
51
  }
45
52
  getTransactionsByAddress({ address, page = 1, }) {
53
+ const _super = Object.create(null, {
54
+ getTransactionsByAddress: { get: () => super.getTransactionsByAddress }
55
+ });
46
56
  return __awaiter(this, void 0, void 0, function* () {
57
+ if (BSNeo3Helper_1.BSNeo3Helper.isCustomNet(this._network)) {
58
+ return yield _super.getTransactionsByAddress.call(this, { address, page });
59
+ }
47
60
  const data = yield NeoRest.addressTXFull(address, page, this._network.id);
48
61
  const promises = data.items.map((item) => __awaiter(this, void 0, void 0, function* () {
49
62
  var _a, _b;
@@ -106,8 +119,14 @@ class DoraBDSNeo3 extends RpcBDSNeo3_1.RPCBDSNeo3 {
106
119
  });
107
120
  }
108
121
  getContract(contractHash) {
122
+ const _super = Object.create(null, {
123
+ getContract: { get: () => super.getContract }
124
+ });
109
125
  var _a, _b;
110
126
  return __awaiter(this, void 0, void 0, function* () {
127
+ if (BSNeo3Helper_1.BSNeo3Helper.isCustomNet(this._network)) {
128
+ return yield _super.getContract.call(this, contractHash);
129
+ }
111
130
  try {
112
131
  const data = yield NeoRest.contract(contractHash, this._network.id);
113
132
  return {
@@ -122,7 +141,13 @@ class DoraBDSNeo3 extends RpcBDSNeo3_1.RPCBDSNeo3 {
122
141
  });
123
142
  }
124
143
  getTokenInfo(tokenHash) {
144
+ const _super = Object.create(null, {
145
+ getTokenInfo: { get: () => super.getTokenInfo }
146
+ });
125
147
  return __awaiter(this, void 0, void 0, function* () {
148
+ if (BSNeo3Helper_1.BSNeo3Helper.isCustomNet(this._network)) {
149
+ return yield _super.getTokenInfo.call(this, tokenHash);
150
+ }
126
151
  const localToken = this._tokens.find(token => token.hash === tokenHash);
127
152
  if (localToken)
128
153
  return localToken;
@@ -146,7 +171,13 @@ class DoraBDSNeo3 extends RpcBDSNeo3_1.RPCBDSNeo3 {
146
171
  });
147
172
  }
148
173
  getBalance(address) {
174
+ const _super = Object.create(null, {
175
+ getBalance: { get: () => super.getBalance }
176
+ });
149
177
  return __awaiter(this, void 0, void 0, function* () {
178
+ if (BSNeo3Helper_1.BSNeo3Helper.isCustomNet(this._network)) {
179
+ return yield _super.getBalance.call(this, address);
180
+ }
150
181
  const response = yield NeoRest.balance(address, this._network.id);
151
182
  const promises = response.map((balance) => __awaiter(this, void 0, void 0, function* () {
152
183
  try {
@@ -171,4 +202,3 @@ class DoraBDSNeo3 extends RpcBDSNeo3_1.RPCBDSNeo3 {
171
202
  }
172
203
  }
173
204
  exports.DoraBDSNeo3 = DoraBDSNeo3;
174
- DoraBDSNeo3.SUPPORTED_NETWORKS = ['mainnet', 'testnet'];
@@ -1,8 +1,8 @@
1
- import { ExplorerService, BuildNftUrlParams } from '@cityofzion/blockchain-service';
2
- import { AvailableNetworkIds } from './BSNeo3Helper';
1
+ import { ExplorerService, BuildNftUrlParams, Network } from '@cityofzion/blockchain-service';
2
+ import { BSNeo3NetworkId } from './BSNeo3Helper';
3
3
  export declare class DoraESNeo3 implements ExplorerService {
4
4
  #private;
5
- constructor(networkType: AvailableNetworkIds);
5
+ constructor(network: Network<BSNeo3NetworkId>);
6
6
  buildTransactionUrl(hash: string): string;
7
7
  buildContractUrl(contractHash: string): string;
8
8
  buildNftUrl({ contractHash, tokenId }: BuildNftUrlParams): string;
@@ -10,30 +10,30 @@ var __classPrivateFieldGet = (this && this.__classPrivateFieldGet) || function (
10
10
  if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError("Cannot read private member from an object whose class did not declare it");
11
11
  return kind === "m" ? f : kind === "a" ? f.call(receiver) : f ? f.value : state.get(receiver);
12
12
  };
13
- var _DoraESNeo3_networkId;
13
+ var _DoraESNeo3_network;
14
14
  Object.defineProperty(exports, "__esModule", { value: true });
15
15
  exports.DoraESNeo3 = void 0;
16
- const DoraBDSNeo3_1 = require("./DoraBDSNeo3");
16
+ const BSNeo3Helper_1 = require("./BSNeo3Helper");
17
17
  class DoraESNeo3 {
18
- constructor(networkType) {
19
- _DoraESNeo3_networkId.set(this, void 0);
20
- __classPrivateFieldSet(this, _DoraESNeo3_networkId, networkType, "f");
18
+ constructor(network) {
19
+ _DoraESNeo3_network.set(this, void 0);
20
+ __classPrivateFieldSet(this, _DoraESNeo3_network, network, "f");
21
21
  }
22
22
  buildTransactionUrl(hash) {
23
- if (!DoraBDSNeo3_1.DoraBDSNeo3.SUPPORTED_NETWORKS.includes(__classPrivateFieldGet(this, _DoraESNeo3_networkId, "f")))
24
- throw new Error('Unsupported network');
25
- return `https://dora.coz.io/transaction/neo3/${__classPrivateFieldGet(this, _DoraESNeo3_networkId, "f")}/${hash}`;
23
+ if (BSNeo3Helper_1.BSNeo3Helper.isCustomNet(__classPrivateFieldGet(this, _DoraESNeo3_network, "f")))
24
+ throw new Error('DoraESNeo3 is only available on mainnet and testnet');
25
+ return `https://dora.coz.io/transaction/neo3/${__classPrivateFieldGet(this, _DoraESNeo3_network, "f").id}/${hash}`;
26
26
  }
27
27
  buildContractUrl(contractHash) {
28
- if (!DoraBDSNeo3_1.DoraBDSNeo3.SUPPORTED_NETWORKS.includes(__classPrivateFieldGet(this, _DoraESNeo3_networkId, "f")))
29
- throw new Error('Unsupported network');
30
- return `https://dora.coz.io/contract/neo3/${__classPrivateFieldGet(this, _DoraESNeo3_networkId, "f")}/${contractHash}`;
28
+ if (BSNeo3Helper_1.BSNeo3Helper.isCustomNet(__classPrivateFieldGet(this, _DoraESNeo3_network, "f")))
29
+ throw new Error('DoraESNeo3 is only available on mainnet and testnet');
30
+ return `https://dora.coz.io/contract/neo3/${__classPrivateFieldGet(this, _DoraESNeo3_network, "f").id}/${contractHash}`;
31
31
  }
32
32
  buildNftUrl({ contractHash, tokenId }) {
33
- if (!DoraBDSNeo3_1.DoraBDSNeo3.SUPPORTED_NETWORKS.includes(__classPrivateFieldGet(this, _DoraESNeo3_networkId, "f")))
34
- throw new Error('Unsupported network');
35
- return `https://dora.coz.io/nft/neo3/${__classPrivateFieldGet(this, _DoraESNeo3_networkId, "f")}/${contractHash}/${tokenId}`;
33
+ if (BSNeo3Helper_1.BSNeo3Helper.isCustomNet(__classPrivateFieldGet(this, _DoraESNeo3_network, "f")))
34
+ throw new Error('DoraESNeo3 is only available on mainnet and testnet');
35
+ return `https://dora.coz.io/nft/neo3/${__classPrivateFieldGet(this, _DoraESNeo3_network, "f").id}/${contractHash}/${tokenId}`;
36
36
  }
37
37
  }
38
38
  exports.DoraESNeo3 = DoraESNeo3;
39
- _DoraESNeo3_networkId = new WeakMap();
39
+ _DoraESNeo3_network = new WeakMap();
@@ -1,9 +1,8 @@
1
- import { CryptoCompareEDS, Currency, ExchangeDataService, GetTokenPriceHistory, Token, TokenPricesHistoryResponse, TokenPricesResponse } from '@cityofzion/blockchain-service';
2
- import { AvailableNetworkIds } from './BSNeo3Helper';
1
+ import { CryptoCompareEDS, ExchangeDataService, GetTokenPriceHistoryParams, GetTokenPricesParams, Network, TokenPricesHistoryResponse, TokenPricesResponse } from '@cityofzion/blockchain-service';
2
+ import { BSNeo3NetworkId } from './BSNeo3Helper';
3
3
  export declare class FlamingoEDSNeo3 extends CryptoCompareEDS implements ExchangeDataService {
4
4
  #private;
5
- constructor(networkId: AvailableNetworkIds, tokens: Token[]);
6
- getTokenPrices(currency: Currency): Promise<TokenPricesResponse[]>;
7
- getTokenPriceHistory(params: GetTokenPriceHistory): Promise<TokenPricesHistoryResponse[]>;
8
- private getCurrencyRatio;
5
+ constructor(network: Network<BSNeo3NetworkId>);
6
+ getTokenPrices(params: GetTokenPricesParams): Promise<TokenPricesResponse[]>;
7
+ getTokenPriceHistory(params: GetTokenPriceHistoryParams): Promise<TokenPricesHistoryResponse[]>;
9
8
  }
@@ -22,33 +22,36 @@ var __classPrivateFieldGet = (this && this.__classPrivateFieldGet) || function (
22
22
  var __importDefault = (this && this.__importDefault) || function (mod) {
23
23
  return (mod && mod.__esModule) ? mod : { "default": mod };
24
24
  };
25
- var _FlamingoEDSNeo3_networkId, _FlamingoEDSNeo3_axiosInstance;
25
+ var _FlamingoEDSNeo3_network, _FlamingoEDSNeo3_axiosInstance;
26
26
  Object.defineProperty(exports, "__esModule", { value: true });
27
27
  exports.FlamingoEDSNeo3 = void 0;
28
28
  const blockchain_service_1 = require("@cityofzion/blockchain-service");
29
29
  const axios_1 = __importDefault(require("axios"));
30
+ const BSNeo3Helper_1 = require("./BSNeo3Helper");
30
31
  class FlamingoEDSNeo3 extends blockchain_service_1.CryptoCompareEDS {
31
- constructor(networkId, tokens) {
32
- super(tokens);
33
- _FlamingoEDSNeo3_networkId.set(this, void 0);
32
+ constructor(network) {
33
+ super();
34
+ _FlamingoEDSNeo3_network.set(this, void 0);
34
35
  _FlamingoEDSNeo3_axiosInstance.set(this, void 0);
35
- __classPrivateFieldSet(this, _FlamingoEDSNeo3_networkId, networkId, "f");
36
+ __classPrivateFieldSet(this, _FlamingoEDSNeo3_network, network, "f");
36
37
  __classPrivateFieldSet(this, _FlamingoEDSNeo3_axiosInstance, axios_1.default.create({ baseURL: 'https://api.flamingo.finance' }), "f");
37
38
  }
38
- getTokenPrices(currency) {
39
+ getTokenPrices(params) {
39
40
  return __awaiter(this, void 0, void 0, function* () {
40
- if (__classPrivateFieldGet(this, _FlamingoEDSNeo3_networkId, "f") !== 'mainnet')
41
+ if (!BSNeo3Helper_1.BSNeo3Helper.isMainnet(__classPrivateFieldGet(this, _FlamingoEDSNeo3_network, "f")))
41
42
  throw new Error('Exchange is only available on mainnet');
42
- const { data: prices } = yield __classPrivateFieldGet(this, _FlamingoEDSNeo3_axiosInstance, "f").get('/token-info/prices');
43
- let currencyRatio = 1;
44
- if (currency !== 'USD') {
45
- currencyRatio = yield this.getCurrencyRatio(currency);
46
- }
47
- return prices.map(price => ({
48
- price: price.usd_price * currencyRatio,
49
- symbol: price.symbol,
50
- hash: price.hash,
51
- }));
43
+ const { data } = yield __classPrivateFieldGet(this, _FlamingoEDSNeo3_axiosInstance, "f").get('/token-info/prices');
44
+ const prices = [];
45
+ data.forEach(item => {
46
+ const token = params.tokens.find(token => token.hash === item.hash);
47
+ if (!token)
48
+ return;
49
+ prices.push({
50
+ usdPrice: item.usd_price,
51
+ token,
52
+ });
53
+ });
54
+ return prices;
52
55
  });
53
56
  }
54
57
  getTokenPriceHistory(params) {
@@ -56,17 +59,11 @@ class FlamingoEDSNeo3 extends blockchain_service_1.CryptoCompareEDS {
56
59
  getTokenPriceHistory: { get: () => super.getTokenPriceHistory }
57
60
  });
58
61
  return __awaiter(this, void 0, void 0, function* () {
59
- if (__classPrivateFieldGet(this, _FlamingoEDSNeo3_networkId, "f") !== 'mainnet')
62
+ if (!BSNeo3Helper_1.BSNeo3Helper.isMainnet(__classPrivateFieldGet(this, _FlamingoEDSNeo3_network, "f")))
60
63
  throw new Error('Exchange is only available on mainnet');
61
64
  return yield _super.getTokenPriceHistory.call(this, params);
62
65
  });
63
66
  }
64
- getCurrencyRatio(currency) {
65
- return __awaiter(this, void 0, void 0, function* () {
66
- const { data } = yield __classPrivateFieldGet(this, _FlamingoEDSNeo3_axiosInstance, "f").get(`/fiat/exchange-rate?pair=USD_${currency}`);
67
- return data;
68
- });
69
- }
70
67
  }
71
68
  exports.FlamingoEDSNeo3 = FlamingoEDSNeo3;
72
- _FlamingoEDSNeo3_networkId = new WeakMap(), _FlamingoEDSNeo3_axiosInstance = new WeakMap();
69
+ _FlamingoEDSNeo3_network = new WeakMap(), _FlamingoEDSNeo3_axiosInstance = new WeakMap();
@@ -1,13 +1,13 @@
1
1
  import { NftResponse, NftsResponse, GetNftParam, GetNftsByAddressParams, Network } from '@cityofzion/blockchain-service';
2
- import { AvailableNetworkIds } from './BSNeo3Helper';
2
+ import { BSNeo3NetworkId } from './BSNeo3Helper';
3
3
  import { RpcNDSNeo3 } from './RpcNDSNeo3';
4
4
  export declare class GhostMarketNDSNeo3 extends RpcNDSNeo3 {
5
5
  #private;
6
- static CONFIG_BY_NETWORK_ID: Partial<Record<AvailableNetworkIds, {
6
+ static CONFIG_BY_NETWORK_ID: Partial<Record<BSNeo3NetworkId, {
7
7
  url: string;
8
8
  chain: string;
9
9
  }>>;
10
- constructor(network: Network<AvailableNetworkIds>);
10
+ constructor(network: Network<BSNeo3NetworkId>);
11
11
  getNftsByAddress({ address, size, cursor }: GetNftsByAddressParams): Promise<NftsResponse>;
12
12
  getNft({ contractHash, tokenId }: GetNftParam): Promise<NftResponse>;
13
13
  }
@@ -72,7 +72,7 @@ _GhostMarketNDSNeo3_network = new WeakMap(), _GhostMarketNDSNeo3_instances = new
72
72
  }, _GhostMarketNDSNeo3_getUrlWithParams = function _GhostMarketNDSNeo3_getUrlWithParams(params) {
73
73
  const config = GhostMarketNDSNeo3.CONFIG_BY_NETWORK_ID[__classPrivateFieldGet(this, _GhostMarketNDSNeo3_network, "f").id];
74
74
  if (!config)
75
- throw new Error('Unsupported network');
75
+ throw new Error('GhostMarketNDSNeo3 does not support this network');
76
76
  const parameters = query_string_1.default.stringify(Object.assign({ chain: config.chain }, params), { arrayFormat: 'bracket' });
77
77
  return `${config.url}/assets?${parameters}`;
78
78
  }, _GhostMarketNDSNeo3_parse = function _GhostMarketNDSNeo3_parse(data) {
@@ -1,13 +1,13 @@
1
1
  import { BDSClaimable, BalanceResponse, BlockchainDataService, ContractResponse, Network, RpcResponse, Token, TransactionResponse, TransactionsByAddressParams, TransactionsByAddressResponse } from '@cityofzion/blockchain-service';
2
- import { AvailableNetworkIds } from './BSNeo3Helper';
2
+ import { BSNeo3NetworkId } from './BSNeo3Helper';
3
3
  export declare class RPCBDSNeo3 implements BlockchainDataService, BDSClaimable {
4
4
  readonly _tokenCache: Map<string, Token>;
5
5
  readonly _feeToken: Token;
6
6
  readonly _claimToken: Token;
7
- readonly _network: Network<AvailableNetworkIds>;
7
+ readonly _network: Network<BSNeo3NetworkId>;
8
8
  readonly _tokens: Token[];
9
9
  maxTimeToConfirmTransactionInMs: number;
10
- constructor(network: Network<AvailableNetworkIds>, feeToken: Token, claimToken: Token, tokens: Token[]);
10
+ constructor(network: Network<BSNeo3NetworkId>, feeToken: Token, claimToken: Token, tokens: Token[]);
11
11
  getTransaction(hash: string): Promise<TransactionResponse>;
12
12
  getTransactionsByAddress(_params: TransactionsByAddressParams): Promise<TransactionsByAddressResponse>;
13
13
  getContract(contractHash: string): Promise<ContractResponse>;
@@ -1,8 +1,8 @@
1
1
  import { GetNftParam, GetNftsByAddressParams, HasTokenParam, Network, NftDataService, NftResponse, NftsResponse } from '@cityofzion/blockchain-service';
2
- import { AvailableNetworkIds } from './BSNeo3Helper';
2
+ import { BSNeo3NetworkId } from './BSNeo3Helper';
3
3
  export declare abstract class RpcNDSNeo3 implements NftDataService {
4
4
  #private;
5
- protected constructor(network: Network<AvailableNetworkIds>);
5
+ protected constructor(network: Network<BSNeo3NetworkId>);
6
6
  abstract getNftsByAddress(params: GetNftsByAddressParams): Promise<NftsResponse>;
7
7
  abstract getNft(params: GetNftParam): Promise<NftResponse>;
8
8
  hasToken({ contractHash, address }: HasTokenParam): Promise<boolean>;
@@ -1,11 +1,11 @@
1
1
  import { Account, Network, SwapControllerService, SwapControllerServiceEvents, SwapControllerServiceSwapToReceiveArgs, SwapControllerServiceSwapToUseArgs, Token } from '@cityofzion/blockchain-service';
2
2
  import TypedEmitter from 'typed-emitter';
3
- import { AvailableNetworkIds } from '../BSNeo3Helper';
4
- export declare class FlamingoSwapControllerService implements SwapControllerService<AvailableNetworkIds> {
3
+ import { BSNeo3NetworkId } from '../BSNeo3Helper';
4
+ export declare class FlamingoSwapControllerService implements SwapControllerService<BSNeo3NetworkId> {
5
5
  #private;
6
6
  eventEmitter: TypedEmitter<SwapControllerServiceEvents>;
7
- constructor(network: Network<AvailableNetworkIds>);
8
- buildSwapArgs(): SwapControllerServiceSwapToReceiveArgs<AvailableNetworkIds> | SwapControllerServiceSwapToUseArgs<AvailableNetworkIds>;
7
+ constructor(network: Network<BSNeo3NetworkId>);
8
+ buildSwapArgs(): SwapControllerServiceSwapToReceiveArgs<BSNeo3NetworkId> | SwapControllerServiceSwapToUseArgs<BSNeo3NetworkId>;
9
9
  setAccountToUse(account: Account | null): void;
10
10
  setAmountToUse(val: string | null): void;
11
11
  setAmountToReceive(val: string | null): void;
@@ -1,6 +1,6 @@
1
1
  import BigNumber from 'bignumber.js';
2
2
  import { Network, Token } from '@cityofzion/blockchain-service';
3
- import { AvailableNetworkIds } from '../BSNeo3Helper';
3
+ import { BSNeo3NetworkId } from '../BSNeo3Helper';
4
4
  type TGetSwapArgs = {
5
5
  amountToUse: string | null;
6
6
  amountToReceive: string | null;
@@ -9,7 +9,7 @@ type TGetSwapArgs = {
9
9
  reservesToUse: string;
10
10
  reservesToReceive: string;
11
11
  slippage: number;
12
- network: Network<AvailableNetworkIds>;
12
+ network: Network<BSNeo3NetworkId>;
13
13
  };
14
14
  export type SwapScriptHashes = {
15
15
  flamingoSwapRouter: string;
@@ -28,8 +28,8 @@ export declare class FlamingoSwapHelper {
28
28
  static readonly BN_1000: BigNumber;
29
29
  static readonly FEE_RATE: BigNumber;
30
30
  static readonly GAS_PER_NEO = 0.001;
31
- static getSwapScriptHashes(network: Network<AvailableNetworkIds>): SwapScriptHashes;
32
- static getBneoToken(network: Network<AvailableNetworkIds>): Token;
31
+ static getSwapScriptHashes(network: Network<BSNeo3NetworkId>): SwapScriptHashes;
32
+ static getBneoToken(network: Network<BSNeo3NetworkId>): Token;
33
33
  static getSwapFields(params: TGetSwapArgs): {
34
34
  amountToReceiveToDisplay: string;
35
35
  amountToUseToDisplay: string;
@@ -39,7 +39,7 @@ export declare class FlamingoSwapHelper {
39
39
  minimumReceived: string | null;
40
40
  maximumSelling: string | null;
41
41
  };
42
- static overrideToken(network: Network<AvailableNetworkIds>, token: Token): Token;
42
+ static overrideToken(network: Network<BSNeo3NetworkId>, token: Token): Token;
43
43
  private static createTradeData;
44
44
  private static overrideAmountInput;
45
45
  private static overrideAmountToDisplay;
@@ -1,13 +1,13 @@
1
1
  import { ContractInvocationMulti } from '@cityofzion/neon-dappkit-types';
2
2
  import { Network, SwapControllerServiceSwapToUseArgs, SwapControllerServiceSwapToReceiveArgs } from '@cityofzion/blockchain-service';
3
- import { AvailableNetworkIds } from '../BSNeo3Helper';
3
+ import { BSNeo3NetworkId } from '../BSNeo3Helper';
4
4
  type GetReservesArgs = {
5
- network: Network<AvailableNetworkIds>;
5
+ network: Network<BSNeo3NetworkId>;
6
6
  tokenToReceiveScriptHash: string;
7
7
  tokenToUseScriptHash: string;
8
8
  };
9
9
  export declare class FlamingoSwapNeonDappKitInvocationBuilder {
10
- static swapInvocation(data: SwapControllerServiceSwapToReceiveArgs<AvailableNetworkIds> | SwapControllerServiceSwapToUseArgs<AvailableNetworkIds>): ContractInvocationMulti;
10
+ static swapInvocation(data: SwapControllerServiceSwapToReceiveArgs<BSNeo3NetworkId> | SwapControllerServiceSwapToUseArgs<BSNeo3NetworkId>): ContractInvocationMulti;
11
11
  static getReservesInvocation({ network, tokenToReceiveScriptHash, tokenToUseScriptHash, }: GetReservesArgs): ContractInvocationMulti;
12
12
  private static swapTokenToReceiveForTokenToUseInvocation;
13
13
  private static swapTokenToUseForTokenToReceiveInvocation;
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@cityofzion/bs-neo3",
3
- "version": "1.0.3",
3
+ "version": "1.1.0",
4
4
  "main": "dist/index.js",
5
5
  "types": "dist/index.d.ts",
6
6
  "repository": "https://github.com/CityOfZion/blockchain-services",
@@ -19,7 +19,7 @@
19
19
  "@cityofzion/neon-dappkit": "0.4.1",
20
20
  "bignumber.js": "~9.1.2",
21
21
  "isomorphic-ws": "~5.0.0",
22
- "@cityofzion/blockchain-service": "1.0.1",
22
+ "@cityofzion/blockchain-service": "1.1.0",
23
23
  "@cityofzion/bs-asteroid-sdk": "0.9.0"
24
24
  },
25
25
  "devDependencies": {