PHP WebShell

Текущая директория: /opt/BitGoJS/modules/sdk-coin-eth/dist/test/unit

Просмотр файла: keyPair.js

"use strict";
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
    if (k2 === undefined) k2 = k;
    var desc = Object.getOwnPropertyDescriptor(m, k);
    if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
      desc = { enumerable: true, get: function() { return m[k]; } };
    }
    Object.defineProperty(o, k2, desc);
}) : (function(o, m, k, k2) {
    if (k2 === undefined) k2 = k;
    o[k2] = m[k];
}));
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
    Object.defineProperty(o, "default", { enumerable: true, value: v });
}) : function(o, v) {
    o["default"] = v;
});
var __importStar = (this && this.__importStar) || (function () {
    var ownKeys = function(o) {
        ownKeys = Object.getOwnPropertyNames || function (o) {
            var ar = [];
            for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
            return ar;
        };
        return ownKeys(o);
    };
    return function (mod) {
        if (mod && mod.__esModule) return mod;
        var result = {};
        if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
        __setModuleDefault(result, mod);
        return result;
    };
})();
var __importDefault = (this && this.__importDefault) || function (mod) {
    return (mod && mod.__esModule) ? mod : { "default": mod };
};
Object.defineProperty(exports, "__esModule", { value: true });
const assert_1 = __importDefault(require("assert"));
const should_1 = __importDefault(require("should"));
const src_1 = require("../../src");
const nacl = __importStar(require("tweetnacl"));
describe('Eth KeyPair', function () {
    // these are all encodings of the same key so the test suite will show that they we can interchange between them
    const xprv = 'xprv9s21ZrQH143K3D8TXfvAJgHVfTEeQNW5Ys9wZtnUZkqPzFzSjbEJrWC1vZ4GnXCvR7rQL2UFX3RSuYeU9MrERm1XBvACow7c36vnz5iYyj2';
    const xpub = 'xpub661MyMwAqRbcFhCvdhTAfpEEDV58oqDvv65YNHC686NNs4KbH8YZQJWVmrfbve7aAVHzxw8bKFxA7MLeDK6BbLfkE3bqkvHLPgaGHHtYGeY';
    const prv = '82A34E3867EA7EA4E67E27865D500AE84E98D07AB1BAB06526F0A5A5FDCC3EBA';
    const pub = '03D63D9FD9FD772A989C5B90EDB37716406356E98273E5F98FE07652247A3A8275';
    const uncompressedPub = '04D63D9FD9FD772A989C5B90EDB37716406356E98273E5F98FE07652247A3A827503E948A2FDBF74A981D4E0054F10EDA7042C2D469F44473D3C7791E0E326E355';
    const address = '0xeb317b9f2e0891d66c061ddc3f5ee7ed42d70a44';
    const invalidPrivateKeyErrorMessage = 'Unsupported private key';
    describe('should create a KeyPair', function () {
        it('from an xpub', () => {
            const keyPair = new src_1.KeyPair({ pub: xpub });
            const defaultKeys = keyPair.getKeys();
            should_1.default.not.exist(defaultKeys.prv);
            defaultKeys.pub.should.equal('03D63D9FD9FD772A989C5B90EDB37716406356E98273E5F98FE07652247A3A8275');
            const extendedKeys = keyPair.getExtendedKeys();
            should_1.default.not.exist(extendedKeys.xprv);
            extendedKeys.xpub.should.equal(xpub);
        });
        it('from an xprv', () => {
            const keyPair = new src_1.KeyPair({ prv: xprv });
            const defaultKeys = keyPair.getKeys();
            defaultKeys.prv.should.equal(prv);
            defaultKeys.pub.should.equal(pub);
            const extendedKeys = keyPair.getExtendedKeys();
            extendedKeys.xprv.should.equal(xprv);
            extendedKeys.xpub.should.equal(xpub);
        });
        it('from an uncompressed public key', () => {
            const keyPair = new src_1.KeyPair({ pub: uncompressedPub });
            const defaultKeys = keyPair.getKeys();
            should_1.default.not.exist(defaultKeys.prv);
            defaultKeys.pub.should.equal(uncompressedPub);
            assert_1.default.throws(() => keyPair.getExtendedKeys());
        });
        it('from a compressed public key', () => {
            const keyPair = new src_1.KeyPair({ pub });
            const defaultKeys = keyPair.getKeys();
            should_1.default.not.exist(defaultKeys.prv);
            defaultKeys.pub.should.equal(uncompressedPub);
            assert_1.default.throws(() => keyPair.getExtendedKeys());
        });
        it('from a raw private key', () => {
            const keyPair = new src_1.KeyPair({ prv });
            const defaultKeys = keyPair.getKeys();
            defaultKeys.prv.should.equal(prv);
            defaultKeys.pub.should.equal(uncompressedPub);
            assert_1.default.throws(() => keyPair.getExtendedKeys());
        });
        it('from an empty value', () => {
            const keyPair = new src_1.KeyPair();
            should_1.default.exists(keyPair.getKeys().prv);
            should_1.default.exists(keyPair.getKeys().pub);
            should_1.default.equal(keyPair.getKeys().prv.length, 64);
            should_1.default.equal(keyPair.getKeys().pub.length, 66);
        });
        it('from seed', () => {
            const seed = nacl.randomBytes(64);
            const keyPair = new src_1.KeyPair({ seed: Buffer.from(seed) });
            keyPair.getKeys().should.have.property('pub');
            keyPair.getKeys().should.have.property('prv');
        });
    });
    describe('should fail to create a KeyPair', function () {
        it('from an invalid public key', () => {
            const source = {
                pub: '01D63D',
            };
            assert_1.default.throws(() => new src_1.KeyPair(source));
        });
        it('from an invalid private key', () => {
            const source = {
                prv: '82A34E',
            };
            assert_1.default.throws(() => new src_1.KeyPair(source));
            assert_1.default.throws(() => new src_1.KeyPair({ prv: prv + pub }), (e) => e.message === invalidPrivateKeyErrorMessage);
        });
    });
    describe('getAddress', function () {
        it('should get an address from xprv', () => {
            const keyPair = new src_1.KeyPair({ prv: xprv });
            const calculatedAddress = keyPair.getAddress();
            calculatedAddress.should.equal(address);
        });
        it('should get an address from xpub', () => {
            const keyPair = new src_1.KeyPair({ pub: xpub });
            const calculatedAddress = keyPair.getAddress();
            calculatedAddress.should.equal(address);
        });
        it('should get an address from prv', () => {
            const keyPair = new src_1.KeyPair({ prv });
            const calculatedAddress = keyPair.getAddress();
            calculatedAddress.should.equal(address);
        });
        it('should get an address from pub', () => {
            const keyPair = new src_1.KeyPair({ pub });
            const calculatedAddress = keyPair.getAddress();
            calculatedAddress.should.equal(address);
        });
        it('should get an address from uncompressed pub', () => {
            const keyPair = new src_1.KeyPair({ pub: uncompressedPub });
            const calculatedAddress = keyPair.getAddress();
            calculatedAddress.should.equal(address);
        });
    });
    describe('getExtendedKeys', function () {
        it('should get the keys in extended format from xprv', () => {
            const keyPair = new src_1.KeyPair({ prv: xprv });
            const { xprv: calculatedXprv, xpub: calculatedXpub } = keyPair.getExtendedKeys();
            calculatedXprv.should.equal(xprv);
            calculatedXpub.should.equal(xpub);
        });
        it('should get the keys in extended format from xpub', () => {
            const keyPair = new src_1.KeyPair({ pub: xpub });
            const { xprv: calculatedXprv, xpub: calculatedXpub } = keyPair.getExtendedKeys();
            should_1.default.not.exist(calculatedXprv);
            calculatedXpub.should.equal(xpub);
        });
        it('should not be able to get keys from prv', () => {
            const keyPair = new src_1.KeyPair({ prv });
            assert_1.default.throws(() => keyPair.getExtendedKeys());
        });
        it('should get the keys in extended format from pub', () => {
            const keyPair = new src_1.KeyPair({ pub });
            assert_1.default.throws(() => keyPair.getExtendedKeys());
        });
        it('should get the keys in extended format from uncompressed pub', () => {
            const keyPair = new src_1.KeyPair({ pub: uncompressedPub });
            assert_1.default.throws(() => keyPair.getExtendedKeys());
        });
    });
});
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"keyPair.js","sourceRoot":"","sources":["../../../test/unit/keyPair.ts"],"names":[],"mappings":"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","sourcesContent":["import assert from 'assert';\nimport should from 'should';\n\nimport { KeyPair } from '../../src';\nimport * as nacl from 'tweetnacl';\n\ndescribe('Eth KeyPair', function () {\n  // these are all encodings of the same key so the test suite will show that they we can interchange between them\n  const xprv =\n    'xprv9s21ZrQH143K3D8TXfvAJgHVfTEeQNW5Ys9wZtnUZkqPzFzSjbEJrWC1vZ4GnXCvR7rQL2UFX3RSuYeU9MrERm1XBvACow7c36vnz5iYyj2';\n  const xpub =\n    'xpub661MyMwAqRbcFhCvdhTAfpEEDV58oqDvv65YNHC686NNs4KbH8YZQJWVmrfbve7aAVHzxw8bKFxA7MLeDK6BbLfkE3bqkvHLPgaGHHtYGeY';\n  const prv = '82A34E3867EA7EA4E67E27865D500AE84E98D07AB1BAB06526F0A5A5FDCC3EBA';\n  const pub = '03D63D9FD9FD772A989C5B90EDB37716406356E98273E5F98FE07652247A3A8275';\n  const uncompressedPub =\n    '04D63D9FD9FD772A989C5B90EDB37716406356E98273E5F98FE07652247A3A827503E948A2FDBF74A981D4E0054F10EDA7042C2D469F44473D3C7791E0E326E355';\n  const address = '0xeb317b9f2e0891d66c061ddc3f5ee7ed42d70a44';\n  const invalidPrivateKeyErrorMessage = 'Unsupported private key';\n\n  describe('should create a KeyPair', function () {\n    it('from an xpub', () => {\n      const keyPair = new KeyPair({ pub: xpub });\n      const defaultKeys = keyPair.getKeys();\n      should.not.exist(defaultKeys.prv);\n      defaultKeys.pub.should.equal('03D63D9FD9FD772A989C5B90EDB37716406356E98273E5F98FE07652247A3A8275');\n\n      const extendedKeys = keyPair.getExtendedKeys();\n      should.not.exist(extendedKeys.xprv);\n      extendedKeys.xpub.should.equal(xpub);\n    });\n\n    it('from an xprv', () => {\n      const keyPair = new KeyPair({ prv: xprv });\n      const defaultKeys = keyPair.getKeys();\n      defaultKeys.prv!.should.equal(prv);\n      defaultKeys.pub.should.equal(pub);\n\n      const extendedKeys = keyPair.getExtendedKeys();\n      extendedKeys.xprv!.should.equal(xprv);\n      extendedKeys.xpub.should.equal(xpub);\n    });\n\n    it('from an uncompressed public key', () => {\n      const keyPair = new KeyPair({ pub: uncompressedPub });\n      const defaultKeys = keyPair.getKeys();\n      should.not.exist(defaultKeys.prv);\n      defaultKeys.pub.should.equal(uncompressedPub);\n\n      assert.throws(() => keyPair.getExtendedKeys());\n    });\n\n    it('from a compressed public key', () => {\n      const keyPair = new KeyPair({ pub });\n      const defaultKeys = keyPair.getKeys();\n      should.not.exist(defaultKeys.prv);\n      defaultKeys.pub.should.equal(uncompressedPub);\n      assert.throws(() => keyPair.getExtendedKeys());\n    });\n\n    it('from a raw private key', () => {\n      const keyPair = new KeyPair({ prv });\n      const defaultKeys = keyPair.getKeys();\n      defaultKeys.prv!.should.equal(prv);\n      defaultKeys.pub.should.equal(uncompressedPub);\n\n      assert.throws(() => keyPair.getExtendedKeys());\n    });\n\n    it('from an empty value', () => {\n      const keyPair = new KeyPair();\n      should.exists(keyPair.getKeys().prv);\n      should.exists(keyPair.getKeys().pub);\n      should.equal(keyPair.getKeys().prv!.length, 64);\n      should.equal(keyPair.getKeys().pub.length, 66);\n    });\n\n    it('from seed', () => {\n      const seed = nacl.randomBytes(64);\n      const keyPair = new KeyPair({ seed: Buffer.from(seed) });\n      keyPair.getKeys().should.have.property('pub');\n      keyPair.getKeys().should.have.property('prv');\n    });\n  });\n\n  describe('should fail to create a KeyPair', function () {\n    it('from an invalid public key', () => {\n      const source = {\n        pub: '01D63D',\n      };\n      assert.throws(() => new KeyPair(source));\n    });\n\n    it('from an invalid private key', () => {\n      const source = {\n        prv: '82A34E',\n      };\n      assert.throws(() => new KeyPair(source));\n      assert.throws(\n        () => new KeyPair({ prv: prv + pub }),\n        (e: any) => e.message === invalidPrivateKeyErrorMessage\n      );\n    });\n  });\n\n  describe('getAddress', function () {\n    it('should get an address from xprv', () => {\n      const keyPair = new KeyPair({ prv: xprv });\n      const calculatedAddress = keyPair.getAddress();\n      calculatedAddress.should.equal(address);\n    });\n\n    it('should get an address from xpub', () => {\n      const keyPair = new KeyPair({ pub: xpub });\n      const calculatedAddress = keyPair.getAddress();\n      calculatedAddress.should.equal(address);\n    });\n\n    it('should get an address from prv', () => {\n      const keyPair = new KeyPair({ prv });\n      const calculatedAddress = keyPair.getAddress();\n      calculatedAddress.should.equal(address);\n    });\n\n    it('should get an address from pub', () => {\n      const keyPair = new KeyPair({ pub });\n      const calculatedAddress = keyPair.getAddress();\n      calculatedAddress.should.equal(address);\n    });\n\n    it('should get an address from uncompressed pub', () => {\n      const keyPair = new KeyPair({ pub: uncompressedPub });\n      const calculatedAddress = keyPair.getAddress();\n      calculatedAddress.should.equal(address);\n    });\n  });\n\n  describe('getExtendedKeys', function () {\n    it('should get the keys in extended format from xprv', () => {\n      const keyPair = new KeyPair({ prv: xprv });\n      const { xprv: calculatedXprv, xpub: calculatedXpub } = keyPair.getExtendedKeys();\n      calculatedXprv!.should.equal(xprv);\n      calculatedXpub.should.equal(xpub);\n    });\n\n    it('should get the keys in extended format from xpub', () => {\n      const keyPair = new KeyPair({ pub: xpub });\n      const { xprv: calculatedXprv, xpub: calculatedXpub } = keyPair.getExtendedKeys();\n      should.not.exist(calculatedXprv);\n      calculatedXpub.should.equal(xpub);\n    });\n\n    it('should not be able to get keys from prv', () => {\n      const keyPair = new KeyPair({ prv });\n\n      assert.throws(() => keyPair.getExtendedKeys());\n    });\n\n    it('should get the keys in extended format from pub', () => {\n      const keyPair = new KeyPair({ pub });\n\n      assert.throws(() => keyPair.getExtendedKeys());\n    });\n\n    it('should get the keys in extended format from uncompressed pub', () => {\n      const keyPair = new KeyPair({ pub: uncompressedPub });\n\n      assert.throws(() => keyPair.getExtendedKeys());\n    });\n  });\n});\n"]}

Выполнить команду


Для локальной разработки. Не используйте в интернете!