@coolwallet/sol
Version:
Coolwallet Solana sdk
187 lines (173 loc) • 16.6 kB
JavaScript
;
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.PublicKey = exports.PUBLIC_KEY_LENGTH = exports.MAX_SEED_LENGTH = void 0;
var _regenerator = _interopRequireDefault(require("@babel/runtime/regenerator"));
var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/asyncToGenerator"));
var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck"));
var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass"));
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
var _bn = _interopRequireDefault(require("bn.js"));
var _bs = _interopRequireDefault(require("bs58"));
var _buffer = require("buffer");
var _sha = require("@noble/hashes/sha256");
/**
* Maximum length of derived pubkey seed
*/
var MAX_SEED_LENGTH = 32;
/**
* Size of public key in bytes
*/
exports.MAX_SEED_LENGTH = MAX_SEED_LENGTH;
var PUBLIC_KEY_LENGTH = 32;
/**
* Value to be converted into public key
*/
/**
* JSON object representation of PublicKey class
*/
exports.PUBLIC_KEY_LENGTH = PUBLIC_KEY_LENGTH;
function isPublicKeyData(value) {
return value._bn !== undefined;
}
// local counter used by PublicKey.unique()
var uniquePublicKeyCounter = 1;
/**
* A public key
*/
var PublicKey = /*#__PURE__*/function () {
/** @internal */
/**
* Create a new PublicKey object
* @param value ed25519 public key as buffer or base-58 encoded string
*/
function PublicKey(value) {
(0, _classCallCheck2["default"])(this, PublicKey);
if (isPublicKeyData(value)) {
this._bn = value._bn;
} else {
if (typeof value === 'string') {
// assume base 58 encoding by default
var decoded = _bs["default"].decode(value);
if (decoded.length != PUBLIC_KEY_LENGTH) {
throw new Error("Invalid public key input");
}
this._bn = new _bn["default"](decoded);
} else {
this._bn = new _bn["default"](value);
}
if (this._bn.byteLength() > PUBLIC_KEY_LENGTH) {
throw new Error("Invalid public key input");
}
}
}
/**
* Returns a unique PublicKey for tests and benchmarks using a counter
*/
(0, _createClass2["default"])(PublicKey, [{
key: "equals",
value:
/**
* Checks if two publicKeys are equal
*/
function equals(publicKey) {
return this._bn.eq(publicKey._bn);
}
/**
* Return the base-58 representation of the public key
*/
}, {
key: "toBase58",
value: function toBase58() {
return _bs["default"].encode(this.toBytes());
}
}, {
key: "toJSON",
value: function toJSON() {
return this.toBase58();
}
/**
* Return the byte array representation of the public key in big endian
*/
}, {
key: "toBytes",
value: function toBytes() {
var buf = this.toBuffer();
return new Uint8Array(buf.buffer, buf.byteOffset, buf.byteLength);
}
/**
* Return the Buffer representation of the public key in big endian
*/
}, {
key: "toBuffer",
value: function toBuffer() {
var b = this._bn.toArrayLike(_buffer.Buffer);
if (b.length === PUBLIC_KEY_LENGTH) {
return b;
}
var zeroPad = _buffer.Buffer.alloc(32);
b.copy(zeroPad, 32 - b.length);
return zeroPad;
}
}, {
key: Symbol.toStringTag,
get: function get() {
return "PublicKey(".concat(this.toString(), ")");
}
/**
* Return the base-58 representation of the public key
*/
}, {
key: "toString",
value: function toString() {
return this.toBase58();
}
/**
* Derive a public key from another key, a seed, and a program ID.
* The program ID will also serve as the owner of the public key, giving
* it permission to write data to the account.
*/
/* eslint-disable require-await */
}], [{
key: "unique",
value: function unique() {
var key = new PublicKey(uniquePublicKeyCounter);
uniquePublicKeyCounter += 1;
return new PublicKey(key.toBuffer());
}
/**
* Default public key value. The base58-encoded string representation is all ones (as seen below)
* The underlying BN number is 32 bytes that are all zeros
*/
}, {
key: "createWithSeed",
value: (function () {
var _createWithSeed = (0, _asyncToGenerator2["default"])(/*#__PURE__*/_regenerator["default"].mark(function _callee(fromPublicKey, seed, programId) {
var buffer, publicKeyBytes;
return _regenerator["default"].wrap(function _callee$(_context) {
while (1) {
switch (_context.prev = _context.next) {
case 0:
buffer = _buffer.Buffer.concat([fromPublicKey.toBuffer(), _buffer.Buffer.from(seed), programId.toBuffer()]);
publicKeyBytes = (0, _sha.sha256)(buffer);
return _context.abrupt("return", new PublicKey(publicKeyBytes));
case 3:
case "end":
return _context.stop();
}
}
}, _callee);
}));
function createWithSeed(_x, _x2, _x3) {
return _createWithSeed.apply(this, arguments);
}
return createWithSeed;
}())
}]);
return PublicKey;
}();
exports.PublicKey = PublicKey;
(0, _defineProperty2["default"])(PublicKey, "default", new PublicKey('11111111111111111111111111111111'));
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_bn","_interopRequireDefault","require","_bs","_buffer","_sha","MAX_SEED_LENGTH","exports","PUBLIC_KEY_LENGTH","isPublicKeyData","value","undefined","uniquePublicKeyCounter","PublicKey","_classCallCheck2","decoded","bs58","decode","length","Error","BN","byteLength","_createClass2","key","equals","publicKey","eq","toBase58","encode","toBytes","toJSON","buf","toBuffer","Uint8Array","buffer","byteOffset","b","toArrayLike","Buffer","zeroPad","alloc","copy","Symbol","toStringTag","get","concat","toString","unique","_createWithSeed","_asyncToGenerator2","_regenerator","mark","_callee","fromPublicKey","seed","programId","publicKeyBytes","wrap","_callee$","_context","prev","next","from","sha256","abrupt","stop","createWithSeed","_x","_x2","_x3","apply","arguments","_defineProperty2"],"sources":["../../src/utils/publickey.ts"],"sourcesContent":["import BN from 'bn.js';\nimport bs58 from 'bs58';\nimport { Buffer } from 'buffer';\nimport { sha256 } from '@noble/hashes/sha256';\n\n/**\n * Maximum length of derived pubkey seed\n */\nexport const MAX_SEED_LENGTH = 32;\n\n/**\n * Size of public key in bytes\n */\nexport const PUBLIC_KEY_LENGTH = 32;\n\n/**\n * Value to be converted into public key\n */\nexport type PublicKeyInitData =\n  | number\n  | string\n  | Uint8Array\n  | Array<number>\n  | PublicKeyData;\n\n/**\n * JSON object representation of PublicKey class\n */\nexport type PublicKeyData = {\n  /** @internal */\n  _bn: BN;\n};\n\nfunction isPublicKeyData(value: PublicKeyInitData): value is PublicKeyData {\n  return (value as PublicKeyData)._bn !== undefined;\n}\n\n// local counter used by PublicKey.unique()\nlet uniquePublicKeyCounter = 1;\n\n/**\n * A public key\n */\nexport class PublicKey {\n  /** @internal */\n  _bn: BN;\n\n  /**\n   * Create a new PublicKey object\n   * @param value ed25519 public key as buffer or base-58 encoded string\n   */\n  constructor(value: PublicKeyInitData) {\n\n    if (isPublicKeyData(value)) {\n      this._bn = value._bn;\n    } else {\n      if (typeof value === 'string') {\n        // assume base 58 encoding by default\n        const decoded = bs58.decode(value);\n        if (decoded.length != PUBLIC_KEY_LENGTH) {\n          throw new Error(`Invalid public key input`);\n        }\n        this._bn = new BN(decoded);\n      } else {\n        this._bn = new BN(value);\n      }\n\n      if (this._bn.byteLength() > PUBLIC_KEY_LENGTH) {\n        throw new Error(`Invalid public key input`);\n      }\n    }\n  }\n\n  /**\n   * Returns a unique PublicKey for tests and benchmarks using a counter\n   */\n  static unique(): PublicKey {\n    const key = new PublicKey(uniquePublicKeyCounter);\n    uniquePublicKeyCounter += 1;\n    return new PublicKey(key.toBuffer());\n  }\n\n  /**\n   * Default public key value. The base58-encoded string representation is all ones (as seen below)\n   * The underlying BN number is 32 bytes that are all zeros\n   */\n  static default: PublicKey = new PublicKey('11111111111111111111111111111111');\n\n  /**\n   * Checks if two publicKeys are equal\n   */\n  equals(publicKey: PublicKey): boolean {\n    return this._bn.eq(publicKey._bn);\n  }\n\n  /**\n   * Return the base-58 representation of the public key\n   */\n  toBase58(): string {\n    return bs58.encode(this.toBytes());\n  }\n\n  toJSON(): string {\n    return this.toBase58();\n  }\n\n  /**\n   * Return the byte array representation of the public key in big endian\n   */\n  toBytes(): Uint8Array {\n    const buf = this.toBuffer();\n    return new Uint8Array(buf.buffer, buf.byteOffset, buf.byteLength);\n  }\n\n  /**\n   * Return the Buffer representation of the public key in big endian\n   */\n  toBuffer(): Buffer {\n    const b = this._bn.toArrayLike(Buffer);\n    if (b.length === PUBLIC_KEY_LENGTH) {\n      return b;\n    }\n\n    const zeroPad = Buffer.alloc(32);\n    b.copy(zeroPad, 32 - b.length);\n    return zeroPad;\n  }\n\n  get [Symbol.toStringTag](): string {\n    return `PublicKey(${this.toString()})`;\n  }\n\n  /**\n   * Return the base-58 representation of the public key\n   */\n  toString(): string {\n    return this.toBase58();\n  }\n\n  /**\n   * Derive a public key from another key, a seed, and a program ID.\n   * The program ID will also serve as the owner of the public key, giving\n   * it permission to write data to the account.\n   */\n  /* eslint-disable require-await */\n  static async createWithSeed(\n    fromPublicKey: PublicKey,\n    seed: string,\n    programId: PublicKey,\n  ): Promise<PublicKey> {\n    const buffer = Buffer.concat([\n      fromPublicKey.toBuffer(),\n      Buffer.from(seed),\n      programId.toBuffer(),\n    ]);\n    const publicKeyBytes = sha256(buffer);\n    return new PublicKey(publicKeyBytes);\n  }\n}\n\n"],"mappings":"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","ignoreList":[]}