PHP WebShell

Текущая директория: /opt/BitGoJS/modules/bitgo/dist/test/v2/unit/tss

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

"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
const sdk_core_1 = require("@bitgo/sdk-core");
const openpgp = require("openpgp");
openpgp.config.rejectCurves = new Set();
describe('commonVerifyWalletSignature', function () {
    let gpgKey1;
    let gpgKey2;
    let gpgKey3;
    let key1Actual;
    let key2Actual;
    let key3Actual;
    let gpgKey1Id;
    let gpgKey2Id;
    before(async function () {
        const keyPromises = [];
        for (let i = 0; i < 3; i++) {
            keyPromises.push(openpgp.generateKey({
                userIDs: [
                    {
                        name: `test${i}`,
                        email: `test${i}@test.com`,
                    },
                ],
                curve: 'secp256k1',
            }));
        }
        [gpgKey1, gpgKey2, gpgKey3] = await Promise.all(keyPromises);
        key1Actual = await openpgp.readKey({ armoredKey: gpgKey1.publicKey });
        key2Actual = await openpgp.readKey({ armoredKey: gpgKey2.publicKey });
        key3Actual = await openpgp.readKey({ armoredKey: gpgKey3.publicKey });
        gpgKey1Id = key1Actual.keyPacket.getFingerprint();
        gpgKey2Id = key2Actual.keyPacket.getFingerprint();
    });
    it('throws error if signature was not done by provided pub', async function () {
        const signatureString = await (0, sdk_core_1.createSharedDataProof)(gpgKey1.privateKey, gpgKey2.publicKey, []);
        const signature = await openpgp.readKey({ armoredKey: signatureString });
        await sdk_core_1.commonTssMethods
            .commonVerifyWalletSignature({
            walletSignature: signature,
            bitgoPub: key2Actual,
            commonKeychain: '',
            userKeyId: '',
            backupKeyId: '',
        })
            .should.be.rejectedWith('Invalid HSM GPG signature');
        await sdk_core_1.commonTssMethods
            .commonVerifyWalletSignature({
            walletSignature: signature,
            bitgoPub: key3Actual,
            commonKeychain: '',
            userKeyId: '',
            backupKeyId: '',
        })
            .should.be.rejectedWith('Invalid HSM GPG signature');
    });
    it('throws error when there are not exactly five raw notations in the signature', async function () {
        const signatureString = await (0, sdk_core_1.createSharedDataProof)(gpgKey1.privateKey, gpgKey2.publicKey, [
            { name: '', value: '' },
        ]);
        const signature = await openpgp.readKey({ armoredKey: signatureString });
        await sdk_core_1.commonTssMethods
            .commonVerifyWalletSignature({
            walletSignature: signature,
            bitgoPub: key1Actual,
            commonKeychain: '',
            userKeyId: '',
            backupKeyId: '',
        })
            .should.be.rejectedWith('invalid wallet signatures');
    });
    it('throws error when first raw notation does not match common keychain', async function () {
        const signatureString = await (0, sdk_core_1.createSharedDataProof)(gpgKey1.privateKey, gpgKey2.publicKey, [
            { name: '', value: '1234' },
            { name: '', value: '' },
            { name: '', value: '' },
            { name: '', value: '' },
            { name: '', value: '' },
        ]);
        const signature = await openpgp.readKey({ armoredKey: signatureString });
        await sdk_core_1.commonTssMethods
            .commonVerifyWalletSignature({
            walletSignature: signature,
            bitgoPub: key1Actual,
            commonKeychain: '5678',
            userKeyId: '',
            backupKeyId: '',
        })
            .should.be.rejectedWith('wallet signature does not match common keychain');
    });
    it('throw error when second raw notation does not match userKeyId', async function () {
        const signatureString = await (0, sdk_core_1.createSharedDataProof)(gpgKey1.privateKey, gpgKey2.publicKey, [
            { name: '', value: '1234' },
            { name: '', value: gpgKey1Id },
            { name: '', value: '' },
            { name: '', value: '' },
            { name: '', value: '' },
        ]);
        const signature = await openpgp.readKey({ armoredKey: signatureString });
        await sdk_core_1.commonTssMethods
            .commonVerifyWalletSignature({
            walletSignature: signature,
            bitgoPub: key1Actual,
            commonKeychain: '1234',
            userKeyId: gpgKey2Id,
            backupKeyId: '',
        })
            .should.be.rejectedWith('wallet signature does not match user key id');
    });
    it('throw error when third raw notation does not match backupKeyId', async function () {
        const signatureString = await (0, sdk_core_1.createSharedDataProof)(gpgKey1.privateKey, gpgKey2.publicKey, [
            { name: '', value: '1234' },
            { name: '', value: gpgKey2Id },
            { name: '', value: gpgKey2Id },
            { name: '', value: '' },
            { name: '', value: '' },
        ]);
        const signature = await openpgp.readKey({ armoredKey: signatureString });
        await sdk_core_1.commonTssMethods
            .commonVerifyWalletSignature({
            walletSignature: signature,
            bitgoPub: key1Actual,
            commonKeychain: '1234',
            userKeyId: gpgKey2Id,
            backupKeyId: gpgKey1Id,
        })
            .should.be.rejectedWith('wallet signature does not match backup key id');
    });
    it('succeeds and returns the raw notations', async function () {
        const rawNotations = [
            { name: '', value: '1234' },
            { name: '', value: gpgKey2Id },
            { name: '', value: gpgKey2Id },
            { name: '', value: '5678' },
            { name: '', value: '9012' },
        ];
        const signatureString = await (0, sdk_core_1.createSharedDataProof)(gpgKey1.privateKey, gpgKey2.publicKey, rawNotations);
        const signature = await openpgp.readKey({ armoredKey: signatureString });
        const returnedRawNotations = await sdk_core_1.commonTssMethods.commonVerifyWalletSignature({
            walletSignature: signature,
            bitgoPub: key1Actual,
            commonKeychain: '1234',
            userKeyId: gpgKey2Id,
            backupKeyId: gpgKey2Id,
        });
        returnedRawNotations.length.should.equal(rawNotations.length);
        for (let i = 0; i < rawNotations.length; i++) {
            Buffer.from(returnedRawNotations[i].value).toString().should.equal(rawNotations[i].value);
        }
    });
});
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"common.js","sourceRoot":"","sources":["../../../../../test/v2/unit/tss/common.ts"],"names":[],"mappings":"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","sourcesContent":["import { createSharedDataProof, commonTssMethods } from '@bitgo/sdk-core';\nimport * as openpgp from 'openpgp';\n\nopenpgp.config.rejectCurves = new Set();\n\ndescribe('commonVerifyWalletSignature', function () {\n  let gpgKey1;\n  let gpgKey2;\n  let gpgKey3;\n  let key1Actual;\n  let key2Actual;\n  let key3Actual;\n  let gpgKey1Id;\n  let gpgKey2Id;\n\n  before(async function () {\n    const keyPromises: Promise<openpgp.SerializedKeyPair<string>>[] = [];\n    for (let i = 0; i < 3; i++) {\n      keyPromises.push(\n        openpgp.generateKey({\n          userIDs: [\n            {\n              name: `test${i}`,\n              email: `test${i}@test.com`,\n            },\n          ],\n          curve: 'secp256k1',\n        })\n      );\n    }\n    [gpgKey1, gpgKey2, gpgKey3] = await Promise.all(keyPromises);\n    key1Actual = await openpgp.readKey({ armoredKey: gpgKey1.publicKey });\n    key2Actual = await openpgp.readKey({ armoredKey: gpgKey2.publicKey });\n    key3Actual = await openpgp.readKey({ armoredKey: gpgKey3.publicKey });\n    gpgKey1Id = key1Actual.keyPacket.getFingerprint();\n    gpgKey2Id = key2Actual.keyPacket.getFingerprint();\n  });\n\n  it('throws error if signature was not done by provided pub', async function () {\n    const signatureString = await createSharedDataProof(gpgKey1.privateKey, gpgKey2.publicKey, []);\n    const signature = await openpgp.readKey({ armoredKey: signatureString });\n\n    await commonTssMethods\n      .commonVerifyWalletSignature({\n        walletSignature: signature,\n        bitgoPub: key2Actual,\n        commonKeychain: '',\n        userKeyId: '',\n        backupKeyId: '',\n      })\n      .should.be.rejectedWith('Invalid HSM GPG signature');\n\n    await commonTssMethods\n      .commonVerifyWalletSignature({\n        walletSignature: signature,\n        bitgoPub: key3Actual,\n        commonKeychain: '',\n        userKeyId: '',\n        backupKeyId: '',\n      })\n      .should.be.rejectedWith('Invalid HSM GPG signature');\n  });\n\n  it('throws error when there are not exactly five raw notations in the signature', async function () {\n    const signatureString = await createSharedDataProof(gpgKey1.privateKey, gpgKey2.publicKey, [\n      { name: '', value: '' },\n    ]);\n    const signature = await openpgp.readKey({ armoredKey: signatureString });\n\n    await commonTssMethods\n      .commonVerifyWalletSignature({\n        walletSignature: signature,\n        bitgoPub: key1Actual,\n        commonKeychain: '',\n        userKeyId: '',\n        backupKeyId: '',\n      })\n      .should.be.rejectedWith('invalid wallet signatures');\n  });\n\n  it('throws error when first raw notation does not match common keychain', async function () {\n    const signatureString = await createSharedDataProof(gpgKey1.privateKey, gpgKey2.publicKey, [\n      { name: '', value: '1234' },\n      { name: '', value: '' },\n      { name: '', value: '' },\n      { name: '', value: '' },\n      { name: '', value: '' },\n    ]);\n    const signature = await openpgp.readKey({ armoredKey: signatureString });\n\n    await commonTssMethods\n      .commonVerifyWalletSignature({\n        walletSignature: signature,\n        bitgoPub: key1Actual,\n        commonKeychain: '5678',\n        userKeyId: '',\n        backupKeyId: '',\n      })\n      .should.be.rejectedWith('wallet signature does not match common keychain');\n  });\n\n  it('throw error when second raw notation does not match userKeyId', async function () {\n    const signatureString = await createSharedDataProof(gpgKey1.privateKey, gpgKey2.publicKey, [\n      { name: '', value: '1234' },\n      { name: '', value: gpgKey1Id },\n      { name: '', value: '' },\n      { name: '', value: '' },\n      { name: '', value: '' },\n    ]);\n    const signature = await openpgp.readKey({ armoredKey: signatureString });\n\n    await commonTssMethods\n      .commonVerifyWalletSignature({\n        walletSignature: signature,\n        bitgoPub: key1Actual,\n        commonKeychain: '1234',\n        userKeyId: gpgKey2Id,\n        backupKeyId: '',\n      })\n      .should.be.rejectedWith('wallet signature does not match user key id');\n  });\n\n  it('throw error when third raw notation does not match backupKeyId', async function () {\n    const signatureString = await createSharedDataProof(gpgKey1.privateKey, gpgKey2.publicKey, [\n      { name: '', value: '1234' },\n      { name: '', value: gpgKey2Id },\n      { name: '', value: gpgKey2Id },\n      { name: '', value: '' },\n      { name: '', value: '' },\n    ]);\n    const signature = await openpgp.readKey({ armoredKey: signatureString });\n\n    await commonTssMethods\n      .commonVerifyWalletSignature({\n        walletSignature: signature,\n        bitgoPub: key1Actual,\n        commonKeychain: '1234',\n        userKeyId: gpgKey2Id,\n        backupKeyId: gpgKey1Id,\n      })\n      .should.be.rejectedWith('wallet signature does not match backup key id');\n  });\n\n  it('succeeds and returns the raw notations', async function () {\n    const rawNotations = [\n      { name: '', value: '1234' },\n      { name: '', value: gpgKey2Id },\n      { name: '', value: gpgKey2Id },\n      { name: '', value: '5678' },\n      { name: '', value: '9012' },\n    ];\n    const signatureString = await createSharedDataProof(gpgKey1.privateKey, gpgKey2.publicKey, rawNotations);\n    const signature = await openpgp.readKey({ armoredKey: signatureString });\n\n    const returnedRawNotations = await commonTssMethods.commonVerifyWalletSignature({\n      walletSignature: signature,\n      bitgoPub: key1Actual,\n      commonKeychain: '1234',\n      userKeyId: gpgKey2Id,\n      backupKeyId: gpgKey2Id,\n    });\n\n    returnedRawNotations.length.should.equal(rawNotations.length);\n    for (let i = 0; i < rawNotations.length; i++) {\n      Buffer.from(returnedRawNotations[i].value).toString().should.equal(rawNotations[i].value);\n    }\n  });\n});\n"]}

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


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