UNPKG

@coolwallet/sol

Version:
136 lines (134 loc) 20 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); var _typeof = require("@babel/runtime/helpers/typeof"); Object.defineProperty(exports, "__esModule", { value: true }); exports.computeBudgetEncode = computeBudgetEncode; exports.numberToStringHex = exports.isBase58Format = exports.formHex = exports.encodeLength = void 0; exports.pubKeyToAddress = pubKeyToAddress; exports.splDataEncode = splDataEncode; exports.toBase58 = toBase58; exports.toBase58Buffer = toBase58Buffer; exports.toPublicKey = toPublicKey; exports.toReverseUintBuffer = toReverseUintBuffer; exports.toUintBuffer = toUintBuffer; var _bs = _interopRequireDefault(require("bs58")); var _bn = _interopRequireDefault(require("bn.js")); var _types = _interopRequireWildcard(require("../config/types")); var types = _types; function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(e) { return e ? t : r; })(e); } function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != _typeof(e) && "function" != typeof e) return { "default": e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && {}.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n["default"] = e, t && t.set(e, n), n; } var HEX_REGEX = /[0-9A-Fa-f]{6}/g; var isBase58Format = exports.isBase58Format = function isBase58Format(value) { if (!value) return false; return /^[A-HJ-NP-Za-km-z1-9]*$/.test(value); }; function isHexFormat(value) { var match = value.match(HEX_REGEX); return !!match; } function toBase58(publicKey) { if (typeof publicKey === 'string') { if (isBase58Format(publicKey)) return publicKey; if (isHexFormat(publicKey)) return _bs["default"].encode(Buffer.from(publicKey, 'hex')); return publicKey; } return _bs["default"].encode(publicKey); } function toBase58Buffer(publicKey) { if (typeof publicKey === 'string') { if (isBase58Format(publicKey)) return _bs["default"].decode(publicKey); if (isHexFormat(publicKey)) return Buffer.from(publicKey, 'hex'); return Buffer.from(publicKey); } return publicKey; } function toPublicKey(publicKey) { if (typeof publicKey === 'string') return publicKey; return _bs["default"].encode(publicKey); } function pubKeyToAddress(publicKey) { var pubKeyBuf = Buffer.from(publicKey, 'hex'); return _bs["default"].encode(pubKeyBuf); } /** * CW-21334 Fixed user's publicKey just matches the base58 encoding, resulting in repeated decoding. * * The user's Solana address (base58 encoded) is: * 5XZiuCyozesbRJsSdoJQCTHQRnTGDfSms5bV1ybLn9yg * * After converting it to Hex: * fc238b62abd32cd576f1d5568d3b6b5cb2fbc57b419cc2b4cd8a2814973919a7 * This hex conform to the Base58 format (without 0, O, i, I, +, /), causing base58.decode to be executed again, resulting in an incorrect publicKey. * * How to fix it: * Adjust base58 verification method. A 32-byte public key can only be base58 encoded using 43 or 44 characters. */ var formHex = exports.formHex = function formHex(address) { if (!address) return ''; if (typeof address === 'string') { if (isBase58Format(address)) return _bs["default"].decode(address).toString('hex'); return address; } return address.toString('hex'); }; var numberToStringHex = exports.numberToStringHex = function numberToStringHex(value, pad) { return Buffer.from(typeof value === 'number' ? [value] : value).toString('hex').padStart(pad, '0'); }; var encodeLength = exports.encodeLength = function encodeLength(bytes, len) { var rem_len = len; for (;;) { var elem = rem_len & 0x7f; rem_len >>= 7; if (rem_len == 0) { bytes.push(elem); break; } else { elem |= 0x80; bytes.push(elem); } } }; function toReverseUintBuffer(numberOrString, byteSize) { var bn = new _bn["default"](numberOrString); var buf = Buffer.from(bn.toArray()).reverse(); return Buffer.alloc(byteSize).fill(buf, 0, buf.length); } function toUintBuffer(numberOrString, byteSize) { var bn = new _bn["default"](numberOrString); var buf = Buffer.from(bn.toArray()); return Buffer.alloc(byteSize).fill(buf, byteSize - buf.length, byteSize); } function computeBudgetEncode(type, amount) { var data; var length; switch (type) { case _types.ComputeBudgetInstruction.SetComputeUnitLimit: data = Buffer.alloc(5); length = 4; break; case _types.ComputeBudgetInstruction.SetComputeUnitPrice: data = Buffer.alloc(9); length = 8; break; default: throw new Error('Not supported ComputeBudgetInstruction type: ' + type); } var typeSpan = 1; data.writeUIntLE(type, 0, typeSpan); var valueBuf = toReverseUintBuffer(amount, length); data.write(valueBuf.toString('hex'), typeSpan, length, 'hex'); return data; } function splDataEncode(amount, tokenDecimals) { var data = Buffer.alloc(10); var programIdIndexSpan = 1; data.writeUIntLE(types.TokenInstruction.TransferChecked, 0, programIdIndexSpan); var valueHex = new _bn["default"](amount).toString(16, 8 * 2); var valueBuf = Buffer.from(valueHex, 'hex').reverse(); data.write(valueBuf.toString('hex'), programIdIndexSpan, 8, 'hex'); data.writeUInt8(+tokenDecimals, 9); return data; } //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_bs","_interopRequireDefault","require","_bn","_types","_interopRequireWildcard","types","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","_typeof","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","HEX_REGEX","isBase58Format","exports","value","test","isHexFormat","match","toBase58","publicKey","base58","encode","Buffer","from","toBase58Buffer","decode","toPublicKey","pubKeyToAddress","pubKeyBuf","formHex","address","toString","numberToStringHex","pad","padStart","encodeLength","bytes","len","rem_len","elem","push","toReverseUintBuffer","numberOrString","byteSize","bn","BN","buf","toArray","reverse","alloc","fill","length","toUintBuffer","computeBudgetEncode","type","amount","data","ComputeBudgetInstruction","SetComputeUnitLimit","SetComputeUnitPrice","Error","typeSpan","writeUIntLE","valueBuf","write","splDataEncode","tokenDecimals","programIdIndexSpan","TokenInstruction","TransferChecked","valueHex","writeUInt8"],"sources":["../../src/utils/stringUtil.ts"],"sourcesContent":["import base58 from 'bs58';\nimport BN from 'bn.js';\nimport * as types from '../config/types';\nimport { ComputeBudgetInstruction } from '../config/types';\n\nconst HEX_REGEX = /[0-9A-Fa-f]{6}/g;\n\nexport const isBase58Format = (value?: string): boolean => {\n  if (!value) return false;\n  return /^[A-HJ-NP-Za-km-z1-9]*$/.test(value);\n};\n\nfunction isHexFormat(value: string): boolean {\n  const match = value.match(HEX_REGEX);\n  return !!match;\n}\n\nexport function toBase58(publicKey: types.Address): string {\n  if (typeof publicKey === 'string') {\n    if (isBase58Format(publicKey)) return publicKey;\n    if (isHexFormat(publicKey)) return base58.encode(Buffer.from(publicKey, 'hex'));\n    return publicKey;\n  }\n  return base58.encode(publicKey);\n}\n\nexport function toBase58Buffer(publicKey: types.Address): Buffer {\n  if (typeof publicKey === 'string') {\n    if (isBase58Format(publicKey)) return base58.decode(publicKey);\n    if (isHexFormat(publicKey)) return Buffer.from(publicKey, 'hex');\n    return Buffer.from(publicKey);\n  }\n  return publicKey;\n}\n\nexport function toPublicKey(publicKey: string | Buffer): string {\n  if (typeof publicKey === 'string') return publicKey;\n  return base58.encode(publicKey);\n}\n\nexport function pubKeyToAddress(publicKey: string): string {\n  const pubKeyBuf = Buffer.from(publicKey, 'hex');\n  return base58.encode(pubKeyBuf);\n}\n\n/**\n * CW-21334 Fixed user's publicKey just matches the base58 encoding, resulting in repeated decoding.\n *\n * The user's Solana address (base58 encoded) is:\n * 5XZiuCyozesbRJsSdoJQCTHQRnTGDfSms5bV1ybLn9yg\n *\n * After converting it to Hex:\n * fc238b62abd32cd576f1d5568d3b6b5cb2fbc57b419cc2b4cd8a2814973919a7\n * This hex conform to the Base58 format (without 0, O, i, I, +, /), causing base58.decode to be executed again, resulting in an incorrect publicKey. \n *\n * How to fix it:\n * Adjust base58 verification method. A 32-byte public key can only be base58 encoded using 43 or 44 characters.\n */\nexport const formHex = (address: string | Buffer | undefined): string => {\n  if (!address) return '';\n  if (typeof address === 'string') {\n    if (isBase58Format(address)) return base58.decode(address).toString('hex');\n    return address;\n  }\n  return address.toString('hex');\n};\n\nexport const numberToStringHex = (value: number | number[], pad: number): string =>\n  Buffer.from(typeof value === 'number' ? [value] : value)\n    .toString('hex')\n    .padStart(pad, '0');\n\nexport const encodeLength = (bytes: number[], len: number): void => {\n  let rem_len = len;\n  for (;;) {\n    let elem = rem_len & 0x7f;\n    rem_len >>= 7;\n    if (rem_len == 0) {\n      bytes.push(elem);\n      break;\n    } else {\n      elem |= 0x80;\n      bytes.push(elem);\n    }\n  }\n};\n\nexport function toReverseUintBuffer(numberOrString: number | string, byteSize: number): Buffer {\n  const bn = new BN(numberOrString);\n  const buf = Buffer.from(bn.toArray()).reverse();\n  return Buffer.alloc(byteSize).fill(buf, 0, buf.length);\n}\n\nexport function toUintBuffer(numberOrString: number | string, byteSize: number): Buffer {\n  const bn = new BN(numberOrString);\n  const buf = Buffer.from(bn.toArray());\n  return Buffer.alloc(byteSize).fill(buf, byteSize - buf.length, byteSize);\n}\n\nexport function computeBudgetEncode(type: ComputeBudgetInstruction, amount: number | string): Buffer {\n  let data;\n  let length;\n  switch (type) {\n    case ComputeBudgetInstruction.SetComputeUnitLimit:\n      data = Buffer.alloc(5);\n      length = 4;\n      break;\n    case ComputeBudgetInstruction.SetComputeUnitPrice:\n      data = Buffer.alloc(9);\n      length = 8;\n      break;\n    default:\n      throw new Error('Not supported ComputeBudgetInstruction type: ' + type);\n  }\n\n  const typeSpan = 1;\n  data.writeUIntLE(type, 0, typeSpan);\n  const valueBuf = toReverseUintBuffer(amount, length);\n  data.write(valueBuf.toString('hex'), typeSpan, length, 'hex');\n\n  return data;\n}\n\nexport function splDataEncode(amount: number | string, tokenDecimals: number | string): Buffer {\n  const data = Buffer.alloc(10);\n  const programIdIndexSpan = 1;\n  data.writeUIntLE(types.TokenInstruction.TransferChecked, 0, programIdIndexSpan);\n\n  const valueHex = new BN(amount).toString(16, 8 * 2);\n  const valueBuf = Buffer.from(valueHex, 'hex').reverse();\n\n  data.write(valueBuf.toString('hex'), programIdIndexSpan, 8, 'hex');\n  data.writeUInt8(+tokenDecimals, 9);\n  return data;\n}\n"],"mappings":"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","ignoreList":[]}