private void processMessageLoop() { while (true) { if (incommingMessageQueue.Count > 0) { MSNMessage message = incommingMessageQueue.Dequeue(); try { String command = message.getCommand(); #region process XFR if (command.StartsWith("XFR")) { incommingXFRQueue.Enqueue(message); Thread t = new Thread(new ThreadStart(processIncommingXFR)); t.Start(); //Invoke(new RefreshDelegate(processIncommingXFR)); } #endregion #region process RNG else if (command.StartsWith("RNG")) { incommingRNGQueue.Enqueue(message); Thread t = new Thread(new ThreadStart(processIncommingRNG)); t.Start(); //Invoke(new RefreshDelegate(processIncommingRNG)); } #endregion } catch (Exception) { if (message != null) { Console.WriteLine("ERROR processing message in MSNSwitchboardController.processMessageLoop(), message = " + message.ToString()); } else { Console.WriteLine("ERROR processing message in MSNSwitchboardController.processMessageLoop(), message = null"); } } } else { try { Thread.Sleep(50); } catch (Exception) { } } } }
internal void processMessage(MSNMessage message) { if (message.getCommand().Equals("CHG")) { currentStatus = MSNStaticHelperFunctions.toUserStatus(message.getData()[0]); controller.sendLocalClientStatusChangeMessage(); } else if (message.getCommand().Equals("PRP")) { Console.WriteLine("MSNLocalClient.processMessage(" + message.ToString() + ") does not handle PRP YET!"); } else if (message.getCommand().Equals("BLP")) { String[] data = message.getData(); if (data[1].Equals("AL")) //allow unknown chat { handleUnknownContact = MSNEnumerations.UnknownContact.allow_chat; } else if (data[1].Equals("BL")) //block unknown chat { handleUnknownContact = MSNEnumerations.UnknownContact.disallow_chat; } } else if (message.getCommand().Equals("REA")) { String[] data = message.getData(); if (data.Length >= 3) { friendlyName = HttpUtility.UrlDecode(data[2]); controller.sendLocalClientFriendlyNameChangeMessage(); } } else if (message.getCommand().Equals("USR")) { String[] data = message.getData(); if (data.Length >= 6) { friendlyName = HttpUtility.UrlDecode(data[3]); controller.sendLocalClientFriendlyNameChangeMessage(); } } }
internal MSNSocketWrapper doAuthentication(String address, int port) { //messenger.hotmail.com:1863 MSNSocketWrapper sw = new MSNSocketWrapper(address, port, false); if (sw.connected() != true) { throw new Exception("Not connecting to messenger.hotmail.com"); } #region negotiate protocol version (VER) #region VER 1 MSNP8 CVR0\r\n MSNMessage outMessage = new MSNMessage("VER " + MSNTrIDGenerator.NextID() + " MSNP9 MSNP8 CVR0\r\n"); sw.send(outMessage); #endregion #region <<< VER 1 MSNP8 CVR0\r\n MSNMessage inMessage = sw.recieve(); if (inMessage.getCommand().Equals("VER") != true) { throw new Exception("VER Expected (" + inMessage.ToString() + ")"); } if (inMessage.getTrID() != outMessage.getTrID()) { throw new Exception("Incorrect TrID reponce in VER (" + inMessage.ToString() + ")"); } String[] messageDataTokens = inMessage.getData(); if (messageDataTokens.Length == 0) { throw new Exception("No data recieved in VER (" + inMessage.ToString() + ")"); } if (messageDataTokens[0].ToString().Equals("0")) { throw new Exception("Protocol MSNP9 MSNP8 CVR0 not supported in VER (" + inMessage.ToString() + ")"); } #endregion #endregion #region negotiate client version (CVR) #region CVR 2 0x0409 win 4.10 i386 MSNMSGR 5.0.0544 MSMSGS [email protected]\r\n outMessage = new MSNMessage("CVR " + MSNTrIDGenerator.NextID() + " 0x0409 win 4.10 i386 MSNMSGR 7.0.0816 MSMSGS " + username + "\r\n"); sw.send(outMessage); #endregion #region CVR 2 7.0.0816 7.0.0816 1.0.0000 http://download.microsoft.com/download/8/a/4/8a42bcae-f533-4468-b871-d2bc8dd32e9e/SETUP9x.EXE http://messenger.msn.com\r\n inMessage = sw.recieve(); if (inMessage.getCommand().Equals("CVR") != true) { throw new Exception("CVR Expected (" + inMessage.ToString() + ")"); } if (inMessage.getTrID() != outMessage.getTrID()) { throw new Exception("Incorrect TrID reponce in CVR (" + inMessage.ToString() + ")"); } messageDataTokens = inMessage.getData(); if (messageDataTokens.Length == 0) { throw new Exception("No data recieved in CVR (" + inMessage.ToString() + ")"); } #endregion #endregion #region get session tpf -> passport session ticket (USR) #region USR 3 TWN I [email protected]\r\n outMessage = new MSNMessage("USR " + MSNTrIDGenerator.NextID() + " TWN I " + username + "\r\n"); sw.send(outMessage); #endregion #region get responce inMessage = sw.recieve(); if (!(inMessage.getCommand().Equals("XFR") == true || inMessage.getCommand().Equals("USR") == true)) { throw new Exception("USR/XFR Expected (" + inMessage.ToString() + ")"); } //HANDLE INITIAL USR if (inMessage.getCommand().Equals("USR")) { String[] data = inMessage.getData(); if (data.Length >= 6) { initialFriendlyName = HttpUtility.UrlDecode(data[4]); } } if (inMessage.getTrID() != outMessage.getTrID()) { throw new Exception("Incorrect TrID reponce in CVR (" + inMessage.ToString() + ")"); } #endregion #region XFR 3 NS 207.46.106.118:1863 0 207.46.104.20:1863\r\n if (inMessage.getCommand().Equals("XFR")) { messageDataTokens = inMessage.getData(); if (messageDataTokens.Length != 4) { throw new Exception("Incorrect data length in XFR (" + inMessage.ToString() + ")"); } try { char[] splitTokens = new char[1]; splitTokens[0] = ':'; String[] addressDataTokens = messageDataTokens[1].Split(splitTokens); String newAddress = addressDataTokens[0]; int newPort = int.Parse(addressDataTokens[1]); return(doAuthentication(newAddress, newPort)); } catch (FormatException) { throw new Exception("Format error in XFR (" + inMessage.ToString() + ")"); } } #endregion String sessionTicket = ""; //First USR #region USR 3 TWN S lc=1033,id=507,tw=40,fs=1,ru=http%3A%2F%2Fmessenger%2Emsn%2Ecom,ct=1062764229,kpp=1,kv=5,ver=2.1.0173.1,tpf=43f8a4c8ed940c04e3740be46c4d1619\r\n if (inMessage.getCommand().Equals("USR")) { String messageStr = inMessage.ToString(); messageStr = messageStr.Replace("\r\n", ""); char[] splitTokens = new char[1]; splitTokens[0] = '='; messageDataTokens = messageStr.Split(splitTokens); String tpf = messageDataTokens[messageDataTokens.Length - 1].ToString(); String ver = messageDataTokens[messageDataTokens.Length - 3].ToString().Replace(",rn", ""); sessionTicket = getPassportTicket(tpf, ver); } #endregion #endregion #region final authentication (USR) #region USR 4 TWN S t=53*1hAu8ADuD3TEwdXoOMi08sD*2!cMrntTwVMTjoB3p6stWTqzbkKZPVQzA5NOt19SLI60PY!b8K4YhC!Ooo5ug$$&p=5eKBBC!yBH6ex5mftp!a9DrSb0B3hU8aqAWpaPn07iCGBw5akemiWSd7t2ot!okPvIR!Wqk!MKvi1IMpxfhkao9wpxlMWYAZ!DqRfACmyQGG112Bp9xrk04!BVBUa9*H9mJLoWw39m63YQRE1yHnYNv08nyz43D3OnMcaCoeSaEHVM7LpR*LWDme29qq2X3j8N\r\n outMessage = new MSNMessage("USR " + MSNTrIDGenerator.NextID() + " TWN S " + sessionTicket + "\r\n"); sw.send(outMessage); #endregion #region USR 4 OK [email protected] example%20display%20name 1 0\r\n inMessage = sw.recieve(); if (inMessage.getCommand().Equals("USR")) { String[] data = inMessage.getData(); if (data.Length >= 3) { initialFriendlyName = HttpUtility.UrlDecode(data[2]); } } if (!inMessage.getCommand().Equals("USR")) { throw new Exception("Unexpected command responce for USR in doAuthentication(" + address + ", " + port + ")"); } if (inMessage.getTrID() != outMessage.getTrID()) { throw new Exception("Unexpected TrID responce for USR in doAuthentication(" + address + ", " + port + ")"); } messageDataTokens = inMessage.getData(); if (messageDataTokens.Length != 5) { throw new Exception("Unexpected length data responce for USR in doAuthentication(" + address + ", " + port + ")"); } if (!messageDataTokens[0].Equals("OK")) { throw new Exception("Unknown failure to authentication for USR in doAuthentication(" + address + ", " + port + ")"); } if (!messageDataTokens[1].Equals(username)) { throw new Exception("Authenticated as incorrect user for USR in doAuthentication(" + address + ", " + port + ")"); } //############################################################################################################################# // AUTHENTICATION PASSED // AUTHENTICATION PASSED // AUTHENTICATION PASSED // AUTHENTICATION PASSED // AUTHENTICATION PASSED // //############################################################################################################################# return(sw); #endregion #endregion }
private void processMessageLoop() { MSNMessage message = new MSNMessage("NULL"); while (true) { if (processingQueue.Count > 0) { try { #region get message from queue message = processingQueue.Dequeue(); String command = message.getCommand(); String[] data = message.getTokens(); #endregion #region handle SYN if (command.Equals("SYN")) { //SYN 9 1 18 7 versionID = int.Parse(data[2]); } #endregion #region handle GTC else if (command.Equals("GTC")) { //GTC A if (data[1].Equals("A")) //manual { handleNewContact = MSNEnumerations.NewContact.manual_add; } else if (data[1].Equals("N")) //auto { handleNewContact = MSNEnumerations.NewContact.auto_add; } } #endregion #region handle LSG else if (command.Equals("LSG")) { //LSG 0 Individuals 0 if (!data[2].Equals("~")) { String groupName = HttpUtility.UrlDecode(data[2]); MSNGroup g = new MSNGroup(controller, groupName, int.Parse(data[1])); if (!groupsByName.ContainsKey(groupName)) { groupsByName.Add(groupName, g); groupsByNumber.Add(int.Parse(data[1]), g); } } } #endregion #region handle LST else if (command.Equals("LST")) { //LST [email protected] derek_bartram 11 3 //all contacts send 11!?! String username = data[1]; #region get / make contact MSNContact c = getContact(username); lastContact = c; #endregion #region process friendly name c.FriendlyName = HttpUtility.UrlDecode(data[2]); #endregion #region process groups if (data.Length == 5) { char[] splitChars = new char[1]; splitChars[0] = ','; String[] groupIDs = data[4].Split(splitChars); for (int i = 0; i < groupIDs.Length; i++) { int groupID = int.Parse(groupIDs[i]); if (groupsByNumber.ContainsKey(int.Parse(groupIDs[i]))) { MSNGroup g = groupsByNumber[int.Parse(groupIDs[i])]; c.Groups.Add(g); g.Contacts.Add(c); } } } #endregion } #endregion #region handle BPR else if (command.Equals("BPR")) { //BPR 12182 [email protected] PHH 555%20555%204321 //BPR 12182 [email protected] PHW I%20AM%20DUMB\r\n //BPR 12182 [email protected] PHM I%20Dont%20Have%20One\r\n //BPR 12182 [email protected] MOB Y\r\n //BPR MOB Y MSNContact c = lastContact; String phoneString = ""; if (data.Length == 3) { phoneString = HttpUtility.UrlDecode(data[2]); } c.setPhone(MSNStaticHelperFunctions.toPhoneTypes(data[1]), phoneString); } #endregion #region handle ILN else if (command.Equals("ILN")) { //ILN 10 NLN [email protected] 80%25%20Andy%20::%205.5%20ml%20Marky 1347272748 %3Cmsnobj%20Creator%3D%22webmaster%40norbosoft.zzn.com%22%20Size%3D%2216657%22%20Type%3D%223%22%20Location%3D%22TFR100.dat%22%20Friendly%3D%22UwBpAGQAAAA%3D%22%20SHA1D%3D%22LCJswyrzD1bDGR41HJ3xmfoBbqM%3D%22%20SHA1C%3D%22bYULHZIyQUxMB%2BFM1FNO%2BYAiP6M%3D%22%20contenttype%3D%22M%22%20contentid%3D%22U3097935%22%2F%3E MSNContact c = getContact(data[3]); c.Status = MSNStaticHelperFunctions.toUserStatus(data[2]); if (data.Length >= 5) { c.FriendlyName = HttpUtility.UrlDecode(data[4]); } } #endregion #region handle NLN else if (command.Equals("NLN")) { //NLN AWY [email protected] derek_bartram 1347272812 %3Cmsnobj%20Creator%3D%22derek_bartram%40hotmail.com%22%20Size%3D%2229106%22%20Type%3D%223%22%20Location%3D%22xpp539.dat%22%20Friendly%3D%22AAA%3D%22%20SHA1D%3D%22YeWGuRSbOGhJ1Wbk3JY5vCzoqT8%3D%22%20SHA1C%3D%22nj0278TZP%2FP4yIGc6qxIXrY2olQ%3D%22%2F%3E MSNContact c = getContact(data[2]); c.Status = MSNStaticHelperFunctions.toUserStatus(data[1]); if (data.Length >= 4) { c.FriendlyName = HttpUtility.UrlDecode(data[3]); } } #endregion else if (command.Equals("FLN")) { MSNContact c = getContact(data[1]); c.Status = MSNStaticHelperFunctions.toUserStatus("FLN"); } #region unknown else { throw new Exception("Unknown message type in MSNContactsList.processMessageLoop() <" + message.ToString() + ">"); } #endregion } catch (Exception) { Console.Error.WriteLine("Error processing command in MSNContactsList.processMessageLoop()\r\n" + message.ToString()); } } else { Thread.Sleep(20); } } }