@bithomp/xrpl-api 3.6.4 → 3.6.8

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.
@@ -33,4 +33,5 @@ import parseURITokenFlags from "../parse/ledger/uritoken-flags";
33
33
  import parseTrustlineFlags from "../parse/ledger/trustline-flags";
34
34
  import parseOfferFlags from "../parse/ledger/offer-flags";
35
35
  import parseCredentialFlags from "../parse/ledger/credential-flags";
36
- export { parseNFTokenMint, parseNFTokenBurn, parseNFTokenFlags, parseNFTOfferFlags, parseNFTokenAcceptOffer, parseNFTokenCancelOffer, parseNFTokenCreateOffer, parseURITokenFlags, parseTrustlineFlags, parseOfferFlags, parseCredentialFlags, };
36
+ import parseMPTokenIssuanceFlags from "../parse/ledger/mptoken-issuance-flags";
37
+ export { parseNFTokenMint, parseNFTokenBurn, parseNFTokenFlags, parseNFTOfferFlags, parseNFTokenAcceptOffer, parseNFTokenCancelOffer, parseNFTokenCreateOffer, parseURITokenFlags, parseTrustlineFlags, parseOfferFlags, parseCredentialFlags, parseMPTokenIssuanceFlags, };
@@ -17,7 +17,7 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
17
17
  return (mod && mod.__esModule) ? mod : { "default": mod };
18
18
  };
19
19
  Object.defineProperty(exports, "__esModule", { value: true });
20
- exports.parseCredentialFlags = exports.parseOfferFlags = exports.parseTrustlineFlags = exports.parseURITokenFlags = exports.parseNFTokenCreateOffer = exports.parseNFTokenCancelOffer = exports.parseNFTokenAcceptOffer = exports.parseNFTOfferFlags = exports.parseNFTokenFlags = exports.parseNFTokenBurn = exports.parseNFTokenMint = exports.parseMPTokenChanges = exports.parseMPTokenIssuanceChanges = exports.parseOrderbookChanges = exports.parseChannelChanges = exports.parseLockedBalanceChanges = exports.parseFinalBalances = exports.parseBalanceChanges = exports.parseURITokenSellOfferChanges = exports.parseURITokenChanges = exports.parseNFTokenOfferChanges = exports.parseNFTokenChanges = exports.parseAffectedObjects = void 0;
20
+ exports.parseMPTokenIssuanceFlags = exports.parseCredentialFlags = exports.parseOfferFlags = exports.parseTrustlineFlags = exports.parseURITokenFlags = exports.parseNFTokenCreateOffer = exports.parseNFTokenCancelOffer = exports.parseNFTokenAcceptOffer = exports.parseNFTOfferFlags = exports.parseNFTokenFlags = exports.parseNFTokenBurn = exports.parseNFTokenMint = exports.parseMPTokenChanges = exports.parseMPTokenIssuanceChanges = exports.parseOrderbookChanges = exports.parseChannelChanges = exports.parseLockedBalanceChanges = exports.parseFinalBalances = exports.parseBalanceChanges = exports.parseURITokenSellOfferChanges = exports.parseURITokenChanges = exports.parseNFTokenOfferChanges = exports.parseNFTokenChanges = exports.parseAffectedObjects = void 0;
21
21
  __exportStar(require("./account_info"), exports);
22
22
  __exportStar(require("./account_nfts"), exports);
23
23
  __exportStar(require("./account_object"), exports);
@@ -76,3 +76,5 @@ const offer_flags_1 = __importDefault(require("../parse/ledger/offer-flags"));
76
76
  exports.parseOfferFlags = offer_flags_1.default;
77
77
  const credential_flags_1 = __importDefault(require("../parse/ledger/credential-flags"));
78
78
  exports.parseCredentialFlags = credential_flags_1.default;
