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
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
|
/*
Jabber Protocol Plugin for Miranda IM
Copyright ( C ) 2002-04 Santithorn Bunchua
Copyright ( C ) 2005-06 George Hazan
This program is free software; you can redistribute it and/or
modify it under the terms of the GNU General Public License
as published by the Free Software Foundation; either version 2
of the License, or ( at your option ) any later version.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with this program; if not, write to the Free Software
Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
File name : $Source: /cvsroot/miranda/miranda/protocols/JabberG/jabber_list.h,v $
Revision : $Revision: 3651 $
Last change on : $Date: 2006-08-30 16:54:52 +0400 (Срд, 30 Авг 2006) $
Last change by : $Author: ghazan $
*/
#ifndef _JABBER_LIST_H_
#define _JABBER_LIST_H_
typedef enum {
LIST_ROSTER, // Roster list
LIST_AGENT, // Agent list to show on the Jabber Agents dialog
LIST_CHATROOM, // Groupchat room currently joined
LIST_ROOM, // Groupchat room list to show on the Jabber groupchat dialog
LIST_FILE, // Current file transfer session
LIST_BYTE, // Bytestream sending connection
LIST_FTSEND,
LIST_FTRECV
} JABBER_LIST;
typedef enum {
SUB_NONE,
SUB_TO,
SUB_FROM,
SUB_BOTH
} JABBER_SUBSCRIPTION;
typedef enum {
AFFILIATION_NONE,
AFFILIATION_OUTCAST,
AFFILIATION_MEMBER,
AFFILIATION_ADMIN,
AFFILIATION_OWNER
} JABBER_GC_AFFILIATION;
typedef enum {
ROLE_NONE,
ROLE_VISITOR,
ROLE_PARTICIPANT,
ROLE_MODERATOR
} JABBER_GC_ROLE;
typedef enum { // initial default to RSMODE_LASTSEEN
RSMODE_SERVER, // always let server decide ( always send correspondence without resouce name )
RSMODE_LASTSEEN, // use the last seen resource ( or let server decide if haven't seen anything yet )
RSMODE_MANUAL // specify resource manually ( see the defaultResource field - must not be NULL )
} JABBER_RESOURCE_MODE;
#define CLIENT_CAP_READY ( 1<<0 ) // have already done disco#info query
#define CLIENT_CAP_SI ( 1<<1 ) // stream initiation ( si ) profile
#define CLIENT_CAP_SIFILE ( 1<<2 ) // file transfer si profile
#define CLIENT_CAP_BYTESTREAM ( 1<<3 ) // socks5 bytestream
#define CLIENT_CAP_CHATSTAT ( 1<<4 ) // http://jabber.org/protocol/chatstates support (JEP-0085)
#define AGENT_CAP_REGISTER ( 1<<13 )
#define AGENT_CAP_SEARCH ( 1<<14 )
#define AGENT_CAP_GROUPCHAT ( 1<<15 )
#define CLIENT_CAP_FILE ( CLIENT_CAP_SI | CLIENT_CAP_SIFILE )
struct JABBER_RESOURCE_STATUS
{
int status;
TCHAR* resourceName;
TCHAR* statusMessage;
TCHAR* software;
TCHAR* version;
TCHAR* system;
unsigned int cap; // 0 = haven't done disco#info yet, see CLIENT_CAP_*
JABBER_GC_AFFILIATION affiliation;
JABBER_GC_ROLE role;
};
struct JABBER_LIST_ITEM
{
JABBER_LIST list;
TCHAR* jid;
// LIST_ROSTER
// jid = jid of the contact
TCHAR* nick;
int resourceCount;
int status; // Main status, currently useful for transport where no resource information is kept.
// On normal contact, this is the same status as shown on contact list.
JABBER_RESOURCE_STATUS *resource;
int defaultResource; // index to resource[x] which is the default, negative ( -1 ) means no resource is chosen yet
JABBER_RESOURCE_MODE resourceMode;
JABBER_SUBSCRIPTION subscription;
TCHAR* statusMessage; // Status message when the update is to JID with no resource specified ( e.g. transport user )
TCHAR* group;
char* photoFileName;
int idMsgAckPending;
TCHAR* messageEventIdStr;
BOOL wantComposingEvent;
WORD cap; // See CLIENT_CAP_* above
// LIST_AGENT
// jid = jid of the agent
// WORD cap; // See AGENT_CAP_* above
TCHAR* name;
TCHAR* service;
// LIST_ROOM
// jid = room JID
// char* name; // room name
TCHAR* type; // room type
// LIST_CHATROOM
// jid = room JID
// char* nick; // my nick in this chat room ( SPECIAL: in TXT )
// JABBER_RESOURCE_STATUS *resource; // participant nicks in this room
BOOL bChatActive;
HWND hwndGcListBan;
HWND hwndGcListAdmin;
HWND hwndGcListOwner;
// LIST_FILE
// jid = string representation of port number
filetransfer* ft;
WORD port;
// LIST_BYTE
// jid = string representation of port number
JABBER_BYTE_TRANSFER *jbt;
// LIST_FTSEND
// jid = string representation of iq id
// ft = file transfer data
// jbt
// LIST_FTRECV
// jid = string representation of stream id ( sid )
// ft = file transfer data
};
void JabberListInit( void );
void JabberListUninit( void );
void JabberListWipe( void );
int JabberListExist( JABBER_LIST list, const TCHAR* jid );
JABBER_LIST_ITEM *JabberListAdd( JABBER_LIST list, const TCHAR* jid );
void JabberListRemove( JABBER_LIST list, const TCHAR* jid );
void JabberListRemoveList( JABBER_LIST list );
void JabberListRemoveByIndex( int index );
int JabberListFindNext( JABBER_LIST list, int fromOffset );
JABBER_LIST_ITEM *JabberListGetItemPtr( JABBER_LIST list, const TCHAR* jid );
JABBER_LIST_ITEM *JabberListGetItemPtrFromIndex( int index );
int JabberListAddResource( JABBER_LIST list, const TCHAR* jid, int status, const TCHAR* statusMessage );
void JabberListRemoveResource( JABBER_LIST list, const TCHAR* jid );
TCHAR* JabberListGetBestResourceNamePtr( const TCHAR* jid );
TCHAR* JabberListGetBestClientResourceNamePtr( const TCHAR* jid );
#endif
|