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/onlinenotifiertask.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/onlinenotifiertask.cpp')
-rw-r--r-- | kopete/protocols/oscar/liboscar/onlinenotifiertask.cpp | 99 |
1 files changed, 99 insertions, 0 deletions
diff --git a/kopete/protocols/oscar/liboscar/onlinenotifiertask.cpp b/kopete/protocols/oscar/liboscar/onlinenotifiertask.cpp new file mode 100644 index 00000000..785e23f7 --- /dev/null +++ b/kopete/protocols/oscar/liboscar/onlinenotifiertask.cpp @@ -0,0 +1,99 @@ +/* + Kopete Oscar Protocol + onlinenotifiertask.cpp - handles all the status notifications + + Copyright (c) 2004 by Matt Rogers <[email protected]> + + Based on code Copyright (c) 2004 SuSE Linux AG <http://www.suse.com> + Based on Iris, Copyright (C) 2003 Justin Karneges + + 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 "onlinenotifiertask.h" +#include "buffer.h" +#include "connection.h" +#include "oscartypes.h" +#include "transfer.h" + +#include <kdebug.h> + +OnlineNotifierTask::OnlineNotifierTask( Task* parent ) : Task( parent ) +{ +} + + +OnlineNotifierTask::~OnlineNotifierTask() +{ +} + + +bool OnlineNotifierTask::forMe( const Transfer* transfer ) const +{ + const SnacTransfer* st = dynamic_cast<const SnacTransfer*>( transfer ); + if ( !st ) + return false; + + if ( st->snacService() == 0x0003 ) + { + switch ( st->snacSubtype() ) + { + case 0x000B: + case 0x000C: + return true; + }; + } + return false; +} + +bool OnlineNotifierTask::take( Transfer* transfer ) +{ + if ( forMe( transfer ) ) + { + SnacTransfer* st = dynamic_cast<SnacTransfer*>( transfer ); + if ( st ) + { + setTransfer( transfer ); + + if ( st->snacSubtype() == 0x000B ) + userOnline(); + else + userOffline(); + + setTransfer( 0 ); + } + return true; + } + return false; +} + +void OnlineNotifierTask::userOnline() +{ + Buffer* buffer = transfer()->buffer(); + UserDetails ud; + ud.fill( buffer ); + QString user = ud.userId(); + //kdDebug( OSCAR_RAW_DEBUG ) << k_funcinfo << user << " is now online" << endl; + emit userIsOnline( user, ud ); +} + +void OnlineNotifierTask::userOffline() +{ + Buffer* buffer = transfer()->buffer(); + UserDetails ud; + ud.fill( buffer ); + QString user = ud.userId(); + //kdDebug( OSCAR_RAW_DEBUG ) << k_funcinfo << user << " is now offline" << endl; + emit userIsOffline( user, ud ); +} + +#include "onlinenotifiertask.moc" +//kate: tab-width 4; indent-mode csands; |