From bcb704366cb5e333a626c18c308c7e0448a8e69f Mon Sep 17 00:00:00 2001 From: toma Date: Wed, 25 Nov 2009 17:56:58 +0000 Subject: 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 --- kopete/protocols/oscar/liboscar/blmlimitstask.cpp | 94 +++++++++++++++++++++++ 1 file changed, 94 insertions(+) create mode 100644 kopete/protocols/oscar/liboscar/blmlimitstask.cpp (limited to 'kopete/protocols/oscar/liboscar/blmlimitstask.cpp') diff --git a/kopete/protocols/oscar/liboscar/blmlimitstask.cpp b/kopete/protocols/oscar/liboscar/blmlimitstask.cpp new file mode 100644 index 00000000..c3fe7e6e --- /dev/null +++ b/kopete/protocols/oscar/liboscar/blmlimitstask.cpp @@ -0,0 +1,94 @@ +/* + Kopete Oscar Protocol + blmlimitstask - Get the BLM service limits + + Copyright (c) 2004 Matt Rogers + + Kopete (c) 2002-2004 by the Kopete developers + + ************************************************************************* + * * + * 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 "blmlimitstask.h" +#include +#include "connection.h" +#include "transfer.h" +#include "oscartypes.h" +#include "oscarutils.h" + +BLMLimitsTask::BLMLimitsTask( Task* parent ) + : Task( parent ) +{ +} + + +BLMLimitsTask::~BLMLimitsTask() +{ +} + + +bool BLMLimitsTask::forMe(const Transfer* transfer) const +{ + const SnacTransfer* st = dynamic_cast( transfer ); + + if (!st) + return false; + + if ( st->snacService() == 3 && st->snacSubtype() == 3 ) + return true; + else + return false; +} + +bool BLMLimitsTask::take(Transfer* transfer) +{ + if ( forMe( transfer ) ) + { + Buffer* buffer = transfer->buffer(); + while ( buffer->length() != 0 ) + { + TLV t = buffer->getTLV(); + switch ( t.type ) + { + case 0x0001: + kdDebug(OSCAR_RAW_DEBUG) << k_funcinfo << "Max BLM entries: " + << t.data << endl; + break; + case 0x0002: + kdDebug( OSCAR_RAW_DEBUG ) << k_funcinfo << "Max watcher entries: " + << t.data << endl; + break; + case 0x0003: + kdDebug( OSCAR_RAW_DEBUG ) << k_funcinfo << "Max online notifications(?): " + << t.data << endl; + break; + } + } + setSuccess( 0, QString::null ); + return true; + } + else + return false; +} + +void BLMLimitsTask::onGo() +{ + kdDebug(OSCAR_RAW_DEBUG) << k_funcinfo << "Sending BLM limits request" << endl; + FLAP f = { 0x02, 0, 0 }; + SNAC s = { 0x0003, 0x0002, 0x0000, client()->snacSequence() }; + + Buffer* buffer = new Buffer(); + buffer->addTLV16( 0x0005, 0x0003 ); + + Transfer *t = createTransfer( f, s, buffer ); + send( t ); +} + +//kate: tab-width 4; indent-mode csands; -- cgit v1.2.1