- added example docker-compose for minisrv + webone - update: wtv-home:/home: reduce size of title to fit longer version numbers - update: wtv-chat:/home: fix colors - update: login system: do not send tellyscript nor login headers to reconnecting (eg client:redial) client - fix: fixed tellyscript path for wtv-1800:/noflash (bf0app braindead) - update flashrom subsystem: - moved duplicate code into WTVFlashrom class - smarter part information detection - http(s) proxy updates: - allow ~ character - fix HTTPS when using HTTP proxy - include example webone.conf for external HTTP Proxy - update: app.js: enable graceful shutdown with SIGTERM - update: add service ip to wtv-tricks:/info
78 lines
2.3 KiB
JavaScript
78 lines
2.3 KiB
JavaScript
var challenge_response, challenge_header = '';
|
|
|
|
var gourl = "wtv-head-waiter:/login-stage-two?";
|
|
if (request_headers.query.relogin) gourl += "relogin=true";
|
|
if (request_headers.query.reconnect) gourl += "reconnect=true";
|
|
|
|
if (socket.ssid !== null) {
|
|
var wtvsec_login = ssid_sessions[socket.ssid].get("wtvsec_login");
|
|
if (request_headers["wtv-ticket"]) {
|
|
if (wtvsec_login.ticket_b64 == null) {
|
|
if (request_headers["wtv-ticket"].length > 8) {
|
|
wtvsec_login.DecodeTicket(request_headers["wtv-ticket"]);
|
|
wtvsec_login.ticket_b64 = request_headers["wtv-ticket"];
|
|
}
|
|
}
|
|
} else {
|
|
if (wtvsec_login) {
|
|
challenge_response = wtvsec_login.challenge_response;
|
|
var client_challenge_response = request_headers["wtv-challenge-response"] || null;
|
|
if (challenge_response && client_challenge_response) {
|
|
if (challenge_response.toString(CryptoJS.enc.Base64).substring(0, 85) == client_challenge_response.substring(0, 85)) {
|
|
console.log(" * wtv-challenge-response success for " + socket.ssid);
|
|
wtvsec_login.PrepareTicket();
|
|
} else {
|
|
challenge_header = "wtv-challenge: " + wtvsec_login.IssueChallenge();
|
|
}
|
|
} else {
|
|
challenge_header = "wtv-challenge: " + wtvsec_login.IssueChallenge();
|
|
}
|
|
} else {
|
|
wtvsec_login = new WTVSec();
|
|
|
|
}
|
|
}
|
|
}
|
|
|
|
/*
|
|
if (request_headers) {
|
|
var cookiedata = {};
|
|
Object.keys(request_headers).forEach(function (k) {
|
|
switch (k) {
|
|
case "wtv-capability-flags":
|
|
case "wtv-system-version":
|
|
case "wtv-client-rom-type":
|
|
case "wtv-client-bootrom-version":
|
|
case "wtv-system-chipversion":
|
|
case "wtv-system-sysconfig":
|
|
case "wtv-system-cpuspeed":
|
|
cookiedata[k] = request_headers[k];
|
|
break;
|
|
}
|
|
});
|
|
}
|
|
*/
|
|
|
|
if (challenge_header != '') {
|
|
headers = `200 OK
|
|
Connection: Keep-Alive
|
|
Expires: Wed, 09 Oct 1991 22:00:00 GMT
|
|
wtv-expire-all: wtv-head-waiter:
|
|
`+ getServiceString('wtv-log') + `
|
|
wtv-log-url: wtv-log:/log
|
|
${challenge_header}
|
|
wtv-relogin-url: wtv-1800:/preregister?relogin=true
|
|
wtv-reconnect-url: wtv-1800:/preregister?reconnect=true
|
|
wtv-visit: ${gourl}
|
|
Content-type: text/html`;
|
|
data = '';
|
|
} else {
|
|
headers = `200 OK
|
|
Connection: Keep-Alive
|
|
Expires: Wed, 09 Oct 1991 22:00:00 GMT
|
|
wtv-expire-all: wtv-head-waiter:
|
|
wtv-expire-all: wtv-1800:
|
|
wtv-visit: wtv-1800:/preregister?relogin=true
|
|
Content-type: text/html`;
|
|
|
|
} |