Initial sioconfig migration work

This commit is contained in:
calzoneman 2015-10-19 22:32:00 -07:00
parent dacda65961
commit 40e2a608f6
8 changed files with 111 additions and 18 deletions

22
NEWS.md
View file

@ -1,3 +1,25 @@
2015-10-19
==========
In order to support future clustering support, the legacy `/sioconfig`
endpoint is being deprecated. Instead, you should make a request to
`/socketconfig/<channel name>.json`. The response will look similar to
these:
```json
{"url":"https://some-website.com:8443","secure":true}
{"error":"Channel \"!@#$\" does not exist."}
```
The `url` key specifies the socket.io URL to connect to, and the `secure`
key indicates whether the connection is secured with TLS. If an `error` key
is present, something went wrong and the value will contain an error
message.
For now, only one URL is returned, however in the future this may be
extended by adding an `alt` key specifying an array of acceptable URLs to
connect to.
2015-10-04
==========

View file

@ -2,7 +2,7 @@
"author": "Calvin Montgomery",
"name": "CyTube",
"description": "Online media synchronizer and chat",
"version": "3.11.2",
"version": "3.12.0",
"repository": {
"url": "http://github.com/calzoneman/sync"
},

View file

@ -0,0 +1,23 @@
export default class IOConfiguration {
constructor(config) {
this.config = config;
}
getSocketURL() {
return this.config.urls[0];
}
}
IOConfiguration.fromOldConfig = function (oldConfig) {
const config = {
urls: []
};
['ipv4-ssl', 'ipv4-nossl', 'ipv6-ssl', 'ipv6-nossl'].forEach(key => {
if (oldConfig.get('io.' + key)) {
config.urls.push(oldConfig.get('io.' + key));
}
});
return new IOConfiguration(config);
};

View file

@ -0,0 +1,11 @@
import Promise from 'bluebird';
export default class NullClusterClient {
constructor(ioConfig) {
this.ioConfig = ioConfig;
}
getSocketURL(channel) {
return Promise.resolve(this.ioConfig.getSocketURL());
}
}

View file

@ -0,0 +1,24 @@
import IOConfiguration from '../../configuration/ioconfig';
import NullClusterClient from '../../io/cluster/nullclusterclient';
import Config from '../../config';
import CyTubeUtil from '../../utilities';
export default function initialize(app) {
const ioConfig = IOConfiguration.fromOldConfig(Config);
const clusterClient = new NullClusterClient(ioConfig);
app.get('/socketconfig/:channel.json', (req, res) => {
if (!req.params.channel || !CyTubeUtil.isValidChannelName(req.params.channel)) {
return res.status(400).json({
error: `Channel "${req.params.channel}" does not exist.`
});
}
clusterClient.getSocketURL(req.params.channel).then(url => {
res.json({
url,
secure: /^(https|wss)/.test(url)
});
});
});
}

View file

@ -117,7 +117,8 @@ function handleIndex(req, res) {
}
/**
* Handles a request for the socket.io information
* Legacy socket.io configuration endpoint. This is being migrated to
* /socketconfig/<channel name>.json (see ./routes/socketconfig.js)
*/
function handleSocketConfig(req, res) {
if (/\.json$/.test(req.path)) {
@ -243,6 +244,7 @@ module.exports = {
app.get("/r/:channel", handleChannel);
app.get("/", handleIndex);
app.get("/sioconfig(.json)?", handleSocketConfig);
require("./routes/socketconfig")(app);
app.get("/useragreement", handleUserAgreement);
app.get("/contact", handleContactPage);
require("./auth").init(app);

View file

@ -239,7 +239,6 @@ html(lang="en")
mixin footer()
script(src=sioSource)
script(src="/js/data.js")
script(src="/sioconfig")
script(src="/js/util.js")
script(src="/js/player.js")
script(src="/js/paginator.js")

View file

@ -1096,27 +1096,39 @@ setupCallbacks = function() {
});
})(key);
}
}
};
try {
(function () {
if (typeof io === "undefined") {
makeAlert("Uh oh!", "It appears the connection to <code>" + IO_URL + "</code> " +
"has failed. If this error persists, a firewall or " +
"antivirus is likely blocking the connection, or the " +
"server is down.", "alert-danger")
.appendTo($("#announcements"));
throw false;
Callbacks.disconnect();
return;
}
var opts = { transports: ["websocket", "polling"] };
if (IO_URL === IO_URLS["ipv4-ssl"] || IO_URL === IO_URLS["ipv6-ssl"]) {
opts.secure = true;
socket = io(IO_URL, { secure: true });
}
socket = io(IO_URL, opts);
setupCallbacks();
} catch (e) {
if (e) {
Callbacks.disconnect();
}
}
$.getJSON("/socketconfig/" + CHANNEL.name + ".json")
.done(function (socketConfig) {
console.log(socketConfig);
if (socketConfig.error) {
makeAlert("Socket.io configuration returned error: " +
socketConfig.error, "alert-danger")
.appendTo($("#announcements"));
return;
}
var opts = {
transports: ["websocket", "polling"],
secure: socketConfig.secure
};
socket = io(socketConfig.url, opts);
setupCallbacks();
}).fail(function () {
makeAlert("Failed to retrieve socket.io configuration", "alert-danger")
.appendTo($("#announcements"));
Callbacks.disconnect();
});
})();