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
94
95
96
97
98
99
100
101
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, TQString() );
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, TQString() );
}
// kate: tab-width 4; indent-mode csands;
|