rewrite messengerlogin to not require additional node module
This commit is contained in:
@@ -4,39 +4,52 @@ wtv-encrypted: true
|
|||||||
Expires: Wed, 09 Oct 1991 22:00:00 GMT
|
Expires: Wed, 09 Oct 1991 22:00:00 GMT
|
||||||
Content-Type: text/plain`
|
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 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 password = ssid_sessions[socket.ssid].decryptPassword(ssid_sessions[socket.ssid].getSessionData("messenger_password"));
|
||||||
var challenge = request_headers.request.split('?')[1];
|
var challenge = request_headers.request.split('?')[1];
|
||||||
|
|
||||||
if (request_headers.request.split('?')[1].substring(0, 3) != "ct=") {
|
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");
|
data = require('crypto').createHash('md5').update(request_headers.request.split('?')[1] + password).digest("hex");
|
||||||
} else {
|
} 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
|
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() {
|
response.on('end', () => {
|
||||||
var response = await fetch('https://msnmsgr.escargot.chat/rdr/pprdr.asp')
|
var passporturls = response.headers['passporturls'].split("DALogin=")[1];
|
||||||
var passporturls = response.headers.get('passporturls').split("DALogin=")[1];
|
request.end();
|
||||||
var options = {
|
var options = {
|
||||||
method: 'GET',
|
method: 'GET',
|
||||||
headers: {"Authorization": "Passport1.4 OrgVerb=GET,OrgURL=http%3A%2F%2Fmessenger%2Emsn%2Ecom,sign-in=" + email + ",pwd=" + encodeURIComponent(password) + "," + challenge}
|
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)
|
const request2 = https.get(passporturls, options, (response) => {
|
||||||
var pp = response.headers.get('authentication-info');
|
let req_data = '';
|
||||||
pp = pp.split("from-PP='")[1];
|
response.on('data', (chunk) => {
|
||||||
pp = pp.split("'")[0];
|
req_data += chunk.toString();
|
||||||
return pp;
|
});
|
||||||
}
|
|
||||||
|
|
||||||
(async () => {
|
response.on('end', () => {
|
||||||
let authdata = await auth();
|
var pp = response.headers['authentication-info'];
|
||||||
sendToClient(socket, headers, authdata);
|
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);
|
||||||
|
});
|
||||||
}
|
}
|
||||||
@@ -243,6 +243,7 @@
|
|||||||
</Content>
|
</Content>
|
||||||
<Content Include="ServiceVault\wtv-news\lobby.js" />
|
<Content Include="ServiceVault\wtv-news\lobby.js" />
|
||||||
<Content Include="ServiceVault\wtv-news\news.js" />
|
<Content Include="ServiceVault\wtv-news\news.js" />
|
||||||
|
<Content Include="ServiceVault\wtv-passport\messengerlogin.js" />
|
||||||
<Content Include="ServiceVault\wtv-register\BeMyGuest.js">
|
<Content Include="ServiceVault\wtv-register\BeMyGuest.js">
|
||||||
<SubType>Code</SubType>
|
<SubType>Code</SubType>
|
||||||
</Content>
|
</Content>
|
||||||
@@ -460,6 +461,7 @@
|
|||||||
<Folder Include="ServiceVault\wtv-music\demo\" />
|
<Folder Include="ServiceVault\wtv-music\demo\" />
|
||||||
<Folder Include="ServiceVault\wtv-music\demo\midi\" />
|
<Folder Include="ServiceVault\wtv-music\demo\midi\" />
|
||||||
<Folder Include="ServiceVault\wtv-news\" />
|
<Folder Include="ServiceVault\wtv-news\" />
|
||||||
|
<Folder Include="ServiceVault\wtv-passport\" />
|
||||||
<Folder Include="ServiceVault\wtv-register\" />
|
<Folder Include="ServiceVault\wtv-register\" />
|
||||||
<Folder Include="ServiceVault\wtv-setup\" />
|
<Folder Include="ServiceVault\wtv-setup\" />
|
||||||
<Folder Include="ServiceVault\wtv-star\" />
|
<Folder Include="ServiceVault\wtv-star\" />
|
||||||
|
|||||||
Reference in New Issue
Block a user