diff options
Diffstat (limited to 'kopete/protocols/msn/msnsecureloginhandler.cpp')
-rw-r--r-- | kopete/protocols/msn/msnsecureloginhandler.cpp | 131 |
1 files changed, 0 insertions, 131 deletions
diff --git a/kopete/protocols/msn/msnsecureloginhandler.cpp b/kopete/protocols/msn/msnsecureloginhandler.cpp deleted file mode 100644 index f8431f9f..00000000 --- a/kopete/protocols/msn/msnsecureloginhandler.cpp +++ /dev/null @@ -1,131 +0,0 @@ -/* - msnsecureloginhandler.cpp - SSL login for MSN protocol - - Copyright (c) 2005 by Michaƫl Larouche <[email protected]> - - Kopete (c) 2002-2005 by the Kopete developers <[email protected]> - - ************************************************************************* - * * - * This program is free software; you can redistribute it and/or modify * - * it under the terms of the GNU General Public License as published by * - * the Free Software Foundation; either version 2 of the License, or * - * (at your option) any later version. * - * * - ************************************************************************* -*/ -#include "msnsecureloginhandler.h" - -// TQt includes -#include <tqregexp.h> - -// KDE includes -#include <tdeio/job.h> -#include <kurl.h> -#include <kdebug.h> - -MSNSecureLoginHandler::MSNSecureLoginHandler(const TQString &accountId, const TQString &password, const TQString &authParameters) - : m_password(password), m_accountId(accountId), m_authentification(authParameters) -{ - -} - -MSNSecureLoginHandler::~MSNSecureLoginHandler() -{ -// kdDebug(14140) << k_funcinfo << endl; -} - -void MSNSecureLoginHandler::login() -{ - // Retrive the login server. - // Do a reload and don't show the progress. - TDEIO::Job *getLoginServer = TDEIO::get(KURL("https://nexus.passport.com/rdr/pprdr.asp"), true, false); - - getLoginServer->addMetaData("cookies", "manual"); - getLoginServer->addMetaData("cache", "reload"); - getLoginServer->addMetaData("PropagateHttpHeader", "true"); - - connect(getLoginServer, TQT_SIGNAL(result(TDEIO::Job *)), this, TQT_SLOT(slotLoginServerReceived(TDEIO::Job* ))); -} - -void MSNSecureLoginHandler::slotLoginServerReceived(TDEIO::Job *loginJob) -{ - if(!loginJob->error()) - { - // Retrive the HTTP header - TQString httpHeaders = loginJob->queryMetaData("HTTP-Headers"); - - // Get the login URL using TQRegExp - TQRegExp rx("PassportURLs: DARealm=(.*),DALogin=(.*),DAReg="); - rx.search(httpHeaders); - - // Set the loginUrl and loginServer - TQString loginUrl = rx.cap(2); - TQString loginServer = loginUrl.section('/', 0, 0); - - kdDebug(14140) << k_funcinfo << loginServer << endl; - - TQString authURL = "https://" + loginUrl; - - TDEIO::Job *authJob = TDEIO::get(KURL(authURL), true, false); - authJob->addMetaData("cookies", "manual"); - - TQString authRequest = "Authorization: Passport1.4 " - "OrgVerb=GET," - "OrgURL=http%3A%2F%2Fmessenger%2Emsn%2Ecom," - "sign-in=" + KURL::encode_string(m_accountId) + - ",pwd=" + KURL::encode_string( m_password ).replace(',',"%2C") + - "," + m_authentification + "\r\n"; - -// warning, this debug contains the password -// kdDebug(14140) << k_funcinfo << "Auth request: " << authRequest << endl; - - authJob->addMetaData("customHTTPHeader", authRequest); - authJob->addMetaData("SendLanguageSettings", "false"); - authJob->addMetaData("PropagateHttpHeader", "true"); - authJob->addMetaData("cookies", "manual"); - authJob->addMetaData("cache", "reload"); - - connect(authJob, TQT_SIGNAL(result(TDEIO::Job *)), this, TQT_SLOT(slotTweenerReceived(TDEIO::Job* ))); - } - else - { - kdDebug(14140) << k_funcinfo << loginJob->errorString() << endl; - - emit loginFailed(); - } -} - -void MSNSecureLoginHandler::slotTweenerReceived(TDEIO::Job *authJob) -{ - if(!authJob->error()) - { - TQString httpHeaders = authJob->queryMetaData("HTTP-Headers"); - -// kdDebug(14140) << k_funcinfo << "HTTP headers: " << httpHeaders << endl; - - // Check if we get "401 Unauthorized", thats means it's a bad password. - if(httpHeaders.contains(TQString::fromUtf8("401 Unauthorized"))) - { -// kdDebug(14140) << k_funcinfo << "MSN Login Bad password." << endl; - emit loginBadPassword(); - } - else - { - TQRegExp rx("from-PP='(.*)'"); - rx.search(httpHeaders); - TQString ticket = rx.cap(1); - - // kdDebug(14140) << k_funcinfo << "Received ticket: " << ticket << endl; - - emit loginSuccesful(ticket); - } - } - else - { - kdDebug(14140) << k_funcinfo << authJob->errorString() << endl; - - emit loginFailed(); - } -} -#include "msnsecureloginhandler.moc" |