79
+ const mptoken_issuance_flags_1 = __importDefault(require("../parse/ledger/mptoken-issuance-flags"));
80
+ exports.parseMPTokenIssuanceFlags = mptoken_issuance_flags_1.default;
@@ -0,0 +1,6 @@
1
+ import { MPTokenIssuanceFlagsKeysInterface } from "../../types/mptokens";
2
+ declare function parseMPTokenIssuanceFlags(value: number, options?: {
3
+ excludeFalse?: boolean;
4
+ nativeCurrency?: string;
5
+ }): MPTokenIssuanceFlagsKeysInterface;
6
+ export default parseMPTokenIssuanceFlags;
@@ -0,0 +1,8 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ const mptokens_1 = require("../../types/mptokens");
4
+ const flags_1 = require("./flags");
5
+ function parseMPTokenIssuanceFlags(value, options = {}) {
6
+ return (0, flags_1.parseFlags)(value, mptokens_1.MPTokenIssuanceFlagsKeys, options);
7
+ }
8
+ exports.default = parseMPTokenIssuanceFlags;
@@ -10,6 +10,7 @@ const bignumber_js_1 = __importDefault(require("bignumber.js"));
10
10
  const common_1 = require("../../common");
11
11
  const client_1 = require("../../client");
12
12
  const utils_1 = require("../utils");
13
+ const mptoken_1 = require("../../models/mptoken");
13
14
  function groupByAddress(balanceChanges) {
14
15
  const grouped = lodash_1.default.groupBy(balanceChanges, function (node) {
15
16
  return node.address;
@@ -27,7 +28,7 @@ function parseValue(value) {
27
28
  if (typeof value === "string" || typeof value === "number") {
28
29
  return new bignumber_js_1.default(value);
29
30
  }
30
- return new bignumber_js_1.default(value.value ?? value.MPTAmount ?? 0);
31
+ return new bignumber_js_1.default(value.value ?? 0);
31
32
  }
32
33
  function computeBalanceChange(node) {
33
34
  let value = null;
@@ -41,7 +42,16 @@ function computeBalanceChange(node) {
41
42
  value = parseValue(node.finalFields.Balance).minus(parseValue(node.previousFields.Balance));
42
43
  }
43
44
  else if (node.previousFields.MPTAmount || node.finalFields.MPTAmount) {
44
- value = parseValue(node.finalFields).minus(parseValue(node.previousFields));
45
+ value = parseValue(node.finalFields.MPTAmount ?? 0).minus(parseValue(node.previousFields.MPTAmount ?? 0));
46
+ }
47
+ else if (node.newFields.MaximumAmount) {
48
+ value = parseValue(node.newFields.MaximumAmount);
49
+ }
50
+ else if (node.diffType === "DeletedNode" && node.finalFields.MaximumAmount) {
51
+ value = parseValue(node.finalFields.MaximumAmount).multipliedBy(-1);
52
+ }
53
+ else if (node.previousFields.OutstandingAmount) {
54
+ value = parseValue(node.previousFields.OutstandingAmount ?? 0).minus(parseValue(node.finalFields.OutstandingAmount ?? 0));
45
55
  }
46
56
  return value === null ? null : value.isZero() ? null : value;
47
57
  }
@@ -53,7 +63,16 @@ function parseFinalBalance(node) {
53
63
  return parseValue(node.finalFields.Balance);
54
64
  }
55
65
  else if (node.finalFields.MPTAmount) {
56
- return parseValue(node.finalFields);
66
+ return parseValue(node.finalFields.MPTAmount);
67
+ }
68
+ else if (node.newFields.MaximumAmount) {
69
+ return parseValue(node.newFields.MaximumAmount);
70
+ }
71
+ else if (node.diffType === "DeletedNode" && node.finalFields.MaximumAmount) {
72
+ return new bignumber_js_1.default(0);
73
+ }
74
+ else if (node.finalFields.MaximumAmount) {
75
+ return parseValue(node.finalFields.MaximumAmount).minus(parseValue(node.finalFields.OutstandingAmount));
57
76
  }
58
77
  return null;
59
78
  }
@@ -125,10 +144,24 @@ function parseMPTQuantity(node, valueParser) {
125
144
  },
126
145
  };
127
146
  }
