dash-platform-sdk 1.2.0 → 1.3.0-dev.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.
Files changed (66) hide show
  1. package/bundle.min.js +1 -1
  2. package/bundle.min.js.LICENSE.txt +0 -4
  3. package/package.json +4 -7
  4. package/src/DashPlatformSDK.d.ts +2 -0
  5. package/src/DashPlatformSDK.js +2 -4
  6. package/src/constants.d.ts +2 -0
  7. package/src/constants.js +3 -1
  8. package/src/contestedResources/createStateTransition.d.ts +3 -0
  9. package/src/contestedResources/createStateTransition.js +9 -0
  10. package/src/contestedResources/getContestedResourceVoteState.js +4 -5
  11. package/src/contestedResources/index.d.ts +1 -1
  12. package/src/dataContracts/getDataContractByIdentifier.js +8 -5
  13. package/src/documents/query.js +8 -9
  14. package/src/identities/getIdentityBalance.js +1 -2
  15. package/src/identities/getIdentityByIdentifier.js +2 -3
  16. package/src/identities/getIdentityByNonUniquePublicKeyHash.js +3 -5
  17. package/src/identities/getIdentityByPublicKeyHash.js +2 -3
  18. package/src/identities/getIdentityContractNonce.js +4 -5
  19. package/src/identities/getIdentityNonce.js +1 -2
  20. package/src/identities/getIdentityPublicKeys.js +5 -5
  21. package/src/names/index.d.ts +35 -2
  22. package/src/names/index.js +86 -16
  23. package/src/names/registerName.d.ts +3 -0
  24. package/src/names/registerName.js +131 -0
  25. package/src/names/searchByIdentity.d.ts +3 -0
  26. package/src/names/searchByIdentity.js +51 -0
  27. package/src/names/searchByName.d.ts +3 -0
  28. package/src/names/{search.js → searchByName.js} +6 -5
  29. package/src/names/testNameContested.d.ts +1 -0
  30. package/src/names/testNameContested.js +6 -0
  31. package/src/names/validateName.d.ts +1 -0
  32. package/src/names/validateName.js +14 -0
  33. package/src/node/epochs.js +10 -4
  34. package/src/node/totalCredits.js +1 -2
  35. package/src/stateTransitions/waitForStateTransitionResult.js +13 -17
  36. package/src/tokens/getIdentitiesTokenBalances.js +1 -2
  37. package/src/tokens/getIdentityTokensBalances.js +1 -2
  38. package/src/tokens/getTokenContractInfo.js +2 -3
  39. package/src/tokens/getTokenTotalSupply.d.ts +1 -7
  40. package/src/tokens/getTokenTotalSupply.js +5 -6
  41. package/src/tokens/index.d.ts +1 -2
  42. package/src/types.d.ts +8 -2
  43. package/src/utils/convertToHomographSafeChars.d.ts +0 -4
  44. package/src/utils/convertToHomographSafeChars.js +0 -4
  45. package/src/utils/createVoterIdentityId.d.ts +2 -0
  46. package/src/utils/createVoterIdentityId.js +12 -0
  47. package/src/utils/getRandomBytes.d.ts +1 -0
  48. package/src/utils/getRandomBytes.js +7 -0
  49. package/src/utils/index.d.ts +1 -3
  50. package/src/utils/index.js +1 -3
  51. package/src/utils/sleep.d.ts +1 -0
  52. package/src/utils/sleep.js +51 -0
  53. package/src/utils/verifyTenderdashProof.js +3 -2
  54. package/src/voting/createStateTransition.d.ts +3 -0
  55. package/src/voting/createStateTransition.js +9 -0
  56. package/src/voting/createVote.d.ts +2 -0
  57. package/src/voting/createVote.js +8 -0
  58. package/src/voting/index.d.ts +38 -0
  59. package/src/voting/index.js +62 -0
  60. package/test/unit/ContestedResources.spec.js +84 -3
  61. package/test/unit/Identity.spec.js +0 -12
  62. package/test/unit/Names.spec.d.ts +1 -0
  63. package/test/unit/Names.spec.js +96 -0
  64. package/src/names/search.d.ts +0 -3
  65. package/src/utils/verifyBls.d.ts +0 -1
  66. package/src/utils/verifyBls.js +0 -15
@@ -1,5 +1 @@
1
- /*! noble-curves - MIT License (c) 2022 Paul Miller (paulmillr.com) */
2
-
3
- /*! noble-hashes - MIT License (c) 2022 Paul Miller (paulmillr.com) */
4
-
5
1
  /*! scure-base - MIT License (c) 2022 Paul Miller (paulmillr.com) */
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "dash-platform-sdk",
3
- "version": "1.2.0",
3
+ "version": "1.3.0-dev.2",
4
4
  "main": "index.js",
5
5
  "description": "Lightweight SDK for accessing Dash Platform blockchain",
6
6
  "ts-standard": {
@@ -13,8 +13,8 @@
13
13
  "@babel/core": "^7.28.0",
14
14
  "@babel/preset-env": "^7.28.0",
15
15
  "@babel/preset-typescript": "^7.27.1",
16
- "@types/dashhd": "git+https://github.com/owl352/types-DashHD.js",
17
- "@types/dashphrase": "git+https://github.com/owl352/types-DashPhrase.js",
16
+ "@types/dashhd": "owl352/types-DashHD.js",
17
+ "@types/dashphrase": "owl352/types-DashPhrase.js",
18
18
  "@types/jest": "^29.5.14",
19
19
  "babel-jest": "^29.7.0",
20
20
  "dets": "^0.16.8",
@@ -49,7 +49,6 @@
49
49
  "dependencies": {
50
50
  "@bufbuild/protobuf": "^2.6.0",
51
51
  "@dashincubator/secp256k1": "^1.7.1-5",
52
- "@noble/curves": "^1.9.2",
53
52
  "@scure/base": "^1.2.4",
54
53
  "cbor-x": "^1.6.0",
55
54
  "dashhd": "^3.3.3",
@@ -58,8 +57,6 @@
58
57
  "grpc-web": "^1.5.0",
59
58
  "hash.js": "^1.1.7",
60
59
  "nice-grpc-web": "^3.3.6",
61
- "pshenmic-dpp": "1.0.23-rc.7",
62
- "rfc4648": "^1.5.4",
63
- "wasm-drive-verify": "github:owl352/wasm-drive-verify#9c572d86992d205d994cd7e0630a4bd14d284f8a"
60
+ "pshenmic-dpp": "1.0.25"
64
61
  }
65
62
  }
@@ -10,6 +10,7 @@ import { DataContractsController } from './dataContracts';
10
10
  import { ContestedResourcesController } from './contestedResources';
11
11
  import { TokensController } from './tokens';
12
12
  import { AbstractSigner } from './signer/AbstractSigner';
