@bithomp/xrpl-api 3.2.16 → 3.2.18

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.
@@ -9,12 +9,42 @@ const common_1 = require("../common");
9
9
  const ledger_1 = require("../models/ledger");
10
10
  function accountObjectsToAccountLines(account, accountObjects) {
11
11
  const notInDefaultState = accountObjects.filter((node) => {
12
- return (node.LedgerEntryType === "RippleState" &&
13
- node.Flags & RippleStateFlags[node.HighLimit.issuer === account ? "lsfHighReserve" : "lsfLowReserve"]);
12
+ if (node.LedgerEntryType !== "RippleState") {
13
+ return false;
14
+ }
15
+ if (node.HighLimit.issuer === account) {
16
+ if (node.Flags & RippleStateFlags.lsfHighReserve) {
17
+ if (isPositiveBalance(node.Balance.value)) {
18
+ return false;
19
+ }
20
+ return true;
21
+ }
22
+ if (isNegativeBalance(node.Balance.value)) {
23
+ return true;
24
+ }
25
+ }
26
+ else {
27
+ if (node.Flags & RippleStateFlags.lsfLowReserve) {
28
+ if (isNegativeBalance(node.Balance.value)) {
29
+ return false;
30
+ }
31
+ return true;
32
+ }
33
+ if (isPositiveBalance(node.Balance.value)) {
34
+ return true;
35
+ }
36
+ }
37
+ return false;
14
38
  });
15
39
  const accountLinesFormatted = notInDefaultState.map((node) => RippleStateToTrustLine(node, account));
16
40
  return accountLinesFormatted;
17
41
  }
