rewrite messengerlogin to not require additional node module

This commit is contained in:
zefie
2022-10-08 08:51:01 -04:00
parent 65a56ab1b9
commit 23c77a653e
2 changed files with 42 additions and 27 deletions

View File

@@ -4,39 +4,52 @@ wtv-encrypted: true
Expires: Wed, 09 Oct 1991 22:00:00 GMT
Content-Type: text/plain`
const crypto = require('crypto');
const https = require("https");
const algorithm = 'aes-256-ctr';
var email = ssid_sessions[socket.ssid].getSessionData("messenger_email") + "%40" + ssid_sessions[socket.ssid].getSessionData("messenger_domain");
var password = ssid_sessions[socket.ssid].decryptPassword(ssid_sessions[socket.ssid].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")
console.log(" *** Logging into Messenger via MSNP3")
data = require('crypto').createHash('md5').update(request_headers.request.split('?')[1] + password).digest("hex");
} else {
const fetch = require('node-fetch')
console.log("Logging into Messenger via MSNP8")
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();
});
async function auth() {
var response = await fetch('https://msnmsgr.escargot.chat/rdr/pprdr.asp')
var passporturls = response.headers.get('passporturls').split("DALogin=")[1];
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 }
}
response = await fetch(passporturls, options)
var pp = response.headers.get('authentication-info');
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];
return pp;
}
data = pp;
sendToClient(socket, headers, data);
});
});
request2.on('error', (error) => {
console.log(' *** Error (Stage 1)', error);
});
(async () => {
let authdata = await auth();
sendToClient(socket, headers, authdata);
})();
});
});
request.on('error', (error) => {
console.log(' *** Error (Stage 1)', error);
});
}

View File

@@ -243,6 +243,7 @@
</Content>
<Content Include="ServiceVault\wtv-news\lobby.js" />
<Content Include="ServiceVault\wtv-news\news.js" />
<Content Include="ServiceVault\wtv-passport\messengerlogin.js" />
<Content Include="ServiceVault\wtv-register\BeMyGuest.js">
<SubType>Code</SubType>
</Content>
@@ -460,6 +461,7 @@
<Folder Include="ServiceVault\wtv-music\demo\" />
<Folder Include="ServiceVault\wtv-music\demo\midi\" />
<Folder Include="ServiceVault\wtv-news\" />
<Folder Include="ServiceVault\wtv-passport\" />
<Folder Include="ServiceVault\wtv-register\" />
<Folder Include="ServiceVault\wtv-setup\" />
<Folder Include="ServiceVault\wtv-star\" />