PHP WebShell
Текущая директория: /opt/BitGoJS/modules/bitgo/dist/test
Просмотр файла: encrypt.js
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
/**
* @prettier
*/
const should = require("should");
const crypto_1 = require("crypto");
const sdk_api_1 = require("@bitgo/sdk-api");
const sdk_test_1 = require("@bitgo/sdk-test");
describe('bytesToWord', () => {
it('should fail if input is not a Uint8Array', () => {
let inputArr = [0, 0, 0, 0];
(() => (0, sdk_api_1.bytesToWord)(inputArr)).should.throw();
inputArr = {};
(() => (0, sdk_api_1.bytesToWord)(inputArr)).should.throw();
inputArr = 'abc';
(() => (0, sdk_api_1.bytesToWord)(inputArr)).should.throw();
});
it('should fail if input is not exactly 4 elements', () => {
let inputArr = Uint8Array.of(0xff, 0xff, 0xff);
(() => (0, sdk_api_1.bytesToWord)(inputArr)).should.throw();
inputArr = Uint8Array.of(0xff, 0xff, 0xff, 0xff, 0xff);
(() => (0, sdk_api_1.bytesToWord)(inputArr)).should.throw();
});
it('should convert to 0', () => {
const inputArr = Uint8Array.of(0, 0, 0, 0);
const res = (0, sdk_api_1.bytesToWord)(inputArr);
res.should.equal(0);
});
it('should convert to 2 ^ 32 - 1', () => {
const inputArr = Uint8Array.of(0xff, 0xff, 0xff, 0xff);
const res = (0, sdk_api_1.bytesToWord)(inputArr);
res.should.equal(Math.pow(2, 32) - 1);
});
it('should convert to 2 ^ 16', () => {
const inputArr = Uint8Array.of(0x00, 0x01, 0x00, 0x00);
const res = (0, sdk_api_1.bytesToWord)(inputArr);
res.should.equal(Math.pow(2, 16));
});
it('should convert 1000 random numbers', () => {
for (let i = 0; i < 1000; i++) {
const inputArr = (0, crypto_1.randomBytes)(4);
const resStr = (0, sdk_api_1.bytesToWord)(inputArr).toString(16);
const arrStr = inputArr.toString('hex');
parseInt(resStr, 16).should.equal(parseInt(arrStr, 16));
}
});
});
describe('encrypt, decrypt', function () {
const passwords = Array.from({ length: 2 }).map((_, i) => `key/${i}`);
const plaintexts = Array.from({ length: 2 }).map((_, i) => `plaintext/${i}`);
it('matches fixture', function () {
const ciphertext = (0, sdk_api_1.encrypt)(passwords[0], plaintexts[0], {
salt: (0, sdk_test_1.getSeed)(`randomSalt`).slice(0, 8),
iv: (0, sdk_test_1.getSeed)(`randomIV`).slice(0, 16),
});
ciphertext.should.eql('{"iv":"BVDN1IpOeJ6E5kSV88MsHA==","v":1,"iter":10000,"ks":256,"ts":64,"mode":"ccm","adata":"","cipher":"aes","salt":"aJjlH+mKW1E=","ct":"loJEsFuypKZMZ+igqCUmbwQfMw=="}');
JSON.parse(ciphertext).should.eql({
adata: '',
cipher: 'aes',
ct: 'loJEsFuypKZMZ+igqCUmbwQfMw==',
iter: 10000,
iv: 'BVDN1IpOeJ6E5kSV88MsHA==',
ks: 256,
mode: 'ccm',
salt: 'aJjlH+mKW1E=',
ts: 64,
v: 1,
});
});
it('encrypts and decrypts', function () {
passwords.forEach((password) => {
plaintexts.forEach((plaintext) => {
const ciphertext1 = (0, sdk_api_1.encrypt)(password, plaintext);
const ciphertext2 = (0, sdk_api_1.encrypt)(password, plaintext);
(ciphertext1 === ciphertext2).should.eql(false);
[ciphertext1, ciphertext2].forEach((ct) => {
passwords.forEach((otherPassword) => {
if (password === otherPassword) {
(0, sdk_api_1.decrypt)(otherPassword, ct).should.eql(plaintext);
}
else {
should.throws(() => (0, sdk_api_1.decrypt)(otherPassword, ct), /ccm: tag doesn't match/);
}
});
});
});
});
});
});
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"encrypt.js","sourceRoot":"","sources":["../../test/encrypt.ts"],"names":[],"mappings":";;AAAA;;GAEG;AACH,iCAAiC;AAEjC,mCAAqC;AACrC,4CAA+D;AAC/D,8CAA0C;AAE1C,QAAQ,CAAC,aAAa,EAAE,GAAG,EAAE;IAC3B,EAAE,CAAC,0CAA0C,EAAE,GAAG,EAAE;QAClD,IAAI,QAAQ,GAAQ,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;QACjC,CAAC,GAAG,EAAE,CAAC,IAAA,qBAAW,EAAC,QAAQ,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,EAAE,CAAC;QAE7C,QAAQ,GAAG,EAAE,CAAC;QACd,CAAC,GAAG,EAAE,CAAC,IAAA,qBAAW,EAAC,QAAQ,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,EAAE,CAAC;QAE7C,QAAQ,GAAG,KAAK,CAAC;QACjB,CAAC,GAAG,EAAE,CAAC,IAAA,qBAAW,EAAC,QAAQ,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,EAAE,CAAC;IAC/C,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,gDAAgD,EAAE,GAAG,EAAE;QACxD,IAAI,QAAQ,GAAG,UAAU,CAAC,EAAE,CAAC,IAAI,EAAE,IAAI,EAAE,IAAI,CAAC,CAAC;QAC/C,CAAC,GAAG,EAAE,CAAC,IAAA,qBAAW,EAAC,QAAQ,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,EAAE,CAAC;QAE7C,QAAQ,GAAG,UAAU,CAAC,EAAE,CAAC,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,CAAC,CAAC;QACvD,CAAC,GAAG,EAAE,CAAC,IAAA,qBAAW,EAAC,QAAQ,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,EAAE,CAAC;IAC/C,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,qBAAqB,EAAE,GAAG,EAAE;QAC7B,MAAM,QAAQ,GAAG,UAAU,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;QAE3C,MAAM,GAAG,GAAG,IAAA,qBAAW,EAAC,QAAQ,CAAC,CAAC;QAClC,GAAG,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;IACtB,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,8BAA8B,EAAE,GAAG,EAAE;QACtC,MAAM,QAAQ,GAAG,UAAU,CAAC,EAAE,CAAC,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,CAAC,CAAC;QAEvD,MAAM,GAAG,GAAG,IAAA,qBAAW,EAAC,QAAQ,CAAC,CAAC;QAClC,GAAG,CAAC,MAAM,CAAC,KAAK,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC;IACxC,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,0BAA0B,EAAE,GAAG,EAAE;QAClC,MAAM,QAAQ,GAAG,UAAU,CAAC,EAAE,CAAC,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,CAAC,CAAC;QAEvD,MAAM,GAAG,GAAG,IAAA,qBAAW,EAAC,QAAQ,CAAC,CAAC;QAClC,GAAG,CAAC,MAAM,CAAC,KAAK,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC;IACpC,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,oCAAoC,EAAE,GAAG,EAAE;QAC5C,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,EAAE,CAAC,EAAE,EAAE,CAAC;YAC9B,MAAM,QAAQ,GAAG,IAAA,oBAAW,EAAC,CAAC,CAAC,CAAC;YAChC,MAAM,MAAM,GAAG,IAAA,qBAAW,EAAC,QAAQ,CAAC,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC;YAClD,MAAM,MAAM,GAAG,QAAQ,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;YACxC,QAAQ,CAAC,MAAM,EAAE,EAAE,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,QAAQ,CAAC,MAAM,EAAE,EAAE,CAAC,CAAC,CAAC;QAC1D,CAAC;IACH,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC;AAEH,QAAQ,CAAC,kBAAkB,EAAE;IAC3B,MAAM,SAAS,GAAG,KAAK,CAAC,IAAI,CAAC,EAAE,MAAM,EAAE,CAAC,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;IACtE,MAAM,UAAU,GAAG,KAAK,CAAC,IAAI,CAAC,EAAE,MAAM,EAAE,CAAC,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,aAAa,CAAC,EAAE,CAAC,CAAC;IAE7E,EAAE,CAAC,iBAAiB,EAAE;QACpB,MAAM,UAAU,GAAG,IAAA,iBAAO,EAAC,SAAS,CAAC,CAAC,CAAC,EAAE,UAAU,CAAC,CAAC,CAAC,EAAE;YACtD,IAAI,EAAE,IAAA,kBAAO,EAAC,YAAY,CAAC,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC;YACvC,EAAE,EAAE,IAAA,kBAAO,EAAC,UAAU,CAAC,CAAC,KAAK,CAAC,CAAC,EAAE,EAAE,CAAC;SACrC,CAAC,CAAC;QACH,UAAU,CAAC,MAAM,CAAC,GAAG,CACnB,wKAAwK,CACzK,CAAC;QACF,IAAI,CAAC,KAAK,CAAC,UAAU,CAAC,CAAC,MAAM,CAAC,GAAG,CAAC;YAChC,KAAK,EAAE,EAAE;YACT,MAAM,EAAE,KAAK;YACb,EAAE,EAAE,8BAA8B;YAClC,IAAI,EAAE,KAAK;YACX,EAAE,EAAE,0BAA0B;YAC9B,EAAE,EAAE,GAAG;YACP,IAAI,EAAE,KAAK;YACX,IAAI,EAAE,cAAc;YACpB,EAAE,EAAE,EAAE;YACN,CAAC,EAAE,CAAC;SACL,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,uBAAuB,EAAE;QAC1B,SAAS,CAAC,OAAO,CAAC,CAAC,QAAQ,EAAE,EAAE;YAC7B,UAAU,CAAC,OAAO,CAAC,CAAC,SAAS,EAAE,EAAE;gBAC/B,MAAM,WAAW,GAAG,IAAA,iBAAO,EAAC,QAAQ,EAAE,SAAS,CAAC,CAAC;gBACjD,MAAM,WAAW,GAAG,IAAA,iBAAO,EAAC,QAAQ,EAAE,SAAS,CAAC,CAAC;gBACjD,CAAC,WAAW,KAAK,WAAW,CAAC,CAAC,MAAM,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;gBAEhD,CAAC,WAAW,EAAE,WAAW,CAAC,CAAC,OAAO,CAAC,CAAC,EAAE,EAAE,EAAE;oBACxC,SAAS,CAAC,OAAO,CAAC,CAAC,aAAa,EAAE,EAAE;wBAClC,IAAI,QAAQ,KAAK,aAAa,EAAE,CAAC;4BAC/B,IAAA,iBAAO,EAAC,aAAa,EAAE,EAAE,CAAC,CAAC,MAAM,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC;wBACnD,CAAC;6BAAM,CAAC;4BACN,MAAM,CAAC,MAAM,CAAC,GAAG,EAAE,CAAC,IAAA,iBAAO,EAAC,aAAa,EAAE,EAAE,CAAC,EAAE,wBAAwB,CAAC,CAAC;wBAC5E,CAAC;oBACH,CAAC,CAAC,CAAC;gBACL,CAAC,CAAC,CAAC;YACL,CAAC,CAAC,CAAC;QACL,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC","sourcesContent":["/**\n * @prettier\n */\nimport * as should from 'should';\n\nimport { randomBytes } from 'crypto';\nimport { decrypt, encrypt, bytesToWord } from '@bitgo/sdk-api';\nimport { getSeed } from '@bitgo/sdk-test';\n\ndescribe('bytesToWord', () => {\n  it('should fail if input is not a Uint8Array', () => {\n    let inputArr: any = [0, 0, 0, 0];\n    (() => bytesToWord(inputArr)).should.throw();\n\n    inputArr = {};\n    (() => bytesToWord(inputArr)).should.throw();\n\n    inputArr = 'abc';\n    (() => bytesToWord(inputArr)).should.throw();\n  });\n\n  it('should fail if input is not exactly 4 elements', () => {\n    let inputArr = Uint8Array.of(0xff, 0xff, 0xff);\n    (() => bytesToWord(inputArr)).should.throw();\n\n    inputArr = Uint8Array.of(0xff, 0xff, 0xff, 0xff, 0xff);\n    (() => bytesToWord(inputArr)).should.throw();\n  });\n\n  it('should convert to 0', () => {\n    const inputArr = Uint8Array.of(0, 0, 0, 0);\n\n    const res = bytesToWord(inputArr);\n    res.should.equal(0);\n  });\n\n  it('should convert to 2 ^ 32 - 1', () => {\n    const inputArr = Uint8Array.of(0xff, 0xff, 0xff, 0xff);\n\n    const res = bytesToWord(inputArr);\n    res.should.equal(Math.pow(2, 32) - 1);\n  });\n\n  it('should convert to 2 ^ 16', () => {\n    const inputArr = Uint8Array.of(0x00, 0x01, 0x00, 0x00);\n\n    const res = bytesToWord(inputArr);\n    res.should.equal(Math.pow(2, 16));\n  });\n\n  it('should convert 1000 random numbers', () => {\n    for (let i = 0; i < 1000; i++) {\n      const inputArr = randomBytes(4);\n      const resStr = bytesToWord(inputArr).toString(16);\n      const arrStr = inputArr.toString('hex');\n      parseInt(resStr, 16).should.equal(parseInt(arrStr, 16));\n    }\n  });\n});\n\ndescribe('encrypt, decrypt', function () {\n  const passwords = Array.from({ length: 2 }).map((_, i) => `key/${i}`);\n  const plaintexts = Array.from({ length: 2 }).map((_, i) => `plaintext/${i}`);\n\n  it('matches fixture', function () {\n    const ciphertext = encrypt(passwords[0], plaintexts[0], {\n      salt: getSeed(`randomSalt`).slice(0, 8),\n      iv: getSeed(`randomIV`).slice(0, 16),\n    });\n    ciphertext.should.eql(\n      '{\"iv\":\"BVDN1IpOeJ6E5kSV88MsHA==\",\"v\":1,\"iter\":10000,\"ks\":256,\"ts\":64,\"mode\":\"ccm\",\"adata\":\"\",\"cipher\":\"aes\",\"salt\":\"aJjlH+mKW1E=\",\"ct\":\"loJEsFuypKZMZ+igqCUmbwQfMw==\"}'\n    );\n    JSON.parse(ciphertext).should.eql({\n      adata: '',\n      cipher: 'aes',\n      ct: 'loJEsFuypKZMZ+igqCUmbwQfMw==',\n      iter: 10000,\n      iv: 'BVDN1IpOeJ6E5kSV88MsHA==',\n      ks: 256,\n      mode: 'ccm',\n      salt: 'aJjlH+mKW1E=',\n      ts: 64,\n      v: 1,\n    });\n  });\n\n  it('encrypts and decrypts', function () {\n    passwords.forEach((password) => {\n      plaintexts.forEach((plaintext) => {\n        const ciphertext1 = encrypt(password, plaintext);\n        const ciphertext2 = encrypt(password, plaintext);\n        (ciphertext1 === ciphertext2).should.eql(false);\n\n        [ciphertext1, ciphertext2].forEach((ct) => {\n          passwords.forEach((otherPassword) => {\n            if (password === otherPassword) {\n              decrypt(otherPassword, ct).should.eql(plaintext);\n            } else {\n              should.throws(() => decrypt(otherPassword, ct), /ccm: tag doesn't match/);\n            }\n          });\n        });\n      });\n    });\n  });\n});\n"]}Выполнить команду
Для локальной разработки. Не используйте в интернете!