Mercurial > pidgin
annotate src/protocols/msn/session.h @ 8175:f347c8d25cf5
[gaim-migrate @ 8889]
Make privacy stuff use an enum for different privacy options. This
started with a fix to make the box for "allow the users below" show
up when opening the privacy dialog when that option was selected.
It might be a good idea for a few people to check their privacy settings
after using this to make sure it's the same as what it used to be.
committer: Tailor Script <tailor@pidgin.im>
author | Mark Doliner <mark@kingant.net> |
---|---|
date | Wed, 28 Jan 2004 05:43:04 +0000 |
parents | d0ba2f7b40e7 |
children | c719f9a181d4 |
rev | line source |
---|---|
5309 | 1 /** |
2 * @file session.h MSN session functions | |
3 * | |
4 * gaim | |
5 * | |
6 * Copyright (C) 2003 Christian Hammond <chipx86@gnupdate.org> | |
6701
b7e113a59b51
[gaim-migrate @ 7227]
Christian Hammond <chipx86@chipx86.com>
parents:
5898
diff
changeset
|
7 * |
5309 | 8 * This program is free software; you can redistribute it and/or modify |
9 * it under the terms of the GNU General Public License as published by | |
10 * the Free Software Foundation; either version 2 of the License, or | |
11 * (at your option) any later version. | |
12 * | |
13 * This program is distributed in the hope that it will be useful, | |
14 * but WITHOUT ANY WARRANTY; without even the implied warranty of | |
15 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | |
16 * GNU General Public License for more details. | |
17 * | |
18 * You should have received a copy of the GNU General Public License | |
19 * along with this program; if not, write to the Free Software | |
20 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA | |
21 */ | |
22 #ifndef _MSN_SESSION_H_ | |
23 #define _MSN_SESSION_H_ | |
24 | |
25 typedef struct _MsnSession MsnSession; | |
26 | |
8171
d0ba2f7b40e7
[gaim-migrate @ 8884]
Christian Hammond <chipx86@chipx86.com>
parents:
7631
diff
changeset
|
27 #include "group.h" |
d0ba2f7b40e7
[gaim-migrate @ 8884]
Christian Hammond <chipx86@chipx86.com>
parents:
7631
diff
changeset
|
28 #include "nexus.h" |
d0ba2f7b40e7
[gaim-migrate @ 8884]
Christian Hammond <chipx86@chipx86.com>
parents:
7631
diff
changeset
|
29 #include "servconn.h" |
6701
b7e113a59b51
[gaim-migrate @ 7227]
Christian Hammond <chipx86@chipx86.com>
parents:
5898
diff
changeset
|
30 #include "sslconn.h" |
5309 | 31 #include "switchboard.h" |
32 #include "user.h" | |
8171
d0ba2f7b40e7
[gaim-migrate @ 8884]
Christian Hammond <chipx86@chipx86.com>
parents:
7631
diff
changeset
|
33 |
5309 | 34 |
35 struct _MsnSession | |
36 { | |
5564
187c740f2a4e
[gaim-migrate @ 5966]
Christian Hammond <chipx86@chipx86.com>
parents:
5518
diff
changeset
|
37 GaimAccount *account; |
5363
ebebc833cf77
[gaim-migrate @ 5739]
Christian Hammond <chipx86@chipx86.com>
parents:
5327
diff
changeset
|
38 MsnUser *user; |
7590
3a48ade4f510
[gaim-migrate @ 8208]
Christian Hammond <chipx86@chipx86.com>
parents:
7288
diff
changeset
|
39 char *away_state; |
5309 | 40 |
7631 | 41 guint protocol_ver; |
6701
b7e113a59b51
[gaim-migrate @ 7227]
Christian Hammond <chipx86@chipx86.com>
parents:
5898
diff
changeset
|
42 |
5309 | 43 char *dispatch_server; |
44 int dispatch_port; | |
45 | |
46 gboolean connected; | |
47 | |
48 MsnServConn *dispatch_conn; | |
49 MsnServConn *notification_conn; | |
50 | |
8171
d0ba2f7b40e7
[gaim-migrate @ 8884]
Christian Hammond <chipx86@chipx86.com>
parents:
7631
diff
changeset
|
51 MsnNexus *nexus; |
d0ba2f7b40e7
[gaim-migrate @ 8884]
Christian Hammond <chipx86@chipx86.com>
parents:
7631
diff
changeset
|
52 |
5309 | 53 unsigned int trId; |
54 | |
7288
ff9127038a5a
[gaim-migrate @ 7869]
Christian Hammond <chipx86@chipx86.com>
parents:
6701
diff
changeset
|
55 gboolean http_method; |
ff9127038a5a
[gaim-migrate @ 7869]
Christian Hammond <chipx86@chipx86.com>
parents:
6701
diff
changeset
|
56 |
5309 | 57 MsnUsers *users; |
5518
bf2a7a7b739d
[gaim-migrate @ 5918]
Christian Hammond <chipx86@chipx86.com>
parents:
5456
diff
changeset
|
58 MsnGroups *groups; |
5309 | 59 |
5898
5baeb89ee2d4
[gaim-migrate @ 6330]
Christian Hammond <chipx86@chipx86.com>
parents:
5564
diff
changeset
|
60 GList *servconns; |
5309 | 61 GList *switches; |
62 | |
63 struct | |
64 { | |
65 GSList *forward; | |
66 GSList *reverse; | |
67 GSList *allow; | |
68 GSList *block; | |
69 | |
70 } lists; | |
71 | |
72 struct | |
73 { | |
74 char *kv; | |
75 char *sid; | |
76 char *mspauth; | |
77 unsigned long sl; | |
78 char *file; | |
6701
b7e113a59b51
[gaim-migrate @ 7227]
Christian Hammond <chipx86@chipx86.com>
parents:
5898
diff
changeset
|
79 char *client_ip; |
b7e113a59b51
[gaim-migrate @ 7227]
Christian Hammond <chipx86@chipx86.com>
parents:
5898
diff
changeset
|
80 int client_port; |
5309 | 81 |
82 } passport_info; | |
83 | |
5322
a4d017bee1de
[gaim-migrate @ 5694]
Christian Hammond <chipx86@chipx86.com>
parents:
5318
diff
changeset
|
84 /* You have no idea how much I hate all that is below. */ |
5309 | 85 GaimPlugin *prpl; |
5322
a4d017bee1de
[gaim-migrate @ 5694]
Christian Hammond <chipx86@chipx86.com>
parents:
5318
diff
changeset
|
86 |
6701
b7e113a59b51
[gaim-migrate @ 7227]
Christian Hammond <chipx86@chipx86.com>
parents:
5898
diff
changeset
|
87 /* For MSNP8 and MSNP9. */ |
b7e113a59b51
[gaim-migrate @ 7227]
Christian Hammond <chipx86@chipx86.com>
parents:
5898
diff
changeset
|
88 int num_users; |
b7e113a59b51
[gaim-migrate @ 7227]
Christian Hammond <chipx86@chipx86.com>
parents:
5898
diff
changeset
|
89 int total_users; |
b7e113a59b51
[gaim-migrate @ 7227]
Christian Hammond <chipx86@chipx86.com>
parents:
5898
diff
changeset
|
90 int num_groups; |
b7e113a59b51
[gaim-migrate @ 7227]
Christian Hammond <chipx86@chipx86.com>
parents:
5898
diff
changeset
|
91 int total_groups; |
b7e113a59b51
[gaim-migrate @ 7227]
Christian Hammond <chipx86@chipx86.com>
parents:
5898
diff
changeset
|
92 MsnUser *last_user_added; |
b7e113a59b51
[gaim-migrate @ 7227]
Christian Hammond <chipx86@chipx86.com>
parents:
5898
diff
changeset
|
93 |
b7e113a59b51
[gaim-migrate @ 7227]
Christian Hammond <chipx86@chipx86.com>
parents:
5898
diff
changeset
|
94 /* For MSNP7 and lower. */ |
5456
40e976d42028
[gaim-migrate @ 5844]
Christian Hammond <chipx86@chipx86.com>
parents:
5406
diff
changeset
|
95 gboolean syncing_lists; |
5406
9acf4832c0dc
[gaim-migrate @ 5782]
Christian Hammond <chipx86@chipx86.com>
parents:
5363
diff
changeset
|
96 gboolean lists_synced; |
9acf4832c0dc
[gaim-migrate @ 5782]
Christian Hammond <chipx86@chipx86.com>
parents:
5363
diff
changeset
|
97 |
5322
a4d017bee1de
[gaim-migrate @ 5694]
Christian Hammond <chipx86@chipx86.com>
parents:
5318
diff
changeset
|
98 /* For moving buddies from one group to another. Ugh. */ |
a4d017bee1de
[gaim-migrate @ 5694]
Christian Hammond <chipx86@chipx86.com>
parents:
5318
diff
changeset
|
99 gboolean moving_buddy; |
5327
b716ffc25d2d
[gaim-migrate @ 5700]
Christian Hammond <chipx86@chipx86.com>
parents:
5322
diff
changeset
|
100 char *dest_group_name; |
5518
bf2a7a7b739d
[gaim-migrate @ 5918]
Christian Hammond <chipx86@chipx86.com>
parents:
5456
diff
changeset
|
101 MsnUser *moving_user; |
bf2a7a7b739d
[gaim-migrate @ 5918]
Christian Hammond <chipx86@chipx86.com>
parents:
5456
diff
changeset
|
102 MsnGroup *old_group; |
5309 | 103 }; |
104 | |
105 /** | |
106 * Creates an MSN session. | |
107 * | |
108 * @param account The account. | |
109 * @param server The dispatch server. | |
110 * @param port The dispatch port. | |
111 * | |
112 * @return The new MSN session. | |
113 */ | |
5564
187c740f2a4e
[gaim-migrate @ 5966]
Christian Hammond <chipx86@chipx86.com>
parents:
5518
diff
changeset
|
114 MsnSession *msn_session_new(GaimAccount *account, |
5309 | 115 const char *server, int port); |
116 | |
117 /** | |
118 * Destroys an MSN session. | |
119 * | |
120 * @param session The MSN session to destroy. | |
121 */ | |
122 void msn_session_destroy(MsnSession *session); | |
123 | |
124 /** | |
125 * Connects to and initiates an MSN session. | |
126 * | |
127 * @param session The MSN session. | |
128 * | |
129 * @return @c TRUE on success, @c FALSE on failure. | |
130 */ | |
131 gboolean msn_session_connect(MsnSession *session); | |
132 | |
133 /** | |
134 * Disconnects from an MSN session. | |
135 * | |
136 * @param session The MSN session. | |
137 */ | |
138 void msn_session_disconnect(MsnSession *session); | |
139 | |
140 /** | |
141 * Opens a new switchboard connection. | |
142 * | |
143 * @param session The MSN session. | |
144 * | |
145 * @return The new switchboard connection. | |
146 */ | |
147 MsnSwitchBoard *msn_session_open_switchboard(MsnSession *session); | |
148 | |
149 /** | |
7590
3a48ade4f510
[gaim-migrate @ 8208]
Christian Hammond <chipx86@chipx86.com>
parents:
7288
diff
changeset
|
150 * Changes the status of the user. |
3a48ade4f510
[gaim-migrate @ 8208]
Christian Hammond <chipx86@chipx86.com>
parents:
7288
diff
changeset
|
151 * |
3a48ade4f510
[gaim-migrate @ 8208]
Christian Hammond <chipx86@chipx86.com>
parents:
7288
diff
changeset
|
152 * @param session The MSN session. |
3a48ade4f510
[gaim-migrate @ 8208]
Christian Hammond <chipx86@chipx86.com>
parents:
7288
diff
changeset
|
153 * @param state The new state. |
3a48ade4f510
[gaim-migrate @ 8208]
Christian Hammond <chipx86@chipx86.com>
parents:
7288
diff
changeset
|
154 */ |
3a48ade4f510
[gaim-migrate @ 8208]
Christian Hammond <chipx86@chipx86.com>
parents:
7288
diff
changeset
|
155 gboolean msn_session_change_status(MsnSession *session, const char *state); |
3a48ade4f510
[gaim-migrate @ 8208]
Christian Hammond <chipx86@chipx86.com>
parents:
7288
diff
changeset
|
156 |
3a48ade4f510
[gaim-migrate @ 8208]
Christian Hammond <chipx86@chipx86.com>
parents:
7288
diff
changeset
|
157 /** |
5309 | 158 * Finds a switch with the given passport. |
159 * | |
160 * @param session The MSN session. | |
161 * @param passport The passport to search for. | |
162 * | |
163 * @return The switchboard, if found. | |
164 */ | |
165 MsnSwitchBoard *msn_session_find_switch_with_passport( | |
166 const MsnSession *session, const char *passport); | |
167 | |
168 /** | |
169 * Finds a switchboard with the given chat ID. | |
170 * | |
171 * @param session The MSN session. | |
172 * @param chat_id The chat ID to search for. | |
173 * | |
174 * @return The switchboard, if found. | |
175 */ | |
176 MsnSwitchBoard *msn_session_find_switch_with_id(const MsnSession *session, | |
177 int chat_id); | |
178 | |
179 /** | |
180 * Finds the first unused switchboard. | |
181 * | |
182 * @param session The MSN session. | |
183 * | |
184 * @return The first unused, writable switchboard, if found. | |
185 */ | |
186 MsnSwitchBoard *msn_session_find_unused_switch(const MsnSession *session); | |
187 | |
188 #endif /* _MSN_SESSION_H_ */ |