source: irc.h @ 246b98b

Last change on this file since 246b98b was 1dcbd3e, checked in by dequis <dx@…>, at 2018-02-11T20:09:43Z

irc.h: Add G_GNUC_PRINTF annotations to printf-like functions

The change in root_commands.c is due to -Wformat-zero-length, which is
bs but whatever. See https://gcc.gnu.org/bugzilla/show_bug.cgi?id=47901

  • Property mode set to 100644
File size: 12.9 KB
Line 
1/********************************************************************\
2  * BitlBee -- An IRC to other IM-networks gateway                     *
3  *                                                                    *
4  * Copyright 2002-2013 Wilmer van der Gaast and others                *
5  \********************************************************************/
6
7/* The IRC-based UI (for now the only one)                              */
8
9/*
10  This program is free software; you can redistribute it and/or modify
11  it under the terms of the GNU General Public License as published by
12  the Free Software Foundation; either version 2 of the License, or
13  (at your option) any later version.
14
15  This program is distributed in the hope that it will be useful,
16  but WITHOUT ANY WARRANTY; without even the implied warranty of
17  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
18  GNU General Public License for more details.
19
20  You should have received a copy of the GNU General Public License with
21  the Debian GNU/Linux distribution in /usr/share/common-licenses/GPL;
22  if not, write to the Free Software Foundation, Inc., 51 Franklin St.,
23  Fifth Floor, Boston, MA  02110-1301  USA
24*/
25
26#ifndef _IRC_H
27#define _IRC_H
28
29#include <sys/socket.h>
30
31#define IRC_MAX_LINE 512
32#define IRC_MAX_ARGS 16
33#define IRC_WORD_WRAP 425
34
35#define IRC_LOGIN_TIMEOUT 60
36#define IRC_PING_STRING "PinglBee"
37
38#define UMODES "abisw"     /* Allowed umodes (although they mostly do nothing) */
39#define UMODES_PRIV "Ro"   /* Allowed, but not by user directly */
40#define UMODES_KEEP "R"    /* Don't allow unsetting using /MODE */
41#define CMODES "ntC"       /* Allowed modes */
42#define CMODE "t"          /* Default mode */
43#define UMODE "s"          /* Default mode */
44
45#define CTYPES "&#"        /* Valid channel name prefixes */
46
47typedef enum {
48        USTATUS_OFFLINE = 0,
49        USTATUS_AUTHORIZED = 1, /* Gave the correct server password (PASS). */
50        USTATUS_LOGGED_IN = 2,  /* USER+NICK(+PASS) finished. */
51        USTATUS_IDENTIFIED = 4, /* To NickServ (root). */
52        USTATUS_SHUTDOWN = 8,   /* Now used to indicate we're shutting down.
53                                   Currently just blocks irc_vawrite(). */
54        USTATUS_CAP_PENDING = 16,
55        USTATUS_SASL_PLAIN_PENDING = 32,
56
57        /* Not really status stuff, but other kinds of flags: For slightly
58           better password security, since the only way to send passwords
59           to the IRC server securely (i.e. not echoing to screen or written
60           to logfiles) is the /OPER command, try to use that command for
61           stuff that matters. */
62        OPER_HACK_IDENTIFY = 0x100,
63        OPER_HACK_IDENTIFY_NOLOAD = 0x01100,
64        OPER_HACK_IDENTIFY_FORCE  = 0x02100,
65        OPER_HACK_REGISTER = 0x200,
66        OPER_HACK_ACCOUNT_PASSWORD = 0x400,
67        OPER_HACK_ANY = 0x3700, /* To check for them all at once. */
68
69        IRC_UTF8_NICKS = 0x10000, /* Disable ASCII restrictions on buddy nicks. */
70} irc_status_t;
71
72typedef enum {
73        CAP_SASL = (1 << 0),
74        CAP_MULTI_PREFIX = (1 << 1),
75        CAP_EXTENDED_JOIN = (1 << 2),
76        CAP_AWAY_NOTIFY = (1 << 3),
77        CAP_USERHOST_IN_NAMES = (1 << 4),
78} irc_cap_flag_t;
79
80struct irc_user;
81
82typedef struct irc {
83        int fd;
84        irc_status_t status;
85        double last_pong;
86        int pinging;
87        char *sendbuffer;
88        char *readbuffer;
89        GIConv iconv, oconv;
90
91        struct irc_user *root;
92        struct irc_user *user;
93
94        char *password; /* HACK: Used to save the user's password, but before
95                           logging in, this may contain a password we should
96                           send to identify after USER/NICK are received. */
97        char *auth_backend;
98
99        char umode[8];
100
101        struct query *queries;
102        GSList *file_transfers;
103
104        GSList *users, *channels;
105        struct irc_channel *default_channel;
106        GHashTable *nick_user_hash;
107        GHashTable *watches; /* See irc_cmd_watch() */
108
109        gint r_watch_source_id;
110        gint w_watch_source_id;
111        gint ping_source_id;
112        gint login_source_id; /* To slightly delay some events at login time. */
113
114        struct otr *otr; /* OTR state and book keeping, used by the OTR plugin.
115                            TODO: Some mechanism for plugindata. */
116
117        struct bee *b;
118        guint32 caps;
119} irc_t;
120
121typedef enum {
122        /* Replaced with iu->last_channel IRC_USER_PRIVATE = 1, */
123        IRC_USER_AWAY = 2,
124
125        IRC_USER_OTR_ENCRYPTED = 0x10000,
126        IRC_USER_OTR_TRUSTED   = 0x20000,
127} irc_user_flags_t;
128
129typedef struct irc_user {
130        irc_t *irc;
131
132        char *nick;
133        char *user;
134        char *host;
135        char *fullname;
136
137        /* Nickname in lowercase for case insensitive searches */
138        char *key;
139
140        irc_user_flags_t flags;
141        struct irc_channel *last_channel;
142
143        GString *pastebuf; /* Paste buffer (combine lines into a multiline msg). */
144        guint pastebuf_timer;
145        time_t away_reply_timeout; /* Only send a 301 if this time passed. */
146
147        struct bee_user *bu;
148
149        const struct irc_user_funcs *f;
150} irc_user_t;
151
152struct irc_user_funcs {
153        gboolean (*privmsg)(irc_user_t *iu, const char *msg);
154        gboolean (*ctcp)(irc_user_t *iu, char * const* ctcp);
155};
156
157extern const struct irc_user_funcs irc_user_root_funcs;
158extern const struct irc_user_funcs irc_user_self_funcs;
159
160typedef enum {
161        IRC_CHANNEL_JOINED = 1, /* The user is currently in the channel. */
162        IRC_CHANNEL_TEMP = 2,   /* Erase the channel when the user leaves,
163                                   and don't save it. */
164
165        /* Hack: Set this flag right before jumping into IM when we expect
166           a call to imcb_chat_new(). */
167        IRC_CHANNEL_CHAT_PICKME = 0x10000,
168} irc_channel_flags_t;
169
170typedef struct irc_channel {
171        irc_t *irc;
172        char *name;
173        char mode[8];
174        int flags;
175
176        char *topic;
177        char *topic_who;
178        time_t topic_time;
179
180        GSList *users; /* struct irc_channel_user */
181        struct irc_user *last_target;
182        struct set *set;
183
184        GString *pastebuf; /* Paste buffer (combine lines into a multiline msg). */
185        guint pastebuf_timer;
186
187        const struct irc_channel_funcs *f;
188        void *data;
189} irc_channel_t;
190
191struct irc_channel_funcs {
192        gboolean (*privmsg)(irc_channel_t *ic, const char *msg);
193        gboolean (*join)(irc_channel_t *ic);
194        gboolean (*part)(irc_channel_t *ic, const char *msg);
195        gboolean (*topic)(irc_channel_t *ic, const char *new_topic);
196        gboolean (*invite)(irc_channel_t *ic, irc_user_t *iu);
197        void (*kick)(irc_channel_t *ic, irc_user_t *iu, const char *msg);
198
199        gboolean (*_init)(irc_channel_t *ic);
200        gboolean (*_free)(irc_channel_t *ic);
201};
202
203typedef enum {
204        IRC_CHANNEL_USER_OP = 1,
205        IRC_CHANNEL_USER_HALFOP = 2,
206        IRC_CHANNEL_USER_VOICE = 4,
207        IRC_CHANNEL_USER_NONE = 8,
208} irc_channel_user_flags_t;
209
210typedef struct irc_channel_user {
211        irc_user_t *iu;
212        int flags;
213} irc_channel_user_t;
214
215typedef enum {
216        IRC_CC_TYPE_DEFAULT  = 0x00001,
217        IRC_CC_TYPE_REST     = 0x00002, /* Still not implemented. */
218        IRC_CC_TYPE_GROUP    = 0x00004,
219        IRC_CC_TYPE_ACCOUNT  = 0x00008,
220        IRC_CC_TYPE_PROTOCOL = 0x00010,
221        IRC_CC_TYPE_MASK     = 0x000ff,
222        IRC_CC_TYPE_INVERT   = 0x00100,
223} irc_control_channel_type_t;
224
225struct irc_control_channel {
226        irc_control_channel_type_t type;
227        struct bee_group *group;
228        struct account *account;
229        struct prpl *protocol;
230        char modes[5];
231};
232
233extern const struct bee_ui_funcs irc_ui_funcs;
234
235typedef enum {
236        IRC_CDU_SILENT,
237        IRC_CDU_PART,
238        IRC_CDU_KICK,
239} irc_channel_del_user_type_t;
240
241/* These are a glued a little bit to the core/bee layer and a little bit to
242   IRC. The first user is OTR, and I guess at some point we'll get to shape
243   this a little bit more as other uses come up. */
244typedef struct irc_plugin {
245        /* Called at the end of irc_new(). Can be used to add settings, etc. */
246        gboolean (*irc_new)(irc_t *irc);
247        /* At the end of irc_free(). */
248        void (*irc_free)(irc_t *irc);
249
250        /* Problem with the following two functions is ordering if multiple
251           plugins are handling them. Let's keep fixing that problem for
252           whenever it becomes important. */
253
254        /* Called by bee_irc_user_privmsg_cb(). Return NULL if you want to
255           abort sending the msg. */
256        char* (*filter_msg_out)(irc_user_t * iu, char *msg, int flags);
257        /* Called by bee_irc_user_msg(). Return NULL if you swallowed the
258           message and don't want anything to go to the user. */
259        char* (*filter_msg_in)(irc_user_t * iu, char *msg, int flags);
260
261        /* From storage.c functions. Ideally these should not be used
262           and instead data should be stored in settings which will get
263           saved automatically. Consider these deprecated! */
264        void (*storage_load)(irc_t *irc);
265        void (*storage_save)(irc_t *irc);
266        void (*storage_remove)(const char *nick);
267} irc_plugin_t;
268
269extern GSList *irc_plugins; /* struct irc_plugin */
270
271/* irc.c */
272extern GSList *irc_connection_list;
273
274irc_t *irc_new(int fd);
275void irc_set_hosts(irc_t *irc, const struct sockaddr *remote_addr, const socklen_t remote_addrlen);
276void irc_abort(irc_t *irc, int immed, char *format, ...) G_GNUC_PRINTF(3, 4);
277void irc_free(irc_t *irc);
278void irc_setpass(irc_t *irc, const char *pass);
279
280void irc_process(irc_t *irc);
281char **irc_parse_line(char *line);
282char *irc_build_line(char **cmd);
283
284void irc_write(irc_t *irc, char *format, ...) G_GNUC_PRINTF(2, 3);
285void irc_write_all(int now, char *format, ...) G_GNUC_PRINTF(2, 3);
286void irc_vawrite(irc_t *irc, char *format, va_list params);
287
288void irc_flush(irc_t *irc);
289void irc_switch_fd(irc_t *irc, int fd);
290void irc_sync(irc_t *irc);
291void irc_desync(irc_t *irc);
292
293int irc_check_login(irc_t *irc);
294
295void irc_umode_set(irc_t *irc, const char *s, gboolean allow_priv);
296
297void register_irc_plugin(const struct irc_plugin *p);
298
299/* irc_channel.c */
300irc_channel_t *irc_channel_new(irc_t *irc, const char *name);
301irc_channel_t *irc_channel_by_name(irc_t *irc, const char *name);
302irc_channel_t *irc_channel_get(irc_t *irc, char *id);
303int irc_channel_free(irc_channel_t *ic);
304void irc_channel_free_soon(irc_channel_t *ic);
305int irc_channel_add_user(irc_channel_t *ic, irc_user_t *iu);
306int irc_channel_del_user(irc_channel_t *ic, irc_user_t *iu, irc_channel_del_user_type_t type, const char *msg);
307irc_channel_user_t *irc_channel_has_user(irc_channel_t *ic, irc_user_t *iu);
308struct irc_channel *irc_channel_with_user(irc_t *irc, irc_user_t *iu);
309int irc_channel_set_topic(irc_channel_t *ic, const char *topic, const irc_user_t *who);
310void irc_channel_user_set_mode(irc_channel_t *ic, irc_user_t *iu, irc_channel_user_flags_t flags);
311void irc_channel_set_mode(irc_channel_t *ic, const char *s);
312void irc_channel_auto_joins(irc_t *irc, struct account *acc);
313void irc_channel_printf(irc_channel_t *ic, char *format, ...) G_GNUC_PRINTF(2, 3);
314gboolean irc_channel_name_ok(const char *name);
315void irc_channel_name_strip(char *name);
316int irc_channel_name_cmp(const char *a_, const char *b_);
317char *irc_channel_name_gen(irc_t *irc, const char *name);
318gboolean irc_channel_name_hint(irc_channel_t *ic, const char *name);
319void irc_channel_update_ops(irc_channel_t *ic, char *value);
320char irc_channel_user_get_prefix(irc_channel_user_t *icu);
321char *set_eval_irc_channel_ops(struct set *set, char *value);
322gboolean irc_channel_wants_user(irc_channel_t *ic, irc_user_t *iu);
323
324/* irc_commands.c */
325void irc_exec(irc_t *irc, char **cmd);
326
327/* irc_send.c */
328void irc_send_num(irc_t *irc, int code, char *format, ...) G_GNUC_PRINTF(3, 4);
329void irc_send_login(irc_t *irc);
330void irc_send_motd(irc_t *irc);
331const char *irc_user_msgdest(irc_user_t *iu);
332void irc_rootmsg(irc_t *irc, char *format, ...) G_GNUC_PRINTF(2, 3);
333void irc_usermsg(irc_user_t *iu, char *format, ...) G_GNUC_PRINTF(2, 3);
334void irc_usernotice(irc_user_t *iu, char *format, ...) G_GNUC_PRINTF(2, 3);
335void irc_send_join(irc_channel_t *ic, irc_user_t *iu);
336void irc_send_part(irc_channel_t *ic, irc_user_t *iu, const char *reason);
337void irc_send_quit(irc_user_t *iu, const char *reason);
338void irc_send_kick(irc_channel_t *ic, irc_user_t *iu, irc_user_t *kicker, const char *reason);
339void irc_send_names(irc_channel_t *ic);
340void irc_send_topic(irc_channel_t *ic, gboolean topic_change);
341void irc_send_whois(irc_user_t *iu);
342void irc_send_who(irc_t *irc, GSList *l, const char *channel);
343void irc_send_msg(irc_user_t *iu, const char *type, const char *dst, const char *msg, const char *prefix);
344void irc_send_msg_raw(irc_user_t *iu, const char *type, const char *dst, const char *msg);
345void irc_send_msg_f(irc_user_t *iu, const char *type, const char *dst, const char *format, ...) G_GNUC_PRINTF(4, 5);
346void irc_send_nick(irc_user_t *iu, const char *new_nick);
347void irc_send_channel_user_mode_diff(irc_channel_t *ic, irc_user_t *iu,
348                                     irc_channel_user_flags_t old_flags, irc_channel_user_flags_t new_flags);
349void irc_send_invite(irc_user_t *iu, irc_channel_t *ic);
350void irc_send_cap(irc_t *irc, char *subcommand, char *body);
351void irc_send_away_notify(irc_user_t *iu);
352
353/* irc_user.c */
354irc_user_t *irc_user_new(irc_t *irc, const char *nick);
355int irc_user_free(irc_t *irc, irc_user_t *iu);
356irc_user_t *irc_user_by_name(irc_t *irc, const char *nick);
357int irc_user_set_nick(irc_user_t *iu, const char *new_nick);
358gint irc_user_cmp(gconstpointer a_, gconstpointer b_);
359const char *irc_user_get_away(irc_user_t *iu);
360void irc_user_quit(irc_user_t *iu, const char *msg);
361
362/* irc_util.c */
363char *set_eval_timezone(struct set *set, char *value);
364char *irc_format_timestamp(irc_t *irc, time_t msg_ts);
365char *set_eval_self_messages(struct set *set, char *value);
366
367/* irc_im.c */
368void bee_irc_channel_update(irc_t *irc, irc_channel_t *ic, irc_user_t *iu);
369void bee_irc_user_nick_reset(irc_user_t *iu);
370
371/* irc_cap.c */
372void irc_cmd_cap(irc_t *irc, char **cmd);
373
374#endif
Note: See TracBrowser for help on using the repository browser.