X-Git-Url: https://jfr.im/git/irc/evilnet/x3.git/blobdiff_plain/e3e5ba494aa6cacd920c5dbc2cbe61e56b6d6cb1..8536ac6b661fa261bad7de981045401f514fb6b7:/src/nickserv.h diff --git a/src/nickserv.h b/src/nickserv.h index 84b4ecf..490382a 100644 --- a/src/nickserv.h +++ b/src/nickserv.h @@ -5,7 +5,7 @@ * * x3 is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by - * the Free Software Foundation; either version 2 of the License, or + * the Free Software Foundation; either version 3 of the License, or * (at your option) any later version. * * This program is distributed in the hope that it will be useful, @@ -22,6 +22,8 @@ #define _nickserv_h #include "hash.h" /* for NICKLEN, etc., and common.h */ +#include "dict.h" +#include /* for regex in nickserv_config */ struct svccmd; #define NICKSERV_HANDLE_LEN ACCOUNTLEN @@ -90,6 +92,7 @@ struct handle_note { struct handle_info { struct nick_info *nicks; struct string_list *masks; + struct string_list *sslfps; struct string_list *ignores; struct userNode *users; struct userData *channels; @@ -101,11 +104,9 @@ struct handle_info { char *infoline; char *handle; char *fakehost; -#ifdef WITH_PROTOCOL_BAHAMUT - unsigned long id; -#endif time_t registered; time_t lastseen; + int karma; unsigned short flags; unsigned short opserv_level; unsigned short screen_width; @@ -131,6 +132,86 @@ struct handle_info_list { extern const char *handle_flags; +enum reclaim_action { + RECLAIM_NONE, + RECLAIM_WARN, + RECLAIM_SVSNICK, + RECLAIM_KILL +}; + +struct nickserv_config { + unsigned int disable_nicks : 1; + unsigned int valid_handle_regex_set : 1; + unsigned int valid_nick_regex_set : 1; + unsigned int valid_fakehost_regex_set : 1; + unsigned int autogag_enabled : 1; + unsigned int email_enabled : 1; + unsigned int email_required : 1; + unsigned int default_hostmask : 1; + unsigned int warn_nick_owned : 1; + unsigned int warn_clone_auth : 1; + unsigned int sync_log : 1; + unsigned long nicks_per_handle; + unsigned long password_min_length; + unsigned long password_min_digits; + unsigned long password_min_upper; + unsigned long password_min_lower; + unsigned long db_backup_frequency; + unsigned long handle_expire_frequency; + unsigned long autogag_duration; + unsigned long email_visible_level; + unsigned long cookie_timeout; + unsigned long handle_expire_delay; + unsigned long nochan_handle_expire_delay; + unsigned long modoper_level; + unsigned long set_epithet_level; + unsigned long set_title_level; + unsigned long set_fakehost_level; + unsigned long handles_per_email; + unsigned long email_search_level; + const char *network_name; + const char *titlehost_suffix; + regex_t valid_handle_regex; + regex_t valid_nick_regex; + regex_t valid_fakehost_regex; + dict_t weak_password_dict; + struct policer_params *auth_policer_params; + enum reclaim_action reclaim_action; + enum reclaim_action auto_reclaim_action; + unsigned long auto_reclaim_delay; + unsigned char default_maxlogins; + unsigned char hard_maxlogins; + unsigned long ounregister_inactive; + unsigned long ounregister_flags; + const char *auto_oper; + const char *auto_admin; + const char *auto_oper_privs; + const char *auto_admin_privs; + char default_style; + struct string_list *denied_fakehost_words; + unsigned int force_handles_lowercase; + unsigned int ldap_enable; +#ifdef WITH_LDAP + const char *ldap_uri; + const char *ldap_base; + const char *ldap_dn_fmt; + unsigned int ldap_version; + unsigned int ldap_autocreate; + + const char *ldap_admin_dn; + const char *ldap_admin_pass; + const char *ldap_field_account; + const char *ldap_field_password; + const char *ldap_field_email; + const char *ldap_field_oslevel; + struct string_list *ldap_object_classes; + const char *ldap_oper_group_dn; + unsigned int ldap_oper_group_level; + const char *ldap_field_group_member; + unsigned int ldap_timeout; +#endif +}; + void init_nickserv(const char *nick); struct handle_info *get_handle_info(const char *handle); struct handle_info *smart_get_handle_info(struct userNode *service, struct userNode *user, const char *name); @@ -143,41 +224,43 @@ int oper_has_access(struct userNode *user, struct userNode *bot, unsigned int mi void nickserv_show_oper_accounts(struct userNode *user, struct svccmd *cmd); struct handle_info *get_victim_oper(struct userNode *user, const char *target); -struct handle_info *loc_auth(char *handle, char *password); +struct handle_info *loc_auth(char *sslfp, char *handle, char *password, char *userhost); -typedef void (*user_mode_func_t)(struct userNode *user, const char *mode_change); -void reg_user_mode_func(user_mode_func_t func); -typedef void (*channel_mode_func_t)(struct userNode *who, struct chanNode *channel, char **mode, unsigned int argc); -void reg_channel_mode_func(channel_mode_func_t func); +typedef void (*user_mode_func_t)(struct userNode *user, const char *mode_change, void *extra); +void reg_user_mode_func(user_mode_func_t func, void *extra); +typedef void (*channel_mode_func_t)(struct userNode *who, struct chanNode *channel, char **mode, unsigned int argc, void *extra); +void reg_channel_mode_func(channel_mode_func_t func, void *extra); /* auth_funcs are called when a user gets a new handle_info. They are * called *after* user->handle_info has been updated. */ -typedef void (*auth_func_t)(struct userNode *user, struct handle_info *old_handle); -void reg_auth_func(auth_func_t func); +typedef void (*auth_func_t)(struct userNode *user, struct handle_info *old_handle, void *extra); +void reg_auth_func(auth_func_t func, void *extra); /* Called just after a handle is renamed. */ -typedef void (*handle_rename_func_t)(struct handle_info *handle, const char *old_handle); -void reg_handle_rename_func(handle_rename_func_t func); +typedef void (*handle_rename_func_t)(struct handle_info *handle, const char *old_handle, void *extra); +void reg_handle_rename_func(handle_rename_func_t func, void *extra); /* unreg_funcs are called right before a handle is unregistered. * `user' is the person who caused the handle to be unregistered (either a * client authed to the handle, or an oper). */ -typedef void (*unreg_func_t)(struct userNode *user, struct handle_info *handle); -void reg_unreg_func(unreg_func_t func); +typedef void (*unreg_func_t)(struct userNode *user, struct handle_info *handle, void *extra); +void reg_unreg_func(unreg_func_t func, void *extra); /* Called just before a handle is merged */ -typedef void (*handle_merge_func_t)(struct userNode *user, struct handle_info *handle_to, struct handle_info *handle_from); -void reg_handle_merge_func(handle_merge_func_t); +typedef void (*handle_merge_func_t)(struct userNode *user, struct handle_info *handle_to, struct handle_info *handle_from, void *extra); +void reg_handle_merge_func(handle_merge_func_t, void *extra); /* Called after an allowauth. handle is null if allowauth authorization was * removed */ -typedef void (*allowauth_func_t)(struct userNode *user, struct userNode *target, struct handle_info *handle); -void reg_allowauth_func(allowauth_func_t func); +typedef void (*allowauth_func_t)(struct userNode *user, struct userNode *target, struct handle_info *handle, void *extra); +void reg_allowauth_func(allowauth_func_t func, void *extra); /* Called when an auth attempt fails because of a bad password */ -typedef void (*failpw_func_t)(struct userNode *user, struct handle_info *handle); -void reg_failpw_func(failpw_func_t func); +typedef void (*failpw_func_t)(struct userNode *user, struct handle_info *handle, void *extra); +void reg_failpw_func(failpw_func_t func, void *extra); void send_func_list(struct userNode *user); +extern dict_t nickserv_handle_dict; + #endif