diff options
author | toma <toma@283d02a7-25f6-0310-bc7c-ecb5cbfe19da> | 2009-11-25 17:56:58 +0000 |
---|---|---|
committer | toma <toma@283d02a7-25f6-0310-bc7c-ecb5cbfe19da> | 2009-11-25 17:56:58 +0000 |
commit | bcb704366cb5e333a626c18c308c7e0448a8e69f (patch) | |
tree | f0d6ab7d78ecdd9207cf46536376b44b91a1ca71 /kopete/protocols/oscar/liboscar/ssiparamstask.cpp | |
download | tdenetwork-bcb704366cb5e333a626c18c308c7e0448a8e69f.tar.gz tdenetwork-bcb704366cb5e333a626c18c308c7e0448a8e69f.zip |
Copy the KDE 3.5 branch to branches/trinity for new KDE 3.5 features.
BUG:215923
git-svn-id: svn://anonsvn.kde.org/home/kde/branches/trinity/kdenetwork@1054174 283d02a7-25f6-0310-bc7c-ecb5cbfe19da
Diffstat (limited to 'kopete/protocols/oscar/liboscar/ssiparamstask.cpp')
-rw-r--r-- | kopete/protocols/oscar/liboscar/ssiparamstask.cpp | 102 |
1 files changed, 102 insertions, 0 deletions
diff --git a/kopete/protocols/oscar/liboscar/ssiparamstask.cpp b/kopete/protocols/oscar/liboscar/ssiparamstask.cpp new file mode 100644 index 00000000..0be172e8 --- /dev/null +++ b/kopete/protocols/oscar/liboscar/ssiparamstask.cpp @@ -0,0 +1,102 @@ +/* + Kopete Oscar Protocol + ssiparamstask.cpp - Get the SSI parameters so we can use them + + 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 "ssiparamstask.h" +#include <kdebug.h> +#include "buffer.h" +#include "connection.h" +#include "transfer.h" +#include "oscartypes.h" +#include "oscarutils.h" +#include "ssimanager.h" + +using namespace Oscar; + +SSIParamsTask::SSIParamsTask(Task* parent): Task(parent) +{ +} + + +SSIParamsTask::~SSIParamsTask() +{ +} + + +bool SSIParamsTask::forMe(const Transfer* transfer) const +{ + const SnacTransfer* st = dynamic_cast<const SnacTransfer*>( transfer ); + if ( !st ) + return false; + + if ( st->snacService() == 0x0013 && st->snacSubtype() == 0x0003 ) + return true; + + return false; +} + +bool SSIParamsTask::take(Transfer* transfer) +{ + if ( forMe( transfer ) ) + { + setTransfer( transfer ); + handleParamReply(); + setTransfer( 0 ); + return true; + } + + return false; +} + +void SSIParamsTask::onGo() +{ + FLAP f = { 0x02, 0, 0 }; + SNAC s = { 0x0013, 0x0002, 0x0000, client()->snacSequence() }; + + Buffer* buffer = new Buffer(); + buffer->addTLV16( 0x000B, 0x000F ); + + Transfer* t = createTransfer( f, s, buffer ); + send( t ); +} + +void SSIParamsTask::handleParamReply() +{ + kdDebug( OSCAR_RAW_DEBUG ) << k_funcinfo << "Getting SSI parameters" << endl; + Buffer* buf = transfer()->buffer(); + //manually parse the TLV out of the packet, since we only want certain things + if ( buf->getWord() != 0x0004 ) + { + setError( -1, QString::null ); + return; //no TLV of type 0x0004, bad packet. do nothing. + } + else + { + buf->skipBytes( 2 ); //the tlv length + WORD maxContacts = buf->getWord(); + WORD maxGroups = buf->getWord(); + WORD maxVisible = buf->getWord(); + WORD maxInvisible = buf->getWord(); + buf->skipBytes( 20 ); + WORD maxIgnore = buf->getWord(); + client()->ssiManager()->setParameters( maxContacts, maxGroups, maxVisible, maxInvisible, maxIgnore ); + } + setSuccess( 0, QString::null ); +} + +// kate: tab-width 4; indent-mode csands; + |