Mercurial > ~mikael > mcabber > hg
annotate mcabber/src/jabglue.h @ 1014:99c5278bf6b8
Keep the status and status messages when we're disconnected
Improve the automatic reconnection after a network failure.
- AutoConnection is only set to false when the user disconnects
explicitly (i.e. in do_disconnect()).
- AutoConnection is set to TRUE after the 1st successful connection.
- In jb_setstatus(), update the status message and the "wanted status"
even in offline mode. It helps with auto-away.
author | Mikael Berthe <mikael@lilotux.net> |
---|---|
date | Sun, 12 Nov 2006 22:25:14 +0100 |
parents | c112423ac012 |
children | 579299b1c9b2 |
rev | line source |
---|---|
29 | 1 #ifndef __JABGLUE_H__ |
2 #define __JABGLUE_H__ 1 | |
3 | |
159 | 4 #include <glib.h> |
5 | |
572
afc2bd38b15c
Implement affiliations handling, add "/room whois"
Mikael Berthe <mikael@lilotux.net>
parents:
568
diff
changeset
|
6 #include "roster.h" |
29 | 7 #include "../libjabber/jabber.h" |
8 | |
237 | 9 #if HAVE_CONFIG_H |
10 # include <config.h> | |
11 #endif | |
12 | |
13 #if ! HAVE_DECL_STRPTIME | |
14 extern char *strptime (); | |
15 #endif | |
16 | |
29 | 17 extern jconn jc; |
1014
99c5278bf6b8
Keep the status and status messages when we're disconnected
Mikael Berthe <mikael@lilotux.net>
parents:
1009
diff
changeset
|
18 extern guint AutoConnection; |
29 | 19 |
46 | 20 extern char imstatus2char[]; |
277
4d7040cff8ee
Remove busy/occupied status, which does not really exist
Mikael Berthe <mikael@lilotux.net>
parents:
272
diff
changeset
|
21 // Status chars: '_', 'o', 'i', 'f', 'd', 'n', 'a' |
46 | 22 |
37 | 23 enum agtype { |
693 | 24 unknown, |
25 groupchat, | |
26 transport, | |
27 search | |
28 }; | |
29 | |
30 enum iqreq_type { | |
31 iqreq_none, | |
32 iqreq_version, | |
1003
c8b1a52b2fd6
Initial VCard retrieval support
Mikael Berthe <mikael@lilotux.net>
parents:
990
diff
changeset
|
33 iqreq_time, |
c8b1a52b2fd6
Initial VCard retrieval support
Mikael Berthe <mikael@lilotux.net>
parents:
990
diff
changeset
|
34 iqreq_vcard |
37 | 35 }; |
36 | |
298
35cda94e570d
Add /connect and /disconnect commands
Mikael Berthe <mikael@lilotux.net>
parents:
294
diff
changeset
|
37 char *compose_jid(const char *username, const char *servername, |
35cda94e570d
Add /connect and /disconnect commands
Mikael Berthe <mikael@lilotux.net>
parents:
294
diff
changeset
|
38 const char *resource); |
403
17aa60c6dc63
Allow a different server name than the jid domain name
Mikael Berthe <mikael@lilotux.net>
parents:
300
diff
changeset
|
39 jconn jb_connect(const char *jid, const char *server, unsigned int port, |
17aa60c6dc63
Allow a different server name than the jid domain name
Mikael Berthe <mikael@lilotux.net>
parents:
300
diff
changeset
|
40 int ssl, const char *pass); |
472
75442262c082
Disable some commands when not connected
Mikael Berthe <mikael@lilotux.net>
parents:
469
diff
changeset
|
41 inline unsigned char jb_getonline(void); |
29 | 42 void jb_disconnect(void); |
952 | 43 void jb_main(void); |
617
d3a8b43bf9e7
Add "/authorization" command
Mikael Berthe <mikael@lilotux.net>
parents:
599
diff
changeset
|
44 void jb_subscr_send_auth(const char *jid); |
d3a8b43bf9e7
Add "/authorization" command
Mikael Berthe <mikael@lilotux.net>
parents:
599
diff
changeset
|
45 void jb_subscr_cancel_auth(const char *jid); |
d3a8b43bf9e7
Add "/authorization" command
Mikael Berthe <mikael@lilotux.net>
parents:
599
diff
changeset
|
46 void jb_subscr_request_auth(const char *jid); |
834
6f913f4fbb2a
Use jb_subscr_ in jb_delbuddy()
Mikael Berthe <mikael@lilotux.net>
parents:
693
diff
changeset
|
47 void jb_subscr_request_cancel(const char *jid); |
244 | 48 void jb_addbuddy(const char *jid, const char *name, const char *group); |
205 | 49 void jb_delbuddy(const char *jid); |
208 | 50 void jb_updatebuddy(const char *jid, const char *name, const char *group); |
952 | 51 inline enum imstatus jb_getstatus(void); |
52 inline const char *jb_getstatusmsg(void); | |
444 | 53 void jb_setstatus(enum imstatus st, const char *recipient, const char *msg); |
1014
99c5278bf6b8
Keep the status and status messages when we're disconnected
Mikael Berthe <mikael@lilotux.net>
parents:
1009
diff
changeset
|
54 inline void jb_setprevstatus(void); |
475
fa49ac0bb8f3
Add "/room topic", and display topic changes
Mikael Berthe <mikael@lilotux.net>
parents:
472
diff
changeset
|
55 void jb_send_msg(const char *jid, const char *text, int type, |
988
6e2bfd1ffded
Add ids to message stanzas if needed
Mikael Berthe <mikael@lilotux.net>
parents:
952
diff
changeset
|
56 const char *subject, const char *id); |
436 | 57 void jb_send_raw(const char *str); |
990
35e7913affb7
Send events/chatstates notifications (JEP-22/JEP-85)
Mikael Berthe <mikael@lilotux.net>
parents:
988
diff
changeset
|
58 void jb_send_chatstate(gpointer buddy, guint chatstate); |
952 | 59 void jb_keepalive(void); |
60 inline void jb_reset_keepalive(void); | |
112 | 61 void jb_set_keepalive_delay(unsigned int delay); |
900
b41684465283
MUC: join password-protected room
Mikael Berthe <mikael@lilotux.net>
parents:
834
diff
changeset
|
62 void jb_room_join(const char *room, const char *nickname, const char *passwd); |
449 | 63 void jb_room_unlock(const char *room); |
599 | 64 void jb_room_destroy(const char *room, const char *venue, const char *reason); |
486 | 65 void jb_room_invite(const char *room, const char *jid, const char *reason); |
584 | 66 int jb_room_setattrib(const char *roomid, const char *jid, const char *nick, |
67 struct role_affil ra, const char *reason); | |
689
281aab5aef50
Introduce jb_iqs_display_list() helper function for debugging
Mikael Berthe <mikael@lilotux.net>
parents:
617
diff
changeset
|
68 void jb_iqs_display_list(void); |
693 | 69 void jb_request(const char *jid, enum iqreq_type reqtype); |
1009 | 70 void jb_set_storage_bookmark(const char *roomid, const char *name, |
71 const char *nick, const char *passwd, | |
72 int autojoin); | |
29 | 73 |
74 #endif /* __JABGLUE_H__ */ | |
576 | 75 |
580 | 76 /* vim: set expandtab cindent cinoptions=>2\:2(0: For Vim users... */ |