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/warningtask.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/warningtask.cpp')
-rw-r--r-- | kopete/protocols/oscar/liboscar/warningtask.cpp | 96 |
1 files changed, 96 insertions, 0 deletions
diff --git a/kopete/protocols/oscar/liboscar/warningtask.cpp b/kopete/protocols/oscar/liboscar/warningtask.cpp new file mode 100644 index 00000000..56051dc8 --- /dev/null +++ b/kopete/protocols/oscar/liboscar/warningtask.cpp @@ -0,0 +1,96 @@ +/* + Kopete Oscar Protocol + warningtask.cpp - send warnings to aim users + + Copyright (c) 2005 by Matt Rogers <[email protected]> + + Kopete (c) 2002-2005 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 "warningtask.h" + +#include <qstring.h> +#include <kdebug.h> +#include "transfer.h" +#include "connection.h" + +WarningTask::WarningTask( Task* parent ): Task( parent ) +{ +} + + +WarningTask::~WarningTask() +{ +} + +void WarningTask::setContact( const QString& contact ) +{ + m_contact = contact; +} + +void WarningTask::setAnonymous( bool anon ) +{ + m_sendAnon = anon; +} + +bool WarningTask::forMe( const Transfer* transfer ) const +{ + const SnacTransfer* st = dynamic_cast<const SnacTransfer*>( transfer ); + if ( !st ) + return false; + if ( st->snacService() == 0x04 && st->snacSubtype() == 0x09 && st->snacRequest() == m_sequence ) + return true; + + return false; +} + +bool WarningTask::take( Transfer* transfer ) +{ + if ( forMe( transfer ) ) + { + setTransfer( transfer ); + Buffer *b = transfer->buffer(); + m_increase = b->getWord(); + m_newLevel = b->getWord(); + kdDebug(OSCAR_RAW_DEBUG) << k_funcinfo << "Got warning ack for " << m_contact << endl; + kdDebug(OSCAR_RAW_DEBUG) << k_funcinfo << "Warning level increased " << m_increase + << " to " << m_newLevel << endl; + emit userWarned( m_contact, m_increase, m_newLevel ); + setSuccess( 0, QString::null ); + setTransfer( 0 ); + return true; + } + else + { + setError( 0, QString::null ); + return false; + } +} + +void WarningTask::onGo() +{ + FLAP f = { 0x0002, 0, 0 }; + SNAC s = { 0x0004, 0x0008, 0x0000, client()->snacSequence() }; + Buffer* b = new Buffer; + if ( m_sendAnon ) + b->addWord( 0x0001 ); + else + b->addWord( 0x0000 ); + + b->addBUIN( m_contact.latin1() ); //TODO i should probably check the encoding here. nyeh + Transfer* t = createTransfer( f, s, b ); + send( t ); +} + +//kate: indent-mode csands; space-indent off; replace-tabs off; tab-width 4; + +#include "warningtask.moc" |