42
+ function isPositiveBalance(balance) {
43
+ return balance !== "0" && balance[0] !== "-";
44
+ }
45
+ function isNegativeBalance(balance) {
46
+ return balance !== "0" && balance[0] === "-";
47
+ }
18
48
  const RippleStateToTrustLine = (ledgerEntry, account) => {
19
49
  const parties = [ledgerEntry.HighLimit, ledgerEntry.LowLimit];
20
50
  const [self, counterparty] = ledgerEntry.HighLimit.issuer === account ? parties : parties.reverse();
@@ -29,4 +29,6 @@ import parseNFTokenAcceptOffer from "../parse/specification/nftoken-accept-offer
29
29
  import parseNFTokenCancelOffer from "../parse/specification/nftoken-cancel-offer";
30
30
  import parseNFTokenCreateOffer from "../parse/specification/nftoken-create-offer";
31
31
  import parseURITokenFlags from "../parse/ledger/uritoken-flags";
32
- export { parseNFTokenMint, parseNFTokenBurn, parseNFTokenFlags, parseNFTOfferFlags, parseNFTokenAcceptOffer, parseNFTokenCancelOffer, parseNFTokenCreateOffer, parseURITokenFlags, };
32
+ import parseTrustlineFlags from "../parse/ledger/trustline-flags";
33
+ import parseOfferFlags from "../parse/ledger/offer-flags";
34
+ export { parseNFTokenMint, parseNFTokenBurn, parseNFTokenFlags, parseNFTOfferFlags, parseNFTokenAcceptOffer, parseNFTokenCancelOffer, parseNFTokenCreateOffer, parseURITokenFlags, parseTrustlineFlags, parseOfferFlags, };
@@ -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.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.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);
@@ -69,3 +69,7 @@ const nftoken_create_offer_1 = __importDefault(require("../parse/specification/n
69
69
  exports.parseNFTokenCreateOffer = nftoken_create_offer_1.default;
70
70
  const uritoken_flags_1 = __importDefault(require("../parse/ledger/uritoken-flags"));
71
71
  exports.parseURITokenFlags = uritoken_flags_1.default;
72
+ const trustline_flags_1 = __importDefault(require("../parse/ledger/trustline-flags"));
73
+ exports.parseTrustlineFlags = trustline_flags_1.default;
74
+ const offer_flags_1 = __importDefault(require("../parse/ledger/offer-flags"));
75
+ exports.parseOfferFlags = offer_flags_1.default;
@@ -0,0 +1,5 @@
1
+ import { OfferFlagsKeysInterface } from "../../types/offers";
2
+ declare function parseOfferFlags(value: number, options?: {
3
+ excludeFalse?: boolean;
4
+ }): OfferFlagsKeysInterface;
5
+ export default parseOfferFlags;
@@ -0,0 +1,8 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ const offers_1 = require("../../types/offers");
4
+ const flags_1 = require("./flags");
5
+ function parseOfferFlags(value, options = {}) {
6
+ return (0, flags_1.parseFlags)(value, offers_1.OfferFlagsKeys, options);
7
+ }
8
+ exports.default = parseOfferFlags;
@@ -0,0 +1,5 @@
1
+ import { TrustlineFlagsKeysInterface } from "../../types/trustlines";
2
+ declare function parseTrustlineFlags(value: number, options?: {
3
+ excludeFalse?: boolean;
4
+ }): TrustlineFlagsKeysInterface;
5
+ export default parseTrustlineFlags;
@@ -0,0 +1,8 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ const trustlines_1 = require("../../types/trustlines");
4
+ const flags_1 = require("./flags");
5
+ function parseTrustlineFlags(value, options = {}) {
6
+ return (0, flags_1.parseFlags)(value, trustlines_1.TrustlineFlagsKeys, options);
7
+ }
8
+ exports.default = parseTrustlineFlags;
@@ -7,12 +7,14 @@ export declare const NFTokenFlagsKeys: {
7
7
  onlyXRP: NFTokenMintFlags;
8
8
  trustLine: NFTokenMintFlags;
9
9
  transferable: NFTokenMintFlags;
10
+ mutable: NFTokenMintFlags;
10
11
  };
11
12
  export interface NFTokenFlagsKeysInterface {
12
13
  burnable?: boolean;
13
14
  onlyXRP?: boolean;
14
15
  trustLine?: boolean;
15
16
  transferable?: boolean;
17
+ mutable?: boolean;
16
18
  }
17
19
  export declare const NFTokenOfferFlagsKeys: {
18
20
  sellToken: NFTokenCreateOfferFlags;
@@ -7,6 +7,7 @@ exports.NFTokenFlagsKeys = {
7
7
  onlyXRP: xrpl_1.NFTokenMintFlags.tfOnlyXRP,
8
8
  trustLine: xrpl_1.NFTokenMintFlags.tfTrustLine,
9
9
  transferable: xrpl_1.NFTokenMintFlags.tfTransferable,
10
+ mutable: xrpl_1.NFTokenMintFlags.tfMutable,
10
11
  };
11
12
  exports.NFTokenOfferFlagsKeys = {
12
13
  sellToken: xrpl_1.NFTokenCreateOfferFlags.tfSellNFToken,
@@ -1,5 +1,14 @@
1
+ import { LedgerEntry } from "xrpl";
1
2
  import { FormattedBaseSpecification } from "./specification";
2
3
  import { FormattedIssuedCurrencyAmount } from "./amounts";
4
+ export declare const OfferFlagsKeys: {
5
+ passive: LedgerEntry.OfferFlags;
6
+ sell: LedgerEntry.OfferFlags;
7
+ };
8
+ export interface OfferFlagsKeysInterface {
9
+ passive: boolean;
10
+ sell: boolean;
11
+ }
3
12
  export type FormattedOfferCancelSpecification = {
4
13
  orderSequence: number;
5
14
  } & FormattedBaseSpecification;
@@ -1,2 +1,9 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.OfferFlagsKeys = void 0;
4
+ const xrpl_1 = require("xrpl");
5
+ const { OfferFlags } = xrpl_1.LedgerEntry;
6
+ exports.OfferFlagsKeys = {
7
+ passive: OfferFlags.lsfPassive,
8
+ sell: OfferFlags.lsfSell,
9
+ };
@@ -1,4 +1,31 @@
1
+ import { LedgerEntry } from "xrpl";
1
2
  import { FormattedBaseSpecification } from "./specification";
3
+ export declare const TrustlineFlagsKeys: {
4
+ lowReserve: LedgerEntry.RippleStateFlags;
5
+ highReserve: LedgerEntry.RippleStateFlags;
6
+ lowAuth: LedgerEntry.RippleStateFlags;
7
+ highAuth: LedgerEntry.RippleStateFlags;
8
+ lowNoRipple: LedgerEntry.RippleStateFlags;
9
+ highNoRipple: LedgerEntry.RippleStateFlags;
10
+ lowFreeze: LedgerEntry.RippleStateFlags;
11
+ highFreeze: LedgerEntry.RippleStateFlags;
12
+ ammNode: LedgerEntry.RippleStateFlags;
13
+ lowDeepFreeze: LedgerEntry.RippleStateFlags;
14
+ highDeepFreeze: LedgerEntry.RippleStateFlags;
15
+ };
16
+ export interface TrustlineFlagsKeysInterface {
17
+ lowReserve: boolean;
18
+ highReserve: boolean;
19
+ lowAuth: boolean;
20
+ highAuth: boolean;
21
+ lowNoRipple: boolean;
22
+ highNoRipple: boolean;
23
+ lowFreeze: boolean;
24
+ highFreeze: boolean;
25
+ ammNode: boolean;
26
+ lowDeepFreeze: boolean;
27
+ highDeepFreeze: boolean;
28
+ }
2
29
  export interface Trustline {
3
30
  account: string;
4
31
  balance: string;
@@ -1,2 +1,18 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.TrustlineFlagsKeys = void 0;
4
+ const xrpl_1 = require("xrpl");
5
+ const { RippleStateFlags } = xrpl_1.LedgerEntry;
6
+ exports.TrustlineFlagsKeys = {
7
+ lowReserve: RippleStateFlags.lsfLowReserve,
8
+ highReserve: RippleStateFlags.lsfHighReserve,
9
+ lowAuth: RippleStateFlags.lsfLowAuth,
10
+ highAuth: RippleStateFlags.lsfHighAuth,
11
+ lowNoRipple: RippleStateFlags.lsfLowNoRipple,
12
+ highNoRipple: RippleStateFlags.lsfHighNoRipple,
13
+ lowFreeze: RippleStateFlags.lsfLowFreeze,
14
+ highFreeze: RippleStateFlags.lsfHighFreeze,
15
+ ammNode: RippleStateFlags.lsfAMMNode,
16
+ lowDeepFreeze: RippleStateFlags.lsfLowDeepFreeze,
17
+ highDeepFreeze: RippleStateFlags.lsfHighDeepFreeze,
18
+ };
package/lib/validator.js CHANGED
@@ -61,7 +61,7 @@ function classicAddressFromValidatorPK(pk) {
61
61
  assert.ok(pubkey.length === 33);
62
62
  assert.ok(Crypto.getHashes().includes("sha256"));
63
63
  assert.ok(Crypto.getHashes().includes("ripemd160"));
64
- const pubkeyInnerHash = Crypto.createHash("sha256").update(Buffer.from(pubkey));
64
+ const pubkeyInnerHash = Crypto.createHash("sha256").update(pubkey);
65
65
  const pubkeyOuterHash = Crypto.createHash("ripemd160");
66
66
  pubkeyOuterHash.update(pubkeyInnerHash.digest());
67
67
  const accountID = pubkeyOuterHash.digest();
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@bithomp/xrpl-api",
3
- "version": "3.2.16",
3
+ "version": "3.2.18",
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",
@@ -52,8 +52,8 @@
52
52
  "lib/**/*"
53
53
  ],
54
54
  "dependencies": {
55
- "axios": "^1.8.1",
56
- "base-x": "^5.0.0",
55
+ "axios": "^1.8.2",
56
+ "base-x": "^5.0.1",
57
57
  "bignumber.js": "^9.1.2",
58
58
  "elliptic": "^6.6.1",
59
59
  "lodash": "^4.17.21",
@@ -63,26 +63,26 @@
63
63
  },
64
64
  "devDependencies": {
65
65
  "@eslint/eslintrc": "^3.3.0",
66
- "@types/chai": "^5.0.1",
66
+ "@types/chai": "^5.2.0",
67
67
  "@types/chai-as-promised": "^8.0.1",
68
- "@types/lodash": "^4.17.15",
68
+ "@types/lodash": "^4.17.16",
69
69
  "@types/mocha": "^10.0.10",
70
70
  "@types/nconf": "^0.10.7",
71
- "@types/node": "^22.13.5",
72
- "@typescript-eslint/eslint-plugin": "^8.25.0",
73
- "@typescript-eslint/parser": "^8.25.0",
71
+ "@types/node": "^22.13.10",
72
+ "@typescript-eslint/eslint-plugin": "^8.26.0",
73
+ "@typescript-eslint/parser": "^8.26.0",
74
74
  "chai": "^4.5.0",
75
75
  "chai-as-promised": "^7.1.2",
76
- "eslint": "^9.21.0",
77
- "eslint-config-prettier": "^10.0.2",
76
+ "eslint": "^9.22.0",
77
+ "eslint-config-prettier": "^10.1.1",
78
78
  "eslint-plugin-chai-friendly": "^1.0.1",
79
79
  "eslint-plugin-import": "^2.31.0",
80
- "eslint-plugin-n": "^17.15.1",
80
+ "eslint-plugin-n": "^17.16.2",
81
81
  "eslint-plugin-promise": "^7.2.1",
82
82
  "mocha": "^11.1.0",
83
83
  "nconf": "^0.12.1",
84
84
  "ts-jest": "^29.2.6",
85
85
  "ts-node": "^10.9.2",
86
- "typescript": "^5.7.3"
86
+ "typescript": "^5.8.2"
87
87
  }
88
88
  }