bitgo
Version:
BitGo JavaScript SDK
106 lines • 15.9 kB
JavaScript
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
const nock = require("nock");
require("should");
const sinon = require("sinon");
const src_1 = require("../../../src");
describe('Auth', () => {
let sandbox;
beforeEach(() => {
sandbox = sinon.createSandbox();
});
afterEach(() => {
sandbox.restore();
});
describe('Auth V3', () => {
it('should set auth version to 3 when initializing a bitgo object with explicit auth version 3', () => {
const bitgo = new src_1.BitGo({ authVersion: 3 });
bitgo.getAuthVersion().should.eql(3);
});
it('should pass "3.0" as the bitgo-auth-version header when auth v3 is enabled', async () => {
const url = 'https://bitgo.invalid';
const bitgo = new src_1.BitGo({ authVersion: 3 });
const scope = nock(url, {
reqheaders: {
'bitgo-auth-version': '3.0',
},
})
.get('/')
.reply(200);
await bitgo.get(url).should.eventually.have.property('status', 200);
scope.done();
});
it('should reject responses outside the response validity window', async () => {
const url = 'https://bitgo.invalid';
const bitgo = new src_1.BitGo({ authVersion: 3, accessToken: `v2x${'0'.repeat(64)}` });
const verifyResponseStub = sinon.stub(bitgo, 'verifyResponse').returns({
isValid: true,
isInResponseValidityWindow: false,
expectedHmac: '',
signatureSubject: '',
verificationTime: 0,
});
const scope = nock(url).get('/').reply(200);
await bitgo.get(url).should.be.rejectedWith('server response outside response validity time window');
verifyResponseStub.restore();
scope.done();
});
it('should accept responses within the response validity window', async () => {
const url = 'https://bitgo.invalid';
const bitgo = new src_1.BitGo({ authVersion: 3, accessToken: `v2x${'0'.repeat(64)}` });
const verifyResponseStub = sinon.stub(bitgo, 'verifyResponse').returns({
isValid: true,
isInResponseValidityWindow: true,
expectedHmac: '',
signatureSubject: '',
verificationTime: 0,
});
const scope = nock(url).get('/').reply(200);
await bitgo.get(url).should.eventually.have.property('status', 200);
verifyResponseStub.restore();
scope.done();
});
it('should include the auth version in the hmac subject', async () => {
const url = 'https://bitgo.invalid';
const accessToken = `v2x${'0'.repeat(64)}`;
const bitgo = new src_1.BitGo({ authVersion: 3, accessToken });
const crypto = require('crypto');
const createHmacSpy = sinon.spy(crypto, 'createHmac');
const updateSpy = sinon.spy(crypto.Hmac.prototype, 'update');
const verifyResponseStub = sinon.stub(bitgo, 'verifyResponse').returns({
isValid: true,
isInResponseValidityWindow: true,
expectedHmac: '',
signatureSubject: '',
verificationTime: 0,
});
const scope = nock(url).get('/').reply(200);
await bitgo.get(url).should.eventually.have.property('status', 200);
createHmacSpy.firstCall.calledWith('sha256', accessToken).should.be.true();
updateSpy.firstCall.calledWith(sinon.match('3.0')).should.be.true();
createHmacSpy.restore();
verifyResponseStub.restore();
scope.done();
});
});
describe('Auth V2', () => {
it('should default to auth version 2 when initializing a bitgo object', () => {
const bitgo = new src_1.BitGo();
bitgo.getAuthVersion().should.eql(2);
});
it('should pass "2.0" as the bitgo-auth-version header when auth v2 is enabled', async () => {
const url = 'https://bitgo.invalid';
const bitgo = new src_1.BitGo();
const scope = nock(url, {
reqheaders: {
'bitgo-auth-version': '2.0',
},
})
.get('/')
.reply(200);
await bitgo.get(url).should.eventually.have.property('status', 200);
scope.done();
});
});
});
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"auth.js","sourceRoot":"","sources":["../../../../test/v2/unit/auth.ts"],"names":[],"mappings":";;AAAA,6BAA8B;AAC9B,kBAAgB;AAChB,+BAA+B;AAE/B,sCAAqC;AAErC,QAAQ,CAAC,MAAM,EAAE,GAAG,EAAE;IACpB,IAAI,OAAO,CAAC;IACZ,UAAU,CAAC,GAAG,EAAE;QACd,OAAO,GAAG,KAAK,CAAC,aAAa,EAAE,CAAC;IAClC,CAAC,CAAC,CAAC;IACH,SAAS,CAAC,GAAG,EAAE;QACb,OAAO,CAAC,OAAO,EAAE,CAAC;IACpB,CAAC,CAAC,CAAC;IACH,QAAQ,CAAC,SAAS,EAAE,GAAG,EAAE;QACvB,EAAE,CAAC,4FAA4F,EAAE,GAAG,EAAE;YACpG,MAAM,KAAK,GAAG,IAAI,WAAK,CAAC,EAAE,WAAW,EAAE,CAAC,EAAE,CAAC,CAAC;YAC5C,KAAK,CAAC,cAAc,EAAE,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;QACvC,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,4EAA4E,EAAE,KAAK,IAAI,EAAE;YAC1F,MAAM,GAAG,GAAG,uBAAuB,CAAC;YACpC,MAAM,KAAK,GAAG,IAAI,WAAK,CAAC,EAAE,WAAW,EAAE,CAAC,EAAE,CAAC,CAAC;YAE5C,MAAM,KAAK,GAAG,IAAI,CAAC,GAAG,EAAE;gBACtB,UAAU,EAAE;oBACV,oBAAoB,EAAE,KAAK;iBAC5B;aACF,CAAC;iBACC,GAAG,CAAC,GAAG,CAAC;iBACR,KAAK,CAAC,GAAG,CAAC,CAAC;YAEd,MAAM,KAAK,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,MAAM,CAAC,UAAU,CAAC,IAAI,CAAC,QAAQ,CAAC,QAAQ,EAAE,GAAG,CAAC,CAAC;YACpE,KAAK,CAAC,IAAI,EAAE,CAAC;QACf,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,8DAA8D,EAAE,KAAK,IAAI,EAAE;YAC5E,MAAM,GAAG,GAAG,uBAAuB,CAAC;YACpC,MAAM,KAAK,GAAG,IAAI,WAAK,CAAC,EAAE,WAAW,EAAE,CAAC,EAAE,WAAW,EAAE,MAAM,GAAG,CAAC,MAAM,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC;YAEjF,MAAM,kBAAkB,GAAG,KAAK,CAAC,IAAI,CAAC,KAAK,EAAE,gBAAgB,CAAC,CAAC,OAAO,CAAC;gBACrE,OAAO,EAAE,IAAI;gBACb,0BAA0B,EAAE,KAAK;gBACjC,YAAY,EAAE,EAAE;gBAChB,gBAAgB,EAAE,EAAE;gBACpB,gBAAgB,EAAE,CAAC;aACpB,CAAC,CAAC;YAEH,MAAM,KAAK,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;YAE5C,MAAM,KAAK,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,MAAM,CAAC,EAAE,CAAC,YAAY,CAAC,uDAAuD,CAAC,CAAC;YACrG,kBAAkB,CAAC,OAAO,EAAE,CAAC;YAC7B,KAAK,CAAC,IAAI,EAAE,CAAC;QACf,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,6DAA6D,EAAE,KAAK,IAAI,EAAE;YAC3E,MAAM,GAAG,GAAG,uBAAuB,CAAC;YACpC,MAAM,KAAK,GAAG,IAAI,WAAK,CAAC,EAAE,WAAW,EAAE,CAAC,EAAE,WAAW,EAAE,MAAM,GAAG,CAAC,MAAM,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC;YAEjF,MAAM,kBAAkB,GAAG,KAAK,CAAC,IAAI,CAAC,KAAK,EAAE,gBAAgB,CAAC,CAAC,OAAO,CAAC;gBACrE,OAAO,EAAE,IAAI;gBACb,0BAA0B,EAAE,IAAI;gBAChC,YAAY,EAAE,EAAE;gBAChB,gBAAgB,EAAE,EAAE;gBACpB,gBAAgB,EAAE,CAAC;aACpB,CAAC,CAAC;YAEH,MAAM,KAAK,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;YAE5C,MAAM,KAAK,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,MAAM,CAAC,UAAU,CAAC,IAAI,CAAC,QAAQ,CAAC,QAAQ,EAAE,GAAG,CAAC,CAAC;YACpE,kBAAkB,CAAC,OAAO,EAAE,CAAC;YAC7B,KAAK,CAAC,IAAI,EAAE,CAAC;QACf,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,qDAAqD,EAAE,KAAK,IAAI,EAAE;YACnE,MAAM,GAAG,GAAG,uBAAuB,CAAC;YACpC,MAAM,WAAW,GAAG,MAAM,GAAG,CAAC,MAAM,CAAC,EAAE,CAAC,EAAE,CAAC;YAC3C,MAAM,KAAK,GAAG,IAAI,WAAK,CAAC,EAAE,WAAW,EAAE,CAAC,EAAE,WAAW,EAAE,CAAC,CAAC;YAEzD,MAAM,MAAM,GAAG,OAAO,CAAC,QAAQ,CAAC,CAAC;YACjC,MAAM,aAAa,GAAG,KAAK,CAAC,GAAG,CAAC,MAAM,EAAE,YAAY,CAAC,CAAC;YACtD,MAAM,SAAS,GAAG,KAAK,CAAC,GAAG,CAAC,MAAM,CAAC,IAAI,CAAC,SAAS,EAAE,QAAQ,CAAC,CAAC;YAE7D,MAAM,kBAAkB,GAAG,KAAK,CAAC,IAAI,CAAC,KAAK,EAAE,gBAAgB,CAAC,CAAC,OAAO,CAAC;gBACrE,OAAO,EAAE,IAAI;gBACb,0BAA0B,EAAE,IAAI;gBAChC,YAAY,EAAE,EAAE;gBAChB,gBAAgB,EAAE,EAAE;gBACpB,gBAAgB,EAAE,CAAC;aACpB,CAAC,CAAC;YAEH,MAAM,KAAK,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;YAE5C,MAAM,KAAK,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,MAAM,CAAC,UAAU,CAAC,IAAI,CAAC,QAAQ,CAAC,QAAQ,EAAE,GAAG,CAAC,CAAC;YAEpE,aAAa,CAAC,SAAS,CAAC,UAAU,CAAC,QAAQ,EAAE,WAAW,CAAC,CAAC,MAAM,CAAC,EAAE,CAAC,IAAI,EAAE,CAAC;YAC3E,SAAS,CAAC,SAAS,CAAC,UAAU,CAAC,KAAK,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC,MAAM,CAAC,EAAE,CAAC,IAAI,EAAE,CAAC;YACpE,aAAa,CAAC,OAAO,EAAE,CAAC;YACxB,kBAAkB,CAAC,OAAO,EAAE,CAAC;YAC7B,KAAK,CAAC,IAAI,EAAE,CAAC;QACf,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,QAAQ,CAAC,SAAS,EAAE,GAAG,EAAE;QACvB,EAAE,CAAC,mEAAmE,EAAE,GAAG,EAAE;YAC3E,MAAM,KAAK,GAAG,IAAI,WAAK,EAAE,CAAC;YAC1B,KAAK,CAAC,cAAc,EAAE,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;QACvC,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,4EAA4E,EAAE,KAAK,IAAI,EAAE;YAC1F,MAAM,GAAG,GAAG,uBAAuB,CAAC;YACpC,MAAM,KAAK,GAAG,IAAI,WAAK,EAAE,CAAC;YAE1B,MAAM,KAAK,GAAG,IAAI,CAAC,GAAG,EAAE;gBACtB,UAAU,EAAE;oBACV,oBAAoB,EAAE,KAAK;iBAC5B;aACF,CAAC;iBACC,GAAG,CAAC,GAAG,CAAC;iBACR,KAAK,CAAC,GAAG,CAAC,CAAC;YAEd,MAAM,KAAK,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,MAAM,CAAC,UAAU,CAAC,IAAI,CAAC,QAAQ,CAAC,QAAQ,EAAE,GAAG,CAAC,CAAC;YACpE,KAAK,CAAC,IAAI,EAAE,CAAC;QACf,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC","sourcesContent":["import nock = require('nock');\nimport 'should';\nimport * as sinon from 'sinon';\n\nimport { BitGo } from '../../../src';\n\ndescribe('Auth', () => {\n  let sandbox;\n  beforeEach(() => {\n    sandbox = sinon.createSandbox();\n  });\n  afterEach(() => {\n    sandbox.restore();\n  });\n  describe('Auth V3', () => {\n    it('should set auth version to 3 when initializing a bitgo object with explicit auth version 3', () => {\n      const bitgo = new BitGo({ authVersion: 3 });\n      bitgo.getAuthVersion().should.eql(3);\n    });\n\n    it('should pass \"3.0\" as the bitgo-auth-version header when auth v3 is enabled', async () => {\n      const url = 'https://bitgo.invalid';\n      const bitgo = new BitGo({ authVersion: 3 });\n\n      const scope = nock(url, {\n        reqheaders: {\n          'bitgo-auth-version': '3.0',\n        },\n      })\n        .get('/')\n        .reply(200);\n\n      await bitgo.get(url).should.eventually.have.property('status', 200);\n      scope.done();\n    });\n\n    it('should reject responses outside the response validity window', async () => {\n      const url = 'https://bitgo.invalid';\n      const bitgo = new BitGo({ authVersion: 3, accessToken: `v2x${'0'.repeat(64)}` });\n\n      const verifyResponseStub = sinon.stub(bitgo, 'verifyResponse').returns({\n        isValid: true,\n        isInResponseValidityWindow: false,\n        expectedHmac: '',\n        signatureSubject: '',\n        verificationTime: 0,\n      });\n\n      const scope = nock(url).get('/').reply(200);\n\n      await bitgo.get(url).should.be.rejectedWith('server response outside response validity time window');\n      verifyResponseStub.restore();\n      scope.done();\n    });\n\n    it('should accept responses within the response validity window', async () => {\n      const url = 'https://bitgo.invalid';\n      const bitgo = new BitGo({ authVersion: 3, accessToken: `v2x${'0'.repeat(64)}` });\n\n      const verifyResponseStub = sinon.stub(bitgo, 'verifyResponse').returns({\n        isValid: true,\n        isInResponseValidityWindow: true,\n        expectedHmac: '',\n        signatureSubject: '',\n        verificationTime: 0,\n      });\n\n      const scope = nock(url).get('/').reply(200);\n\n      await bitgo.get(url).should.eventually.have.property('status', 200);\n      verifyResponseStub.restore();\n      scope.done();\n    });\n\n    it('should include the auth version in the hmac subject', async () => {\n      const url = 'https://bitgo.invalid';\n      const accessToken = `v2x${'0'.repeat(64)}`;\n      const bitgo = new BitGo({ authVersion: 3, accessToken });\n\n      const crypto = require('crypto');\n      const createHmacSpy = sinon.spy(crypto, 'createHmac');\n      const updateSpy = sinon.spy(crypto.Hmac.prototype, 'update');\n\n      const verifyResponseStub = sinon.stub(bitgo, 'verifyResponse').returns({\n        isValid: true,\n        isInResponseValidityWindow: true,\n        expectedHmac: '',\n        signatureSubject: '',\n        verificationTime: 0,\n      });\n\n      const scope = nock(url).get('/').reply(200);\n\n      await bitgo.get(url).should.eventually.have.property('status', 200);\n\n      createHmacSpy.firstCall.calledWith('sha256', accessToken).should.be.true();\n      updateSpy.firstCall.calledWith(sinon.match('3.0')).should.be.true();\n      createHmacSpy.restore();\n      verifyResponseStub.restore();\n      scope.done();\n    });\n  });\n\n  describe('Auth V2', () => {\n    it('should default to auth version 2 when initializing a bitgo object', () => {\n      const bitgo = new BitGo();\n      bitgo.getAuthVersion().should.eql(2);\n    });\n\n    it('should pass \"2.0\" as the bitgo-auth-version header when auth v2 is enabled', async () => {\n      const url = 'https://bitgo.invalid';\n      const bitgo = new BitGo();\n\n      const scope = nock(url, {\n        reqheaders: {\n          'bitgo-auth-version': '2.0',\n        },\n      })\n        .get('/')\n        .reply(200);\n\n      await bitgo.get(url).should.eventually.have.property('status', 200);\n      scope.done();\n    });\n  });\n});\n"]}