blob: eac8196224fdfec3a0cdd9d0529c313b1ea21d4c (
plain)
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
|
// buddyicontask.h
// Copyright (C) 2005 Matt Rogers <[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.1 of the License, or (at your option) any later version.
// This library is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without fdeven the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
// Lesser General Public License for more details.
// You should have received a copy of the GNU Lesser General Public
// License along with this library; if not, write to the Free Software
// Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
// 02111-1307 USA
#ifndef BUDDYICONTASK_H
#define BUDDYICONTASK_H
#include "task.h"
#include <qcstring.h>
class Transfer;
class BuddyIconTask : public Task
{
Q_OBJECT
public:
BuddyIconTask( Task* parent );
void uploadIcon( WORD length, const QByteArray& data );
void setReferenceNum( WORD num );
void requestIconFor( const QString& user );
void setHash( const QByteArray& md5Hash );
void setHashType( BYTE type );
//! Task implementation
void onGo();
bool forMe( const Transfer* transfer );
bool take( Transfer* transfer );
signals:
void haveIcon( const QString&, QByteArray );
private:
void sendIcon();
void handleUploadResponse();
void sendAIMBuddyIconRequest();
void handleAIMBuddyIconResponse();
void sendICQBuddyIconRequest();
void handleICQBuddyIconResponse();
private:
enum Action { Send, Receive };
Action m_action;
WORD m_iconLength;
int m_refNum;
QByteArray m_icon;
QString m_user;
QByteArray m_hash;
BYTE m_hashType;
DWORD m_seq;
};
#endif
|