UNPKG

bitgo

Version:
91 lines • 13.9 kB
"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":"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","sourcesContent":["/**\n * @prettier\n */\nimport should = require('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"]}