Add basic auth

This commit is contained in:
wltsmrz
2015-10-19 13:52:38 -07:00
parent 98422e4153
commit f65b673451
5 changed files with 97 additions and 40 deletions

View File

@@ -307,7 +307,7 @@ describe('Remote', function() {
});
it('Server initialization -- set servers', function() {
assert.deepEqual(new Remote({servers: []}).servers, [ ]);
assert.deepEqual(new Remote({servers: []}).servers, []);
});
it('Server initialization -- set servers -- invalid', function() {
assert.throws(function() {
@@ -792,11 +792,7 @@ describe('Remote', function() {
it('Get server', function() {
remote.addServer('wss://sasdf.ripple.com:443');
remote.connect();
remote._connected = true;
remote._servers.forEach(function(s) {
s._connected = true;
});
remote._servers.concat(remote).forEach(s => s._connected = true);
const message = {
type: 'ledgerClosed',
@@ -828,19 +824,6 @@ describe('Remote', function() {
assert.strictEqual(remote._servers.length, 2);
assert.strictEqual(remote.getServer(), null);
});
it('Get server -- primary server', function() {
const server = remote.addServer({
host: 'sasdf.ripple.com',
port: 443,
secure: true,
primary: true
});
remote.connect();
server._connected = true;
assert.strictEqual(remote.getServer().getServerID(), server.getServerID());
});
it('Parse binary transaction', function() {
const binaryTransaction = require('./fixtures/binary-transaction.json');

View File

@@ -1,6 +1,6 @@
'use strict';
/* eslint-disable no-new */
/* eslint-disable no-new, max-len */
const _ = require('lodash');
const assert = require('assert');
@@ -417,6 +417,67 @@ describe('Server', function() {
server.connect();
});
it('Connect -- with basic auth', function(done) {
const port = 5748;
function verifyClient(info, callback) {
assert.strictEqual(info.req.headers.authorization, 'Basic dXNlcm5hbWU6cGFzc3dvcmQ=');
callback(true);
}
const wss = new ws.Server({port, verifyClient});
function handleSubscribeRequest(_ws, message) {
const m = JSON.parse(message);
assert.deepEqual(m, {
command: 'subscribe',
id: 0,
streams: ['ledger', 'server']
});
_ws.send(JSON.stringify({
id: 0,
status: 'success',
type: 'response',
result: {
fee_base: 10,
fee_ref: 10,
ledger_hash:
'1838539EE12463C36F2C53B079D807C697E3D93A1936B717E565A4A912E11776',
ledger_index: 7053695,
ledger_time: 455414390,
load_base: 256,
load_factor: 256,
random:
'E56C9154D9BE94D49C581179356C2E084E16D18D74E8B09093F2D61207625E6A',
reserve_base: 20000000,
reserve_inc: 5000000,
server_status: 'full',
validated_ledgers: '32570-7053695'
}
}));
}
wss.once('connection', function(_ws) {
_ws.once('message', _.partial(handleSubscribeRequest, _ws));
});
const remote = new Remote({
basic_auth: 'username:password'
});
const server = new Server(remote, `ws://localhost:${port}`);
server.once('connect', function() {
server.once('disconnect', function() {
wss.close();
done();
});
server.disconnect();
});
server.connect();
});
it('Connect - already connected', function(done) {
const server = new Server(new Remote(), 'ws://localhost:5748');
server._connected = true;