[Date Prev][Date Next] [Thread Prev][Thread Next]
[Thread Index]
[Date Index]
[Author Index]
rpms/kdenetwork/FC-3 kdenetwork-3.3.1-kopete-msn-login.patch, NONE, 1.1 kdenetwork.spec, 1.44, 1.45
- From: fedora-cvs-commits redhat com
- To: fedora-cvs-commits redhat com
- Subject: rpms/kdenetwork/FC-3 kdenetwork-3.3.1-kopete-msn-login.patch, NONE, 1.1 kdenetwork.spec, 1.44, 1.45
- Date: Mon, 4 Jul 2005 09:14:19 -0400
Author: than
Update of /cvs/dist/rpms/kdenetwork/FC-3
In directory cvs.devel.redhat.com:/tmp/cvs-serv3747
Modified Files:
kdenetwork.spec
Added Files:
kdenetwork-3.3.1-kopete-msn-login.patch
Log Message:
add backported patch to fix Kopete MSN login #161707
kdenetwork-3.3.1-kopete-msn-login.patch:
Makefile.am | 3
msnnotifysocket.cpp | 111 ++----------
msnnotifysocket.h | 8
sslloginhandler.cpp | 453 ++++++++++++++++++++++++++++++++++++++++++++++++++++
sslloginhandler.h | 96 +++++++++++
5 files changed, 580 insertions(+), 91 deletions(-)
--- NEW FILE kdenetwork-3.3.1-kopete-msn-login.patch ---
--- /dev/null 2005-06-21 18:50:17.147065504 +0200
+++ kdenetwork-3.3.1/kopete/protocols/msn/sslloginhandler.cpp 2005-06-27 09:57:08.000000000 +0200
@@ -0,0 +1,453 @@
+//Imported from KMess (2005-05-19)
+
+/***************************************************************************
+ sslloginhandler.cpp - description
+ -------------------
+ begin : Sat Jun 28 2003
+ copyright : (C) 2003 by Mike K. Bennett
+ email : mkb137b hotmail com
+ ***************************************************************************/
+
+/***************************************************************************
+ * *
+ * 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 "sslloginhandler.h"
+
+#include <qstringlist.h>
+#include <qregexp.h>
+#include <qsocket.h>
+#include <qurl.h>
+
+#include <kdebug.h>
+#include <kextsock.h>
+#include <kssl.h>
+#include <kurl.h>
+
+#if 0
+#include "../kmessdebug.h"
+#include "mimemessage.h"
+#else
+//i didn't want to import the whole MimeMessage from Kmess for Kopete so i
+// reimplemented the base here -Olivier
+
+class MimeMessage
+{
+ public:
+ MimeMessage(const QString &msg) : message(msg) {}
+
+ QString getValue(const QString &key)
+ {
+ QRegExp rx(key+": (.*)\n");
+ rx.search(message);
+ return rx.cap(1);
+ }
+ private:
+ QString message;
+};
+
+#include "sslloginhandler.moc"
+#endif
+//there is nothing modified from here. this is exactly the kmerlin code
+
+
+
+/*
+ * Great documentation about this can be found at
+ * http://siebe.bot2k3.net/docs/
+ */
+
+
+// The constructor
+SslLoginHandler::SslLoginHandler()
+ : mode_(NONE)
+{
+ // Create the SSL handler
+ ssl_ = new KSSL( true );
+
+ // Create and set up the socket.
+ socket_ = new KExtendedSocket( );
+
+ //socket_->setSocketFlags( 0x00 | 0x600000 ); // 0x00 = anySocket | 0x600000 = bufferedSocket
+ socket_->setSocketFlags( 0x00 ); // 0x00 = anySocket | 0x600000 = bufferedSocket
+ socket_->setTimeout( 30 );
+ socket_->enableRead( true );
+ connect( socket_, SIGNAL( readyRead() ),
+ this, SLOT ( dataReceived() ) );
+ connect( socket_, SIGNAL( connectionFailed(int) ),
+ this, SLOT ( socketError(int) ) );
+}
+
+
+
+// The destructor
+SslLoginHandler::~SslLoginHandler()
+{
+ delete ssl_;
+ delete socket_;
+}
+
+
+
+// Data was received over the socket
+void SslLoginHandler::dataReceived()
+{
+#ifdef KMESSDEBUG_SSLLOGINHANDLER
+ kdDebug() << "SslLoginHandler - ******************** Data received ********************" << endl;
+ kdDebug() << "SslLoginHandler - " << socket_->bytesAvailable() << " bytes available." << endl;
+ kdDebug() << "SslLoginHandler - SSL says " << ssl_->pending() << " bytes available." << endl;
+#endif
+
+ QString data;
+ int breakOut = 0;
+ const int maxIterations = 1000;
+ while ( ( !data.contains( QRegExp("\r\n") ) ) && ( breakOut < maxIterations ) )
+ {
+ // Read data via SSL
+ data = readSslData();
+ breakOut ++;
+ }
+
+ // Output the data for debugging
+#ifdef KMESSDEBUG_SSLLOGINHANDLER
+ kdDebug() << "SslLoginHandler - ******************** Contents ********************" << endl;
+ kdDebug() << data << endl;
+ kdDebug() << "SslLoginHandler - ******************** End of data ********************" << endl;
+#endif
+
+ // Warn if timed out
+ if ( breakOut >= maxIterations )
+ {
+ kdDebug() << "WARNING - SSL read timed out." << endl;
+ emit loginFailed();
+ return;
+ }
+
+ if ( data.length() > 0 )
+ {
+ parseHttpResponse(data);
+ }
+ else
+ {
+ kdDebug() << "WARNING - Available data wasn't read from the SSL socket." << endl;
+ emit loginFailed();
+ }
+}
+
+
+
+// Start the login process
+void SslLoginHandler::login( QString parameters, QString handle, QString password )
+{
+#ifdef KMESSDEBUG_SSLLOGINHANDLER
+ kdDebug() << "SslLoginHandler - Starting login with parameters " << parameters << "." << endl;
+#endif
+
+ // Store the given data
+ authenticationParameters_ = parameters;
+ handle_ = handle;
+ password_ = password;
+
+ // Get the login server
+ sendLoginServerRequest("nexus.passport.com");
+ dataReceived();
+}
+
+
+
+// Get the authentication data from a string
+void SslLoginHandler::parseAuthenticationData( QString data )
+{
+ QString twnData;
+
+ // Pull TWN data out of the message
+ twnData = data.right( data.length() - data.find(QRegExp("from-PP='")) - 9 );
+ twnData = twnData.left( twnData.find(QRegExp("',")) );
+
+#ifdef KMESSDEBUG_SSLLOGINHANDLER
+ kdDebug() << "SslLoginHandler - data for TWN is " << twnData << "." << endl;
+#endif
+
+ // Notify the MsnNotificationConnection
+ emit loginSucceeded(twnData);
+}
+
+
+
+// Parse the HTTP response from the server
+void SslLoginHandler::parseHttpResponse(QString data)
+{
+ KURL location;
+ int headerEnd;
+ QString header;
+ int headerCode;
+ QString headerText;
+
+ // Parse the HTTP status header
+ QRegExp re("HTTP/\\d+\\.\\d+ (\\d+) ([^\r\n]+)");
+ headerEnd = data.find("\r\n");
+ header = data.left( (headerEnd == -1) ? 20 : headerEnd );
+
+ re.search(header);
+ headerCode = re.cap(1).toUInt();
+ headerText = re.cap(2);
+
+ // Create a MimeMessage, removing the HTTP status header
+ MimeMessage message( data.section( ",", 1 ) );
+
+
+ switch(mode_)
+ {
+ case GETLOGINSERVER:
+ {
+ // Step 1. This data describes the login server to use.
+ if(headerCode == 302)
+ {
+ // HTTP Redirect
+ location = KURL( message.getValue( "Location" ) );
+ sendLoginServerRequest(location.host());
+ }
+ else
+ {
+ // Parse the data
+ QString loginServer;
+ QString page;
+ parseLoginServerData( loginServer, page, message.getValue("PassportURLs") );
+
+ // Send the authentication request
+ sendAuthenticationRequest( loginServer, page );
+ }
+ break;
+ }
+ case GETAUTHENTICATIONDATA:
+ {
+ // Step 2. Get the authentication data
+ if(headerCode == 200)
+ {
+ // Login success
+ parseAuthenticationData(message.getValue("Authentication-Info"));
+ }
+ else if(headerCode == 302)
+ {
+ // HTTP Redirect
+ location = KURL( message.getValue( "Location" ) );
+ sendAuthenticationRequest(location.host(), location.path());
+ }
+ else if(headerCode == 401)
+ {
+ // Got a HTTP "401 Unauthorized"; Login failed
+ emit loginIncorrect();
+ }
+ else
+ {
+ kdDebug() << "SslLoginHandler::parseHttpResponse: WARNING "
+ << "- Unhandled response code " << headerCode << " " << headerText << endl;
+ emit loginFailed();
+ }
+ break;
+ }
+ default:
+ {
+ kdDebug() << "SslLoginHandler::parseHttpResponse: WARNING - Entered illegal state" << endl;
+ emit loginFailed();
+ }
+ }
+}
+
+
+// Get login server data from a string
+void SslLoginHandler::parseLoginServerData( QString &host, QString &page, QString serverData )
+{
+ int slashIndex;
+
+ // Get everything between "DLLogin=" and to the comma.
+ serverData = serverData.right( serverData.length() - serverData.find( "DALogin=" ) - 8 );
+ serverData = serverData.left( serverData.find( "," ) );
+
+#ifdef KMESSDEBUG_SSLLOGINHANDLER
+ kdDebug() << "SslLoginHandler - host/page=" << serverData << endl;
+#endif
+
+ // Separate the "host/page" string.
+ slashIndex = serverData.find( "/" );
+ host = serverData.left( slashIndex );
+ page = serverData.right( serverData.length() - slashIndex );
+
+#ifdef KMESSDEBUG_SSLLOGINHANDLER
+ kdDebug() << "SslLoginHandler - host=" << host << " page=" << page << endl;
+#endif
+}
+
+
+
+// Read data from the socket via SSL
+QString SslLoginHandler::readSslData()
+{
+ char rawblock[1024];
+ QCString block;
+ QString data = "";
+ int noBytesRead = 1;
+
+ // Read data from the SSL socket.
+ if ( ssl_ != 0 )
+ {
+// while( ( ssl_->pending() > 0 ) && ( noBytesRead > 0 ) )
+// while( ( socket_->bytesAvailable() > 0 ) && ( noBytesRead > 0 ) )
+ while(noBytesRead > 0)
+ {
+ noBytesRead = ssl_->read( rawblock, 1024 );
+#ifdef KMESSDEBUG_SSLLOGINHANDLER
+ kdDebug() << "SslLoginHandler - " << noBytesRead << " bytes read." << endl;
+#endif
+ block = rawblock;
+ block = block.left( noBytesRead );
+ data += QString::fromUtf8( block );
+ }
+ }
+
+ return data;
+}
+
+
+
+// Send the authenticationn request
+void SslLoginHandler::sendAuthenticationRequest( QString loginServer, QString page )
+{
+#ifdef KMESSDEBUG_SSLLOGINHANDLER
+ kdDebug() << "SslLoginHandler - Step 2. Requesting authentication data." << endl;
+#endif
+
+ QString request;
+ QString encodedHandle = handle_;
+ QString encodedPassword = password_;
+
+ QUrl::encode(encodedHandle);
+ QUrl::encode(encodedPassword);
+
+ request = "GET " + page + " HTTP/1.1\r\n"
+ "Authorization: Passport1.4"
+ " OrgVerb=GET"
+ ",OrgURL=http%3A%2F%2Fmessenger%2Emsn%2Ecom"
+ ",sign-in=" + encodedHandle +
+ ",pwd=" + encodedPassword +
+ "," + authenticationParameters_ + "\r\n"
+ "User-Agent: MSMSGS\r\n" // Make sure the server won't discriminate
+ "Host: " + loginServer + "\r\n"
+ "Connection: Keep-Alive\r\n"
+ "Cache-Control: no-cache\r\n\r\n";
+
+ // Step 2. Send the authorisation request
+ mode_ = GETAUTHENTICATIONDATA;
+ sendHttpRequest( request, loginServer, 443 );
+}
+
+
+
+// Send a HTTP request to the server
+void SslLoginHandler::sendHttpRequest( QString request, QString host, int port )
+{
+ QString response;
+ QString responseBody;
+
+ if ( socket_ == 0 )
+ {
+ kdDebug() << "SslLoginHandler::sendHttpRequest - WARNING "
+ << "- Trying to login using a null socket." << endl;
+ return;
+ }
+
+ // Configure the socket
+#ifdef KMESSDEBUG_SSLLOGINHANDLER
+ kdDebug() << "SslLoginHandler - Close and reset the socket." << endl;
+#endif
+ ssl_->setAutoReconfig( true );
+ ssl_->reInitialize();
+ socket_->closeNow();
+ socket_->reset();
+
+ // Try to connect
+#ifdef KMESSDEBUG_SSLLOGINHANDLER
+ kdDebug() << "SslLoginHandler - Connecting to " << host << ":" << port << "." << endl;
+#endif
+ socket_->setAddress( host, port );
+ socket_->lookup();
+ int connectionSuccess = socket_->connect();
+ if ( connectionSuccess != 0 )
+ {
+ kdDebug() << "SslLoginHandler::sendHttpRequest - WARNING "
+ << "- Connection failed, giving " << connectionSuccess << endl;
+ return;
+ }
+
+ // Try to wrap the SSL handler
+#ifdef KMESSDEBUG_SSLLOGINHANDLER
+ kdDebug() << "SslLoginHandler - Connection success, binding SSL to socket fd " << socket_->fd() << endl;
+#endif
+ int sslConnectionSuccess = ssl_->connect( socket_->fd() );
+ if ( sslConnectionSuccess != 1 )
+ {
+ kdDebug() << "SslLoginHandler::sendHttpRequest - WARNING "
+ << "- SSL Connection failed, giving " << sslConnectionSuccess << endl;
+ return;
+ }
+
+ // Send the request
+#ifdef KMESSDEBUG_SSLLOGINHANDLER
+ kdDebug() << "SslLoginHandler - SSL connected OK, sending the request." << endl;
+ kdDebug() << request;
+#endif
+ writeSslData( request );
+}
+
+
+
+// Request the name of the login server
+void SslLoginHandler::sendLoginServerRequest(QString hostname)
+{
+#ifdef KMESSDEBUG_SSLLOGINHANDLER
+ kdDebug() << "SslLoginHandler - Step 1. Requesting the login server." << endl;
+#endif
+
+ // Step 1. Send the login server request
+ // The server will respond with the location of the main SSL server.
+ mode_ = GETLOGINSERVER;
+ sendHttpRequest( "GET /rdr/pprdr.asp\r\n\r\n", hostname, 443 );
+}
+
+
+
+// Detect a socket error
+void SslLoginHandler::socketError(int error)
+{
+ kdDebug() << "SslLoginHandler : WARNING - Received error " << error << " from the socket." << endl;
+}
+
+
+
+// Write data to the socket via SSL
+void SslLoginHandler::writeSslData( QString data )
+{
+ int noBytesWritten;
+
+ if(socket_ != 0 && ssl_ != 0)
+ {
+ noBytesWritten = ssl_->write( data.latin1(), data.length() );
+ if(noBytesWritten != (int)data.length())
+ {
+ kdDebug() << "WARNING - Wanted to write " << data.length() << " to the socket, "
+ << " wrote " << noBytesWritten << "." << endl;
+ }
+#ifdef KMESSDEBUG_SSLLOGINHANDLER
+ else
+ {
+ kdDebug() << "SslLoginHandler - Sent " << noBytesWritten << " bytes via SSL." << endl;
+ }
+#endif
+ }
+}
+
--- kdenetwork-3.3.1/kopete/protocols/msn/msnnotifysocket.h.tn 2004-06-25 11:10:14.000000000 +0200
+++ kdenetwork-3.3.1/kopete/protocols/msn/msnnotifysocket.h 2005-06-27 09:57:08.000000000 +0200
@@ -29,6 +29,7 @@
class MSNDispatchSocket;
class MSNAccount;
class KTempFile;
+class SslLoginHandler;
#include <kio/job.h>
@@ -138,8 +139,9 @@
- void slotAuthJobDataReceived ( KIO::Job *, const QByteArray &data);
- void slotAuthJobDone ( KIO::Job *);
+ void sslLoginFailed();
+ void sslLoginIncorrect();
+ void sslLoginSucceeded(QString);
private:
@@ -171,7 +173,7 @@
QString m_kv;
QString m_sid;
QString m_loginTime;
- QString m_authData;
+ SslLoginHandler *m_sslLoginHandler;
QTimer *m_keepaliveTimer;
--- kdenetwork-3.3.1/kopete/protocols/msn/Makefile.am.tn 2004-06-25 11:10:14.000000000 +0200
+++ kdenetwork-3.3.1/kopete/protocols/msn/Makefile.am 2005-06-27 09:57:08.000000000 +0200
@@ -12,7 +12,8 @@
libkopete_msn_shared_la_SOURCES = msnprotocol.cpp msnaccount.cpp msnaddcontactpage.cpp msncontact.cpp \
msnsocket.cpp msnmessagemanager.cpp msndebugrawcmddlg.cpp \
- msnnotifysocket.cpp msnswitchboardsocket.cpp msnfiletransfersocket.cpp msninvitation.cpp msnp2p.cpp sha1.cpp
+ msnnotifysocket.cpp msnswitchboardsocket.cpp msnfiletransfersocket.cpp msninvitation.cpp msnp2p.cpp sha1.cpp \
+ sslloginhandler.cpp
libkopete_msn_shared_la_LIBADD = ./ui/libkopetemsnui.la ../../libkopete/libkopete.la $(LIB_KIO)
libkopete_msn_shared_la_LDFLAGS = -version-info 0:0:0 -no-undefined $(all_libraries)
--- /dev/null 2005-06-21 18:50:17.147065504 +0200
+++ kdenetwork-3.3.1/kopete/protocols/msn/sslloginhandler.h 2005-06-27 09:57:08.000000000 +0200
@@ -0,0 +1,96 @@
+//Imported from KMess - 2005-05-19
+
+/***************************************************************************
+ sslloginhandler.h - description
+ -------------------
+ begin : Sat Jun 28 2003
+ copyright : (C) 2003 by Mike K. Bennett
+ email : mkb137b hotmail com
+ ***************************************************************************/
+
+/***************************************************************************
+ * *
+ * 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. *
+ * *
+ ***************************************************************************/
+
+#ifndef SSLLOGINHANDLER_H
+#define SSLLOGINHANDLER_H
+
+#include <qobject.h>
+#include <qstringlist.h>
+
+// Forward declarations
+class KExtendedSocket;
+class KSSL;
+class MimeMessage;
+
+/**This class handles the SSL portion of the login.
+ * author Mike K. Bennett
+ */
+
+class SslLoginHandler : public QObject
+{
+ Q_OBJECT
+
+ public:
+ // The constructor
+ SslLoginHandler();
+ // The destructor
+ ~SslLoginHandler();
+ // Start the login process
+ void login( QString parameters, QString handle, QString password );
+
+ private : // Private methods
+ // Get the authentication data from a string
+ void parseAuthenticationData( QString data );
+ // Parse the HTTP response from the server
+ void parseHttpResponse(QString data);
+ // Get login server data from a string
+ void parseLoginServerData( QString &host, QString &page, QString serverData );
+ // Read data from the socket via SSL
+ QString readSslData();
+ // Send the authenticationn request
+ void sendAuthenticationRequest( QString loginServer, QString page );
+ // Send a HTTP request to the server
+ void sendHttpRequest( QString request, QString host, int port );
+ // Request the name of the login server
+ void sendLoginServerRequest(QString hostname);
+ // Write data to the socket via SSL
+ void writeSslData( QString data );
+
+ private slots : // Private slots
+ // Data was received over the socket
+ void dataReceived();
+ // Detect a socket error
+ void socketError(int error);
+
+ private : // Private attributes
+ // The mode of the transfer.
+ enum Mode { NONE = 0, GETLOGINSERVER = 1, GETAUTHENTICATIONDATA = 2 } mode_;
+ // The list of parameters sent by the notification server
+ QString authenticationParameters_;
+ // The cookies we received from the server
+ QStringList cookies_;
+ // The user's handle
+ QString handle_;
+ // The user's password
+ QString password_;
+ // The socket over which the SSL data is written and read
+ KExtendedSocket *socket_;
+ // The SSL handler
+ KSSL *ssl_;
+
+ signals : // Public signals
+ // Signal that the login was aborted because an internal error occured
+ void loginFailed();
+ // Signal that the login failed, username/password was incorrect
+ void loginIncorrect();
+ // Signal that the login succeeded
+ void loginSucceeded( QString authentication );
+};
+
+#endif
--- kdenetwork-3.3.1/kopete/protocols/msn/msnnotifysocket.cpp.tn 2004-08-05 21:26:24.000000000 +0200
+++ kdenetwork-3.3.1/kopete/protocols/msn/msnnotifysocket.cpp 2005-06-27 09:57:08.000000000 +0200
@@ -23,6 +23,7 @@
#include "msnnotifysocket.h"
#include "msncontact.h"
#include "msnaccount.h"
+#include "sslloginhandler.h"
#include <qregexp.h>
@@ -47,7 +48,8 @@
: MSNSocket( account )
{
m_newstatus = MSNProtocol::protocol()->NLN;
-
+ m_sslLoginHandler = 0l;
+
m_isHotmailAccount=false;
m_ping=false;
@@ -66,6 +68,7 @@
MSNNotifySocket::~MSNNotifySocket()
{
+ delete m_sslLoginHandler;
delete m_tmpMailFile;
kdDebug(14140) << k_funcinfo << endl;
}
@@ -246,7 +249,7 @@
if ( cmd == "VER" )
{
- sendCommand( "CVR", "0x0409 winnt 5.1 i386 MSNMSGR 6.0.0602 MSMSGS " + m_account->accountId() );
+ sendCommand( "CVR", "0x0409 winnt 5.1 i386 MSNMSGR 6.2.0205 MSMSGS " + m_account->accountId() );
/*
struct utsname utsBuf;
uname ( &utsBuf );
@@ -264,26 +267,15 @@
{
if( data.section( ' ', 1, 1 ) == "S" )
{
- m_authData=data.section( ' ' , 2 , 2 );
- m_kv=QString::null;
+ m_sslLoginHandler = new SslLoginHandler();
+ QObject::connect( m_sslLoginHandler, SIGNAL( loginFailed() ),
+ this, SLOT ( sslLoginFailed() ) );
+ QObject::connect( m_sslLoginHandler, SIGNAL( loginIncorrect() ),
+ this, SLOT ( sslLoginIncorrect() ) );
+ QObject::connect( m_sslLoginHandler, SIGNAL( loginSucceeded(QString) ),
+ this, SLOT ( sslLoginSucceeded(QString) ) );
- if( m_account->accountId().contains("@hotmail.com") )
- m_sid="loginnet.passport.com";
- else if( m_account->accountId().contains("@msn.com") || m_account->accountId().contains("@compaq.net") || m_account->accountId().contains("@webtv.net") )
- m_sid="msnialogin.passport.com";
- else
- m_sid="login.passport.com";
-
- QString authURL="https://"+m_sid+"/login.srf?" + m_authData;
- authURL.replace("," , "&" ) ;
-
- kdDebug(14140) << k_funcinfo << "downlaod URL: " << authURL << endl;
-
- KIO::Job *job = KIO::get( KURL( authURL ), true, false );
- job->addMetaData("cookies", "manual");
- // This should force kio to download the page even is we are in the konqueror offline mode. [see bug #68483]
- job->addMetaData("cache", "reload");
- QObject::connect( job, SIGNAL(result( KIO::Job *)), this, SLOT(slotAuthJobDone( KIO::Job *)) );
+ m_sslLoginHandler->login( data.section( ' ' , 2 , 2 ), m_account->accountId() , m_password );
}
else
{
@@ -570,78 +562,23 @@
}
-void MSNNotifySocket::slotAuthJobDataReceived ( KIO::Job */*job*/,const QByteArray &data)
+void MSNNotifySocket::sslLoginFailed()
{
- m_authData += QCString( data, data.size()+1 );
-// kdDebug(14140) << "MSNNotifySocket::slotAuthJobDataReceived: " << data << endl;
+ disconnect();
}
-void MSNNotifySocket::slotAuthJobDone ( KIO::Job *job)
+void MSNNotifySocket::sslLoginIncorrect()
{
-// kdDebug(14140) << "MSNNotifySocket::slotAuthJobDone: "<< m_authData << endl;
-
- if(job->error())
- {
- //FIXME: Shouldn't we say that we are the MSN plugin?
- job->showErrorDialog();
- disconnect();
- return;
- }
-
- if(m_kv.isNull())
- {
- QStringList cookielist=QStringList::split("\n", job->queryMetaData("setcookies") );
- QString cookies="Cookie: ";
- for ( QStringList::Iterator it = cookielist.begin(); it != cookielist.end(); ++it )
- {
- QRegExp rx("Set-Cookie: ([^;]*)");
- rx.search(*it);
- cookies+=rx.cap(1)+";";
- }
-
- //QRegExp rx("lc=([1-9]*),id=([1-9]*),tw=([1-9]*),fs=[1-9]*,ru=[1-9a-zA-Z%]*,ct=[1-9]*,kpp=[1-9]*,kv=([1-9]*),");
- QRegExp rx("lc=([0-9]*),id=([0-9]*),tw=([0-9]*),.*kv=([0-9]*),");
- rx.search(m_authData);
-
- QString authURL = "https://" + m_sid + "/ppsecure/post.srf?lc=" + rx.cap( 1 ) + "&id=" +
- rx.cap( 2 ) + "&tw=" + rx.cap( 3 ) + "&cbid=" + rx.cap( 2 ) + "&da=passport.com&login=" +
- KURL::encode_string( m_account->accountId()) + "&domain=passport.com&passwd=";
-
- kdDebug( 14140 ) << k_funcinfo << "Download URL: " << authURL << "(*******)" << endl;
-
- m_authData = QString::null;
- m_kv=rx.cap(4);
- if(m_kv.isNull()) m_kv="";
-
- authURL += KURL::encode_string( m_password ) ;
- job = KIO::get( KURL( authURL ), false, false );
- job->addMetaData("cookies", "manual");
- job->addMetaData("setcookies", cookies);
- job->addMetaData("cache", "reload");
-
- QObject::connect( job, SIGNAL(data( KIO::Job *,const QByteArray&)), this, SLOT(slotAuthJobDataReceived( KIO::Job *,const QByteArray&)) );
- QObject::connect( job, SIGNAL(result( KIO::Job *)), this, SLOT(slotAuthJobDone( KIO::Job *)) );
- }
- else
- {
- if(m_authData.contains("CookiesDisabled"))
- {
- // FIXME: is this still possible now we add our meta data? - Martijn
- disconnect();
- KMessageBox::queuedMessageBox( Kopete::UI::Global::mainWidget(), KMessageBox::Error,
- i18n( "Unable to connect to the MSN Network.\nYour Web browser options are currently set to disable cookies.\n"
- "To use .NET Passport, you must enable cookies at least for the passport.com domain" ), i18n( "MSN Plugin" ) );
- return;
- }
-
- QRegExp rx(/*URL=http://memberservices.passport.net/memberservice.srf*/"\\?did=[0-9]*&(t=[0-9A-Za-z!$*]*&p=[0-9A-Za-z!$*]*)\"");
- rx.search(m_authData);
-
- m_badPassword=true; //if this disconnect, that mean the password was bad
- sendCommand("USR" , "TWN S " + rx.cap(1));
- }
+ m_badPassword = true;
+ disconnect();
}
+void MSNNotifySocket::sslLoginSucceeded(QString a)
+{
+ sendCommand("USR" , "TWN S " + a);
+ m_sslLoginHandler->deleteLater();
+ m_sslLoginHandler = 0;
+}
void MSNNotifySocket::slotOpenInbox()
{
Index: kdenetwork.spec
===================================================================
RCS file: /cvs/dist/rpms/kdenetwork/FC-3/kdenetwork.spec,v
retrieving revision 1.44
retrieving revision 1.45
diff -u -r1.44 -r1.45
--- kdenetwork.spec 15 Mar 2005 12:51:26 -0000 1.44
+++ kdenetwork.spec 4 Jul 2005 13:14:17 -0000 1.45
@@ -9,7 +9,7 @@
Name: kdenetwork
Version: 3.3.1
-Release: 3
+Release: 3.1
Summary: K Desktop Environment - Network Applications
Epoch: 7
Group: Applications/Internet
@@ -29,6 +29,7 @@
Patch4: kdenetwork-3.2.3-resolv.patch
Patch5: kdenetwork-3.3.0-ksirc.patch
Patch7: kdenetwork-3.3-cvs.patch
+Patch8: kdenetwork-3.3.1-kopete-msn-login.patch
Requires: kdelibs >= 6:%{version}
Requires: kdebase >= 6:%{version}
@@ -77,6 +78,7 @@
%patch4 -p1 -b .ppp
%patch5 -p1 -b .ksirc
%patch7 -p1 -b .cvs
+%patch8 -p1 -b .msn
find -name CVS | xargs rm -rf
@@ -318,6 +320,9 @@
%changelog
+* Mon Jul 04 2005 Than Ngo <than redhat com> 7:3.3.1-3.1
+- add backported patch to fix Kopete MSN login #161707
+
* Tue Mar 15 2005 Than Ngo <than redhat com> 7:3.3.1-3
- CVS backport includes fixes:
- Kopete fails to store passwords in kde wallet rh#145692
[Date Prev][Date Next] [Thread Prev][Thread Next]
[Thread Index]
[Date Index]
[Author Index]