147
+ function parseMPTokenIssuanceQuantity(node, valueParser) {
148
+ const value = valueParser(node);
149
+ if (value === null) {
150
+ return null;
151
+ }
152
+ const fields = lodash_1.default.isEmpty(node.newFields) ? node.finalFields : node.newFields;
153
+ return {
154
+ address: fields.Issuer,
155
+ balance: {
156
+ value: value.toString(),
157
+ mpt_issuance_id: (0, mptoken_1.buildMPTokenIssuanceID)(fields.Sequence, fields.Issuer),
158
+ },
159
+ };
160
+ }
128
161
  function parseQuantities(metadata, valueParser, nativeCurrency) {
129
162
  const values = metadata.AffectedNodes.map(function (affectedNode) {
130
163
  const node = affectedNode.CreatedNode || affectedNode.ModifiedNode || affectedNode.DeletedNode;
131
- if (!["AccountRoot", "RippleState", "MPToken"].includes(node.LedgerEntryType)) {
164
+ if (!["AccountRoot", "RippleState", "MPToken", "MPTokenIssuance"].includes(node.LedgerEntryType)) {
132
165
  return [];
133
166
  }
134
167
  const normalizedNode = (0, utils_1.normalizeNode)(affectedNode);
@@ -141,6 +174,9 @@ function parseQuantities(metadata, valueParser, nativeCurrency) {
141
174
  else if (node.LedgerEntryType === "MPToken") {
142
175
  return [parseMPTQuantity(normalizedNode, valueParser)];
143
176
  }
177
+ else if (node.LedgerEntryType === "MPTokenIssuance") {
178
+ return [parseMPTokenIssuanceQuantity(normalizedNode, valueParser)];
179
+ }
144
180
  return [];
145
181
  });
146
182
  return groupByAddress(lodash_1.default.compact(lodash_1.default.flatten(values)));
@@ -7,6 +7,7 @@ exports.parseMPTokenIssuanceChanges = parseMPTokenIssuanceChanges;
7
7
  const bignumber_js_1 = __importDefault(require("bignumber.js"));
8
8
  const common_1 = require("../../common");
9
9
  const mptoken_1 = require("../../models/mptoken");
10
+ const mptoken_issuance_flags_1 = __importDefault(require("../ledger/mptoken-issuance-flags"));
10
11
  function parseMPTokenIssuanceChanges(tx) {
11
12
  return new MPTokenIssuanceChanges(tx).call();
12
13
  }
@@ -42,7 +43,7 @@ class MPTokenIssuanceChanges {
42
43
  const mptIssuanceID = (0, mptoken_1.buildMPTokenIssuanceID)(node.NewFields.Sequence, node.NewFields.Issuer);
43
44
  this.addChange(mptIssuanceID, {
44
45
  status: "added",
45
- flags: node.NewFields.Flags,
46
+ flags: (0, mptoken_issuance_flags_1.default)(node.NewFields.Flags),
46
47
  mptIssuanceID,
47
48
  issuer: node.NewFields.Issuer,
48
49
  sequence: node.NewFields.Sequence,
@@ -63,7 +64,7 @@ class MPTokenIssuanceChanges {
63
64
  }
64
65
  this.addChange(mptIssuanceID, {
65
66
  status: "modified",
66
- flags: node.FinalFields.Flags,
67
+ flags: (0, mptoken_issuance_flags_1.default)(node.FinalFields.Flags),
67
68
  mptIssuanceID,
68
69
  issuer: node.FinalFields.Issuer,
69
70
  sequence: node.FinalFields.Sequence,
@@ -73,14 +74,14 @@ class MPTokenIssuanceChanges {
73
74
  metadata: node.FinalFields.Metadata,
74
75
  scale: node.FinalFields.AssetScale,
75
76
  outstandingAmountChange,
76
- flagsChange: node.PreviousFields.Flags,
77
+ flagsChange: node.PreviousFields.hasOwnProperty("Flags") ? (0, mptoken_issuance_flags_1.default)(node.PreviousFields.Flags) : undefined,
77
78
  });
78
79
  }
79
80
  if (affectedNode.DeletedNode) {
80
81
  const mptIssuanceID = (0, mptoken_1.buildMPTokenIssuanceID)(node.FinalFields.Sequence, node.FinalFields.Issuer);
81
82
  this.addChange(mptIssuanceID, {
82
83
  status: "removed",
83
- flags: node.FinalFields.Flags,
84
+ flags: (0, mptoken_issuance_flags_1.default)(node.FinalFields.Flags),
84
85
  mptIssuanceID,
85
86
  issuer: node.FinalFields.Issuer,
86
87
  sequence: node.FinalFields.Sequence,
@@ -1,6 +1,24 @@
1
1
  import { MPTokenIssuanceCreateFlags, MPTokenIssuanceSetFlags, MPTokenAuthorizeFlags } from "xrpl";
2
2
  import { FormattedBaseSpecification } from "./specification";
3
3
  import { TxGlobalFlagsKeysInterface } from "./global";
4
+ export declare const MPTokenIssuanceFlagsKeys: {
5
+ locked: number;
6
+ canLock: MPTokenIssuanceCreateFlags;
7
+ requireAuth: MPTokenIssuanceCreateFlags;
8
+ canEscrow: MPTokenIssuanceCreateFlags;
9
+ canTrade: MPTokenIssuanceCreateFlags;
10
+ canTransfer: MPTokenIssuanceCreateFlags;
11
+ canClawback: MPTokenIssuanceCreateFlags;
12
+ };
13
+ export interface MPTokenIssuanceFlagsKeysInterface {
14
+ locked?: boolean;
15
+ canLock?: boolean;
16
+ requireAuth?: boolean;
17
+ canEscrow?: boolean;
18
+ canTrade?: boolean;
19
+ canTransfer?: boolean;
20
+ canClawback?: boolean;
21
+ }
4
22
  export declare const MPTokenIssuanceCreateFlagsKeys: {
5
23
  canLock: MPTokenIssuanceCreateFlags;
6
24
  requireAuth: MPTokenIssuanceCreateFlags;
@@ -1,12 +1,21 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.MPTokenAuthorizeFlagsKeys = exports.MPTokenIssuanceSetFlagsKeys = exports.MPTokenIssuanceCreateFlagsKeys = void 0;
3
+ exports.MPTokenAuthorizeFlagsKeys = exports.MPTokenIssuanceSetFlagsKeys = exports.MPTokenIssuanceCreateFlagsKeys = exports.MPTokenIssuanceFlagsKeys = void 0;
4
4
  exports.getMPTokenIssuanceCreateFlagsKeys = getMPTokenIssuanceCreateFlagsKeys;
5
5
  exports.getMPTokenIssuanceSetFlagsKeys = getMPTokenIssuanceSetFlagsKeys;
6
6
  exports.getMPTokenAuthorizeFlagsKeys = getMPTokenAuthorizeFlagsKeys;
7
7
  const xrpl_1 = require("xrpl");
8
8
  const global_1 = require("./global");
9
9
  const common_1 = require("../common");
10
+ exports.MPTokenIssuanceFlagsKeys = {
11
+ locked: 0x00000001,
12
+ canLock: xrpl_1.MPTokenIssuanceCreateFlags.tfMPTCanLock,
13
+ requireAuth: xrpl_1.MPTokenIssuanceCreateFlags.tfMPTRequireAuth,
14
+ canEscrow: xrpl_1.MPTokenIssuanceCreateFlags.tfMPTCanEscrow,
15
+ canTrade: xrpl_1.MPTokenIssuanceCreateFlags.tfMPTCanTrade,
16
+ canTransfer: xrpl_1.MPTokenIssuanceCreateFlags.tfMPTCanTransfer,
17
+ canClawback: xrpl_1.MPTokenIssuanceCreateFlags.tfMPTCanClawback,
18
+ };
10
19
  exports.MPTokenIssuanceCreateFlagsKeys = {
11
20
  canLock: xrpl_1.MPTokenIssuanceCreateFlags.tfMPTCanLock,
12
21
  requireAuth: xrpl_1.MPTokenIssuanceCreateFlags.tfMPTRequireAuth,
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@bithomp/xrpl-api",
3
- "version": "3.6.4",
3
+ "version": "3.6.8",
4
4
  "description": "A Bithomp JavaScript/TypeScript library for interacting with the XRP Ledger",
5
5
  "main": "lib/index.js",
6
6
  "types": "lib/index.d.ts",
@@ -43,7 +43,7 @@
43
43
  "format": "prettier --write \"src/**/*.ts\" \"src/**/*.js\"",
44
44
  "lint": "eslint",
45
45
  "prepare": "npm run build",
46
- "prepublishOnly": "npm test && npm run lint",
46
+ "-prepublishOnly": "npm test && npm run lint",
47
47
  "preversion": "npm run lint",
48
48
  "version": "npm run format && git add -A src",
49
49
  "postversion": "git push && git push --tags"