PHP WebShell
Текущая директория: /opt/BitGoJS/modules/express/dist/test/integration
Просмотр файла: bitgoExpress.js
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
/**
* @prettier
*/
const should = require("should");
require("should-http");
const supertest_1 = require("supertest");
const config_1 = require("../../src/config");
const expressApp_1 = require("../../src/expressApp");
const nock = require("nock");
const sdk_core_1 = require("@bitgo/sdk-core");
describe('Bitgo Express', function () {
let agent;
before(function () {
nock.restore();
const args = {
...config_1.DefaultConfig,
debug: false,
env: 'test',
logfile: '/dev/null',
};
const app = (0, expressApp_1.app)(args);
agent = (0, supertest_1.agent)(app);
});
describe('verify address', function () {
describe('failure', function () {
it('should mark as invalid bad btc address', async function () {
const res = await agent
.post('/api/v2/btc/verifyaddress')
.send({ address: '3P14159f73E4gFr7JterCCQh9QjiTjiZrR' });
res.should.have.status(200);
res.body.isValid.should.equal(false);
});
it('should mark as invalid bad ltc address', async function () {
const res = await agent
.post('/api/v2/ltc/verifyaddress')
.send({ address: '3Ps3MeHaYm2s5WPsRo1kHkCvS8EFawzG7R' });
res.should.have.status(200);
res.body.isValid.should.equal(false);
});
it('should mark as invalid bad tltc address', async function () {
const res = await agent
.post('/api/v2/tltc/verifyaddress')
.send({ address: 'QeKCcxtfqprzZsWZihRgxJk2QJrrLMjS4s' });
res.should.have.status(200);
res.body.isValid.should.equal(false);
});
it('should mark as invalid bad tltc address when not allowing old script hash version', async function () {
const res = await agent
.post('/api/v2/ltc/verifyaddress')
.send({ address: '3Ps3MeHaYm2s5WPsRo1kHkCvS8EFawzG7Q' });
res.should.have.status(200);
res.body.isValid.should.equal(false);
});
it('should mark as invalid bad eth address', async function () {
const res = await agent
.post('/api/v2/eth/verifyaddress')
.send({ address: '0xd4a4aa09f57b7e83cd817ec24df9f86daf253d1' });
res.should.have.status(200);
res.body.isValid.should.equal(false);
});
it('should mark as invalid bad xrp address', async function () {
const res = await agent
.post('/api/v2/xrp/verifyaddress')
.send({ address: 'rw5bfvumHWZirKLG5gUQ89dyqtiUUbmxP' });
res.should.have.status(200);
res.body.isValid.should.equal(false);
});
});
describe('success', function () {
it('should verify valid btc address', async function () {
const res = await agent
.post('/api/v2/btc/verifyaddress')
.send({ address: '3P14159f73E4gFr7JterCCQh9QjiTjiZrG' });
res.should.have.status(200);
res.body.isValid.should.equal(true);
});
it('should verify valid tbtc address', async function () {
const res = await agent
.post('/api/v2/tbtc/verifyaddress')
.send({ address: '2MzQwSSnBHWHqSAqtTVQ6v47XtaisrJa1Vc' });
res.should.have.status(200);
res.body.isValid.should.equal(true);
});
it('should verify valid ltc address', async function () {
const res = await agent
.post('/api/v2/ltc/verifyaddress')
.send({ address: 'MW5BfXhYVstHt1fmXg167PTKkpphfP6xQ3' });
res.should.have.status(200);
res.body.isValid.should.equal(true);
});
it('should verify old-style P2SH ltc address when allowing old script hash version', async function () {
const res = await agent.post('/api/v2/ltc/verifyaddress').send({
address: '3Ps3MeHaYm2s5WPsRo1kHkCvS8EFawzG7Q',
supportOldScriptHashVersion: true,
});
res.should.have.status(200);
res.body.isValid.should.equal(true);
});
it('should verify tltc address', async function () {
const res = await agent
.post('/api/v2/tltc/verifyaddress')
.send({ address: 'QeKCcxtfqprzZsWZihRgxJk2QJrrLMjS4c' });
res.should.have.status(200);
res.body.isValid.should.equal(true);
});
it('should verify valid eth address', async function () {
const res = await agent
.post('/api/v2/eth/verifyaddress')
.send({ address: '0xd4a4aa09f57b7e83cd817ec24df9f86daf253d1d' });
res.should.have.status(200);
res.body.isValid.should.equal(true);
});
it('should verify valid xrp address', async function () {
const res = await agent
.post('/api/v2/xrp/verifyaddress')
.send({ address: 'rw5bfvumHWZirKLG5gUQ89dyqtiUUbmxPD' });
res.should.have.status(200);
res.body.isValid.should.equal(true);
});
});
});
describe('Request body size limits', () => {
it('should handle request bodies <=20mb', async function () {
// actual number of bytes sent will be roughly 6x the number of bytes in
// the buffer. Therefore, to create a request body between 12mb and 20mb,
// we should create a buffer with between 2e6 and 3.3e6 bytes
const numBytes = Math.floor(Math.random() * 2e6 + 1.3e6);
const res = await agent
.post('/api/v2/btc/verifyaddress')
.send({ address: '3P14159f73E4gFr7JterCCQh9QjiTjiZrG', garbage: Buffer.alloc(numBytes).toString('utf8') });
res.should.have.status(200);
res.body.isValid.should.equal(true);
});
it('should fail for request bodies >20mb', async function () {
// actual number of bytes sent will be roughly 6x the number of bytes in
// the buffer. Therefore, to create a request body between 20mb and 25mb,
// we should create a buffer with between 3.334e6 and 4.166e6 bytes.
// we use 3.5e6 instead to give a bit of buffer space (no pun intended)
const numBytes = Math.floor(Math.random() * 0.826e6 + 3.5e6);
const res = await agent
.post('/api/v2/btc/verifyaddress')
.send({ address: '3P14159f73E4gFr7JterCCQh9QjiTjiZrG', garbage: Buffer.alloc(numBytes).toString('utf8') });
res.should.have.status(413);
});
});
it('should not proxy a non-api route', async function () {
const res = await agent.get('/info/solutions').send();
res.should.have.status(404);
});
it('should proxy the oauth/token route', async function () {
const res = await agent.post('/oauth/token').send();
res.should.not.have.status(404);
});
it('should handle coinless routes', async function () {
const routes = [
agent.get('/api/v2/reports/'),
agent.get('/api/v2/wallet/balances/merged/'),
agent.get('/api/v2/enterprise/1234/'),
agent.post('/api/v2/sendlabels/'),
agent.put('/api/v2/sendlabels/123'),
agent.delete('/api/v2/sendlabels/323'),
];
for (const res of await Promise.all(routes)) {
res.should.have.status(401);
}
});
it('should handle coinless routes with multiple query params', async function () {
const res = await agent.get('/api/v2/market/latest?coin=tbtc&coin=tltc');
res.should.have.status(200);
should.exist(res.body.marketData);
res.body.marketData.should.have.length(2);
res.body.marketData[0].should.have.property('coin', 'tbtc');
res.body.marketData[1].should.have.property('coin', 'tltc');
});
it('should handle coinless routes with a single query param', async function () {
const res = await agent.get('/api/v2/market/latest?coin=tbtc');
res.should.have.status(200);
should.exist(res.body.marketData);
res.body.marketData.should.have.length(1);
res.body.marketData[0].should.have.property('coin', 'tbtc');
});
it('should pass POST body data to the proxy target url', async function () {
const path = '/api/v2/post';
const body = { some: 'data' };
const serverResponse = { testResponse: 'server response' };
// client constants are retrieved upon BitGo
// object creation so they need to be nocked
const scopes = [
nock(sdk_core_1.Environments.test.uri).get('/api/v1/client/constants').reply(200, {}),
nock(sdk_core_1.Environments.test.uri).post(path, body).reply(200, serverResponse),
];
const postRes = await agent.post(path).send(body);
postRes.should.have.status(200);
postRes.should.have.property('body', serverResponse);
scopes.forEach((s) => s.done());
});
describe('proxy error handling', () => {
let agent;
before(() => {
const args = {
...config_1.DefaultConfig,
debug: true,
env: 'test',
timeout: 500,
};
const app = (0, expressApp_1.app)(args);
agent = (0, supertest_1.agent)(app);
if (!nock.isActive()) {
nock.activate();
}
nock.disableNetConnect();
nock.enableNetConnect('127.0.0.1');
});
after(() => {
if (nock.isActive()) {
nock.restore();
}
});
it('should handle ECONNRESET errors from the proxy server', async function () {
const path = '/api/v2/fakeroute';
// client constants are retrieved upon BitGo
// object creation so they need to be nocked
nock(sdk_core_1.Environments.test.uri).get('/api/v1/client/constants').reply(200, {});
// first request to ping endpoint should time out
nock(sdk_core_1.Environments.test.uri).get(path).delayConnection(1000).reply(200);
// we should return 503 in the case of a timeout
let pingRes = await agent.get(path).send({});
pingRes.should.have.status(503);
nock(sdk_core_1.Environments.test.uri).get(path).reply(200);
pingRes = await agent.get(path).send({});
pingRes.should.have.status(200);
});
it('should handle log4j injection string', async function () {
const res = await agent.get('/').query('a=${jndi:dns://3.127.145.40:53/}').send({});
res.should.have.status(404);
});
});
});
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"bitgoExpress.js","sourceRoot":"","sources":["../../../test/integration/bitgoExpress.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @prettier\n */\nimport * as should from 'should';\nimport 'should-http';\n\nimport { agent as supertest } from 'supertest';\nimport { DefaultConfig } from '../../src/config';\nimport { app as expressApp } from '../../src/expressApp';\nimport * as nock from 'nock';\nimport { Environments } from '@bitgo/sdk-core';\n\ndescribe('Bitgo Express', function () {\n  let agent;\n  before(function () {\n    nock.restore();\n\n    const args = {\n      ...DefaultConfig,\n      debug: false,\n      env: 'test' as const,\n      logfile: '/dev/null',\n    };\n\n    const app = expressApp(args);\n    agent = supertest(app);\n  });\n\n  describe('verify address', function () {\n    describe('failure', function () {\n      it('should mark as invalid bad btc address', async function () {\n        const res = await agent\n          .post('/api/v2/btc/verifyaddress')\n          .send({ address: '3P14159f73E4gFr7JterCCQh9QjiTjiZrR' });\n\n        res.should.have.status(200);\n        res.body.isValid.should.equal(false);\n      });\n\n      it('should mark as invalid bad ltc address', async function () {\n        const res = await agent\n          .post('/api/v2/ltc/verifyaddress')\n          .send({ address: '3Ps3MeHaYm2s5WPsRo1kHkCvS8EFawzG7R' });\n\n        res.should.have.status(200);\n        res.body.isValid.should.equal(false);\n      });\n\n      it('should mark as invalid bad tltc address', async function () {\n        const res = await agent\n          .post('/api/v2/tltc/verifyaddress')\n          .send({ address: 'QeKCcxtfqprzZsWZihRgxJk2QJrrLMjS4s' });\n\n        res.should.have.status(200);\n        res.body.isValid.should.equal(false);\n      });\n\n      it('should mark as invalid bad tltc address when not allowing old script hash version', async function () {\n        const res = await agent\n          .post('/api/v2/ltc/verifyaddress')\n          .send({ address: '3Ps3MeHaYm2s5WPsRo1kHkCvS8EFawzG7Q' });\n\n        res.should.have.status(200);\n        res.body.isValid.should.equal(false);\n      });\n\n      it('should mark as invalid bad eth address', async function () {\n        const res = await agent\n          .post('/api/v2/eth/verifyaddress')\n          .send({ address: '0xd4a4aa09f57b7e83cd817ec24df9f86daf253d1' });\n\n        res.should.have.status(200);\n        res.body.isValid.should.equal(false);\n      });\n\n      it('should mark as invalid bad xrp address', async function () {\n        const res = await agent\n          .post('/api/v2/xrp/verifyaddress')\n          .send({ address: 'rw5bfvumHWZirKLG5gUQ89dyqtiUUbmxP' });\n\n        res.should.have.status(200);\n        res.body.isValid.should.equal(false);\n      });\n    });\n\n    describe('success', function () {\n      it('should verify valid btc address', async function () {\n        const res = await agent\n          .post('/api/v2/btc/verifyaddress')\n          .send({ address: '3P14159f73E4gFr7JterCCQh9QjiTjiZrG' });\n\n        res.should.have.status(200);\n        res.body.isValid.should.equal(true);\n      });\n\n      it('should verify valid tbtc address', async function () {\n        const res = await agent\n          .post('/api/v2/tbtc/verifyaddress')\n          .send({ address: '2MzQwSSnBHWHqSAqtTVQ6v47XtaisrJa1Vc' });\n\n        res.should.have.status(200);\n        res.body.isValid.should.equal(true);\n      });\n\n      it('should verify valid ltc address', async function () {\n        const res = await agent\n          .post('/api/v2/ltc/verifyaddress')\n          .send({ address: 'MW5BfXhYVstHt1fmXg167PTKkpphfP6xQ3' });\n\n        res.should.have.status(200);\n        res.body.isValid.should.equal(true);\n      });\n\n      it('should verify old-style P2SH ltc address when allowing old script hash version', async function () {\n        const res = await agent.post('/api/v2/ltc/verifyaddress').send({\n          address: '3Ps3MeHaYm2s5WPsRo1kHkCvS8EFawzG7Q',\n          supportOldScriptHashVersion: true,\n        });\n\n        res.should.have.status(200);\n        res.body.isValid.should.equal(true);\n      });\n\n      it('should verify tltc address', async function () {\n        const res = await agent\n          .post('/api/v2/tltc/verifyaddress')\n          .send({ address: 'QeKCcxtfqprzZsWZihRgxJk2QJrrLMjS4c' });\n\n        res.should.have.status(200);\n        res.body.isValid.should.equal(true);\n      });\n\n      it('should verify valid eth address', async function () {\n        const res = await agent\n          .post('/api/v2/eth/verifyaddress')\n          .send({ address: '0xd4a4aa09f57b7e83cd817ec24df9f86daf253d1d' });\n\n        res.should.have.status(200);\n        res.body.isValid.should.equal(true);\n      });\n\n      it('should verify valid xrp address', async function () {\n        const res = await agent\n          .post('/api/v2/xrp/verifyaddress')\n          .send({ address: 'rw5bfvumHWZirKLG5gUQ89dyqtiUUbmxPD' });\n\n        res.should.have.status(200);\n        res.body.isValid.should.equal(true);\n      });\n    });\n  });\n\n  describe('Request body size limits', () => {\n    it('should handle request bodies <=20mb', async function () {\n      // actual number of bytes sent will be roughly 6x the number of bytes in\n      // the buffer. Therefore, to create a request body between 12mb and 20mb,\n      // we should create a buffer with between 2e6 and 3.3e6 bytes\n      const numBytes = Math.floor(Math.random() * 2e6 + 1.3e6);\n      const res = await agent\n        .post('/api/v2/btc/verifyaddress')\n        .send({ address: '3P14159f73E4gFr7JterCCQh9QjiTjiZrG', garbage: Buffer.alloc(numBytes).toString('utf8') });\n\n      res.should.have.status(200);\n      res.body.isValid.should.equal(true);\n    });\n\n    it('should fail for request bodies >20mb', async function () {\n      // actual number of bytes sent will be roughly 6x the number of bytes in\n      // the buffer. Therefore, to create a request body between 20mb and 25mb,\n      // we should create a buffer with between 3.334e6 and 4.166e6 bytes.\n      // we use 3.5e6 instead to give a bit of buffer space (no pun intended)\n      const numBytes = Math.floor(Math.random() * 0.826e6 + 3.5e6);\n      const res = await agent\n        .post('/api/v2/btc/verifyaddress')\n        .send({ address: '3P14159f73E4gFr7JterCCQh9QjiTjiZrG', garbage: Buffer.alloc(numBytes).toString('utf8') });\n\n      res.should.have.status(413);\n    });\n  });\n\n  it('should not proxy a non-api route', async function () {\n    const res = await agent.get('/info/solutions').send();\n    res.should.have.status(404);\n  });\n\n  it('should proxy the oauth/token route', async function () {\n    const res = await agent.post('/oauth/token').send();\n    res.should.not.have.status(404);\n  });\n\n  it('should handle coinless routes', async function () {\n    const routes = [\n      agent.get('/api/v2/reports/'),\n      agent.get('/api/v2/wallet/balances/merged/'),\n      agent.get('/api/v2/enterprise/1234/'),\n      agent.post('/api/v2/sendlabels/'),\n      agent.put('/api/v2/sendlabels/123'),\n      agent.delete('/api/v2/sendlabels/323'),\n    ];\n\n    for (const res of await Promise.all(routes)) {\n      res.should.have.status(401);\n    }\n  });\n\n  it('should handle coinless routes with multiple query params', async function () {\n    const res = await agent.get('/api/v2/market/latest?coin=tbtc&coin=tltc');\n    res.should.have.status(200);\n    should.exist(res.body.marketData);\n    res.body.marketData.should.have.length(2);\n    res.body.marketData[0].should.have.property('coin', 'tbtc');\n    res.body.marketData[1].should.have.property('coin', 'tltc');\n  });\n\n  it('should handle coinless routes with a single query param', async function () {\n    const res = await agent.get('/api/v2/market/latest?coin=tbtc');\n    res.should.have.status(200);\n    should.exist(res.body.marketData);\n    res.body.marketData.should.have.length(1);\n    res.body.marketData[0].should.have.property('coin', 'tbtc');\n  });\n\n  it('should pass POST body data to the proxy target url', async function () {\n    const path = '/api/v2/post';\n    const body = { some: 'data' };\n    const serverResponse = { testResponse: 'server response' };\n\n    // client constants are retrieved upon BitGo\n    // object creation so they need to be nocked\n    const scopes = [\n      nock(Environments.test.uri).get('/api/v1/client/constants').reply(200, {}),\n      nock(Environments.test.uri).post(path, body).reply(200, serverResponse),\n    ];\n\n    const postRes = await agent.post(path).send(body);\n    postRes.should.have.status(200);\n    postRes.should.have.property('body', serverResponse);\n    scopes.forEach((s) => s.done());\n  });\n\n  describe('proxy error handling', () => {\n    let agent;\n    before(() => {\n      const args = {\n        ...DefaultConfig,\n        debug: true,\n        env: 'test' as const,\n        timeout: 500,\n      };\n\n      const app = expressApp(args);\n      agent = supertest(app);\n\n      if (!nock.isActive()) {\n        nock.activate();\n      }\n      nock.disableNetConnect();\n      nock.enableNetConnect('127.0.0.1');\n    });\n\n    after(() => {\n      if (nock.isActive()) {\n        nock.restore();\n      }\n    });\n\n    it('should handle ECONNRESET errors from the proxy server', async function () {\n      const path = '/api/v2/fakeroute';\n\n      // client constants are retrieved upon BitGo\n      // object creation so they need to be nocked\n      nock(Environments.test.uri).get('/api/v1/client/constants').reply(200, {});\n\n      // first request to ping endpoint should time out\n      nock(Environments.test.uri).get(path).delayConnection(1000).reply(200);\n\n      // we should return 503 in the case of a timeout\n      let pingRes = await agent.get(path).send({});\n      pingRes.should.have.status(503);\n\n      nock(Environments.test.uri).get(path).reply(200);\n\n      pingRes = await agent.get(path).send({});\n      pingRes.should.have.status(200);\n    });\n\n    it('should handle log4j injection string', async function () {\n      const res = await agent.get('/').query('a=${jndi:dns://3.127.145.40:53/}').send({});\n      res.should.have.status(404);\n    });\n  });\n});\n"]}Выполнить команду
Для локальной разработки. Не используйте в интернете!