1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
|
/*
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 <tqstring.h>
#include <kdebug.h>
#include "transfer.h"
#include "connection.h"
WarningTask::WarningTask( Task* parent ): Task( parent )
{
}
WarningTask::~WarningTask()
{
}
void WarningTask::setContact( const TQString& 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, TQString() );
setTransfer( 0 );
return true;
}
else
{
setError( 0, TQString() );
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 );
}
#include "warningtask.moc"
|