summaryrefslogtreecommitdiffstats
path: root/kopete/protocols/oscar/liboscar
diff options
context:
space:
mode:
Diffstat (limited to 'kopete/protocols/oscar/liboscar')
-rw-r--r--kopete/protocols/oscar/liboscar/CMakeLists.txt2
-rw-r--r--kopete/protocols/oscar/liboscar/Makefile.am2
-rw-r--r--kopete/protocols/oscar/liboscar/aimlogintask.cpp254
-rw-r--r--kopete/protocols/oscar/liboscar/aimlogintask.h83
-rw-r--r--kopete/protocols/oscar/liboscar/buddyicontask.cpp42
-rw-r--r--kopete/protocols/oscar/liboscar/buddyicontask.h2
-rw-r--r--kopete/protocols/oscar/liboscar/changevisibilitytask.h2
-rw-r--r--kopete/protocols/oscar/liboscar/client.cpp81
-rw-r--r--kopete/protocols/oscar/liboscar/client.h22
-rw-r--r--kopete/protocols/oscar/liboscar/clientreadytask.cpp35
-rw-r--r--kopete/protocols/oscar/liboscar/connection.cpp5
-rw-r--r--kopete/protocols/oscar/liboscar/connection.h1
-rw-r--r--kopete/protocols/oscar/liboscar/logintask.cpp52
-rw-r--r--kopete/protocols/oscar/liboscar/logintask.h5
-rw-r--r--kopete/protocols/oscar/liboscar/oscartypes.h4
-rw-r--r--kopete/protocols/oscar/liboscar/profiletask.cpp40
-rw-r--r--kopete/protocols/oscar/liboscar/profiletask.h3
-rw-r--r--kopete/protocols/oscar/liboscar/sendmessagetask.cpp33
-rw-r--r--kopete/protocols/oscar/liboscar/serverversionstask.cpp21
-rw-r--r--kopete/protocols/oscar/liboscar/tests/logintest.cpp1
-rw-r--r--kopete/protocols/oscar/liboscar/tests/ssigrouptest.cpp1
-rw-r--r--kopete/protocols/oscar/liboscar/tests/userinfotest.cpp1
22 files changed, 57 insertions, 635 deletions
diff --git a/kopete/protocols/oscar/liboscar/CMakeLists.txt b/kopete/protocols/oscar/liboscar/CMakeLists.txt
index 6053541f..102ac0ff 100644
--- a/kopete/protocols/oscar/liboscar/CMakeLists.txt
+++ b/kopete/protocols/oscar/liboscar/CMakeLists.txt
@@ -27,7 +27,7 @@ tde_add_library( oscar STATIC_PIC AUTOMOC
inputprotocolbase.cpp coreprotocol.cpp flapprotocol.cpp
snacprotocol.cpp transfer.cpp rtf.cc bytestream.cpp
oscarclientstream.cpp safedelete.cpp stream.cpp oscarconnector.cpp
- oscarbytestream.cpp buffer.cpp md5.c logintask.cpp aimlogintask.cpp
+ oscarbytestream.cpp buffer.cpp md5.c logintask.cpp
icqlogintask.cpp closeconnectiontask.cpp rateclassmanager.cpp
serverversionstask.cpp rateinfotask.cpp errortask.cpp
locationrightstask.cpp profiletask.cpp blmlimitstask.cpp
diff --git a/kopete/protocols/oscar/liboscar/Makefile.am b/kopete/protocols/oscar/liboscar/Makefile.am
index ab0def67..2a235e83 100644
--- a/kopete/protocols/oscar/liboscar/Makefile.am
+++ b/kopete/protocols/oscar/liboscar/Makefile.am
@@ -8,7 +8,7 @@ AM_CPPFLAGS = -I$(top_srcdir)/kopete/libkopete $(all_includes)
liboscar_la_SOURCES = oscarutils.cpp client.cpp task.cpp connector.cpp \
inputprotocolbase.cpp coreprotocol.cpp flapprotocol.cpp snacprotocol.cpp transfer.cpp rtf.cc \
bytestream.cpp oscarclientstream.cpp safedelete.cpp stream.cpp oscarconnector.cpp \
- oscarbytestream.cpp buffer.cpp md5.c logintask.cpp aimlogintask.cpp icqlogintask.cpp \
+ oscarbytestream.cpp buffer.cpp md5.c logintask.cpp icqlogintask.cpp \
closeconnectiontask.cpp rateclassmanager.cpp serverversionstask.cpp rateinfotask.cpp \
errortask.cpp locationrightstask.cpp profiletask.cpp blmlimitstask.cpp \
servicesetuptask.cpp icbmparamstask.cpp ssimanager.cpp rateclass.cpp rateclass.h \
diff --git a/kopete/protocols/oscar/liboscar/aimlogintask.cpp b/kopete/protocols/oscar/liboscar/aimlogintask.cpp
deleted file mode 100644
index a371b0df..00000000
--- a/kopete/protocols/oscar/liboscar/aimlogintask.cpp
+++ /dev/null
@@ -1,254 +0,0 @@
-/*
- Kopete Oscar Protocol
- aimlogintask.h - Handles logging into to the AIM service
-
- Copyright (c) 2004 Matt Rogers <[email protected]>
-
- Kopete (c) 2002-2004 by the Kopete developers <[email protected]>
-
- *************************************************************************
- * *
- * This library is free software; you can redistribute it and/or *
- * modify it under the terms of the GNU Lesser General Public *
- * License as published by the Free Software Foundation; either *
- * version 2 of the License, or (at your option) any later version. *
- * *
- *************************************************************************
-*/
-#include "aimlogintask.h"
-
-#include <stdlib.h>
-#include <kdebug.h>
-#include <tdelocale.h>
-#include "connection.h"
-#include "oscartypes.h"
-#include "oscarutils.h"
-#include "transfer.h"
-
-#include "md5.h"
-
-using namespace Oscar;
-
-AimLoginTask::AimLoginTask( Task* parent )
- : Task ( parent )
-{
-}
-
-AimLoginTask::~AimLoginTask()
-{
-}
-
-void AimLoginTask::onGo()
-{
- //send Snac 17,06
- sendAuthStringRequest();
- //when we have the authKey, login
- connect( this, TQT_SIGNAL( haveAuthKey() ), this, TQT_SLOT( sendLoginRequest() ) );
-}
-
-bool AimLoginTask::forMe( Transfer* transfer ) const
-{
- SnacTransfer* st = dynamic_cast<SnacTransfer*>( transfer );
-
- if (!st)
- return false;
-
- if ( st && st->snacService() == 0x17 )
- {
- WORD subtype = st->snacSubtype();
- switch ( subtype )
- {
- case 0x0002:
- case 0x0003:
- case 0x0006:
- case 0x0007:
- return true;
- break;
- default:
- return false;
- break;
- }
- }
- return false;
-}
-
-const TQByteArray& AimLoginTask::cookie() const
-{
- return m_cookie;
-}
-
-const TQString& AimLoginTask::bosHost() const
-{
- return m_bosHost;
-}
-
-const TQString& AimLoginTask::bosPort() const
-{
- return m_bosPort;
-}
-
-bool AimLoginTask::take( Transfer* transfer )
-{
- if ( forMe( transfer ) )
- {
- SnacTransfer* st = dynamic_cast<SnacTransfer*>( transfer );
- if (!st)
- return false;
-
- WORD subtype = st->snacSubtype();
- switch ( subtype )
- {
- case 0x0003:
- setTransfer( transfer );
- handleLoginResponse();
- setTransfer( 0 );
- return true;
- break;
- case 0x0007:
- setTransfer( transfer );
- processAuthStringReply();
- setTransfer( 0 );
- return true;
- break;
- default:
- return false;
- break;
- }
-
- return false;
- }
- return false;
-}
-
-void AimLoginTask::sendAuthStringRequest()
-{
- kdDebug(OSCAR_RAW_DEBUG) << k_funcinfo
- << "SEND CLI_AUTH_REQUEST, sending login request" << endl;
-
- FLAP f = { 0x02, 0, 0 };
- SNAC s = { 0x0017, 0x0006, 0x0000, client()->snacSequence() };
-
- Buffer* outbuf = new Buffer;
- outbuf->addTLV(0x0001, client()->userId().length(), client()->userId().latin1() );
- outbuf->addDWord(0x004B0000); // empty TLV 0x004B
- outbuf->addDWord(0x005A0000); // empty TLV 0x005A
-
- Transfer* st = createTransfer( f, s, outbuf );
- send( st );
-}
-
-void AimLoginTask::processAuthStringReply()
-{
- kdDebug(OSCAR_RAW_DEBUG) << k_funcinfo << "Got the authorization key" << endl;
- Buffer *inbuf = transfer()->buffer();
- WORD keylen = inbuf->getWord();
- kdDebug(OSCAR_RAW_DEBUG) << k_funcinfo << "Key length is " << keylen << endl;
- m_authKey.duplicate( inbuf->getBlock(keylen) );
- emit haveAuthKey();
-}
-
-void AimLoginTask::sendLoginRequest()
-{
- kdDebug(OSCAR_RAW_DEBUG) << k_funcinfo << "SEND (CLI_MD5_LOGIN) sending AIM login" << endl;
-
- FLAP f = { 0x02, 0, 0 };
- SNAC s = { 0x0017, 0x0002, 0x0000, client()->snacSequence() };
- Buffer *outbuf = new Buffer;
- const Oscar::ClientVersion* version = client()->version();
-
- outbuf->addTLV(0x0001, client()->userId().length(), client()->userId().latin1());
-
- TQByteArray digest( 17 ); //apparently MD5 digests are 16 bytes long
- encodePassword( digest );
- digest[16] = '\0'; //do this so that addTLV sees a NULL-terminator
-
- outbuf->addTLV(0x0025, 16, digest);
- outbuf->addTLV(0x0003, version->clientString.length(), version->clientString.latin1() );
- outbuf->addTLV16(0x0016, version->clientId );
- outbuf->addTLV16(0x0017, version->major );
- outbuf->addTLV16(0x0018, version->minor );
- outbuf->addTLV16(0x0019, version->point );
- outbuf->addTLV16(0x001a, version->build );
- outbuf->addDWord(0x00140004); //TLV type 0x0014, length 0x0004
- outbuf->addDWord( version->other ); //TLV data for type 0x0014
- outbuf->addTLV(0x000f, version->lang.length(), version->lang.latin1() );
- outbuf->addTLV(0x000e, version->country.length(), version->country.latin1() );
-
- //if set, old-style buddy lists will not work... you will need to use SSI
- outbuf->addTLV8(0x004a,0x01);
-
- Transfer *st = createTransfer( f, s, outbuf );
- send( st );
-}
-
-void AimLoginTask::handleLoginResponse()
-{
- kdDebug(OSCAR_RAW_DEBUG) << k_funcinfo << "RECV SNAC 0x17, 0x07 - AIM Login Response" << endl;
-
- SnacTransfer* st = dynamic_cast<SnacTransfer*> ( transfer() );
-
- if ( !st )
- {
- setError( -1 , TQString() );
- return;
- }
-
- TQValueList<TLV> tlvList = st->buffer()->getTLVList();
-
- TLV uin = findTLV( tlvList, 0x0001 );
- if ( uin )
- {
- kdDebug(OSCAR_RAW_DEBUG) << k_funcinfo << "found TLV(1) [SN], SN=" << TQString( uin.data ) << endl;
- }
-
- TLV err = findTLV( tlvList, 0x0008 );
-
- if ( err )
- {
- WORD errorNum = ( ( err.data[0] << 8 ) | err.data[1] );
-
- kdDebug(OSCAR_RAW_DEBUG) << k_funcinfo << k_funcinfo << "found TLV(8) [ERROR] error= " <<
- errorNum << endl;
- Oscar::SNAC s = { 0, 0, 0, 0 };
- client()->fatalTaskError( s, errorNum );
- setError( errorNum, TQString() );
- return; //if there's an error, we'll need to disconnect anyways
- }
-
- TLV server = findTLV( tlvList, 0x0005 );
- if ( server )
- {
- TQString ip = TQString( server.data );
- kdDebug(OSCAR_RAW_DEBUG) << k_funcinfo << "found TLV(5) [SERVER] " << ip << endl;
- int index = ip.find( ':' );
- m_bosHost = ip.left( index );
- ip.remove( 0 , index+1 ); //get rid of the colon and everything before it
- m_bosPort = ip.left(4); //we only need 4 bytes
- kdDebug(OSCAR_RAW_DEBUG) << k_funcinfo << "We should reconnect to server '" << m_bosHost <<
- "' on port " << m_bosPort << endl;
- }
-
- TLV cookie = findTLV( tlvList, 0x0006 );
- if ( cookie )
- {
- kdDebug(OSCAR_RAW_DEBUG) << k_funcinfo << "found TLV(6) [COOKIE]" << endl;
- m_cookie.duplicate( cookie.data );
- setSuccess( 0, TQString() );
- }
- tlvList.clear();
-}
-
-void AimLoginTask::encodePassword( TQByteArray& digest ) const
-{
- kdDebug(OSCAR_RAW_DEBUG) << k_funcinfo << endl;
- md5_state_t state;
- md5_init( &state );
- md5_append( &state, ( const md5_byte_t* ) m_authKey.data(), m_authKey.size() );
- md5_append( &state, ( const md5_byte_t* ) client()->password().latin1(), client()->password().length() );
- md5_append( &state, ( const md5_byte_t* ) AIM_MD5_STRING, strlen( AIM_MD5_STRING ) );
- md5_finish( &state, ( md5_byte_t* ) digest.data() );
-}
-
-//kate: indent-mode csands; tab-width 4;
-
-#include "aimlogintask.moc"
diff --git a/kopete/protocols/oscar/liboscar/aimlogintask.h b/kopete/protocols/oscar/liboscar/aimlogintask.h
deleted file mode 100644
index 82850a47..00000000
--- a/kopete/protocols/oscar/liboscar/aimlogintask.h
+++ /dev/null
@@ -1,83 +0,0 @@
-/*
- Kopete Oscar Protocol
- aimlogintask.h - Handles logging into to the AIM service
-
- Copyright (c) 2004 Matt Rogers <[email protected]>
-
- Kopete (c) 2002-2004 by the Kopete developers <[email protected]>
-
- *************************************************************************
- * *
- * This library is free software; you can redistribute it and/or *
- * modify it under the terms of the GNU Lesser General Public *
- * License as published by the Free Software Foundation; either *
- * version 2 of the License, or (at your option) any later version. *
- * *
- *************************************************************************
-*/
-
-#ifndef _OSCAR_AIMLOGINTASK_H_
-#define _OSCAR_AIMLOGINTASK_H_
-
-#include "task.h"
-
-using namespace Oscar;
-
-class AimLoginTask : public Task
-{
-Q_OBJECT
-
-public:
- AimLoginTask( Task* parent );
- ~AimLoginTask();
- bool take( Transfer* transfer );
- virtual void onGo();
-
- //Protocol specific stuff
- const TQByteArray& cookie() const;
- const TQString& bosHost() const;
- const TQString& bosPort() const;
-
-protected:
- bool forMe( Transfer* transfer ) const;
-
-signals:
- void haveAuthKey();
-
-private:
- //! Encodes a password using MD5
- void encodePassword( TQByteArray& digest ) const;
-
- //! Send SNAC 0x17, 0x06
- void sendAuthStringRequest();
-
- //! Handle SNAC 0x17, 0x07
- void processAuthStringReply();
-
- //! Handle SNAC 0x17, 0x03
- void handleLoginResponse();
-
- //! Parse the error codes to generate a reason why sign-on failed
- //Massive code duplication with CloseConnectionTask
- bool parseDisconnectCode( int error, TQString& reason );
-
-private slots:
- //! Send SNAC 0x17, 0x02
- void sendLoginRequest();
-
-private:
- //! The authorization key to use when encoding the password
- TQByteArray m_authKey;
-
- //! The all important connection cookie
- TQByteArray m_cookie;
-
- //! The new BOS Host
- TQString m_bosHost;
-
- //! The new BOS Port
- TQString m_bosPort;
-
-};
-
-#endif
diff --git a/kopete/protocols/oscar/liboscar/buddyicontask.cpp b/kopete/protocols/oscar/liboscar/buddyicontask.cpp
index c7661481..43e3e792 100644
--- a/kopete/protocols/oscar/liboscar/buddyicontask.cpp
+++ b/kopete/protocols/oscar/liboscar/buddyicontask.cpp
@@ -69,10 +69,7 @@ void BuddyIconTask::onGo()
if ( m_action == Receive )
{
- if ( client()->isIcq() )
- sendICQBuddyIconRequest();
- else
- sendAIMBuddyIconRequest();
+ sendICQBuddyIconRequest();
}
else
sendIcon();
@@ -120,8 +117,6 @@ bool BuddyIconTask::take( Transfer* transfer )
setTransfer( transfer );
if ( st->snacSubtype() == 0x0003 )
handleUploadResponse();
- else if ( st->snacSubtype() == 0x0005 )
- handleAIMBuddyIconResponse();
else
handleICQBuddyIconResponse();
@@ -157,41 +152,6 @@ void BuddyIconTask::handleUploadResponse()
}
-void BuddyIconTask::sendAIMBuddyIconRequest()
-{
- kdDebug(OSCAR_RAW_DEBUG) << k_funcinfo << "requesting buddy icon for " << m_user << endl;
- FLAP f = { 0x02, 0, 0 };
- m_seq = client()->snacSequence();
- SNAC s = { 0x0010, 0x0004, 0x0000, m_seq };
- Buffer* b = new Buffer;
-
- b->addBUIN( m_user.latin1() ); //TODO: check encoding
- b->addByte( 0x01 );
- b->addWord( 0x0001 );
- b->addByte( m_hashType );
- b->addByte( m_hash.size() ); //MD5 Hash Size
- b->addString( m_hash, m_hash.size() ); //MD5 Hash
- Transfer* t = createTransfer( f, s, b );
- send( t );
-}
-
-void BuddyIconTask::handleAIMBuddyIconResponse()
-{
- Buffer* b = transfer()->buffer();
- TQString user = b->getBUIN();
- kdDebug(OSCAR_RAW_DEBUG) << k_funcinfo << "Receiving buddy icon for " << user << endl;
- b->skipBytes(2); //unknown field. not used
- BYTE iconType = b->getByte();
- Q_UNUSED( iconType );
- BYTE hashSize = b->getByte();
- TQByteArray iconHash;
- iconHash.duplicate( b->getBlock(hashSize) );
- WORD iconSize = b->getWord();
- TQByteArray icon;
- icon.duplicate( b->getBlock(iconSize) );
- emit haveIcon( user, icon );
-}
-
void BuddyIconTask::sendICQBuddyIconRequest()
{
kdDebug(OSCAR_RAW_DEBUG) << k_funcinfo << "requesting buddy icon for " << m_user << endl;
diff --git a/kopete/protocols/oscar/liboscar/buddyicontask.h b/kopete/protocols/oscar/liboscar/buddyicontask.h
index c3b7c4f9..1a18aa45 100644
--- a/kopete/protocols/oscar/liboscar/buddyicontask.h
+++ b/kopete/protocols/oscar/liboscar/buddyicontask.h
@@ -50,8 +50,6 @@ signals:
private:
void sendIcon();
void handleUploadResponse();
- void sendAIMBuddyIconRequest();
- void handleAIMBuddyIconResponse();
void sendICQBuddyIconRequest();
void handleICQBuddyIconResponse();
diff --git a/kopete/protocols/oscar/liboscar/changevisibilitytask.h b/kopete/protocols/oscar/liboscar/changevisibilitytask.h
index 0ec5ab04..554645f4 100644
--- a/kopete/protocols/oscar/liboscar/changevisibilitytask.h
+++ b/kopete/protocols/oscar/liboscar/changevisibilitytask.h
@@ -24,7 +24,7 @@
/**
* This class provides a way to change how the account user
* appears on everybody else's contact list. It is used to
- * implement the invisible online status in ICQ and AIM
+ * implement the invisible online status in ICQ
* @author Matt Rogers
*/
class ChangeVisibilityTask : public Task
diff --git a/kopete/protocols/oscar/liboscar/client.cpp b/kopete/protocols/oscar/liboscar/client.cpp
index fe24fdb3..2bae2155 100644
--- a/kopete/protocols/oscar/liboscar/client.cpp
+++ b/kopete/protocols/oscar/liboscar/client.cpp
@@ -93,7 +93,6 @@ public:
int stage;
//Protocol specific data
- bool isIcq;
bool redirectRequested;
TQValueList<WORD> redirectionServices;
WORD currentRedirect;
@@ -146,9 +145,8 @@ Client::Client( TQObject* parent )
d = new ClientPrivate;
d->tzoffset = 0;
d->active = false;
- d->isIcq = false; //default to AIM
d->redirectRequested = false;
- d->currentRedirect = 0;
+ d->currentRedirect = 0;
d->connectAsStatus = 0x0; // default to online
d->ssiManager = new SSIManager( this );
d->settings = new Oscar::Settings();
@@ -233,30 +231,6 @@ void Client::close()
d->ssiManager->clear();
}
-void Client::setStatus( AIMStatus status, const TQString &_message )
-{
- // AIM: you're away exactly when your away message isn't empty.
- // can't use TQString() as a message either; ProfileTask
- // interprets null as "don't change".
- TQString message;
- if ( status == Online )
- message = TQString::fromAscii("");
- else
- {
- if ( _message.isEmpty() )
- message = TQString::fromAscii(" ");
- else
- message = _message;
- }
-
- Connection* c = d->connections.connectionForFamily( 0x0002 );
- if ( !c )
- return;
- ProfileTask* pt = new ProfileTask( c->rootTask() );
- pt->setAwayMessage( message );
- pt->go( true );
-}
-
void Client::setStatus( DWORD status, const TQString &message )
{
// remember the message to reply with, when requested
@@ -398,24 +372,21 @@ void Client::serviceSetupFinished()
{
d->active = true;
- if ( isIcq() )
- setStatus( d->connectAsStatus, d->connectWithMessage );
+ setStatus( d->connectAsStatus, d->connectWithMessage );
d->ownStatusTask->go();
- if ( isIcq() )
- {
- //retrieve offline messages
- Connection* c = d->connections.connectionForFamily( 0x0015 );
- if ( !c )
- return;
-
- OfflineMessagesTask *offlineMsgTask = new OfflineMessagesTask( c->rootTask() );
- connect( offlineMsgTask, TQT_SIGNAL( receivedOfflineMessage(const Oscar::Message& ) ),
- this, TQT_SIGNAL( messageReceived(const Oscar::Message& ) ) );
- offlineMsgTask->go( true );
+ //retrieve offline messages
+ Connection* c = d->connections.connectionForFamily( 0x0015 );
+ if ( !c ) {
+ return;
}
+ OfflineMessagesTask *offlineMsgTask = new OfflineMessagesTask( c->rootTask() );
+ connect( offlineMsgTask, TQT_SIGNAL( receivedOfflineMessage(const Oscar::Message& ) ),
+ this, TQT_SIGNAL( messageReceived(const Oscar::Message& ) ) );
+ offlineMsgTask->go( true );
+
emit haveSSIList();
emit loggedIn();
}
@@ -595,16 +566,6 @@ bool Client::isActive() const
return d->active;
}
-bool Client::isIcq() const
-{
- return d->isIcq;
-}
-
-void Client::setIsIcq( bool isIcq )
-{
- d->isIcq = isIcq;
-}
-
void Client::debug( const TQString& str )
{
Q_UNUSED(str);
@@ -852,16 +813,6 @@ void Client::setChatExchangeList( const TQValueList<int>& exchanges )
d->exchanges = exchanges;
}
-void Client::requestAIMProfile( const TQString& contact )
-{
- d->userInfoTask->requestInfoFor( contact, UserInfoTask::Profile );
-}
-
-void Client::requestAIMAwayMessage( const TQString& contact )
-{
- d->userInfoTask->requestInfoFor( contact, UserInfoTask::AwayMessage );
-}
-
void Client::requestICQAwayMessage( const TQString& contact, ICQStatus contactStatus )
{
kdDebug(OSCAR_RAW_DEBUG) << k_funcinfo << "requesting away message for " << contact << endl;
@@ -993,16 +944,6 @@ void Client::uinSearch( const TQString& uin )
ust->searchUserByUIN( uin );
}
-void Client::updateProfile( const TQString& profile )
-{
- Connection* c = d->connections.connectionForFamily( 0x0002 );
- if ( !c )
- return;
- ProfileTask* pt = new ProfileTask( c->rootTask() );
- pt->setProfileText( profile );
- pt->go(true);
-}
-
void Client::sendTyping( const TQString & contact, bool typing )
{
Connection* c = d->connections.connectionForFamily( 0x0004 );
diff --git a/kopete/protocols/oscar/liboscar/client.h b/kopete/protocols/oscar/liboscar/client.h
index 71cf668a..f71a8333 100644
--- a/kopete/protocols/oscar/liboscar/client.h
+++ b/kopete/protocols/oscar/liboscar/client.h
@@ -68,7 +68,6 @@ public:
FatalProtocolError = 3
};
- enum AIMStatus { Online = 0, Away };
enum ICQStatus { ICQOnline = 0, ICQAway, ICQNotAvailable, ICQOccupied, ICQDoNotDisturb, ICQFreeForChat };
/*************
@@ -102,8 +101,6 @@ public:
/** Logout and disconnect */
void close();
- /** Set our status for AIM */
- void setStatus( AIMStatus status, const TQString &message = TQString() );
/** Set our status for ICQ */
void setStatus( DWORD status, const TQString &message = TQString() );
@@ -241,18 +238,6 @@ public:
TQValueList<int> chatExchangeList() const;
/**
- * Request the aim profile
- * \param contact the contact to get info for
- */
- void requestAIMProfile( const TQString& contact );
-
- /**
- * Request the aim away message
- * \param contact the contact to get info for
- */
- void requestAIMAwayMessage( const TQString& contact );
-
- /**
* Add the icq away message request to queue
* \param contact the contact to get info for
*/
@@ -273,9 +258,6 @@ public:
//! Run a UIN search
void uinSearch( const TQString& uin );
- //! Update the user's AIM profile
- void updateProfile( const TQString& profile );
-
//! Get buddy icon information for a person
void requestBuddyIcon( const TQString& user, const TQByteArray& hash, BYTE hashType );
@@ -344,10 +326,6 @@ public:
/** Change the current status message w/o changing status */
void setStatusMessage( const TQString &message );
- /** ICQ Settings */
- bool isIcq() const;
- void setIsIcq( bool isIcq );
-
/** Host's IP address */
TQCString ipAddress() const;
diff --git a/kopete/protocols/oscar/liboscar/clientreadytask.cpp b/kopete/protocols/oscar/liboscar/clientreadytask.cpp
index 3025a0d8..6d1b07a7 100644
--- a/kopete/protocols/oscar/liboscar/clientreadytask.cpp
+++ b/kopete/protocols/oscar/liboscar/clientreadytask.cpp
@@ -64,38 +64,21 @@ void ClientReadyTask::onGo()
buffer->addWord( 0x0003 );
break;
case 0x0013:
- buffer->addWord( client()->isIcq() ? 0x0002 : 0x0003 );
+ buffer->addWord( 0x0002 );
break;
default:
buffer->addWord( 0x0001 );
};
-
- if ( client()->isIcq() )
- {
- if ( i == 0x0002 )
- buffer->addWord( 0x0101 );
- else
- buffer->addWord( 0x0110 );
-
- //always add 0x047B
- buffer->addWord( 0x047B );
+
+ if ( i == 0x0002 ) {
+ buffer->addWord( 0x0101 );
}
- else //we're AIM so AOL has us do something completely different! *sigh*
- {
- switch( i )
- {
- case 0x0008:
- case 0x000B:
- case 0x000C:
- buffer->addWord( 0x0104 );
- buffer->addWord( 0x0001 );
- break;
- default:
- buffer->addWord( 0x0110 );
- buffer->addWord( 0x059B );
- break;
- };
+ else {
+ buffer->addWord( 0x0110 );
}
+
+ //always add 0x047B
+ buffer->addWord( 0x047B );
}
//send the damn thing so we can finally be finished
diff --git a/kopete/protocols/oscar/liboscar/connection.cpp b/kopete/protocols/oscar/liboscar/connection.cpp
index 16757785..dc66aefa 100644
--- a/kopete/protocols/oscar/liboscar/connection.cpp
+++ b/kopete/protocols/oscar/liboscar/connection.cpp
@@ -154,11 +154,6 @@ TQString Connection::password() const
return d->client->password();
}
-bool Connection::isIcq() const
-{
- return d->client->isIcq();
-}
-
Task* Connection::rootTask() const
{
return d->root;
diff --git a/kopete/protocols/oscar/liboscar/connection.h b/kopete/protocols/oscar/liboscar/connection.h
index 9a3cd861..962c84c1 100644
--- a/kopete/protocols/oscar/liboscar/connection.h
+++ b/kopete/protocols/oscar/liboscar/connection.h
@@ -143,7 +143,6 @@ public:
TQString userId() const;
TQString password() const;
- bool isIcq() const;
SSIManager* ssiManager() const;
const Oscar::ClientVersion* version() const;
RateClassManager* rateManager() const;
diff --git a/kopete/protocols/oscar/liboscar/logintask.cpp b/kopete/protocols/oscar/liboscar/logintask.cpp
index 73379e40..c3d568f9 100644
--- a/kopete/protocols/oscar/liboscar/logintask.cpp
+++ b/kopete/protocols/oscar/liboscar/logintask.cpp
@@ -1,6 +1,6 @@
/*
Kopete Oscar Protocol
- logintask.cpp - Handles logging into to the AIM or ICQ service
+ logintask.cpp - Handles logging into to the ICQ service
Copyright (c) 2004 Matt Rogers <[email protected]>
@@ -22,7 +22,6 @@
#include <kdebug.h>
#include <tdelocale.h>
-#include "aimlogintask.h"
#include "connection.h"
#include "closeconnectiontask.h"
#include "icqlogintask.h"
@@ -40,49 +39,26 @@
StageOneLoginTask::StageOneLoginTask( Task* parent )
: Task ( parent )
{
- m_aimTask = 0L;
m_icqTask = 0L;
m_closeTask = 0L;
}
StageOneLoginTask::~StageOneLoginTask()
{
- delete m_aimTask;
delete m_icqTask;
delete m_closeTask;
}
bool StageOneLoginTask::take( Transfer* transfer )
{
- if ( forMe( transfer ) )
- {
- if ( client()->isIcq() )
- {
- kdDebug(OSCAR_RAW_DEBUG) << k_funcinfo << "Starting ICQ login" << endl;
- m_icqTask = new IcqLoginTask( client()->rootTask() );
- m_closeTask = new CloseConnectionTask( client()->rootTask() );
-
- //connect finished signal
- connect( m_closeTask, TQT_SIGNAL( finished() ), this, TQT_SLOT( closeTaskFinished() ) );
- m_icqTask->go( true );
- }
- else
- {
- kdDebug(OSCAR_RAW_DEBUG) << k_funcinfo << "Starting AIM login" << endl;
- kdDebug(OSCAR_RAW_DEBUG) << k_funcinfo << "Sending the FLAP version back" << endl;
-
- //send the flap version response
- FLAP f = { 0x01, 0 , 0 };
- Buffer *outbuf = new Buffer;
- outbuf->addDWord(0x00000001); //flap version
- f.length = outbuf->length();
- Transfer* ft = createTransfer( f, outbuf );
- send( ft );
-
- m_aimTask = new AimLoginTask( client()->rootTask() );
- connect( m_aimTask, TQT_SIGNAL( finished() ), this, TQT_SLOT( aimTaskFinished() ) );
- m_aimTask->go( true );
- }
+ if ( forMe( transfer ) ) {
+ kdDebug(OSCAR_RAW_DEBUG) << k_funcinfo << "Starting ICQ login" << endl;
+ m_icqTask = new IcqLoginTask( client()->rootTask() );
+ m_closeTask = new CloseConnectionTask( client()->rootTask() );
+
+ //connect finished signal
+ connect( m_closeTask, TQT_SIGNAL( finished() ), this, TQT_SLOT( closeTaskFinished() ) );
+ m_icqTask->go( true );
return true;
}
return false;
@@ -98,16 +74,6 @@ void StageOneLoginTask::closeTaskFinished()
setSuccess( m_closeTask->statusCode(), m_closeTask->statusString() );
}
-void StageOneLoginTask::aimTaskFinished()
-{
- kdDebug(OSCAR_RAW_DEBUG) << k_funcinfo << endl;
- m_cookie = m_aimTask->cookie();
- m_bosPort = m_aimTask->bosPort();
- m_bosServer = m_aimTask->bosHost();
-
- setSuccess( m_aimTask->statusCode(), m_aimTask->statusString() );
-}
-
bool StageOneLoginTask::forMe( Transfer* transfer ) const
{
FlapTransfer* ft = dynamic_cast<FlapTransfer*> ( transfer );
diff --git a/kopete/protocols/oscar/liboscar/logintask.h b/kopete/protocols/oscar/liboscar/logintask.h
index 3e1a21c5..626de7bb 100644
--- a/kopete/protocols/oscar/liboscar/logintask.h
+++ b/kopete/protocols/oscar/liboscar/logintask.h
@@ -1,6 +1,6 @@
/*
Kopete Oscar Protocol
- logintask.h - Handles logging into to the AIM or ICQ service
+ logintask.h - Handles logging into to the ICQ service
Copyright (c) 2004 Matt Rogers <[email protected]>
@@ -23,7 +23,6 @@
#include "oscartypes.h"
#include "task.h"
-#include "aimlogintask.h"
#include "icqlogintask.h"
#include "closeconnectiontask.h"
@@ -70,7 +69,6 @@ public:
public slots:
void closeTaskFinished();
- void aimTaskFinished();
protected:
bool forMe( Transfer* transfer ) const;
@@ -78,7 +76,6 @@ protected:
private:
//Tasks we want to control
- AimLoginTask* m_aimTask;
IcqLoginTask* m_icqTask;
CloseConnectionTask* m_closeTask;
diff --git a/kopete/protocols/oscar/liboscar/oscartypes.h b/kopete/protocols/oscar/liboscar/oscartypes.h
index 4e13a509..ffe76c30 100644
--- a/kopete/protocols/oscar/liboscar/oscartypes.h
+++ b/kopete/protocols/oscar/liboscar/oscartypes.h
@@ -27,7 +27,6 @@
//! Debug Areas
const int OSCAR_RAW_DEBUG = 14151;
const int OSCAR_GEN_DEBUG = 14150;
-const int OSCAR_AIM_DEBUG = 14152;
const int OSCAR_ICQ_DEBUG = 14153;
namespace Oscar
@@ -248,9 +247,6 @@ struct ClientVersion
/* ICQ Version Characteristics */
const unsigned char ICQ_TCP_VERSION = 0x0008;
- /* AIM Version Characteristics */
- const char AIM_MD5_STRING[] = "AOL Instant Messenger (SM)";
-
/* SSI types */
const WORD ROSTER_CONTACT = 0x0000; // a normal contact
const WORD ROSTER_GROUP = 0x0001; // a group of contacts
diff --git a/kopete/protocols/oscar/liboscar/profiletask.cpp b/kopete/protocols/oscar/liboscar/profiletask.cpp
index 1544a5b4..4b2122a0 100644
--- a/kopete/protocols/oscar/liboscar/profiletask.cpp
+++ b/kopete/protocols/oscar/liboscar/profiletask.cpp
@@ -74,39 +74,13 @@ void ProfileTask::sendProfileUpdate()
Buffer *buffer = new Buffer();
Buffer capBuf;
- if ( !m_profileText.isNull() && !client()->isIcq() )
- {
- static const TQString defencoding = "text/aolrtf; charset=\"us-ascii\"";
- buffer->addTLV(0x0001, defencoding.length(), defencoding.latin1());
- buffer->addTLV(0x0002, m_profileText.length(), m_profileText.local8Bit());
- kdDebug(OSCAR_RAW_DEBUG) << k_funcinfo << "setting profile = " << m_profileText << endl;
- }
-
- if ( !m_awayMessage.isNull() && !client()->isIcq() )
- {
- static const TQString defencoding = "text/aolrtf; charset=\"us-ascii\"";
- buffer->addTLV(0x0003, defencoding.length(), defencoding.latin1());
- buffer->addTLV(0x0004, m_awayMessage.length(), m_awayMessage.local8Bit());
- kdDebug(OSCAR_RAW_DEBUG) << k_funcinfo << "setting away message = " << m_awayMessage << endl;
- }
-
- if ( client()->isIcq() )
- {
- capBuf.addString( oscar_caps[CAP_ICQSERVERRELAY], 16 ); // we support type-2 messages
- capBuf.addString( oscar_caps[CAP_UTF8], 16 ); // we can send/receive UTF encoded messages
- capBuf.addString( oscar_caps[CAP_ISICQ], 16 ); // I think this is an icq client, but maybe I'm wrong
- capBuf.addString( oscar_caps[CAP_KOPETE], 16 ); // we are the borg, resistance is futile
- //capBuf.addString( oscar_caps[CAP_RTFMSGS], 16 ); // we do incoming RTF messages
- capBuf.addString( oscar_caps[CAP_TYPING], 16 ); // we know you're typing something to us!
- capBuf.addString( oscar_caps[CAP_BUDDYICON], 16 ); //can you take my picture?
- }
- else
- {
- capBuf.addString( oscar_caps[CAP_UTF8], 16 ); //we can send/receive UTF encoded messages
- capBuf.addString( oscar_caps[CAP_KOPETE], 16 ); // we are the borg, resistance is futile
- capBuf.addString( oscar_caps[CAP_TYPING], 16 ); // we know you're typing something to us!
- capBuf.addString( oscar_caps[CAP_BUDDYICON], 16 ); //can you take my picture?
- }
+ capBuf.addString( oscar_caps[CAP_ICQSERVERRELAY], 16 ); // we support type-2 messages
+ capBuf.addString( oscar_caps[CAP_UTF8], 16 ); // we can send/receive UTF encoded messages
+ capBuf.addString( oscar_caps[CAP_ISICQ], 16 ); // I think this is an icq client, but maybe I'm wrong
+ capBuf.addString( oscar_caps[CAP_KOPETE], 16 ); // we are the borg, resistance is futile
+ //capBuf.addString( oscar_caps[CAP_RTFMSGS], 16 ); // we do incoming RTF messages
+ capBuf.addString( oscar_caps[CAP_TYPING], 16 ); // we know you're typing something to us!
+ capBuf.addString( oscar_caps[CAP_BUDDYICON], 16 ); //can you take my picture?
//kdDebug(OSCAR_RAW_DEBUG) << k_funcinfo << "adding capabilities, size=" << capBuf.length() << endl;
buffer->addTLV(0x0005, capBuf.length(), capBuf.buffer());
diff --git a/kopete/protocols/oscar/liboscar/profiletask.h b/kopete/protocols/oscar/liboscar/profiletask.h
index a51075a5..69d1119e 100644
--- a/kopete/protocols/oscar/liboscar/profiletask.h
+++ b/kopete/protocols/oscar/liboscar/profiletask.h
@@ -21,8 +21,7 @@
#include "task.h"
/**
-Task that sets the profile and away message on the server (AIM only).
-Also takes care of updating the capabilities supported by the client (AIM and ICQ).
+Also takes care of updating the capabilities supported by the client (ICQ).
The profile will be updated only if the profile text has been set non-null.
The away message will be set only if the away message has been set non-null.
diff --git a/kopete/protocols/oscar/liboscar/sendmessagetask.cpp b/kopete/protocols/oscar/liboscar/sendmessagetask.cpp
index 5f4146e3..af180be1 100644
--- a/kopete/protocols/oscar/liboscar/sendmessagetask.cpp
+++ b/kopete/protocols/oscar/liboscar/sendmessagetask.cpp
@@ -98,22 +98,11 @@ void SendMessageTask::onGo()
break;
}
- // Add the TLV to indicate if this is an autoresponse: 0x00040000
- // Right now, only supported for the AIM client, I'm not sure about ICQ
- // For some reason you can't have both a 0x0004 and 0x0003 TLV in the same
- // SNAC, if you do the AIM server complains
- if ( !client()->isIcq() && (m_autoResponse == true) )
- {
- TLV tlv4( 0x0004, 0, NULL);
- b->addTLV( tlv4 );
- }
- else
- {
- b->addDWord( 0x00030000 ); //empty TLV 3 to get an ack from the server
- }
+ b->addDWord( 0x00030000 ); //empty TLV 3 to get an ack from the server
- if ( client()->isIcq() && m_message.type() != 2 && ! m_message.hasProperty( Oscar::Message::StatusMessageRequest ) )
+ if ( m_message.type() != 2 && ! m_message.hasProperty( Oscar::Message::StatusMessageRequest ) ) {
b->addDWord( 0x00060000 ); //empty TLV 6 to store message on the server if not online
+ }
}
else
{
@@ -141,18 +130,10 @@ void SendMessageTask::addChannel1Data( Buffer* b )
{
Buffer tlv2buffer;
- //Send features TLV using data from pidgin. Features are different
- //depending on whether we're ICQ or AIM
- if ( client()->isIcq() )
- {
- tlv2buffer.addDWord( 0x05010002 ); //TLV 0x0501, length 2
- tlv2buffer.addWord( 0x0106 ); //TLV 0x0501 data
- }
- else
- {
- tlv2buffer.addDWord( 0x05010004 ); //TLV 0x0501, length 4
- tlv2buffer.addDWord( 0x01010102 ); //TLV 0x0501 data.
- }
+ //Send features TLV using data from pidgin.
+ tlv2buffer.addDWord( 0x05010002 ); //TLV 0x0501, length 2
+ tlv2buffer.addWord( 0x0106 ); //TLV 0x0501 data
+
//we only send one message part. There's only one client that actually uses
//them and it's quite old and infrequently used
tlv2buffer.addWord( 0x0101 ); //add TLV(0x0101) also known as TLV(257)
diff --git a/kopete/protocols/oscar/liboscar/serverversionstask.cpp b/kopete/protocols/oscar/liboscar/serverversionstask.cpp
index 336f3b02..7d001ec3 100644
--- a/kopete/protocols/oscar/liboscar/serverversionstask.cpp
+++ b/kopete/protocols/oscar/liboscar/serverversionstask.cpp
@@ -115,7 +115,6 @@ void ServerVersionsTask::handleFamilies()
void ServerVersionsTask::requestFamilyVersions()
{
- bool isIcq = client()->isIcq();
int listLength = m_familiesList.count();
FLAP f = { 0x02, 0, 0 };
@@ -125,22 +124,18 @@ void ServerVersionsTask::requestFamilyVersions()
kdDebug(OSCAR_RAW_DEBUG) << k_funcinfo << "SEND SNAC 0x01, 0x17 - Snac family versions we want" << endl;
- for ( int i = 0; i < listLength; i++ )
- {
+ for ( int i = 0; i < listLength; i++ ) {
outbuf->addWord( m_familiesList[i] );
- if ( m_familiesList[i] == 0x0001 )
+ if ( m_familiesList[i] == 0x0001 ) {
val = 0x0003;
- else
- {
- if ( m_familiesList[i] == 0x0013 )
- {
- if ( isIcq )
- val = 0x0004; // for ICQ2002
- else
- val = 0x0003;
+ }
+ else {
+ if ( m_familiesList[i] == 0x0013 ) {
+ val = 0x0004; // for ICQ2002
}
- else
+ else {
val = 0x0001;
+ }
}
outbuf->addWord(val);
diff --git a/kopete/protocols/oscar/liboscar/tests/logintest.cpp b/kopete/protocols/oscar/liboscar/tests/logintest.cpp
index d1025059..e344c3e1 100644
--- a/kopete/protocols/oscar/liboscar/tests/logintest.cpp
+++ b/kopete/protocols/oscar/liboscar/tests/logintest.cpp
@@ -33,7 +33,6 @@ void LoginTest::slotDoTest()
// connect to server
tqDebug( "connecting to server ");
- myClient->setIsIcq( true );
myClient->start( server, 5190, "userid", "password" );
myClient->connectToServer( myConnection, server, true );
connected = true;
diff --git a/kopete/protocols/oscar/liboscar/tests/ssigrouptest.cpp b/kopete/protocols/oscar/liboscar/tests/ssigrouptest.cpp
index 410b6021..2f646ecf 100644
--- a/kopete/protocols/oscar/liboscar/tests/ssigrouptest.cpp
+++ b/kopete/protocols/oscar/liboscar/tests/ssigrouptest.cpp
@@ -33,7 +33,6 @@ void LoginTest::slotDoTest()
// connect to server
tqDebug( "connecting to server ");
- myClient->setIsIcq( true );
myClient->start( server, 5190, "userid", "password" );
myClient->connectToServer( myConnection, server, true );
TQTimer::singleShot( 10000, this, TQT_SLOT(runAddGroupTest() ) );
diff --git a/kopete/protocols/oscar/liboscar/tests/userinfotest.cpp b/kopete/protocols/oscar/liboscar/tests/userinfotest.cpp
index 8d75b79d..d7ccac68 100644
--- a/kopete/protocols/oscar/liboscar/tests/userinfotest.cpp
+++ b/kopete/protocols/oscar/liboscar/tests/userinfotest.cpp
@@ -33,7 +33,6 @@ void LoginTest::slotDoTest()
// connect to server
tqDebug( "connecting to server ");
- myClient->setIsIcq( true );
myClient->start( server, 5190, "userid", "password" );
myClient->connectToServer( myConnection, server, true );
//TQObject::connect( myClient, TQT_SIGNAL( userIsOnline( const TQString& ) ), this, TQT_SLOT( runUserInfoTest()));