Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Plugins #865

Open
wants to merge 137 commits into
base: next
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
137 commits
Select commit Hold shift + click to select a range
9f8b98d
Added package.json for plugin_router.
mlucy Aug 11, 2016
98e828a
Added index.js to plugin_router.
mlucy Aug 12, 2016
8b3bcac
Added package.json for permissions plugin.
mlucy Aug 12, 2016
e1e13c6
checkpoint
mlucy Aug 12, 2016
f123d52
checkpoint
mlucy Aug 13, 2016
8cfac85
Reworked reliable stuff.
mlucy Aug 15, 2016
1378c09
added ReliableMetadata sketch
Aug 16, 2016
bd146d1
Added reliable shit.
mlucy Aug 16, 2016
2143e8c
style fixes
mlucy Aug 16, 2016
9dc76cf
merged
mlucy Aug 16, 2016
a35437d
style fixes
mlucy Aug 16, 2016
365896f
checkpoint
mlucy Aug 16, 2016
58cc7f3
fixed syntax
Aug 16, 2016
b10f02c
working on middleware execution
Aug 16, 2016
2651ec1
it build!
mlucy Aug 17, 2016
25b91b6
checkpoint
mlucy Aug 17, 2016
c9136c7
checkpoint
mlucy Aug 17, 2016
9425197
fixing test bugs
Aug 17, 2016
7fdb2f2
fixed more test problems
Aug 17, 2016
757fc07
fixed eslint problems
Aug 17, 2016
ea26fec
wrote broken graph code
mlucy Aug 18, 2016
1432a9e
fixed eslint errors in plugin router
Aug 18, 2016
7df9136
checkpoint
Aug 18, 2016
5748188
checkpoint
Aug 19, 2016
5094ea8
checkpoint
mlucy Aug 20, 2016
e4b93bc
fixed square brackets style
mlucy Aug 23, 2016
54ba00a
checkpoint
mlucy Aug 24, 2016
359039a
theoretically working
mlucy Aug 25, 2016
13d6109
moved logic from server to permissions plugin
Aug 25, 2016
75f96a9
moving horizon.js to index.js
Aug 25, 2016
9ef28ae
checkpoint
Aug 25, 2016
4bf76e8
camelcase changes
Aug 25, 2016
0c9f57a
checkpoint
Aug 25, 2016
b8d4a08
checkpoint
Aug 25, 2016
8a50370
cleanup of obsolete code
Aug 25, 2016
b370128
fixed server
Aug 25, 2016
82d20df
Everything works
Aug 25, 2016
c62e3e0
everything works a little more
Aug 26, 2016
386a8e3
getting stuff running
Aug 30, 2016
75cc00a
plugins almost working
Aug 31, 2016
bc7bdee
checkpoint
Aug 31, 2016
128aa95
checkpoint
Aug 31, 2016
77f3db8
working on stuff
mlucy Aug 31, 2016
7f7b975
collection broken
mlucy Sep 1, 2016
c99fd73
added stuff
mlucy Sep 1, 2016
102fdc0
fixing bugs in testing
Sep 1, 2016
b281558
reworking plugin dependencies
Sep 2, 2016
06c79d0
restructuring plugins module
Sep 2, 2016
7ce2cea
more plugins module resturcturing
Sep 2, 2016
032554a
more plugin reorganization
Sep 2, 2016
027d064
fixing eslint errors in plugins
Sep 2, 2016
26613f4
working on getting the test server running again
Sep 2, 2016
f948716
fixing es6 compat
Sep 2, 2016
12846c2
broke plugins up into separate modules
Sep 2, 2016
9cb6e71
reorganizing some plugin stuff
Sep 2, 2016
9cf5acd
added module for default plugins
Sep 2, 2016
dead3b0
working on getting dev environment easy to set up
Sep 2, 2016
7eab310
fixed up setupDev.sh to provision plugins
Sep 2, 2016
a78b0db
fixing bugs
Sep 2, 2016
1615b7a
fixed incorrect error handling in collection creation
Sep 2, 2016
43c921a
about to fix namespaces
mlucy Sep 3, 2016
f5a8415
fixed namespacing
mlucy Sep 3, 2016
a1dfb87
fixing bugs
Sep 5, 2016
16575ca
about to start moving and writing tests
Sep 5, 2016
0a26b50
stuffs
mlucy Sep 5, 2016
4a33c83
Merge branch 'next' into grey_plugins
Sep 5, 2016
2da2dc1
Merge branch 'plugins' into grey_plugins
Sep 5, 2016
7845099
migrated permissions template tests
Sep 5, 2016
ec572f1
adding source-map-support devDependency to plugins
Sep 5, 2016
3f42c9d
migrating server tests to integration tests
Sep 5, 2016
d6b196a
fix a few test bugs
Sep 7, 2016
9b1e023
added 5 sec wait for metadata to sync
Sep 7, 2016
b14fa0d
got protocol tests passing
Sep 8, 2016
03673ca
fixed collections and permissions readiness
Sep 8, 2016
890070f
fixed test create_collection
Sep 8, 2016
b4f7882
fixed some tests
Sep 8, 2016
750b95e
reworking plugin-router, added stubs for differend backend implementa…
Sep 8, 2016
02cfdb9
no longer pass server to plugins, but a curated plugin context
Sep 9, 2016
6fda005
got previously working tests working again
Sep 9, 2016
8079784
fixing problems in integration tests
Sep 9, 2016
9361715
fixed cleanup, removed old console log statements
Sep 9, 2016
06d1427
fixed some tests
Sep 9, 2016
0392e90
almost have all server tests running
Sep 10, 2016
f61425c
changed how user info is passed to validators
Sep 11, 2016
bddb240
fixed all server tests
Sep 11, 2016
dc9ef13
got test server running
Sep 11, 2016
328d124
checkpoint
Sep 13, 2016
da538ed
camelCasing and fixing tests
Sep 13, 2016
203b420
checkpoint
Sep 16, 2016
492ef1f
fixing build
Tryneus Oct 2, 2016
480da06
working on client for new protocol
Tryneus Oct 2, 2016
db8143d
checkpoint
Tryneus Oct 7, 2016
127e379
(maybe) working script for symlinking across modules in this repo
Tryneus Oct 7, 2016
7864924
fixing module symlinks and deps
Tryneus Oct 7, 2016
3ecc060
tests are running
Tryneus Oct 8, 2016
dfdae9f
server tests running
Tryneus Oct 8, 2016
7f215bd
:checkpoint
Tryneus Oct 12, 2016
0de9487
checkpoint
Tryneus Oct 13, 2016
fe2c89a
checkpoint
Tryneus Oct 15, 2016
8e8b363
lots of refactoring and style fixes
Tryneus Oct 18, 2016
85e7643
tests passing again
Tryneus Oct 20, 2016
a3c6e4d
camelcasing
Tryneus Oct 20, 2016
2430c8a
fixed some problems in client tests
Tryneus Oct 23, 2016
1c2340c
working on client socket handling
Tryneus Oct 26, 2016
b565a41
checkpoint
Tryneus Oct 27, 2016
b5d4da7
checkpoint
Tryneus Oct 27, 2016
68e7a07
fixed client reconnection logic
Tryneus Oct 27, 2016
3913388
some client tests working
Tryneus Oct 27, 2016
a8b4054
fixing tests, sort of
Tryneus Oct 28, 2016
72b1839
compatibility changes and test fixes
Tryneus Oct 29, 2016
01f0a29
checkpoint
Tryneus Dec 12, 2016
8307bcb
add server auth unit tests
Tryneus Dec 18, 2016
c303677
moving client to client_connection
Tryneus Dec 19, 2016
05d1499
add tests, fix lint errors
Tryneus Dec 19, 2016
dca7a64
add response tests
Tryneus Dec 19, 2016
e995e4b
fix flipped logic in findAll
Tryneus Dec 20, 2016
63ec280
fix find query
Tryneus Dec 20, 2016
5ffde58
fix some client tests and compatibility
Tryneus Dec 21, 2016
a63596e
fixing bugs
Tryneus Dec 23, 2016
ae85fcf
fixing tests
Tryneus Dec 23, 2016
ca16d29
fixing tests and style
Tryneus Dec 24, 2016
baeac8f
fixing tests
Tryneus Dec 24, 2016
1ddd5cf
fixing tests
Tryneus Dec 24, 2016
c3a015b
fix some tests, currentUser
Tryneus Dec 25, 2016
bdc2be5
fix some tests
Tryneus Dec 25, 2016
83d6008
fix between problems
Tryneus Dec 25, 2016
a0cce9c
all client tests passing
Tryneus Dec 25, 2016
14aa2c9
removing old dependency
Tryneus Dec 26, 2016
d5e82b4
style and cleanup
Tryneus Dec 27, 2016
a8c1564
fix some problems in examples
Tryneus Dec 28, 2016
74bc243
some router fixes
Tryneus Dec 28, 2016
aa4b826
fix some problems in the framework integrations
Tryneus Dec 29, 2016
336b5ea
change versions
Tryneus Jan 28, 2017
6e3ce54
trying to fix setupDev.sh
Tryneus Jan 29, 2017
a39c252
temporarily sequester some test code
Tryneus Jan 29, 2017
4eb7ff0
trying to fix dev setup
Tryneus Jan 29, 2017
d7e8223
more missing links
Tryneus Jan 30, 2017
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
fixing bugs in testing
  • Loading branch information
