mirror of
https://we.phorge.it/source/phorge.git
synced 2025-01-07 05:11:05 +01:00
Break Aphlict's flash policy server into a separate class
Summary: Ref T4324. One of the server we start just sends pre-canned XML responses. Separate it out of the main file and hand it all the objects it interacts with in structured, reasonable ways. Test Plan: Hit "Send Test Notification", saw notification, saw flash policy info in the log. Reviewers: btrahan Reviewed By: btrahan CC: aran Maniphest Tasks: T4324 Differential Revision: https://secure.phabricator.com/D8257
This commit is contained in:
parent
28fe44da0a
commit
f302bfc8f8
2 changed files with 74 additions and 23 deletions
|
@ -8,6 +8,7 @@
|
||||||
|
|
||||||
var JX = require('./lib/javelin').JX;
|
var JX = require('./lib/javelin').JX;
|
||||||
|
|
||||||
|
JX.require('lib/AphlictFlashPolicyServer', __dirname);
|
||||||
JX.require('lib/AphlictListenerList', __dirname);
|
JX.require('lib/AphlictListenerList', __dirname);
|
||||||
JX.require('lib/AphlictLog', __dirname);
|
JX.require('lib/AphlictLog', __dirname);
|
||||||
|
|
||||||
|
@ -64,33 +65,15 @@ var http = require('http');
|
||||||
var url = require('url');
|
var url = require('url');
|
||||||
var querystring = require('querystring');
|
var querystring = require('querystring');
|
||||||
|
|
||||||
|
|
||||||
process.on('uncaughtException', function (err) {
|
process.on('uncaughtException', function (err) {
|
||||||
log("\n<<< UNCAUGHT EXCEPTION! >>>\n\n" + err);
|
debug.log("\n<<< UNCAUGHT EXCEPTION! >>>\n\n" + err);
|
||||||
process.exit(1);
|
process.exit(1);
|
||||||
});
|
});
|
||||||
|
|
||||||
function getFlashPolicy() {
|
var flash_server = new JX.AphlictFlashPolicyServer()
|
||||||
return [
|
.setDebugLog(debug)
|
||||||
'<?xml version="1.0"?>',
|
.setAccessPort(config.port)
|
||||||
'<!DOCTYPE cross-domain-policy SYSTEM ' +
|
.start();
|
||||||
'"http://www.macromedia.com/xml/dtds/cross-domain-policy.dtd">',
|
|
||||||
'<cross-domain-policy>',
|
|
||||||
'<allow-access-from domain="*" to-ports="'+config.port+'"/>',
|
|
||||||
'</cross-domain-policy>'
|
|
||||||
].join('\n');
|
|
||||||
}
|
|
||||||
|
|
||||||
net.createServer(function(socket) {
|
|
||||||
socket.write(getFlashPolicy() + '\0');
|
|
||||||
socket.end();
|
|
||||||
|
|
||||||
debug.log('[' + socket.remoteAddress + '] Sent Flash Policy');
|
|
||||||
|
|
||||||
socket.on('error', function (e) {
|
|
||||||
debug.log('Error in policy server: ' + e);
|
|
||||||
});
|
|
||||||
}).listen(843);
|
|
||||||
|
|
||||||
|
|
||||||
var send_server = net.createServer(function(socket) {
|
var send_server = net.createServer(function(socket) {
|
||||||
|
|
68
support/aphlict/server/lib/AphlictFlashPolicyServer.js
Normal file
68
support/aphlict/server/lib/AphlictFlashPolicyServer.js
Normal file
|
@ -0,0 +1,68 @@
|
||||||
|
var JX = require('javelin').JX;
|
||||||
|
|
||||||
|
var net = require('net');
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Server which handles cross-domain policy requests for Flash.
|
||||||
|
*
|
||||||
|
* var server = new AphlictFlashPolicyServer()
|
||||||
|
* .setAccessPort(9999)
|
||||||
|
* .start();
|
||||||
|
*/
|
||||||
|
JX.install('AphlictFlashPolicyServer', {
|
||||||
|
|
||||||
|
members: {
|
||||||
|
_server: null,
|
||||||
|
_port: 843,
|
||||||
|
_accessPort: null,
|
||||||
|
_debug: null,
|
||||||
|
|
||||||
|
setDebugLog : function(log) {
|
||||||
|
this._debug = log;
|
||||||
|
return this;
|
||||||
|
},
|
||||||
|
|
||||||
|
setAccessPort : function(port) {
|
||||||
|
this._accessPort = port;
|
||||||
|
return this;
|
||||||
|
},
|
||||||
|
|
||||||
|
start: function() {
|
||||||
|
this._server = net.createServer(JX.bind(this, this._didConnect));
|
||||||
|
this._server.listen(this._port);
|
||||||
|
return this;
|
||||||
|
},
|
||||||
|
|
||||||
|
_didConnect: function(socket) {
|
||||||
|
this._log('<FlashPolicy> Policy Request From %s', socket.remoteAddress);
|
||||||
|
|
||||||
|
socket.on('error', JX.bind(this, this._didSocketError, socket));
|
||||||
|
|
||||||
|
socket.write(this._getFlashPolicyResponse());
|
||||||
|
socket.end();
|
||||||
|
},
|
||||||
|
|
||||||
|
_didSocketError: function(socket, error) {
|
||||||
|
this._log('<FlashPolicy> Socket Error: %s', error);
|
||||||
|
},
|
||||||
|
|
||||||
|
_log: function(pattern) {
|
||||||
|
this._debug && this._debug.log.apply(this._debug, arguments);
|
||||||
|
},
|
||||||
|
|
||||||
|
_getFlashPolicyResponse: function() {
|
||||||
|
var policy = [
|
||||||
|
'<?xml version="1.0"?>',
|
||||||
|
'<!DOCTYPE cross-domain-policy SYSTEM ' +
|
||||||
|
'"http://www.macromedia.com/xml/dtds/cross-domain-policy.dtd">',
|
||||||
|
'<cross-domain-policy>',
|
||||||
|
'<allow-access-from domain="*" to-ports="' + this._accessPort + '"/>',
|
||||||
|
'</cross-domain-policy>'
|
||||||
|
];
|
||||||
|
|
||||||
|
return policy.join("\n") + "\0";
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
});
|
Loading…
Reference in a new issue