Allow Aphlict to load Javelin and use Javelin class definitions
Summary: Ref T4324. The server code is probably going to get a fair amount more complicated, so allow it to load Javelin classes in a mostly-reasonable way. This integration has a few warts, but should be good enough to let us manage complexity through the next iteration of the server. (Mostly I just want the concicse Javelin mechanism for defining new classes.) Version bump is just so I can figure stuff out if this creates any issues for users based on which version of things they're running. Test Plan: Started server, posted some messages through it. Reviewers: btrahan Reviewed By: btrahan CC: aran Maniphest Tasks: T4324 Differential Revision: https://secure.phabricator.com/D8253
This commit is contained in:
@@ -2,7 +2,7 @@
|
|||||||
|
|
||||||
final class PhabricatorNotificationClient {
|
final class PhabricatorNotificationClient {
|
||||||
|
|
||||||
const EXPECT_VERSION = 2;
|
const EXPECT_VERSION = 3;
|
||||||
|
|
||||||
public static function getServerStatus() {
|
public static function getServerStatus() {
|
||||||
$uri = PhabricatorEnv::getEnvConfig('notification.server-uri');
|
$uri = PhabricatorEnv::getEnvConfig('notification.server-uri');
|
||||||
|
@@ -6,6 +6,11 @@
|
|||||||
* You can also specify `port`, `admin`, `host` and `log`.
|
* You can also specify `port`, `admin`, `host` and `log`.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
var JX = require('./lib/javelin').JX;
|
||||||
|
JX.require('lib/AphlictIDGenerator', __dirname);
|
||||||
|
|
||||||
|
var id_generator = new JX.AphlictIDGenerator();
|
||||||
|
|
||||||
var config = parse_command_line_arguments(process.argv);
|
var config = parse_command_line_arguments(process.argv);
|
||||||
|
|
||||||
function parse_command_line_arguments(argv) {
|
function parse_command_line_arguments(argv) {
|
||||||
@@ -108,25 +113,9 @@ function write_json(socket, data) {
|
|||||||
|
|
||||||
var clients = {};
|
var clients = {};
|
||||||
var current_connections = 0;
|
var current_connections = 0;
|
||||||
// According to the internet up to 2^53 can
|
|
||||||
// be stored in javascript, this is less than that
|
|
||||||
var MAX_ID = 9007199254740991;//2^53 -1
|
|
||||||
|
|
||||||
// If we get one connections per millisecond this will
|
|
||||||
// be fine as long as someone doesn't maintain a
|
|
||||||
// connection for longer than 6854793 years. If
|
|
||||||
// you want to write something pretty be my guest
|
|
||||||
|
|
||||||
function generate_id() {
|
|
||||||
if (typeof generate_id.current_id == 'undefined' ||
|
|
||||||
generate_id.current_id > MAX_ID) {
|
|
||||||
generate_id.current_id = 0;
|
|
||||||
}
|
|
||||||
return generate_id.current_id++;
|
|
||||||
}
|
|
||||||
|
|
||||||
var send_server = net.createServer(function(socket) {
|
var send_server = net.createServer(function(socket) {
|
||||||
var client_id = generate_id();
|
var client_id = id_generator.generateNext();
|
||||||
var client_name = '[' + socket.remoteAddress + '] [#' + client_id + '] ';
|
var client_name = '[' + socket.remoteAddress + '] [#' + client_id + '] ';
|
||||||
|
|
||||||
clients[client_id] = socket;
|
clients[client_id] = socket;
|
||||||
@@ -189,11 +178,11 @@ var receive_server = http.createServer(function(request, response) {
|
|||||||
var status = {
|
var status = {
|
||||||
'uptime': (new Date().getTime() - start_time),
|
'uptime': (new Date().getTime() - start_time),
|
||||||
'clients.active': current_connections,
|
'clients.active': current_connections,
|
||||||
'clients.total': generate_id.current_id || 0,
|
'clients.total': id_generator.getTotalCount(),
|
||||||
'messages.in': messages_in,
|
'messages.in': messages_in,
|
||||||
'messages.out': messages_out,
|
'messages.out': messages_out,
|
||||||
'log': config.log,
|
'log': config.log,
|
||||||
'version': 2
|
'version': 3
|
||||||
};
|
};
|
||||||
|
|
||||||
response.write(JSON.stringify(status));
|
response.write(JSON.stringify(status));
|
||||||
|
18
support/aphlict/server/lib/AphlictIDGenerator.js
Normal file
18
support/aphlict/server/lib/AphlictIDGenerator.js
Normal file
@@ -0,0 +1,18 @@
|
|||||||
|
var JX = require('javelin').JX;
|
||||||
|
|
||||||
|
JX.install('AphlictIDGenerator', {
|
||||||
|
|
||||||
|
members : {
|
||||||
|
_next : 0,
|
||||||
|
|
||||||
|
generateNext : function() {
|
||||||
|
this._next = ((this._next + 1) % 1000000000000);
|
||||||
|
return this._next;
|
||||||
|
},
|
||||||
|
|
||||||
|
getTotalCount : function() {
|
||||||
|
return this._next;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
});
|
13
support/aphlict/server/lib/javelin.js
Normal file
13
support/aphlict/server/lib/javelin.js
Normal file
@@ -0,0 +1,13 @@
|
|||||||
|
var javelin_root = '../../../../webroot/rsrc/externals/javelin/';
|
||||||
|
var JX = require(javelin_root + 'core/init_node.js').JX;
|
||||||
|
|
||||||
|
JX.require('core/util');
|
||||||
|
JX.require('core/install');
|
||||||
|
|
||||||
|
// NOTE: This is faking out a piece of code in JX.install which waits for
|
||||||
|
// Stratcom before running static initializers.
|
||||||
|
JX.Stratcom = {ready : true};
|
||||||
|
JX.require('core/Event');
|
||||||
|
JX.require('core/Stratcom');
|
||||||
|
|
||||||
|
exports.JX = JX;
|
45
webroot/rsrc/externals/javelin/core/init_node.js
vendored
Normal file
45
webroot/rsrc/externals/javelin/core/init_node.js
vendored
Normal file
@@ -0,0 +1,45 @@
|
|||||||
|
/**
|
||||||
|
* Alternative Javelin init file for Node.js.
|
||||||
|
*
|
||||||
|
* @javelin-installs JX.enableDispatch
|
||||||
|
* @javelin-installs JX.onload
|
||||||
|
* @javelin-installs JX.flushHoldingQueue
|
||||||
|
* @javelin-installs JX.require
|
||||||
|
*
|
||||||
|
* @javelin
|
||||||
|
*/
|
||||||
|
|
||||||
|
var JX = {};
|
||||||
|
var fs = require('fs');
|
||||||
|
var vm = require('vm');
|
||||||
|
var pathModule = require('path');
|
||||||
|
|
||||||
|
var noop = function() {};
|
||||||
|
|
||||||
|
JX.enableDispatch = noop;
|
||||||
|
JX.flushHoldingQueue = noop;
|
||||||
|
|
||||||
|
JX.onload = function(func) {
|
||||||
|
func();
|
||||||
|
};
|
||||||
|
|
||||||
|
JX.require = function(thing, relative) {
|
||||||
|
relative = relative || __dirname + '/..';
|
||||||
|
var path = relative + '/' + thing + '.js';
|
||||||
|
var content = fs.readFileSync(path);
|
||||||
|
|
||||||
|
var sandbox = {
|
||||||
|
JX : this,
|
||||||
|
__DEV__ : 0,
|
||||||
|
console : console,
|
||||||
|
window : {},
|
||||||
|
require : function (thing) {
|
||||||
|
return require(pathModule.dirname(path) + '/' + thing);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
vm.createScript(content, path)
|
||||||
|
.runInNewContext(sandbox, path);
|
||||||
|
};
|
||||||
|
|
||||||
|
exports.JX = JX;
|
Reference in New Issue
Block a user