- convert post_data to query if valid query data - wtv-register system - Store Session data as JSON flat file - wtv-cookie support - spent way too much time on a page no one will read - move filterSSID to WTVClientSessionData - disable compression until fixed - do not delete WTVSec on last socket, instead recreate on prereg - set 'wtv-bypass-proxy' to false - rework header whitelist system for HTTP(s) proxy - clean up SSID session data only if client is not seen for 3 minutes - add shouldWeCompress() function - add additional headers to wtv-setup:/get - add initial blank wtv-music:/get-playlist - update: WTVClientCapabilities: add unknown bits instead of logging error - update: fix flashrom system - update: webone example config - update: app.js: more 'binary block' exclusions - update: fix tellyscript folder name for case-sensitive filesystems - add Lzpf compression
65 lines
2.2 KiB
JavaScript
65 lines
2.2 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";
|
|
var send_to_relogin = true;
|
|
|
|
if (socket.ssid) {
|
|
if (ssid_sessions[socket.ssid]) {
|
|
if (request_headers["wtv-ticket"]) {
|
|
if (ssid_sessions[socket.ssid].data_store.wtvsec_login.ticket_b64 == null) {
|
|
if (request_headers["wtv-ticket"].length > 8) {
|
|
ssid_sessions[socket.ssid].data_store.wtvsec_login.DecodeTicket(request_headers["wtv-ticket"]);
|
|
ssid_sessions[socket.ssid].data_store.wtvsec_login.ticket_b64 = request_headers["wtv-ticket"];
|
|
send_to_relogin = false;
|
|
}
|
|
}
|
|
} else {
|
|
if (ssid_sessions[socket.ssid].data_store.wtvsec_login) {
|
|
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);
|
|
ssid_sessions[socket.ssid].data_store.wtvsec_login.PrepareTicket();
|
|
send_to_relogin = false;
|
|
} else {
|
|
challenge_header = "wtv-challenge: " + ssid_sessions[socket.ssid].data_store.wtvsec_login.IssueChallenge();
|
|
send_to_relogin = false;
|
|
}
|
|
} else {
|
|
challenge_header = "wtv-challenge: " + ssid_sessions[socket.ssid].data_store.wtvsec_login.IssueChallenge();
|
|
send_to_relogin = false;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
if (!send_to_relogin) {
|
|
|
|
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`;
|
|
if (challenge_header != "") headers += "\n" + challenge_header;
|
|
headers += `
|
|
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`;
|
|
data = '';
|
|
} |