Marc Hesse committed Sep 1, 2016
commit 102fdc0351d0da69d4e26086f986243c3cfc4b0a
2 changes: 1 addition & 1 deletion babelify.sh
100644 → 100755
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
#!/bin/bash
#!/usr/bin/env bash

dirs="server server-utils plugins plugin_router"
for path in `find $dirs -name .babelrc | grep -v node_modules`; do
Expand Down
14 changes: 7 additions & 7 deletions plugin_router/src/index.js
Original file line number Diff line number Diff line change
Expand Up @@ -17,6 +17,7 @@ class PluginRouter extends EventEmitter {

noteReady(plugin) {
if (!this.readyPlugins.has(plugin)) {
console.log(`noteReady(${plugin}): ${this.readyPlugins.size}/${this.plugins.size}`);
this.readyPlugins.add(plugin);
this.emit('pluginReady', plugin, this);
if (this.readyPlugins.size === this.plugins.size) {
Expand All @@ -27,6 +28,7 @@ class PluginRouter extends EventEmitter {

noteUnready(plugin) {
if (this.readyPlugins.has(plugin)) {
console.log(`noteUnready(${plugin}): ${this.readyPlugins.size}/${this.plugins.size}`);
this.readyPlugins.delete(plugin);
this.emit('pluginUnready', plugin, this);
if (this.readyPlugins.size === this.plugins.size - 1) {
Expand All @@ -40,9 +42,12 @@ class PluginRouter extends EventEmitter {
return Promise.reject(
new Error(`Plugin conflict: "${plugin.name}" already present.`));
}
const activePlugin = Promise.resolve(this.server).then((server) => {
// Placeholder so we don't say we're ready too soon
this.plugins.set(plugin.name, null);
this.plugins.set(plugin.name, Promise.resolve(this.server).then((server) => {
this.emit('unready', this);
if (plugin.activate.length > 1) {
console.log(`activating ${plugin.name} with ready callbacks`);
return plugin.activate(
server,
() => this.noteReady(plugin.name),
Expand All @@ -53,8 +58,7 @@ class PluginRouter extends EventEmitter {
return x;
});
}
});
this.plugins.set(plugin.name, activePlugin.then((active) => {
}).then((active) => {
if (this.httpRoutes[plugin.name]) {
throw new Error(`Plugin conflict: "${plugin.name}" already present.`);
}
Expand All @@ -71,10 +75,6 @@ class PluginRouter extends EventEmitter {
this.methods[m] = active.methods[m];
this._requirementsOrdering = null;
}
}).catch((err) => {
this.server.logger.error(`Error when adding plugin ${plugin.name}: ${err}`);
this.server.logger.debug(`${err.stack}`);
throw err;
}));
return this.plugins.get(plugin.name);
}
Expand Down
5 changes: 4 additions & 1 deletion plugin_router/src/request.js
Original file line number Diff line number Diff line change
@@ -1,12 +1,15 @@
'use strict';

const assert = require('assert');

class Request {
constructor(request, currentMethod) {
this.request_id = request.request_id;
this.options = request.options;
this.clientCtx = request.clientCtx;
this._parameters = request.parameters;
this._parameters = request._parameters;
this._currentMethod = currentMethod;
Object.freeze(this);
}

getParameter(methodName) {
Expand Down
2 changes: 1 addition & 1 deletion plugins/collection/src/collection.js
Original file line number Diff line number Diff line change
Expand Up @@ -66,7 +66,7 @@ class Collection {

_get_table() {
if (this._tables.size === 0) {
throw new error.CollectionNotReady(this);
throw new Error(`Collection ${this.name} is not ready.`);
}
return this._tables.values().next().value;
}
Expand Down
8 changes: 6 additions & 2 deletions plugins/collection/src/main.js
Original file line number Diff line number Diff line change
Expand Up @@ -11,6 +11,7 @@ function collection(server, metadata) {
next(new Error('First argument to "collection" must be a string.'));
} else {
metadata.collection(args[0]).then((collection) => {
// RSI: pick up here trucks here reads aren't getting this?
req.setParameter(collection);
next();
}).catch(next);
Expand All @@ -20,15 +21,18 @@ function collection(server, metadata) {

export default function(raw_config) {
return {
name: (raw_config && raw_config.name) || 'permissions',
name: (raw_config && raw_config.name) || 'collection',
// RSI: make sure we check the arity and become ready if people
// don't take the callbacks.
activate: (server, onReady, onUnready) => {
const metadata = new ReliableMetadata(
server,
raw_config.auto_create_collection,
raw_config.auto_create_index);
metadata.subscribe({onReady, onUnready});
metadata.subscribe({onReady: () => {
console.log('metadata ready');
onReady();
}, onUnready});
return {
methods: {
collection: {
Expand Down
52 changes: 24 additions & 28 deletions plugins/collection/src/metadata.js
Original file line number Diff line number Diff line change
Expand Up @@ -44,14 +44,15 @@ class StaleAttemptError extends Error { }

// RSI: fix all this shit.
class ReliableInit extends Reliable {
constructor(db, reliable_conn, auto_create_collection) {
constructor(r, logger, db, reliable_conn, auto_create_collection) {
super();
this.logger = logger;
this._db = db;
this._auto_create_collection = auto_create_collection;
this._conn_subs = reliable_conn.subscribe({
onReady: (conn) => {
this.current_attempt = Symbol();
this.do_init(conn, this.current_attempt);
this.do_init(r, conn, this.current_attempt);
},
onUnready: () => {
this.current_attempt = null;
Expand All @@ -68,15 +69,15 @@ class ReliableInit extends Reliable {
}
}

do_init(conn, attempt) {
do_init(r, conn, attempt) {
Promise.resolve().then(() => {
this.check_attempt(attempt);
logger.debug('checking rethinkdb version');
this.logger.debug('checking rethinkdb version');
const q = r.db('rethinkdb').table('server_status').nth(0)('process')('version');
return q.run(conn).then((res) => utils.rethinkdb_version_check(res));
}).then(() => {
this.check_attempt(attempt);
logger.debug('checking for old metadata version');
this.logger.debug('checking for old metadata version');
const old_metadata_db = `${this._db}_internal`;
return r.dbList().contains(old_metadata_db).run(conn).then((has_old_db) => {
if (has_old_db) {
Expand All @@ -87,9 +88,9 @@ class ReliableInit extends Reliable {
});
}).then(() => {
this.check_attempt(attempt);
logger.debug('checking for internal tables');
this.logger.debug('checking for internal tables');
if (this._auto_create_collection) {
return initialize_metadata(this.r, this._db, conn);
return initialize_metadata(r, this._db, conn);
} else {
return r.dbList().contains(this._db).run(conn).then((has_db) => {
if (!has_db) {
Expand All @@ -101,12 +102,12 @@ class ReliableInit extends Reliable {
}
}).then(() => {
this.check_attempt(attempt);
logger.debug('waiting for internal tables');
this.logger.debug('waiting for internal tables');
return r.expr(['hz_collections', 'hz_users_auth', 'hz_groups', 'users'])
.forEach((table) => r.db(this._db).table(table).wait({timeout: 30})).run(conn);
}).then(() => {
this.check_attempt(attempt);
logger.debug('adding admin user');
this.logger.debug('adding admin user');
return Promise.all([
r.db(this._db).table('users').get('admin')
.replace((old_row) =>
Expand Down Expand Up @@ -139,12 +140,12 @@ class ReliableInit extends Reliable {
]);
}).then(() => {
this.check_attempt(attempt);
logger.debug('metadata sync complete');
this.logger.debug('metadata sync complete');
this.emit('onReady');
}).catch((err) => {
if (!(err instanceof StaleAttemptError)) {
logger.debug(`Metadata initialization failed: ${err}`);
setTimeout(() => { this.do_init(conn, attempt); }, 1000);
this.logger.debug(`Metadata initialization failed: ${err.stack}`);
setTimeout(() => { this.do_init(r, conn, attempt); }, 1000);
}
});
}
Expand All @@ -171,7 +172,7 @@ export class ReliableMetadata extends Reliable {
this._collections = new Map();

this._reliable_init = new ReliableInit(
this._db, reliable_conn, auto_create_collection);
this.r, this.logger, this._db, this._reliable_conn, auto_create_collection);

this._conn_subscription = this._reliable_conn.subscribe({
onReady: (conn) => {
Expand All @@ -183,7 +184,7 @@ export class ReliableMetadata extends Reliable {
});

this._collection_changefeed = server.makeReliableChangefeed(
r.db(this._db)
this.r.db(this._db)
.table('hz_collections')
.filter((row) => row('id').match('^hzp?_').not())
.changes({squash: false, includeInitial: true, includeTypes: true}),
Expand All @@ -198,7 +199,7 @@ export class ReliableMetadata extends Reliable {
let collection = this._collections.get(collection_name);
if (!collection) {
collection = new Collection(
this._db, collection_name, this.logger, this.r);
this._db, collection_name, this._reliable_conn, this.logger, this.r);
this._collections.set(collection_name, collection);
}
collection._register();
Expand All @@ -225,19 +226,17 @@ export class ReliableMetadata extends Reliable {
},
});


this._index_changefeed = new ReliableChangefeed(
r.db('rethinkdb')
this._index_changefeed = server.makeReliableChangefeed(
this.r.db('rethinkdb')
.table('table_config')
.filter((row) => r.and(row('db').eq(this._db),
row('name').match('^hzp?_').not()))
.filter((row) => this.r.and(row('db').eq(this._db),
row('name').match('^hzp?_').not()))
.map((row) => ({
id: row('id'),
name: row('name'),
indexes: row('indexes').filter((idx) => idx.match('^hz_')),
}))
.changes({squash: true, includeInitial: true, includeTypes: true}),
reliable_conn,
{
onChange: (change) => {
if (!this._connection) { return; }
Expand All @@ -252,7 +251,7 @@ export class ReliableMetadata extends Reliable {
let collection = this._collections.get(collection_name);
if (!collection) {
collection = new Collection(
this._db, collection_name, this.logger, this.r);
this._db, collection_name, this._reliable_conn, this.logger, this.r);
this._collections.set(collection_name, collection);
}
collection._update_table(
Expand Down Expand Up @@ -338,6 +337,7 @@ export class ReliableMetadata extends Reliable {
}

create_collection(name) {
let collection;
return Promise.resolve().then(() => {
if (name.indexOf('hz_') === 0 || name.indexOf('hzp_') === 0) {
throw new Error(`Collection "${name}" is reserved for internal use ` +
Expand All @@ -348,7 +348,7 @@ export class ReliableMetadata extends Reliable {
throw new Error(`Collection "${name}" already exists.`);
}

const collection = new Collection(this._db, name, this.logger, this.r);
collection = new Collection(this._db, name, this._reliable_conn, this.logger, this.r);
this._collections.set(name, collection);

return create_collection(this.r, this._db, name, this._reliable_conn.connection());
Expand All @@ -364,15 +364,11 @@ export class ReliableMetadata extends Reliable {
}
}));
}).catch((err) => {
if (collection._is_safe_to_remove()) {
if (collection && collection._is_safe_to_remove()) {
this._collections.delete(name);
collection.close();
}
throw err;
});
}

reliable_connection() {
return this._reliable_conn;
}
}
2 changes: 1 addition & 1 deletion plugins/permit_all/src/index.js
Original file line number Diff line number Diff line change
Expand Up @@ -8,7 +8,7 @@ module.exports = (raw_config) => ({
hz_permissions: {
type: 'preReq',
handler: (req, res, next) => {
req.validate = () => null;
req.setParameter(() => null);
next();
},
},
Expand Down
2 changes: 1 addition & 1 deletion plugins/reads/src/fetch.js
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,7 @@ const common = require('./common');

module.exports = (server) => (req, res, next) => {
const args = req.options.fetch;
const permissions = req.getParameter('permissions');
const permissions = req.getParameter('hz_permissions');
const conn = server.rdb_connection().connection();

if (args.length !== 0) {
Expand Down
2 changes: 1 addition & 1 deletion plugins/reads/src/watch.js
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,7 @@ const common = require('./common');

module.exports = (server) => (req, res, next) => {
const args = req.options.watch;
const permissions = req.getParameter('permissions');
const permissions = req.getParameter('hz_permissions');
const conn = server.rdb_connection().connection();

if (args.length !== 0) {
Expand Down
2 changes: 1 addition & 1 deletion plugins/writes/src/insert.js
Original file line number Diff line number Diff line change
Expand Up @@ -7,7 +7,7 @@ module.exports = (server) => (request, response, next) => {
const conn = server.rdb_connection().connection();
const timeout = request.getParameter('timeout');
const collection = request.getParameter('collection');
const permissions = request.getParameter('permissions');
const permissions = request.getParameter('hz_permissions');

if (!collection) {
throw new Error('No collection given for insert operation.');
Expand Down
2 changes: 1 addition & 1 deletion plugins/writes/src/remove.js
Original file line number Diff line number Diff line change
Expand Up @@ -8,7 +8,7 @@ module.exports = (server) => (request, response, next) => {
const conn = server.rdb_connection().connection();
const timeout = request.getParameter('timeout');
const collection = request.getParameter('collection');
const permissions = request.getParameter('permissions');
const permissions = request.getParameter('hz_permissions');

if (!collection) {
throw new Error('No collection given for insert operation.');
Expand Down
2 changes: 1 addition & 1 deletion plugins/writes/src/replace.js
Original file line number Diff line number Diff line change
Expand Up @@ -8,7 +8,7 @@ module.exports = (server) => (request, response, next) => {
const conn = server.rdb_connection().connection();
const timeout = request.getParameter('timeout');
const collection = request.getParameter('collection');
const permissions = request.getParameter('permissions');
const permissions = request.getParameter('hz_permissions');

if (!collection) {
throw new Error('No collection given for insert operation.');
Expand Down
2 changes: 1 addition & 1 deletion plugins/writes/src/store.js
Original file line number Diff line number Diff line change
Expand Up @@ -8,7 +8,7 @@ module.exports = (server) => (request, response, next) => {
const conn = server.rdb_connection().connection();
const timeout = request.getParameter('timeout');
const collection = request.getParameter('collection');
const permissions = request.getParameter('permissions');
const permissions = request.getParameter('hz_permissions');

if (!collection) {
throw new Error('No collection given for insert operation.');
Expand Down
2 changes: 1 addition & 1 deletion plugins/writes/src/update.js
Original file line number Diff line number Diff line change
Expand Up @@ -8,7 +8,7 @@ module.exports = (server) => (request, response, next) => {
const conn = server.rdb_connection().connection();
const timeout = request.getParameter('timeout');
const collection = request.getParameter('collection');
const permissions = request.getParameter('permissions');
const permissions = request.getParameter('hz_permissions');

if (!collection) {
throw new Error('No collection given for insert operation.');
Expand Down
2 changes: 1 addition & 1 deletion plugins/writes/src/upsert.js
Original file line number Diff line number Diff line change
Expand Up @@ -8,7 +8,7 @@ module.exports = (server) => (request, response, next) => {
const conn = server.rdb_connection().connection();
const timeout = request.getParameter('timeout');
const collection = request.getParameter('collection');
const permissions = request.getParameter('permissions');
const permissions = request.getParameter('hz_permissions');

if (!collection) {
throw new Error('No collection given for insert operation.');
Expand Down
10 changes: 6 additions & 4 deletions server-utils/src/reliable.js
Original file line number Diff line number Diff line change
Expand Up @@ -31,8 +31,9 @@ export class Reliable {
try {
cbs.onReady.apply(cbs, this.ready);
} catch (e) {
logger.error('Unexpected error in reliable callback, ' +
`event: subscribe onReady, error: ${e.stack}`);
// RSI: use logging facilities
console.error('Unexpected error in reliable callback, ' +
`event: subscribe onReady, error: ${e.stack}`);
}
}
return this[subs].get(subId);
Expand Down Expand Up @@ -60,8 +61,9 @@ export class Reliable {
event.apply(sub.cbs, args);
}
} catch (e) {
logger.error('Unexpected error in reliable callback, ' +
`event: ${eventType}, error: ${e.stack}`);
// RSI: use logging facilities
console.error('Unexpected error in reliable callback, ' +
`event: ${eventType}, error: ${e.stack}`);
}
});
}
Expand Down
2 changes: 1 addition & 1 deletion server/src/client.js
Original file line number Diff line number Diff line change
Expand Up @@ -80,7 +80,7 @@ class ClientConnection {

if (request.request_id === undefined) {
// This is pretty much an unrecoverable protocol error, so close the connection
this.close({reqId, error: `Protocol error: ${err}`, error_code: 0});
this.close({reqId, error: `Protocol error: ${err_str}`, error_code: 0});
} else {
this.send_error(reqId, new Error(err_str));
}
Expand Down
Loading