X-Git-Url: https://jfr.im/git/irc/evilnet/x3.git/blobdiff_plain/8d88296547880e2eb6a89764cef4b0505705c114..HEAD:/src/hash.h diff --git a/src/hash.h b/src/hash.h index 513638a..3c36823 100644 --- a/src/hash.h +++ b/src/hash.h @@ -23,7 +23,9 @@ #include "common.h" #include "dict.h" +#include "eventhooks.h" #include "policer.h" +#include "recdb.h" #define MODE_CHANOP 0x00000001 /* +o USER */ #define MODE_VOICE 0x00000002 /* +v USER */ @@ -186,6 +188,11 @@ enum Priv { PRIV_REMOVE, /**< oper can force remove deactivated glines, shuns and zlines. */ PRIV_SPAMFILTER, /**< oper can set spamfilters via SPAMFILTER */ + PRIV_ADMIN, /**< oper is an IRC Admin */ + PRIV_APASS_OPMODE, /**< oper can use OPMODE to set/unset channel modes +A and +U */ + PRIV_HIDE_OPER, /**< oper can set/unset user mode +H */ + PRIV_REMOTE, /**< oper can use his/her operator block from a remote server */ + PRIV_SERVICE, /**< oper can set/unset user mode +k */ PRIV_LAST_PRIV /**< number of privileges */ }; @@ -246,6 +253,8 @@ struct userNode { char *version_reply; /* only filled in if a version query was triggered */ char *sslfp; /* only filled in if a mark SSLCLIFP is received */ + struct string_list *marks; /* list of user's marks */ + time_t timestamp; /* Time of last nick change */ time_t idle_since; struct server *uplink; /* Server that user is connected to */ @@ -375,6 +384,11 @@ struct route { struct routeList *servers; }; +/* generic hook function args */ +struct funcargs { + void *func; + void *extra; +}; extern struct server *self; extern dict_t channels; @@ -384,6 +398,8 @@ extern unsigned int max_clients, invis_clients; extern time_t max_clients_time; extern struct userList curr_opers, curr_helpers; +extern unsigned int count_opers; + struct server* GetServerH(const char *name); /* using full name */ struct userNode* GetUserH(const char *nick); /* using nick */ struct chanNode* GetChannel(const char *name); @@ -395,8 +411,14 @@ typedef int (*server_link_func_t) (struct server *server, void *extra); void reg_server_link_func(server_link_func_t handler, void *extra); void call_server_link_funcs(struct server *server); +typedef void (*sasl_input_func_t) (struct server* source ,const char *identifier, const char *subcmd, const char *data, const char *ext, void *extra); +void reg_sasl_input_func(sasl_input_func_t handler, void *extra); +void call_sasl_input_func(struct server* source ,const char *identifier, const char *subcmd, const char *data, const char *ext); +void unreg_sasl_input_func(sasl_input_func_t handler, void *extra); + typedef int (*new_user_func_t) (struct userNode *user, void *extra); void reg_new_user_func(new_user_func_t handler, void *extra); +void reg_new_user_func_pos(new_user_func_t handler, void *extra, int pos); void call_new_user_funcs(struct userNode *user); typedef void (*del_user_func_t) (struct userNode *user, struct userNode *killer, const char *why, void *extra); void reg_del_user_func(del_user_func_t handler, void *extra); @@ -418,6 +440,7 @@ void set_geoip_info(struct userNode *user); typedef void (*new_channel_func_t) (struct chanNode *chan, void *extra); void reg_new_channel_func(new_channel_func_t handler, void *extra); typedef int (*join_func_t) (struct modeNode *mNode, void *extra); +void reg_join_func_pos(join_func_t handler, void *extra, int pos); void reg_join_func(join_func_t handler, void *extra); typedef void (*del_channel_func_t) (struct chanNode *chan, void *extra); void reg_del_channel_func(del_channel_func_t handler, void *extra);