13
+ import { VotingController } from './voting';
13
14
  export interface GRPCOptions {
14
15
  poolLimit: 5;
15
16
  dapiUrl?: string | string[];
@@ -36,6 +37,7 @@ export declare class DashPlatformSDK {
36
37
  identities: IdentitiesController;
37
38
  documents: DocumentsController;
38
39
  keyPair: KeyPairController;
40
+ voting: VotingController;
39
41
  tokens: TokensController;
40
42
  utils: UtilsController;
41
43
  names: NamesController;
@@ -12,8 +12,7 @@ var names_1 = require("./names");
12
12
  var dataContracts_1 = require("./dataContracts");
13
13
  var contestedResources_1 = require("./contestedResources");
14
14
  var tokens_1 = require("./tokens");
15
- var wasm_drive_verify_1 = require("wasm-drive-verify");
16
- var base_1 = require("@scure/base");
15
+ var voting_1 = require("./voting");
17
16
  /**
18
17
  * Javascript SDK for that let you interact with a Dash Platform blockchain
19
18
  */
@@ -40,8 +39,6 @@ var DashPlatformSDK = /** @class */ (function () {
40
39
  }
41
40
  this.grpcPool = new grpcConnectionPool_1.default(this.network, (_b = this.options) === null || _b === void 0 ? void 0 : _b.grpc);
42
41
  this._initialize(this.grpcPool, this.network);
43
- var driveVerifyWASMBytes = base_1.base64.decode(wasm_drive_verify_1.wasmBase64);
44
- (0, wasm_drive_verify_1.initSync)({ module: driveVerifyWASMBytes });
45
42
  }
46
43
  /**
47
44
  * @private
@@ -58,6 +55,7 @@ var DashPlatformSDK = /** @class */ (function () {
58
55
  this.dataContracts = new dataContracts_1.DataContractsController(grpcPool);
59
56
  this.identities = new identities_1.IdentitiesController(grpcPool);
60
57
  this.documents = new documents_1.DocumentsController(grpcPool);
58
+ this.voting = new voting_1.VotingController();
61
59
  this.node = new node_1.NodeController(grpcPool, network);
62
60
  this.tokens = new tokens_1.TokensController(grpcPool);
63
61
  this.names = new names_1.NamesController(grpcPool);
@@ -6,3 +6,5 @@ export declare const HALVING_INTERVAL = 210240;
6
6
  export declare const TESTNET_ACTIVATION_HEIGHT = 1066900;
7
7
  export declare const MAINNET_ACTIVATION_HEIGHT = 2128896;
8
8
  export declare const GRPC_DEFAULT_POOL_LIMIT = 5;
9
+ export declare const DPNS_DATA_CONTRACT_ID = "GWRSAVFMjXx8HpQFaNJMqBV7MBgMK4br5UESsB4S31Ec";
10
+ export declare const DPNS_DATA_CONTRACT_BYTES = "AeZoxlmvZq7h5ywYbd57W34KHXEqCcQNVyH2Ir9TxTFVAAAAAAABAQAAAQAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAIGZG9tYWluFgsSEGRvY3VtZW50c011dGFibGUTABIMY2FuQmVEZWxldGVkEwESDHRyYW5zZmVyYWJsZQIBEgl0cmFkZU1vZGUCARIEdHlwZRIGb2JqZWN0EgdpbmRpY2VzFQIWBBIEbmFtZRIScGFyZW50TmFtZUFuZExhYmVsEgpwcm9wZXJ0aWVzFQIWARIabm9ybWFsaXplZFBhcmVudERvbWFpbk5hbWUSA2FzYxYBEg9ub3JtYWxpemVkTGFiZWwSA2FzYxIGdW5pcXVlEwESCWNvbnRlc3RlZBYDEgxmaWVsZE1hdGNoZXMVARYCEgVmaWVsZBIPbm9ybWFsaXplZExhYmVsEgxyZWdleFBhdHRlcm4SE15bYS16QS1aMDEtXXszLDE5fSQSCnJlc29sdXRpb24CABILZGVzY3JpcHRpb24SqklmIHRoZSBub3JtYWxpemVkIGxhYmVsIHBhcnQgb2YgdGhpcyBpbmRleCBpcyBsZXNzIHRoYW4gMjAgY2hhcmFjdGVycyAoYWxsIGFscGhhYmV0IGEteiwgQS1aLCAwLCAxLCBhbmQgLSkgdGhlbiBhIG1hc3Rlcm5vZGUgdm90ZSBjb250ZXN0IHRha2VzIHBsYWNlIHRvIGdpdmUgb3V0IHRoZSBuYW1lFgMSBG5hbWUSCmlkZW50aXR5SWQSDm51bGxTZWFyY2hhYmxlEwASCnByb3BlcnRpZXMVARYBEhByZWNvcmRzLmlkZW50aXR5EgNhc2MSCnByb3BlcnRpZXMWBxIFbGFiZWwWBhIEdHlwZRIGc3RyaW5nEgdwYXR0ZXJuEipeW2EtekEtWjAtOV1bYS16QS1aMC05LV17MCw2MX1bYS16QS1aMC05XSQSCW1pbkxlbmd0aAIDEgltYXhMZW5ndGgCPxIIcG9zaXRpb24CABILZGVzY3JpcHRpb24SGURvbWFpbiBsYWJlbC4gZS5nLiAnQm9iJy4SD25vcm1hbGl6ZWRMYWJlbBYGEgR0eXBlEgZzdHJpbmcSB3BhdHRlcm4SPF5bYS1oai1rbS1ucC16MC05XVthLWhqLWttLW5wLXowLTktXXswLDYxfVthLWhqLWttLW5wLXowLTldJBIJbWF4TGVuZ3RoAj8SCHBvc2l0aW9uAgESC2Rlc2NyaXB0aW9uEqNEb21haW4gbGFiZWwgY29udmVydGVkIHRvIGxvd2VyY2FzZSBmb3IgY2FzZS1pbnNlbnNpdGl2ZSB1bmlxdWVuZXNzIHZhbGlkYXRpb24uICJvIiwgImkiIGFuZCAibCIgcmVwbGFjZWQgd2l0aCAiMCIgYW5kICIxIiB0byBtaXRpZ2F0ZSBob21vZ3JhcGggYXR0YWNrLiBlLmcuICdiMGInEggkY29tbWVudBJcTXVzdCBiZSBlcXVhbCB0byB0aGUgbGFiZWwgaW4gbG93ZXJjYXNlLiAibyIsICJpIiBhbmQgImwiIG11c3QgYmUgcmVwbGFjZWQgd2l0aCAiMCIgYW5kICIxIi4SEHBhcmVudERvbWFpbk5hbWUWBhIEdHlwZRIGc3RyaW5nEgdwYXR0ZXJuEi1eJHxeW2EtekEtWjAtOV1bYS16QS1aMC05LV17MCw2MX1bYS16QS1aMC05XSQSCW1pbkxlbmd0aAIAEgltYXhMZW5ndGgCPxIIcG9zaXRpb24CAhILZGVzY3JpcHRpb24SJ0EgZnVsbCBwYXJlbnQgZG9tYWluIG5hbWUuIGUuZy4gJ2Rhc2gnLhIabm9ybWFsaXplZFBhcmVudERvbWFpbk5hbWUWBxIEdHlwZRIGc3RyaW5nEgdwYXR0ZXJuEkFeJHxeW2EtaGota20tbnAtejAtOV1bYS1oai1rbS1ucC16MC05LVwuXXswLDYxfVthLWhqLWttLW5wLXowLTldJBIJbWluTGVuZ3RoAgASCW1heExlbmd0aAI/Eghwb3NpdGlvbgIDEgtkZXNjcmlwdGlvbhKiQSBwYXJlbnQgZG9tYWluIG5hbWUgaW4gbG93ZXJjYXNlIGZvciBjYXNlLWluc2Vuc2l0aXZlIHVuaXF1ZW5lc3MgdmFsaWRhdGlvbi4gIm8iLCAiaSIgYW5kICJsIiByZXBsYWNlZCB3aXRoICIwIiBhbmQgIjEiIHRvIG1pdGlnYXRlIGhvbW9ncmFwaCBhdHRhY2suIGUuZy4gJ2Rhc2gnEggkY29tbWVudBLATXVzdCBlaXRoZXIgYmUgZXF1YWwgdG8gYW4gZXhpc3RpbmcgZG9tYWluIG9yIGVtcHR5IHRvIGNyZWF0ZSBhIHRvcCBsZXZlbCBkb21haW4uICJvIiwgImkiIGFuZCAibCIgbXVzdCBiZSByZXBsYWNlZCB3aXRoICIwIiBhbmQgIjEiLiBPbmx5IHRoZSBkYXRhIGNvbnRyYWN0IG93bmVyIGNhbiBjcmVhdGUgdG9wIGxldmVsIGRvbWFpbnMuEgxwcmVvcmRlclNhbHQWBhIEdHlwZRIFYXJyYXkSCWJ5dGVBcnJheRMBEghtaW5JdGVtcwIgEghtYXhJdGVtcwIgEghwb3NpdGlvbgIEEgtkZXNjcmlwdGlvbhIiU2FsdCB1c2VkIGluIHRoZSBwcmVvcmRlciBkb2N1bWVudBIHcmVjb3JkcxYFEgR0eXBlEgZvYmplY3QSCnByb3BlcnRpZXMWARIIaWRlbnRpdHkWBxIEdHlwZRIFYXJyYXkSCWJ5dGVBcnJheRMBEghtaW5JdGVtcwIgEghtYXhJdGVtcwIgEghwb3NpdGlvbgIBEhBjb250ZW50TWVkaWFUeXBlEiFhcHBsaWNhdGlvbi94LmRhc2guZHBwLmlkZW50aWZpZXISC2Rlc2NyaXB0aW9uEjFJZGVudGlmaWVyIG5hbWUgcmVjb3JkIHRoYXQgcmVmZXJzIHRvIGFuIElkZW50aXR5Eg1taW5Qcm9wZXJ0aWVzAgESCHBvc2l0aW9uAgUSFGFkZGl0aW9uYWxQcm9wZXJ0aWVzEwASDnN1YmRvbWFpblJ1bGVzFgYSBHR5cGUSBm9iamVjdBIKcHJvcGVydGllcxYBEg9hbGxvd1N1YmRvbWFpbnMWBBIEdHlwZRIHYm9vbGVhbhILZGVzY3JpcHRpb24SW1RoaXMgb3B0aW9uIGRlZmluZXMgd2hvIGNhbiBjcmVhdGUgc3ViZG9tYWluczogdHJ1ZSAtIGFueW9uZTsgZmFsc2UgLSBvbmx5IHRoZSBkb21haW4gb3duZXISCCRjb21tZW50Ek9Pbmx5IHRoZSBkb21haW4gb3duZXIgaXMgYWxsb3dlZCB0byBjcmVhdGUgc3ViZG9tYWlucyBmb3Igbm9uIHRvcC1sZXZlbCBkb21haW5zEghwb3NpdGlvbgIAEghwb3NpdGlvbgIGEgtkZXNjcmlwdGlvbhJCU3ViZG9tYWluIHJ1bGVzIGFsbG93IGRvbWFpbiBvd25lcnMgdG8gZGVmaW5lIHJ1bGVzIGZvciBzdWJkb21haW5zEhRhZGRpdGlvbmFsUHJvcGVydGllcxMAEghyZXF1aXJlZBUBEg9hbGxvd1N1YmRvbWFpbnMSCHJlcXVpcmVkFQkSCiRjcmVhdGVkQXQSCiR1cGRhdGVkQXQSDiR0cmFuc2ZlcnJlZEF0EgVsYWJlbBIPbm9ybWFsaXplZExhYmVsEhpub3JtYWxpemVkUGFyZW50RG9tYWluTmFtZRIMcHJlb3JkZXJTYWx0EgdyZWNvcmRzEg5zdWJkb21haW5SdWxlcxIJdHJhbnNpZW50FQESDHByZW9yZGVyU2FsdBIUYWRkaXRpb25hbFByb3BlcnRpZXMTABIIJGNvbW1lbnQS+wE3SW4gb3JkZXIgdG8gcmVnaXN0ZXIgYSBkb21haW4geW91IG5lZWQgdG8gY3JlYXRlIGEgcHJlb3JkZXIuIFRoZSBwcmVvcmRlciBzdGVwIGlzIG5lZWRlZCB0byBwcmV2ZW50IG1hbi1pbi10aGUtbWlkZGxlIGF0dGFja3MuIG5vcm1hbGl6ZWRMYWJlbCArICcuJyArIG5vcm1hbGl6ZWRQYXJlbnREb21haW4gbXVzdCBub3QgYmUgbG9uZ2VyIHRoYW4gMjUzIGNoYXJzIGxlbmd0aCBhcyBkZWZpbmVkIGJ5IFJGQyAxMDM1LiBEb21haW4gZG9jdW1lbnRzIGFyZSBpbW11dGFibGU6IG1vZGlmaWNhdGlvbiBhbmQgZGVsZXRpb24gYXJlIHJlc3RyaWN0ZWQIcHJlb3JkZXIWCBIQZG9jdW1lbnRzTXV0YWJsZRMAEgxjYW5CZURlbGV0ZWQTARIEdHlwZRIGb2JqZWN0EgdpbmRpY2VzFQEWAxIEbmFtZRIKc2FsdGVkSGFzaBIKcHJvcGVydGllcxUBFgESEHNhbHRlZERvbWFpbkhhc2gSA2FzYxIGdW5pcXVlEwESCnByb3BlcnRpZXMWARIQc2FsdGVkRG9tYWluSGFzaBYGEgR0eXBlEgVhcnJheRIJYnl0ZUFycmF5EwESCG1pbkl0ZW1zAiASCG1heEl0ZW1zAiASCHBvc2l0aW9uAgASC2Rlc2NyaXB0aW9uEllEb3VibGUgc2hhLTI1NiBvZiB0aGUgY29uY2F0ZW5hdGlvbiBvZiBhIDMyIGJ5dGUgcmFuZG9tIHNhbHQgYW5kIGEgbm9ybWFsaXplZCBkb21haW4gbmFtZRIIcmVxdWlyZWQVARIQc2FsdGVkRG9tYWluSGFzaBIUYWRkaXRpb25hbFByb3BlcnRpZXMTABIIJGNvbW1lbnQSSlByZW9yZGVyIGRvY3VtZW50cyBhcmUgaW1tdXRhYmxlOiBtb2RpZmljYXRpb24gYW5kIGRlbGV0aW9uIGFyZSByZXN0cmljdGVkAAAAAAAAAAAAAA==";
package/src/constants.js CHANGED
@@ -1,6 +1,6 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.GRPC_DEFAULT_POOL_LIMIT = exports.MAINNET_ACTIVATION_HEIGHT = exports.TESTNET_ACTIVATION_HEIGHT = exports.HALVING_INTERVAL = exports.DAPI_DEFAULT_LIMIT = void 0;
3
+ exports.DPNS_DATA_CONTRACT_BYTES = exports.DPNS_DATA_CONTRACT_ID = exports.GRPC_DEFAULT_POOL_LIMIT = exports.MAINNET_ACTIVATION_HEIGHT = exports.TESTNET_ACTIVATION_HEIGHT = exports.HALVING_INTERVAL = exports.DAPI_DEFAULT_LIMIT = void 0;
4
4
  /**
5
5
  * Default amount of documents to retrieve from DAPI
6
6
  */
@@ -9,3 +9,5 @@ exports.HALVING_INTERVAL = 210240;
9
9
  exports.TESTNET_ACTIVATION_HEIGHT = 1066900;
10
10
  exports.MAINNET_ACTIVATION_HEIGHT = 2128896;
11
11
  exports.GRPC_DEFAULT_POOL_LIMIT = 5;
12
+ exports.DPNS_DATA_CONTRACT_ID = 'GWRSAVFMjXx8HpQFaNJMqBV7MBgMK4br5UESsB4S31Ec';
13
+ exports.DPNS_DATA_CONTRACT_BYTES = 'AeZoxlmvZq7h5ywYbd57W34KHXEqCcQNVyH2Ir9TxTFVAAAAAAABAQAAAQAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAIGZG9tYWluFgsSEGRvY3VtZW50c011dGFibGUTABIMY2FuQmVEZWxldGVkEwESDHRyYW5zZmVyYWJsZQIBEgl0cmFkZU1vZGUCARIEdHlwZRIGb2JqZWN0EgdpbmRpY2VzFQIWBBIEbmFtZRIScGFyZW50TmFtZUFuZExhYmVsEgpwcm9wZXJ0aWVzFQIWARIabm9ybWFsaXplZFBhcmVudERvbWFpbk5hbWUSA2FzYxYBEg9ub3JtYWxpemVkTGFiZWwSA2FzYxIGdW5pcXVlEwESCWNvbnRlc3RlZBYDEgxmaWVsZE1hdGNoZXMVARYCEgVmaWVsZBIPbm9ybWFsaXplZExhYmVsEgxyZWdleFBhdHRlcm4SE15bYS16QS1aMDEtXXszLDE5fSQSCnJlc29sdXRpb24CABILZGVzY3JpcHRpb24SqklmIHRoZSBub3JtYWxpemVkIGxhYmVsIHBhcnQgb2YgdGhpcyBpbmRleCBpcyBsZXNzIHRoYW4gMjAgY2hhcmFjdGVycyAoYWxsIGFscGhhYmV0IGEteiwgQS1aLCAwLCAxLCBhbmQgLSkgdGhlbiBhIG1hc3Rlcm5vZGUgdm90ZSBjb250ZXN0IHRha2VzIHBsYWNlIHRvIGdpdmUgb3V0IHRoZSBuYW1lFgMSBG5hbWUSCmlkZW50aXR5SWQSDm51bGxTZWFyY2hhYmxlEwASCnByb3BlcnRpZXMVARYBEhByZWNvcmRzLmlkZW50aXR5EgNhc2MSCnByb3BlcnRpZXMWBxIFbGFiZWwWBhIEdHlwZRIGc3RyaW5nEgdwYXR0ZXJuEipeW2EtekEtWjAtOV1bYS16QS1aMC05LV17MCw2MX1bYS16QS1aMC05XSQSCW1pbkxlbmd0aAIDEgltYXhMZW5ndGgCPxIIcG9zaXRpb24CABILZGVzY3JpcHRpb24SGURvbWFpbiBsYWJlbC4gZS5nLiAnQm9iJy4SD25vcm1hbGl6ZWRMYWJlbBYGEgR0eXBlEgZzdHJpbmcSB3BhdHRlcm4SPF5bYS1oai1rbS1ucC16MC05XVthLWhqLWttLW5wLXowLTktXXswLDYxfVthLWhqLWttLW5wLXowLTldJBIJbWF4TGVuZ3RoAj8SCHBvc2l0aW9uAgESC2Rlc2NyaXB0aW9uEqNEb21haW4gbGFiZWwgY29udmVydGVkIHRvIGxvd2VyY2FzZSBmb3IgY2FzZS1pbnNlbnNpdGl2ZSB1bmlxdWVuZXNzIHZhbGlkYXRpb24uICJvIiwgImkiIGFuZCAibCIgcmVwbGFjZWQgd2l0aCAiMCIgYW5kICIxIiB0byBtaXRpZ2F0ZSBob21vZ3JhcGggYXR0YWNrLiBlLmcuICdiMGInEggkY29tbWVudBJcTXVzdCBiZSBlcXVhbCB0byB0aGUgbGFiZWwgaW4gbG93ZXJjYXNlLiAibyIsICJpIiBhbmQgImwiIG11c3QgYmUgcmVwbGFjZWQgd2l0aCAiMCIgYW5kICIxIi4SEHBhcmVudERvbWFpbk5hbWUWBhIEdHlwZRIGc3RyaW5nEgdwYXR0ZXJuEi1eJHxeW2EtekEtWjAtOV1bYS16QS1aMC05LV17MCw2MX1bYS16QS1aMC05XSQSCW1pbkxlbmd0aAIAEgltYXhMZW5ndGgCPxIIcG9zaXRpb24CAhILZGVzY3JpcHRpb24SJ0EgZnVsbCBwYXJlbnQgZG9tYWluIG5hbWUuIGUuZy4gJ2Rhc2gnLhIabm9ybWFsaXplZFBhcmVudERvbWFpbk5hbWUWBxIEdHlwZRIGc3RyaW5nEgdwYXR0ZXJuEkFeJHxeW2EtaGota20tbnAtejAtOV1bYS1oai1rbS1ucC16MC05LVwuXXswLDYxfVthLWhqLWttLW5wLXowLTldJBIJbWluTGVuZ3RoAgASCW1heExlbmd0aAI/Eghwb3NpdGlvbgIDEgtkZXNjcmlwdGlvbhKiQSBwYXJlbnQgZG9tYWluIG5hbWUgaW4gbG93ZXJjYXNlIGZvciBjYXNlLWluc2Vuc2l0aXZlIHVuaXF1ZW5lc3MgdmFsaWRhdGlvbi4gIm8iLCAiaSIgYW5kICJsIiByZXBsYWNlZCB3aXRoICIwIiBhbmQgIjEiIHRvIG1pdGlnYXRlIGhvbW9ncmFwaCBhdHRhY2suIGUuZy4gJ2Rhc2gnEggkY29tbWVudBLATXVzdCBlaXRoZXIgYmUgZXF1YWwgdG8gYW4gZXhpc3RpbmcgZG9tYWluIG9yIGVtcHR5IHRvIGNyZWF0ZSBhIHRvcCBsZXZlbCBkb21haW4uICJvIiwgImkiIGFuZCAibCIgbXVzdCBiZSByZXBsYWNlZCB3aXRoICIwIiBhbmQgIjEiLiBPbmx5IHRoZSBkYXRhIGNvbnRyYWN0IG93bmVyIGNhbiBjcmVhdGUgdG9wIGxldmVsIGRvbWFpbnMuEgxwcmVvcmRlclNhbHQWBhIEdHlwZRIFYXJyYXkSCWJ5dGVBcnJheRMBEghtaW5JdGVtcwIgEghtYXhJdGVtcwIgEghwb3NpdGlvbgIEEgtkZXNjcmlwdGlvbhIiU2FsdCB1c2VkIGluIHRoZSBwcmVvcmRlciBkb2N1bWVudBIHcmVjb3JkcxYFEgR0eXBlEgZvYmplY3QSCnByb3BlcnRpZXMWARIIaWRlbnRpdHkWBxIEdHlwZRIFYXJyYXkSCWJ5dGVBcnJheRMBEghtaW5JdGVtcwIgEghtYXhJdGVtcwIgEghwb3NpdGlvbgIBEhBjb250ZW50TWVkaWFUeXBlEiFhcHBsaWNhdGlvbi94LmRhc2guZHBwLmlkZW50aWZpZXISC2Rlc2NyaXB0aW9uEjFJZGVudGlmaWVyIG5hbWUgcmVjb3JkIHRoYXQgcmVmZXJzIHRvIGFuIElkZW50aXR5Eg1taW5Qcm9wZXJ0aWVzAgESCHBvc2l0aW9uAgUSFGFkZGl0aW9uYWxQcm9wZXJ0aWVzEwASDnN1YmRvbWFpblJ1bGVzFgYSBHR5cGUSBm9iamVjdBIKcHJvcGVydGllcxYBEg9hbGxvd1N1YmRvbWFpbnMWBBIEdHlwZRIHYm9vbGVhbhILZGVzY3JpcHRpb24SW1RoaXMgb3B0aW9uIGRlZmluZXMgd2hvIGNhbiBjcmVhdGUgc3ViZG9tYWluczogdHJ1ZSAtIGFueW9uZTsgZmFsc2UgLSBvbmx5IHRoZSBkb21haW4gb3duZXISCCRjb21tZW50Ek9Pbmx5IHRoZSBkb21haW4gb3duZXIgaXMgYWxsb3dlZCB0byBjcmVhdGUgc3ViZG9tYWlucyBmb3Igbm9uIHRvcC1sZXZlbCBkb21haW5zEghwb3NpdGlvbgIAEghwb3NpdGlvbgIGEgtkZXNjcmlwdGlvbhJCU3ViZG9tYWluIHJ1bGVzIGFsbG93IGRvbWFpbiBvd25lcnMgdG8gZGVmaW5lIHJ1bGVzIGZvciBzdWJkb21haW5zEhRhZGRpdGlvbmFsUHJvcGVydGllcxMAEghyZXF1aXJlZBUBEg9hbGxvd1N1YmRvbWFpbnMSCHJlcXVpcmVkFQkSCiRjcmVhdGVkQXQSCiR1cGRhdGVkQXQSDiR0cmFuc2ZlcnJlZEF0EgVsYWJlbBIPbm9ybWFsaXplZExhYmVsEhpub3JtYWxpemVkUGFyZW50RG9tYWluTmFtZRIMcHJlb3JkZXJTYWx0EgdyZWNvcmRzEg5zdWJkb21haW5SdWxlcxIJdHJhbnNpZW50FQESDHByZW9yZGVyU2FsdBIUYWRkaXRpb25hbFByb3BlcnRpZXMTABIIJGNvbW1lbnQS+wE3SW4gb3JkZXIgdG8gcmVnaXN0ZXIgYSBkb21haW4geW91IG5lZWQgdG8gY3JlYXRlIGEgcHJlb3JkZXIuIFRoZSBwcmVvcmRlciBzdGVwIGlzIG5lZWRlZCB0byBwcmV2ZW50IG1hbi1pbi10aGUtbWlkZGxlIGF0dGFja3MuIG5vcm1hbGl6ZWRMYWJlbCArICcuJyArIG5vcm1hbGl6ZWRQYXJlbnREb21haW4gbXVzdCBub3QgYmUgbG9uZ2VyIHRoYW4gMjUzIGNoYXJzIGxlbmd0aCBhcyBkZWZpbmVkIGJ5IFJGQyAxMDM1LiBEb21haW4gZG9jdW1lbnRzIGFyZSBpbW11dGFibGU6IG1vZGlmaWNhdGlvbiBhbmQgZGVsZXRpb24gYXJlIHJlc3RyaWN0ZWQIcHJlb3JkZXIWCBIQZG9jdW1lbnRzTXV0YWJsZRMAEgxjYW5CZURlbGV0ZWQTARIEdHlwZRIGb2JqZWN0EgdpbmRpY2VzFQEWAxIEbmFtZRIKc2FsdGVkSGFzaBIKcHJvcGVydGllcxUBFgESEHNhbHRlZERvbWFpbkhhc2gSA2FzYxIGdW5pcXVlEwESCnByb3BlcnRpZXMWARIQc2FsdGVkRG9tYWluSGFzaBYGEgR0eXBlEgVhcnJheRIJYnl0ZUFycmF5EwESCG1pbkl0ZW1zAiASCG1heEl0ZW1zAiASCHBvc2l0aW9uAgASC2Rlc2NyaXB0aW9uEllEb3VibGUgc2hhLTI1NiBvZiB0aGUgY29uY2F0ZW5hdGlvbiBvZiBhIDMyIGJ5dGUgcmFuZG9tIHNhbHQgYW5kIGEgbm9ybWFsaXplZCBkb21haW4gbmFtZRIIcmVxdWlyZWQVARIQc2FsdGVkRG9tYWluSGFzaBIUYWRkaXRpb25hbFByb3BlcnRpZXMTABIIJGNvbW1lbnQSSlByZW9yZGVyIGRvY3VtZW50cyBhcmUgaW1tdXRhYmxlOiBtb2RpZmljYXRpb24gYW5kIGRlbGV0aW9uIGFyZSByZXN0cmljdGVkAAAAAAAAAAAAAA==';
@@ -0,0 +1,3 @@
1
+ import { StateTransitionWASM } from 'pshenmic-dpp';
2
+ import { VoteWASM } from 'pshenmic-dpp/dist/wasm/pshenmic_dpp';
3
+ export default function createStateTransition(voteWASM: VoteWASM, proTxHash: string, identityNonce: bigint): StateTransitionWASM;
@@ -0,0 +1,9 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.default = createStateTransition;
4
+ var pshenmic_dpp_1 = require("pshenmic-dpp");
5
+ function createStateTransition(voteWASM, proTxHash, identityNonce) {
6
+ var voterIdentity = pshenmic_dpp_1.IdentifierWASM.fromHex(proTxHash);
7
+ var masternodeVoteTransition = new pshenmic_dpp_1.MasternodeVoteTransitionWASM(proTxHash, voterIdentity, voteWASM, identityNonce);
8
+ return masternodeVoteTransition.toStateTransition();
9
+ }
@@ -50,7 +50,6 @@ Object.defineProperty(exports, "__esModule", { value: true });
50
50
  exports.default = getContestedResourceVoteState;
51
51
  var platform_1 = require("../../proto/generated/platform");
52
52
  var pshenmic_dpp_1 = require("pshenmic-dpp");
53
- var wasm_drive_verify_1 = require("wasm-drive-verify");
54
53
  var verifyTenderdashProof_1 = require("../utils/verifyTenderdashProof");
55
54
  var getQuorumPublicKey_1 = require("../utils/getQuorumPublicKey");
56
55
  var bytesToHex_1 = require("../utils/bytesToHex");
@@ -90,7 +89,7 @@ function getContestedResourceVoteState(grpcPool, contract, documentTypeName, ind
90
89
  if (metadata == null) {
91
90
  throw new Error('Metadata not found');
92
91
  }
93
- _b = (0, wasm_drive_verify_1.verifyVotePollVoteStateProof)(proof.grovedbProof, contract.bytes(pshenmic_dpp_1.PlatformVersionWASM.PLATFORM_V9), documentTypeName, indexName, indexValues, resultType, allowIncludeLockedAndAbstainingVoteTally, count, startAtIdentifierInfo, pshenmic_dpp_1.PlatformVersionWASM.PLATFORM_V9), rootHash = _b.root_hash, result = _b.result;
92
+ _b = (0, pshenmic_dpp_1.verifyVotePollVoteStateProof)(proof.grovedbProof, contract, documentTypeName, indexName, indexValues, resultType, allowIncludeLockedAndAbstainingVoteTally, count, startAtIdentifierInfo, pshenmic_dpp_1.PlatformVersionWASM.PLATFORM_V9), rootHash = _b.rootHash, result = _b.result;
94
93
  return [4 /*yield*/, (0, getQuorumPublicKey_1.getQuorumPublicKey)(grpcPool.network, proof.quorumType, (0, bytesToHex_1.default)(proof.quorumHash))];
95
94
  case 2:
96
95
  quorumPublicKey = _e.sent();
@@ -104,9 +103,9 @@ function getContestedResourceVoteState(grpcPool, contract, documentTypeName, ind
104
103
  throw new Error('Vote state not found');
105
104
  }
106
105
  return [2 /*return*/, {
107
- contenders: contenders.map(function (contender) { return (__assign(__assign({}, contender), { identifier: new pshenmic_dpp_1.IdentifierWASM(contender.identifier), document: contender.document != null ? pshenmic_dpp_1.DocumentWASM.fromBytes(contender.document, contract, documentTypeName, pshenmic_dpp_1.PlatformVersionWASM.PLATFORM_V9) : undefined })); }),
108
- abstainVoteTally: (_c = result === null || result === void 0 ? void 0 : result.abstainVoteTally) !== null && _c !== void 0 ? _c : 0,
109
- lockVoteTally: (_d = result === null || result === void 0 ? void 0 : result.lockVoteTally) !== null && _d !== void 0 ? _d : 0,
106
+ contenders: contenders.map(function (contender) { return (__assign(__assign({}, contender), { identifier: contender.identityId, document: contender.serializedDocument != null ? pshenmic_dpp_1.DocumentWASM.fromBytes(contender.serializedDocument, contract, documentTypeName, pshenmic_dpp_1.PlatformVersionWASM.PLATFORM_V9) : undefined })); }),
107
+ abstainVoteTally: (_c = result === null || result === void 0 ? void 0 : result.abstainingVoteTally) !== null && _c !== void 0 ? _c : 0,
108
+ lockVoteTally: (_d = result === null || result === void 0 ? void 0 : result.lockedVoteTally) !== null && _d !== void 0 ? _d : 0,
110
109
  finishedVoteInfo: (winner != null)
111
110
  ? {
112
111
  type: winner.type,
@@ -1,7 +1,7 @@
1
1
  import GRPCConnectionPool from '../grpcConnectionPool';
2
2
  import { ContestedResourceVoteState, ContestedStateResultType } from '../types';
3
- import { StartAtIdentifierInfo } from './getContestedResourceVoteState';
4
3
  import { DataContractWASM } from 'pshenmic-dpp';
4
+ import { StartAtIdentifierInfo } from './getContestedResourceVoteState';
5
5
  /**
6
6
  * Contested Resources controller for requesting information about contested resources
7
7
  *
@@ -39,17 +39,20 @@ Object.defineProperty(exports, "__esModule", { value: true });
39
39
  exports.default = getByIdentifier;
40
40
  var pshenmic_dpp_1 = require("pshenmic-dpp");
41
41
  var platform_1 = require("../../proto/generated/platform");
42
- var wasm_drive_verify_1 = require("wasm-drive-verify");
43
42
  var getQuorumPublicKey_1 = require("../utils/getQuorumPublicKey");
44
43
  var bytesToHex_1 = require("../utils/bytesToHex");
45
44
  var verifyTenderdashProof_1 = require("../utils/verifyTenderdashProof");
45
+ var constants_1 = require("../constants");
46
46
  function getByIdentifier(grpcPool, identifier) {
47
47
  return __awaiter(this, void 0, void 0, function () {
48
- var id, getDataContractRequest, v0, _a, proof, metadata, _b, rootHash, contract, quorumPublicKey, verify;
48
+ var id, getDataContractRequest, v0, _a, proof, metadata, _b, rootHash, dataContract, quorumPublicKey, verify;
49
49
  return __generator(this, function (_c) {
50
50
  switch (_c.label) {
51
51
  case 0:
52
52
  id = new pshenmic_dpp_1.IdentifierWASM(identifier);
53
+ if (id.base58() === constants_1.DPNS_DATA_CONTRACT_ID) {
54
+ return [2 /*return*/, pshenmic_dpp_1.DataContractWASM.fromBase64(constants_1.DPNS_DATA_CONTRACT_BYTES, true, 9)];
55
+ }
53
56
  getDataContractRequest = platform_1.GetDataContractRequest.fromPartial({
54
57
  v0: {
55
58
  id: id.bytes(),
@@ -66,8 +69,8 @@ function getByIdentifier(grpcPool, identifier) {
66
69
  if (metadata == null) {
67
70
  throw new Error('Metadata not found');
68
71
  }
69
- _b = (0, wasm_drive_verify_1.verifyContract)(proof.grovedbProof, undefined, false, false, id.bytes(), 9), rootHash = _b.root_hash, contract = _b.contract;
70
- if (contract == null) {
72
+ _b = (0, pshenmic_dpp_1.verifyContractProof)(proof.grovedbProof, undefined, false, false, id.bytes(), pshenmic_dpp_1.PlatformVersionWASM.PLATFORM_V9), rootHash = _b.rootHash, dataContract = _b.dataContract;
73
+ if (dataContract == null) {
71
74
  throw new Error("Data Contract with identifier ".concat(id.base58(), " not found"));
72
75
  }
73
76
  return [4 /*yield*/, (0, getQuorumPublicKey_1.getQuorumPublicKey)(grpcPool.network, proof.quorumType, (0, bytesToHex_1.default)(proof.quorumHash))];
@@ -77,7 +80,7 @@ function getByIdentifier(grpcPool, identifier) {
77
80
  if (!verify) {
78
81
  throw new Error('Failed to verify query');
79
82
  }
80
- return [2 /*return*/, pshenmic_dpp_1.DataContractWASM.fromBytes(contract, true, pshenmic_dpp_1.PlatformVersionWASM.PLATFORM_V9)];
83
+ return [2 /*return*/, dataContract];
81
84
  }
82
85
  });
83
86
  });
@@ -40,7 +40,6 @@ exports.default = query;
40
40
  var platform_1 = require("../../proto/generated/platform");
41
41
  var pshenmic_dpp_1 = require("pshenmic-dpp");
42
42
  var constants_1 = require("../constants");
43
- var wasm_drive_verify_1 = require("wasm-drive-verify");
44
43
  var getQuorumPublicKey_1 = require("../utils/getQuorumPublicKey");
45
44
  var bytesToHex_1 = require("../utils/bytesToHex");
46
45
  var verifyTenderdashProof_1 = require("../utils/verifyTenderdashProof");
@@ -49,10 +48,10 @@ var getDataContractByIdentifier_1 = require("../dataContracts/getDataContractByI
49
48
  function query(grpcPool_1, dataContractId_1, documentTypeName_1, where_1, orderBy_1) {
50
49
  return __awaiter(this, arguments, void 0, function (grpcPool, dataContractId, documentTypeName, where, orderBy, limit, startAt, startAfter) {
51
50
  var getDocumentsRequest, dataContract, v0, _a, proof, metadata, startAtIncluded, _b, rootHash, documents, quorumPublicKey, verify;
52
- var _c, _d, _e;
51
+ var _c, _d;
53
52
  if (limit === void 0) { limit = 100; }
54
- return __generator(this, function (_f) {
55
- switch (_f.label) {
53
+ return __generator(this, function (_e) {
54
+ switch (_e.label) {
56
55
  case 0:
57
56
  getDocumentsRequest = platform_1.GetDocumentsRequest.fromPartial({
58
57
  v0: {
@@ -68,10 +67,10 @@ function query(grpcPool_1, dataContractId_1, documentTypeName_1, where_1, orderB
68
67
  });
69
68
  return [4 /*yield*/, (0, getDataContractByIdentifier_1.default)(grpcPool, dataContractId)];
70
69
  case 1:
71
- dataContract = _f.sent();
70
+ dataContract = _e.sent();
72
71
  return [4 /*yield*/, grpcPool.getClient().getDocuments(getDocumentsRequest)];
73
72
  case 2:
74
- v0 = (_f.sent()).v0;
73
+ v0 = (_e.sent()).v0;
75
74
  _a = v0, proof = _a.proof, metadata = _a.metadata;
76
75
  if (proof == null) {
77
76
  throw new Error('Proof not found');
@@ -80,15 +79,15 @@ function query(grpcPool_1, dataContractId_1, documentTypeName_1, where_1, orderB
80
79
  throw new Error('Metadata not found');
81
80
  }
82
81
  startAtIncluded = ((_c = getDocumentsRequest.v0) === null || _c === void 0 ? void 0 : _c.startAfter) == null;
83
- _b = (0, wasm_drive_verify_1.verifyDocumentProof)(proof.grovedbProof, dataContract.bytes(pshenmic_dpp_1.PlatformVersionWASM.PLATFORM_V9), documentTypeName, where, orderBy, limit, (_d = getDocumentsRequest.v0) === null || _d === void 0 ? void 0 : _d.startAt, startAtIncluded, BigInt(metadata === null || metadata === void 0 ? void 0 : metadata.timeMs), pshenmic_dpp_1.PlatformVersionWASM.PLATFORM_V9), rootHash = _b.root_hash, documents = _b.documents;
82
+ _b = (0, pshenmic_dpp_1.verifyDocumentsProof)(proof.grovedbProof, dataContract, documentTypeName, where, orderBy, limit, (_d = getDocumentsRequest.v0) === null || _d === void 0 ? void 0 : _d.startAt, startAtIncluded, BigInt(metadata === null || metadata === void 0 ? void 0 : metadata.timeMs), pshenmic_dpp_1.PlatformVersionWASM.PLATFORM_V9), rootHash = _b.rootHash, documents = _b.documents;
84
83
  return [4 /*yield*/, (0, getQuorumPublicKey_1.getQuorumPublicKey)(grpcPool.network, proof.quorumType, (0, bytesToHex_1.default)(proof.quorumHash))];
85
84
  case 3:
86
- quorumPublicKey = _f.sent();
85
+ quorumPublicKey = _e.sent();
87
86
  verify = (0, verifyTenderdashProof_1.default)(proof, metadata, rootHash, quorumPublicKey);
88
87
  if (!verify) {
89
88
  throw new Error('Failed to verify query');
90
89
  }
91
- return [2 /*return*/, (_e = documents === null || documents === void 0 ? void 0 : documents.map(function (document) { return pshenmic_dpp_1.DocumentWASM.fromBytes(document, dataContract, documentTypeName, pshenmic_dpp_1.PlatformVersionWASM.PLATFORM_V9); })) !== null && _e !== void 0 ? _e : []];
90
+ return [2 /*return*/, documents !== null && documents !== void 0 ? documents : []];
92
91
  }
93
92
  });
94
93
  });
@@ -39,7 +39,6 @@ Object.defineProperty(exports, "__esModule", { value: true });
39
39
  exports.default = getIdentityBalance;
40
40
  var platform_1 = require("../../proto/generated/platform");
41
41
  var pshenmic_dpp_1 = require("pshenmic-dpp");
42
- var wasm_drive_verify_1 = require("wasm-drive-verify");
43
42
  var verifyTenderdashProof_1 = require("../utils/verifyTenderdashProof");
44
43
  var getQuorumPublicKey_1 = require("../utils/getQuorumPublicKey");
45
44
  var bytesToHex_1 = require("../utils/bytesToHex");
@@ -66,7 +65,7 @@ function getIdentityBalance(grpcPool, identifier) {
66
65
  if (metadata == null) {
67
66
  throw new Error('Metadata not found');
68
67
  }
69
- _b = (0, wasm_drive_verify_1.verifyIdentityBalanceForIdentityId)(proof.grovedbProof, id.bytes(), true, pshenmic_dpp_1.PlatformVersionWASM.PLATFORM_V9), rootHash = _b.root_hash, balance = _b.balance;
68
+ _b = (0, pshenmic_dpp_1.verifyIdentityBalanceProof)(proof.grovedbProof, id.bytes(), true, pshenmic_dpp_1.PlatformVersionWASM.PLATFORM_V9), rootHash = _b.rootHash, balance = _b.balance;
70
69
  if (balance == null) {
71
70
  throw new Error("Failed to fetch balance for identifier ".concat(id.base58()));
72
71
  }
@@ -39,7 +39,6 @@ Object.defineProperty(exports, "__esModule", { value: true });
39
39
  exports.default = getIdentityByIdentifier;
40
40
  var platform_1 = require("../../proto/generated/platform");
41
41
  var pshenmic_dpp_1 = require("pshenmic-dpp");
42
- var wasm_drive_verify_1 = require("wasm-drive-verify");
43
42
  var getQuorumPublicKey_1 = require("../utils/getQuorumPublicKey");
44
43
  var bytesToHex_1 = require("../utils/bytesToHex");
45
44
  var verifyTenderdashProof_1 = require("../utils/verifyTenderdashProof");
@@ -66,7 +65,7 @@ function getIdentityByIdentifier(grpcPool, identifier) {
66
65
  if (metadata == null) {
67
66
  throw new Error('Metadata not found');
68
67
  }
69
- _b = (0, wasm_drive_verify_1.verifyFullIdentityByIdentityId)(proof.grovedbProof, true, id.bytes(), pshenmic_dpp_1.PlatformVersionWASM.PLATFORM_V9), rootHash = _b.root_hash, identity = _b.identity;
68
+ _b = (0, pshenmic_dpp_1.verifyIdentityByIdentifierProof)(proof.grovedbProof, id, true, pshenmic_dpp_1.PlatformVersionWASM.PLATFORM_V9), rootHash = _b.rootHash, identity = _b.identity;
70
69
  if (identity == null) {
71
70
  throw new Error("Identity with identifier ".concat(id.base58(), " not found"));
72
71
  }
@@ -77,7 +76,7 @@ function getIdentityByIdentifier(grpcPool, identifier) {
77
76
  if (!verify) {
78
77
  throw new Error('Failed to verify query');
79
78
  }
80
- return [2 /*return*/, pshenmic_dpp_1.IdentityWASM.fromBytes(identity)];
79
+ return [2 /*return*/, identity];
81
80
  }
82
81
  });
83
82
  });
@@ -40,14 +40,13 @@ exports.default = getIdentityByNonUniquePublicKeyHash;
40
40
  var platform_1 = require("../../proto/generated/platform");
41
41
  var pshenmic_dpp_1 = require("pshenmic-dpp");
42
42
  var hexToBytes_1 = require("../utils/hexToBytes");
43
- var wasm_drive_verify_1 = require("wasm-drive-verify");
44
43
  var getQuorumPublicKey_1 = require("../utils/getQuorumPublicKey");
45
44
  var bytesToHex_1 = require("../utils/bytesToHex");
46
45
  var verifyTenderdashProof_1 = require("../utils/verifyTenderdashProof");
47
46
  var getIdentityByIdentifier_1 = require("./getIdentityByIdentifier");
48
47
  function getIdentityByNonUniquePublicKeyHash(grpcPool, hex) {
49
48
  return __awaiter(this, void 0, void 0, function () {
50
- var getIdentityByNonUniquePublicKeyHashRequest, v0, _a, proof, metadata, _b, rootHash, identityId, identifier, quorumPublicKey, verify;
49
+ var getIdentityByNonUniquePublicKeyHashRequest, v0, _a, proof, metadata, _b, rootHash, identifier, quorumPublicKey, verify;
51
50
  return __generator(this, function (_c) {
52
51
  switch (_c.label) {
53
52
  case 0:
@@ -67,11 +66,10 @@ function getIdentityByNonUniquePublicKeyHash(grpcPool, hex) {
67
66
  if (metadata == null) {
68
67
  throw new Error('Metadata not found');
69
68
  }
70
- _b = (0, wasm_drive_verify_1.verifyIdentityIdByNonUniquePublicKeyHash)(proof.grovedbIdentityPublicKeyHashProof.grovedbProof, false, (0, hexToBytes_1.default)(hex), undefined, pshenmic_dpp_1.PlatformVersionWASM.PLATFORM_V9), rootHash = _b.root_hash, identityId = _b.identity_id;
71
- if (identityId == null) {
69
+ _b = (0, pshenmic_dpp_1.verifyIdentifierByNonUniquePublicKeyHashProof)(proof.grovedbIdentityPublicKeyHashProof.grovedbProof, false, (0, hexToBytes_1.default)(hex), undefined, pshenmic_dpp_1.PlatformVersionWASM.PLATFORM_V9), rootHash = _b.rootHash, identifier = _b.identifier;
70
+ if (identifier == null) {
72
71
  throw new Error("Identity with non unique public key hash ".concat(hex, " not found"));
73
72
  }
74
- identifier = new pshenmic_dpp_1.IdentifierWASM(identityId);
75
73
  return [4 /*yield*/, (0, getQuorumPublicKey_1.getQuorumPublicKey)(grpcPool.network, proof.grovedbIdentityPublicKeyHashProof.quorumType, (0, bytesToHex_1.default)(proof.grovedbIdentityPublicKeyHashProof.quorumHash))];
76
74
  case 2:
77
75
  quorumPublicKey = _c.sent();
@@ -40,7 +40,6 @@ exports.default = getIdentityByPublicKeyHash;
40
40
  var platform_1 = require("../../proto/generated/platform");
41
41
  var pshenmic_dpp_1 = require("pshenmic-dpp");
42
42
  var hexToBytes_1 = require("../utils/hexToBytes");
43
- var wasm_drive_verify_1 = require("wasm-drive-verify");
44
43
  var getQuorumPublicKey_1 = require("../utils/getQuorumPublicKey");
45
44
  var bytesToHex_1 = require("../utils/bytesToHex");
46
45
  var verifyTenderdashProof_1 = require("../utils/verifyTenderdashProof");
@@ -66,7 +65,7 @@ function getIdentityByPublicKeyHash(grpcPool, hex) {
66
65
  if (metadata == null) {
67
66
  throw new Error('Metadata not found');
68
67
  }
69
- _b = (0, wasm_drive_verify_1.verifyFullIdentityByUniquePublicKeyHash)(proof.grovedbProof, (0, hexToBytes_1.default)(hex), pshenmic_dpp_1.PlatformVersionWASM.PLATFORM_V9), rootHash = _b.root_hash, identity = _b.identity;
68
+ _b = (0, pshenmic_dpp_1.verifyIdentityByUniqueKeyHashProof)(proof.grovedbProof, (0, hexToBytes_1.default)(hex), pshenmic_dpp_1.PlatformVersionWASM.PLATFORM_V9), rootHash = _b.rootHash, identity = _b.identity;
70
69
  if (identity == null) {
71
70
  throw new Error("Identity with public key hash ".concat(hex, " not found"));
72
71
  }
@@ -77,7 +76,7 @@ function getIdentityByPublicKeyHash(grpcPool, hex) {
77
76
  if (!verify) {
78
77
  throw new Error('Failed to verify query');
79
78
  }
80
- return [2 /*return*/, pshenmic_dpp_1.IdentityWASM.fromBytes(identity)];
79
+ return [2 /*return*/, identity];
81
80
  }
82
81
  });
83
82
  });
@@ -39,14 +39,13 @@ Object.defineProperty(exports, "__esModule", { value: true });
39
39
  exports.default = getIdentityContractNonce;
40
40
  var platform_1 = require("../../proto/generated/platform");
41
41
  var pshenmic_dpp_1 = require("pshenmic-dpp");
42
- var wasm_drive_verify_1 = require("wasm-drive-verify");
43
42
  var getQuorumPublicKey_1 = require("../utils/getQuorumPublicKey");
44
43
  var bytesToHex_1 = require("../utils/bytesToHex");
45
44
  var verifyTenderdashProof_1 = require("../utils/verifyTenderdashProof");
46
45
  var IDENTITY_CONTRACT_NONCE_VALUE_FILTER = BigInt(0xFFFFFFFFFF);
47
46
  function getIdentityContractNonce(grpcPool, identity, dataContract) {
48
47
  return __awaiter(this, void 0, void 0, function () {
49
- var identityIdentifier, dataContractIdentifier, getIdentityContractNonceRequest, v0, _a, proof, metadata, _b, rootHash, identityContractNonce, quorumPublicKey, verify;
48
+ var identityIdentifier, dataContractIdentifier, getIdentityContractNonceRequest, v0, _a, proof, metadata, _b, rootHash, contractNonce, quorumPublicKey, verify;
50
49
  return __generator(this, function (_c) {
51
50
  switch (_c.label) {
52
51
  case 0:
@@ -69,8 +68,8 @@ function getIdentityContractNonce(grpcPool, identity, dataContract) {
69
68
  if (metadata == null) {
70
69
  throw new Error('Metadata not found');
71
70
  }
72
- _b = (0, wasm_drive_verify_1.verifyIdentityContractNonce)(proof.grovedbProof, identityIdentifier.bytes(), dataContractIdentifier.bytes(), true, pshenmic_dpp_1.PlatformVersionWASM.PLATFORM_V9), rootHash = _b.root_hash, identityContractNonce = _b.nonce;
73
- if (identityContractNonce == null) {
71
+ _b = (0, pshenmic_dpp_1.verifyIdentityContractNonceProof)(proof.grovedbProof, identityIdentifier.bytes(), dataContractIdentifier.bytes(), true, pshenmic_dpp_1.PlatformVersionWASM.PLATFORM_V9), rootHash = _b.rootHash, contractNonce = _b.contractNonce;
72
+ if (contractNonce == null) {
74
73
  return [2 /*return*/, BigInt(0)];
75
74
  }
76
75
  return [4 /*yield*/, (0, getQuorumPublicKey_1.getQuorumPublicKey)(grpcPool.network, proof.quorumType, (0, bytesToHex_1.default)(proof.quorumHash))];
@@ -80,7 +79,7 @@ function getIdentityContractNonce(grpcPool, identity, dataContract) {
80
79
  if (!verify) {
81
80
  throw new Error('Failed to verify query');
82
81
  }
83
- return [2 /*return*/, BigInt(identityContractNonce) & IDENTITY_CONTRACT_NONCE_VALUE_FILTER];
82
+ return [2 /*return*/, BigInt(contractNonce) & IDENTITY_CONTRACT_NONCE_VALUE_FILTER];
84
83
  }
85
84
  });
86
85
  });
@@ -39,7 +39,6 @@ Object.defineProperty(exports, "__esModule", { value: true });
39
39
  exports.default = getIdentityNonce;
40
40
  var platform_1 = require("../../proto/generated/platform");
41
41
  var pshenmic_dpp_1 = require("pshenmic-dpp");
42
- var wasm_drive_verify_1 = require("wasm-drive-verify");
43
42
  var getQuorumPublicKey_1 = require("../utils/getQuorumPublicKey");
44
43
  var bytesToHex_1 = require("../utils/bytesToHex");
45
44
  var verifyTenderdashProof_1 = require("../utils/verifyTenderdashProof");
@@ -67,7 +66,7 @@ function getIdentityNonce(grpcPool, identifier) {
67
66
  if (metadata == null) {
68
67
  throw new Error('Metadata not found');
69
68
  }
70
- _b = (0, wasm_drive_verify_1.verifyIdentityNonce)(proof.grovedbProof, id.bytes(), true, pshenmic_dpp_1.PlatformVersionWASM.PLATFORM_V9), rootHash = _b.root_hash, nonce = _b.nonce;
69
+ _b = (0, pshenmic_dpp_1.verifyIdentityNonceProof)(proof.grovedbProof, id.bytes(), true, pshenmic_dpp_1.PlatformVersionWASM.PLATFORM_V9), rootHash = _b.rootHash, nonce = _b.nonce;
71
70
  if (nonce == null) {
72
71
  return [2 /*return*/, BigInt(0)];
73
72
  }
@@ -39,13 +39,12 @@ Object.defineProperty(exports, "__esModule", { value: true });
39
39
  exports.default = getIdentityPublicKeys;
40
40
  var platform_1 = require("../../proto/generated/platform");
41
41
  var pshenmic_dpp_1 = require("pshenmic-dpp");
42
- var wasm_drive_verify_1 = require("wasm-drive-verify");
43
42
  var getQuorumPublicKey_1 = require("../utils/getQuorumPublicKey");
44
43
  var bytesToHex_1 = require("../utils/bytesToHex");
45
44
  var verifyTenderdashProof_1 = require("../utils/verifyTenderdashProof");
46
45
  function getIdentityPublicKeys(grpcPool, identifier) {
47
46
  return __awaiter(this, void 0, void 0, function () {
48
- var id, getIdentityKeysRequest, v0, _a, proof, metadata, _b, rootHash, loadedIdentityKeys, quorumPublicKey, verify;
47
+ var id, getIdentityKeysRequest, v0, _a, proof, metadata, _b, rootHash, identity, quorumPublicKey, verify, loadedKeysIds;
49
48
  return __generator(this, function (_c) {
50
49
  switch (_c.label) {
51
50
  case 0:
@@ -67,8 +66,8 @@ function getIdentityPublicKeys(grpcPool, identifier) {
67
66
  if (metadata == null) {
68
67
  throw new Error('Metadata not found');
69
68
  }
70
- _b = (0, wasm_drive_verify_1.verifyIdentityKeysByIdentityId)(proof.grovedbProof, id.bytes(), null, false, false, true, null, null, pshenmic_dpp_1.PlatformVersionWASM.PLATFORM_V9), rootHash = _b.root_hash, loadedIdentityKeys = _b.loaded_identity_keys;
71
- if (loadedIdentityKeys == null) {
69
+ _b = (0, pshenmic_dpp_1.verifyIdentityKeysByIdentifierProof)(proof.grovedbProof, id.bytes(), null, false, false, true, null, null, pshenmic_dpp_1.PlatformVersionWASM.PLATFORM_V9), rootHash = _b.rootHash, identity = _b.identity;
70
+ if (identity == null) {
72
71
  throw new Error("Identity with identifier ".concat(id.base58(), " not found"));
73
72
  }
74
73
  return [4 /*yield*/, (0, getQuorumPublicKey_1.getQuorumPublicKey)(grpcPool.network, proof.quorumType, (0, bytesToHex_1.default)(proof.quorumHash))];
@@ -78,7 +77,8 @@ function getIdentityPublicKeys(grpcPool, identifier) {
78
77
  if (!verify) {
79
78
  throw new Error('Failed to verify query');
80
79
  }
81
- return [2 /*return*/, loadedIdentityKeys.map(function (loadedIdentityKey) { return pshenmic_dpp_1.IdentityPublicKeyWASM.fromBytes(loadedIdentityKey); })];
80
+ loadedKeysIds = Object.keys(identity.loadedPublicKeys);
81
+ return [2 /*return*/, loadedKeysIds.map(function (id) { return identity.loadedPublicKeys[id]; })];
82
82
  }
83
83
  });
84
84
  });
@@ -1,5 +1,6 @@
1
1
  import GRPCConnectionPool from '../grpcConnectionPool';
2
- import { DocumentWASM } from 'pshenmic-dpp';
2
+ import { DocumentWASM, PrivateKeyWASM } from 'pshenmic-dpp';
3
+ import { IdentifierLike } from '../types';
3
4
  /**
4
5
  * Functions related to DPNS names (usernames)
5
6
  *
@@ -23,5 +24,37 @@ export declare class NamesController {
23
24
  *
24
25
  * @return Promise<DocumentWASM | null>
25
26
  */
26
- search(name: string): Promise<DocumentWASM | null>;
27
+ searchByName(name: string): Promise<DocumentWASM[]>;
28
+ /**
29
+ * Tests a given username against contested names rules.
30
+ * Contested names includes an additional fee of 0.2 Dash
31
+ * as a voting resolution fee
32
+ *
33
+ * This function return boolean whether given username (f.e pshenmic.dash)
34
+ * falls under contested names rules.
35
+ * @param name
36
+ */
37
+ testNameContested(name: string): boolean;
38
+ searchByIdentity(identifier: IdentifierLike): Promise<DocumentWASM[]>;
39
+ /**
40
+ * Performs a DPNS name registration sequence
41
+ * Contested names are include additional fee of 0.2 Dash
42
+ * Check your name is contested with .testNameContested(name) method to check if additional fee will be charged
43
+ *
44
+ * @param name {string} username (ex. pshenmic.dash)
45
+ * @param identityId {IdentifierLike} identity identifier
46
+ * @param privateKey {PrivateKeyWASM} Authentication / High private key from your identity
47
+ */
48
+ registerName(name: string, identityId: IdentifierLike, privateKey: PrivateKeyWASM): Promise<void>;
49
+ /**
50
+ * Converts DPNS name to normalized format (ex. alice.dash -> al1ce.dash)
51
+ *
52
+ * source: https://github.com/dashpay/platform/blob/master/packages/js-dash-sdk/src/utils/convertToHomographSafeChars.ts
53
+ *
54
+ *
55
+ * @param label {string}
56
+ *
57
+ * @return {string}
58
+ */
59
+ normalizeLabel(label: string): string;
27
60
  }