X-Git-Url: https://jfr.im/git/solanum.git/blobdiff_plain/5b96d9a6b92f3ca219ff2baab7596cc94580813d..0ba1da59101281fd8c6a91e068ba6dab1b9292dd:/include/hook.h diff --git a/include/hook.h b/include/hook.h index 24da17e7..c9dcf93e 100644 --- a/include/hook.h +++ b/include/hook.h @@ -1,8 +1,6 @@ /* * Copyright (C) 2004-2005 Lee Hardy * Copyright (C) 2004-2005 ircd-ratbox development team - * - * $Id: hook.h 906 2006-02-21 02:25:43Z nenolod $ */ #ifndef INCLUDED_HOOK_H #define INCLUDED_HOOK_H @@ -13,41 +11,69 @@ typedef struct rb_dlink_list hooks; } hook; +enum hook_priority +{ + HOOK_LOWEST = 10, + HOOK_LOW = 20, + HOOK_NORMAL = 30, + HOOK_HIGH = 40, + HOOK_HIGHEST = 50, + HOOK_MONITOR = 100 +}; + typedef void (*hookfn) (void *data); -int h_iosend_id; -int h_iorecv_id; -int h_iorecvctrl_id; - -int h_burst_client; -int h_burst_channel; -int h_burst_finished; -int h_server_introduced; -int h_server_eob; -int h_client_exit; -int h_umode_changed; -int h_new_local_user; -int h_new_remote_user; -int h_introduce_client; +extern int h_iosend_id; +extern int h_iorecv_id; +extern int h_iorecvctrl_id; + +extern int h_burst_client; +extern int h_burst_channel; +extern int h_burst_finished; +extern int h_server_introduced; +extern int h_server_eob; +extern int h_client_exit; +extern int h_after_client_exit; +extern int h_umode_changed; +extern int h_new_local_user; +extern int h_new_remote_user; +extern int h_introduce_client; +extern int h_can_kick; +extern int h_privmsg_channel; +extern int h_privmsg_user; +extern int h_conf_read_start; +extern int h_conf_read_end; +extern int h_outbound_msgbuf; +extern int h_rehash; +extern int h_cap_change; void init_hook(void); int register_hook(const char *name); void add_hook(const char *name, hookfn fn); +void add_hook_prio(const char *name, hookfn fn, enum hook_priority priority); void remove_hook(const char *name, hookfn fn); void call_hook(int id, void *arg); +typedef struct +{ + struct Client *client; + void *arg1; + void *arg2; +} hook_data; + typedef struct { struct Client *client; const void *arg1; const void *arg2; -} hook_data; +} hook_cdata; typedef struct { struct Client *client; const void *arg1; int arg2; + int result; } hook_data_int; typedef struct @@ -67,12 +93,35 @@ typedef struct { struct Client *client; struct Channel *chptr; - char *key; + const char *key; } hook_data_channel_activity; typedef struct { struct Client *client; + struct Channel *chptr; + struct membership *msptr; + struct Client *target; + int approved; + int dir; + const char *modestr; + const char *error; +} hook_data_channel_approval; + +typedef struct +{ + struct Client *client; + struct Client *target; + struct Channel *chptr; + struct membership *clientms; + struct membership *targetms; + int approved; +} hook_data_channel_visibility; + +typedef struct +{ + struct Client *client; + struct Client *target; int approved; } hook_data_client_approval; @@ -84,6 +133,13 @@ typedef struct const char *comment; } hook_data_client_exit; +typedef struct +{ + struct Client *client; + const char *reason; + const char *orig_reason; +} hook_data_client_quit; + typedef struct { struct Client *client; @@ -91,4 +147,42 @@ typedef struct unsigned int oldsnomask; } hook_data_umode_changed; +typedef struct +{ + struct Client *client; + int oldcaps; + int add; + int del; +} hook_data_cap_change; + +enum message_type { + MESSAGE_TYPE_NOTICE, + MESSAGE_TYPE_PRIVMSG, + MESSAGE_TYPE_PART, + MESSAGE_TYPE_COUNT +}; + +typedef struct +{ + enum message_type msgtype; + struct Client *source_p; + struct Channel *chptr; + const char *text; + int approved; +} hook_data_privmsg_channel; + +typedef struct +{ + enum message_type msgtype; + struct Client *source_p; + struct Client *target_p; + const char *text; + int approved; +} hook_data_privmsg_user; + +typedef struct +{ + bool signal; +} hook_data_rehash; + #endif