- numerous bug fixes - wtv-mail system - user account updates - viewergen alpha (experimental webtv viewer patcher on pc_service) - implement wtv-favorites with huge help from @JarHead4 - add wtv-ticket store api - Bump vm2 from 3.9.5 to 3.9.7 in /zefie_wtvp_minisrv - fix bf0app default rom - Add wtv-1800 service to wtv-1800:/noflash - handle webtvism: - allow get/post variables to be the same name multiple times - rather than overwrite, the server will now change the variable from a string to an array. - Rewrite script processing a bit - Instead of using eval() we now use a proper VM Context - As a result, any scripting errors will now give a more useful filename and line number. - However, some things may break, if they are dependant on variables we are not allowing in the context. - BREAKING CHANGES: - `ssid_sessions[socket.ssid]` is now `session_data` - `require` is no longer allowed in user scripts - add star service - change how we handle modules for services in the VM - fixed wtv-disk:/sync always failed the first time - implement production-like wtv-star handling (when a service port becomes unavailable, it requests the url over the wtv-star port to show an error page) - renamed WTVDownloadList.js to WTVDisk.js - a bit more work on WTVNews (created class) - probably more stuff I can't remember
55 lines
1.8 KiB
JavaScript
55 lines
1.8 KiB
JavaScript
headers = `200 OK
|
|
Connection: Keep-Alive
|
|
wtv-encrypted: true
|
|
Expires: Wed, 09 Oct 1991 22:00:00 GMT
|
|
Content-Type: text/plain`
|
|
|
|
|
|
var email = session_data.getSessionData("messenger_email") + "%40" + session_data.getSessionData("messenger_domain");
|
|
var password = session_data.decryptPassword(session_data.getSessionData("messenger_password"));
|
|
var challenge = request_headers.request.split('?')[1];
|
|
|
|
if (request_headers.request.split('?')[1].substring(0, 3) != "ct=") {
|
|
console.log(" *** Logging into Messenger via MSNP3")
|
|
data = crypto.createHash('md5').update(request_headers.request.split('?')[1] + password).digest("hex");
|
|
} else {
|
|
console.log(" *** Logging into Messenger via MSNP8")
|
|
request_is_async = true; // Make us async
|
|
const request = https.get('https://msnmsgr.escargot.chat/rdr/pprdr.asp', (response) => {
|
|
let req_data = '';
|
|
response.on('data', (chunk) => {
|
|
req_data += chunk.toString();
|
|
});
|
|
|
|
response.on('end', () => {
|
|
var passporturls = response.headers['passporturls'].split("DALogin=")[1];
|
|
request.end();
|
|
var options = {
|
|
method: 'GET',
|
|
headers: { "Authorization": "Passport1.4 OrgVerb=GET,OrgURL=http%3A%2F%2Fmessenger%2Emsn%2Ecom,sign-in=" + email + ",pwd=" + encodeURIComponent(password) + "," + challenge }
|
|
}
|
|
const request2 = https.get(passporturls, options, (response) => {
|
|
let req_data = '';
|
|
response.on('data', (chunk) => {
|
|
req_data += chunk.toString();
|
|
});
|
|
|
|
response.on('end', () => {
|
|
var pp = response.headers['authentication-info'];
|
|
pp = pp.split("from-PP='")[1];
|
|
pp = pp.split("'")[0];
|
|
data = pp;
|
|
sendToClient(socket, headers, data);
|
|
});
|
|
});
|
|
request2.on('error', (error) => {
|
|
console.log(' *** Error (Stage 1)', error);
|
|
});
|
|
|
|
});
|
|
});
|
|
|
|
request.on('error', (error) => {
|
|
console.log(' *** Error (Stage 1)', error);
|
|
});
|
|
} |