PHP WebShell

Текущая директория: /opt/BitGoJS/modules/sdk-coin-hbar/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 = __importStar(require("should"));
const nacl = __importStar(require("tweetnacl"));
const src_1 = require("../../src");
const testData = __importStar(require("../resources/hbar"));
const utils_1 = require("../../src/lib/utils");
const pub = testData.ACCOUNT_1.pubKeyWithPrefix;
const prv = testData.ACCOUNT_1.prvKeyWithPrefix;
describe('Hedera Key Pair', () => {
    describe('should create a valid KeyPair', () => {
        it('from an empty value', () => {
            const keyPair = new src_1.KeyPair();
            should.exists(keyPair.getKeys().prv);
            should.exists(keyPair.getKeys().pub);
            should.equal(keyPair.getKeys(true).prv.length, 64);
            should.equal(keyPair.getKeys(true).pub.length, 64);
            should.equal(keyPair.getKeys().prv.slice(0, 32), testData.ed25519PrivKeyPrefix);
            should.equal(keyPair.getKeys().pub.slice(0, 24), testData.ed25519PubKeyPrefix);
        });
        it('from a seed', () => {
            const keyPair = new src_1.KeyPair({ seed: Buffer.from((0, utils_1.toUint8Array)(testData.ACCOUNT_1.prvKeyWithPrefix.slice(32))) });
            should.equal(keyPair.getKeys().prv, testData.ACCOUNT_1.prvKeyWithPrefix);
            should.equal(keyPair.getKeys().pub, testData.ACCOUNT_1.pubKeyWithPrefix);
        });
        it('from a public key', () => {
            const keyPair = new src_1.KeyPair({ pub: pub });
            should.equal(keyPair.getKeys().pub, pub);
        });
        it('from a public key with prefix', () => {
            const stellarPubs = [
                'GBVEZT27ZUCMJABF76XIPPO7M3KUABVR4GZNPBAD3YTPXUSDA57ANRLD',
                'GDMQYYBRX3ZD34VHU4IJNSLASAQY6VZ7B6UJD5OFKSOW7XFJI5MZMETW',
                'GAD2SVW5EZLCH6HDC3VK7UE4DZK7KCIUHVCY2PO7ZEUERSWU6QQ6QIHB',
            ];
            stellarPubs.forEach((stellarPub) => {
                const edPub = (0, utils_1.convertFromStellarPub)(stellarPub);
                const keyPair = new src_1.KeyPair({ pub: edPub });
                should.exist(keyPair.getKeys().pub);
                should.not.exist(keyPair.getKeys().prv);
            });
        });
        it('from a private key', () => {
            const keyPair = new src_1.KeyPair({ prv: prv });
            should.equal(keyPair.getKeys().prv, prv);
            should.equal(keyPair.getKeys().pub, pub);
        });
        it('from a private key with prefix', () => {
            const keyPair = new src_1.KeyPair({ prv: testData.ACCOUNT_1.prvKeyWithPrefix });
            should.equal(keyPair.getKeys().prv, prv);
            should.equal(keyPair.getKeys().pub, pub);
        });
        it('from seed', () => {
            const seed = nacl.randomBytes(32);
            const keyPair = new src_1.KeyPair({ seed: Buffer.from(seed) });
            keyPair.getKeys().should.have.property('pub');
            keyPair.getKeys().should.have.property('prv');
        });
        it('without source', () => {
            const keyPair = new src_1.KeyPair();
            keyPair.getKeys().should.have.property('pub');
            keyPair.getKeys().should.have.property('prv');
        });
        it('from a byte array private key', () => {
            const keyPair = new src_1.KeyPair({ prv: Buffer.from(testData.ACCOUNT_1.privateKeyBytes).toString('hex') });
            should.equal(keyPair.getKeys().prv, prv);
        });
        it('from a byte array public key', () => {
            const keyPair = new src_1.KeyPair({ pub: Buffer.from(testData.ACCOUNT_1.publicKeyBytes).toString('hex') });
            should.equal(keyPair.getKeys().pub, pub);
        });
    });
    describe('should fail to create a KeyPair', () => {
        it('from an invalid public key', () => {
            const source = { pub: '01D63D' };
            assert_1.default.throws(() => new src_1.KeyPair(source), (e) => e.message.includes(testData.errorMessageInvalidPublicKey));
        });
        it('from an invalid private key', () => {
            const shorterPrv = { prv: '82A34E' };
            const longerPrv = { prv: prv + '12' };
            const prvWithPrefix = { prv: testData.ed25519PrivKeyPrefix + prv + '12' };
            const prvWithOddNumber = { prv: testData.ed25519PrivKeyPrefix + prv + '1' };
            const prvWithNonHex = { prv: testData.ed25519PrivKeyPrefix + prv + 'GG' };
            assert_1.default.throws(() => new src_1.KeyPair(shorterPrv), (e) => e.message === testData.errorMessageInvalidPrivateKey);
            assert_1.default.throws(() => new src_1.KeyPair(longerPrv), (e) => e.message === testData.errorMessageInvalidPrivateKey);
            assert_1.default.throws(() => new src_1.KeyPair(prvWithPrefix), (e) => e.message === testData.errorMessageInvalidPrivateKey);
            assert_1.default.throws(() => new src_1.KeyPair({ prv: prv + pub }), (e) => e.message === testData.errorMessageInvalidPrivateKey);
            assert_1.default.throws(() => new src_1.KeyPair(prvWithOddNumber), (e) => e.message === testData.errorMessageOddLengthOrNonHexPrivateKey);
            assert_1.default.throws(() => new src_1.KeyPair(prvWithNonHex), (e) => e.message === testData.errorMessageOddLengthOrNonHexPrivateKey);
        });
    });
    describe('should fail to get address ', () => {
        it('from a private key', () => {
            const keyPair = new src_1.KeyPair({ prv: prv });
            assert_1.default.throws(() => keyPair.getAddress(), (e) => e.message === testData.errorMessageNotPossibleToDeriveAddress);
        });
        it('from a public key', () => {
            const keyPair = new src_1.KeyPair({ pub: pub });
            assert_1.default.throws(() => keyPair.getAddress(), (e) => e.message === testData.errorMessageNotPossibleToDeriveAddress);
        });
    });
    describe('should succeed to sign and verify ', () => {
        it('a random message', () => {
            const message = 'Hello World!';
            const keyPair = new src_1.KeyPair({ prv: prv });
            const signature = keyPair.signMessage(message);
            const isValid = keyPair.verifySignature(message, signature);
            isValid.should.be.true();
        });
        it('a public key in hex format', () => {
            const keyPair = new src_1.KeyPair({ prv: prv });
            const message = keyPair.getKeys().pub;
            const signature = keyPair.signMessage(message);
            const isValid = keyPair.verifySignature(message, signature);
            isValid.should.be.true();
        });
        it('a message in hex format', () => {
            const userPub = '302a300506032b657003210012558e304e09d468d3ab07edf6f7e634adc4788cee76d6a9eb2aff9385698077';
            const message = '302a300506032b6570032100aa3de24a1df3ce6fb61c8397358985f1df517853ef01523daee5b19dc82f40d5';
            const signature = Buffer.from('76ca6556fbfcc5a8b43c12ba6425c5a6c90f5033180628410b5c29f651719f58ef4c1e' +
                '78dddd5fd794c555ec38c9b9c02ea76d3eef4d8422ae7ea8363cab920c', 'hex');
            const keyPair = new src_1.KeyPair({ pub: userPub });
            const isValid = keyPair.verifySignature(message, new Uint8Array(signature));
            isValid.should.be.true();
        });
        it('an empty message', () => {
            const message = '';
            const keyPair = new src_1.KeyPair({ prv: prv });
            const signature = keyPair.signMessage(message);
            const isValid = keyPair.verifySignature(message, signature);
            isValid.should.be.true();
        });
    });
    describe('should fail sign ', () => {
        it('a message without a private key', () => {
            const message = 'Hello World!';
            const keyPair = new src_1.KeyPair({ pub: pub });
            assert_1.default.throws(() => keyPair.signMessage(message), (e) => e.message === testData.errorMessageMissingPrivateKey);
        });
    });
});
//# 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 * as should from 'should';\nimport * as nacl from 'tweetnacl';\nimport { KeyPair } from '../../src';\nimport * as testData from '../resources/hbar';\nimport { convertFromStellarPub, toUint8Array } from '../../src/lib/utils';\n\nconst pub = testData.ACCOUNT_1.pubKeyWithPrefix;\nconst prv = testData.ACCOUNT_1.prvKeyWithPrefix;\n\ndescribe('Hedera Key Pair', () => {\n  describe('should create a valid KeyPair', () => {\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(true).prv!.length, 64);\n      should.equal(keyPair.getKeys(true).pub.length, 64);\n      should.equal(keyPair.getKeys().prv!.slice(0, 32), testData.ed25519PrivKeyPrefix);\n      should.equal(keyPair.getKeys().pub.slice(0, 24), testData.ed25519PubKeyPrefix);\n    });\n\n    it('from a seed', () => {\n      const keyPair = new KeyPair({ seed: Buffer.from(toUint8Array(testData.ACCOUNT_1.prvKeyWithPrefix.slice(32))) });\n      should.equal(keyPair.getKeys().prv!, testData.ACCOUNT_1.prvKeyWithPrefix);\n      should.equal(keyPair.getKeys().pub, testData.ACCOUNT_1.pubKeyWithPrefix);\n    });\n\n    it('from a public key', () => {\n      const keyPair = new KeyPair({ pub: pub });\n      should.equal(keyPair.getKeys().pub, pub);\n    });\n\n    it('from a public key with prefix', () => {\n      const stellarPubs = [\n        'GBVEZT27ZUCMJABF76XIPPO7M3KUABVR4GZNPBAD3YTPXUSDA57ANRLD',\n        'GDMQYYBRX3ZD34VHU4IJNSLASAQY6VZ7B6UJD5OFKSOW7XFJI5MZMETW',\n        'GAD2SVW5EZLCH6HDC3VK7UE4DZK7KCIUHVCY2PO7ZEUERSWU6QQ6QIHB',\n      ];\n\n      stellarPubs.forEach((stellarPub) => {\n        const edPub = convertFromStellarPub(stellarPub);\n        const keyPair = new KeyPair({ pub: edPub });\n\n        should.exist(keyPair.getKeys().pub);\n        should.not.exist(keyPair.getKeys().prv);\n      });\n    });\n\n    it('from a private key', () => {\n      const keyPair = new KeyPair({ prv: prv });\n      should.equal(keyPair.getKeys().prv!, prv);\n      should.equal(keyPair.getKeys().pub, pub);\n    });\n\n    it('from a private key with prefix', () => {\n      const keyPair = new KeyPair({ prv: testData.ACCOUNT_1.prvKeyWithPrefix });\n      should.equal(keyPair.getKeys().prv!, prv);\n      should.equal(keyPair.getKeys().pub, pub);\n    });\n\n    it('from seed', () => {\n      const seed = nacl.randomBytes(32);\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    it('without source', () => {\n      const keyPair = new KeyPair();\n      keyPair.getKeys().should.have.property('pub');\n      keyPair.getKeys().should.have.property('prv');\n    });\n\n    it('from a byte array private key', () => {\n      const keyPair = new KeyPair({ prv: Buffer.from(testData.ACCOUNT_1.privateKeyBytes).toString('hex') });\n      should.equal(keyPair.getKeys().prv!, prv);\n    });\n\n    it('from a byte array public key', () => {\n      const keyPair = new KeyPair({ pub: Buffer.from(testData.ACCOUNT_1.publicKeyBytes).toString('hex') });\n      should.equal(keyPair.getKeys().pub, pub);\n    });\n  });\n\n  describe('should fail to create a KeyPair', () => {\n    it('from an invalid public key', () => {\n      const source = { pub: '01D63D' };\n      assert.throws(\n        () => new KeyPair(source),\n        (e: any) => e.message.includes(testData.errorMessageInvalidPublicKey)\n      );\n    });\n\n    it('from an invalid private key', () => {\n      const shorterPrv = { prv: '82A34E' };\n      const longerPrv = { prv: prv + '12' };\n      const prvWithPrefix = { prv: testData.ed25519PrivKeyPrefix + prv + '12' };\n      const prvWithOddNumber = { prv: testData.ed25519PrivKeyPrefix + prv + '1' };\n      const prvWithNonHex = { prv: testData.ed25519PrivKeyPrefix + prv + 'GG' };\n      assert.throws(\n        () => new KeyPair(shorterPrv),\n        (e: any) => e.message === testData.errorMessageInvalidPrivateKey\n      );\n      assert.throws(\n        () => new KeyPair(longerPrv),\n        (e: any) => e.message === testData.errorMessageInvalidPrivateKey\n      );\n      assert.throws(\n        () => new KeyPair(prvWithPrefix),\n        (e: any) => e.message === testData.errorMessageInvalidPrivateKey\n      );\n      assert.throws(\n        () => new KeyPair({ prv: prv + pub }),\n        (e: any) => e.message === testData.errorMessageInvalidPrivateKey\n      );\n      assert.throws(\n        () => new KeyPair(prvWithOddNumber),\n        (e: any) => e.message === testData.errorMessageOddLengthOrNonHexPrivateKey\n      );\n      assert.throws(\n        () => new KeyPair(prvWithNonHex),\n        (e: any) => e.message === testData.errorMessageOddLengthOrNonHexPrivateKey\n      );\n    });\n  });\n\n  describe('should fail to get address ', () => {\n    it('from a private key', () => {\n      const keyPair = new KeyPair({ prv: prv });\n      assert.throws(\n        () => keyPair.getAddress(),\n        (e: any) => e.message === testData.errorMessageNotPossibleToDeriveAddress\n      );\n    });\n\n    it('from a public key', () => {\n      const keyPair = new KeyPair({ pub: pub });\n      assert.throws(\n        () => keyPair.getAddress(),\n        (e: any) => e.message === testData.errorMessageNotPossibleToDeriveAddress\n      );\n    });\n  });\n\n  describe('should succeed to sign and verify ', () => {\n    it('a random message', () => {\n      const message = 'Hello World!';\n      const keyPair = new KeyPair({ prv: prv });\n      const signature = keyPair.signMessage(message);\n      const isValid = keyPair.verifySignature(message, signature);\n      isValid.should.be.true();\n    });\n\n    it('a public key in hex format', () => {\n      const keyPair = new KeyPair({ prv: prv });\n      const message = keyPair.getKeys().pub;\n      const signature = keyPair.signMessage(message);\n      const isValid = keyPair.verifySignature(message, signature);\n      isValid.should.be.true();\n    });\n\n    it('a message in hex format', () => {\n      const userPub = '302a300506032b657003210012558e304e09d468d3ab07edf6f7e634adc4788cee76d6a9eb2aff9385698077';\n      const message = '302a300506032b6570032100aa3de24a1df3ce6fb61c8397358985f1df517853ef01523daee5b19dc82f40d5';\n      const signature = Buffer.from(\n        '76ca6556fbfcc5a8b43c12ba6425c5a6c90f5033180628410b5c29f651719f58ef4c1e' +\n          '78dddd5fd794c555ec38c9b9c02ea76d3eef4d8422ae7ea8363cab920c',\n        'hex'\n      );\n\n      const keyPair = new KeyPair({ pub: userPub });\n      const isValid = keyPair.verifySignature(message, new Uint8Array(signature));\n      isValid.should.be.true();\n    });\n\n    it('an empty message', () => {\n      const message = '';\n      const keyPair = new KeyPair({ prv: prv });\n      const signature = keyPair.signMessage(message);\n      const isValid = keyPair.verifySignature(message, signature);\n      isValid.should.be.true();\n    });\n  });\n\n  describe('should fail sign ', () => {\n    it('a message without a private key', () => {\n      const message = 'Hello World!';\n      const keyPair = new KeyPair({ pub: pub });\n      assert.throws(\n        () => keyPair.signMessage(message),\n        (e: any) => e.message === testData.errorMessageMissingPrivateKey\n      );\n    });\n  });\n});\n"]}

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


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