/* nickserv.h - Nick/authentiction service
* Copyright 2000-2004 srvx Development Team
*
- * This file is part of srvx.
+ * This file is part of x3.
*
* srvx is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
#include "hash.h" /* for NICKLEN, etc., and common.h */
struct svccmd;
-#define NICKSERV_HANDLE_LEN NICKLEN
+#define NICKSERV_HANDLE_LEN ACCOUNTLEN
#define COOKIELEN 10
/* HI_FLAG_* go into handle_info.flags */
#define HI_FLAG_NODELETE 0x00000080
#define HI_FLAG_NETWORK_HELPER 0x00000100
#define HI_FLAG_BOT 0x00000200
+#define HI_FLAG_AUTOHIDE 0x00000400
/* Flag characters for the above. First char is LSB, etc. */
-#define HANDLE_FLAGS "SphgscfnHb"
+#define HANDLE_FLAGS "SphgscfnHbx"
/* HI_STYLE_* go into handle_info.userlist_style */
#define HI_STYLE_DEF 'd'
char cookie[COOKIELEN+1];
};
+struct handle_note {
+ char setter[NICKSERV_HANDLE_LEN+1];
+ time_t date;
+ char note[1];
+};
+
struct handle_info {
struct nick_info *nicks;
struct string_list *masks;
struct userNode *users;
struct userData *channels;
struct handle_cookie *cookie;
+ struct handle_note *note;
struct language *language;
char *email_addr;
char *epithet;
int oper_has_access(struct userNode *user, struct userNode *bot, unsigned int min_level, unsigned int quiet);
void nickserv_show_oper_accounts(struct userNode *user, struct svccmd *cmd);
+struct handle_info *loc_auth(char *handle, char *password);
+
/* 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);
typedef void (*failpw_func_t)(struct userNode *user, struct handle_info *handle);
void reg_failpw_func(failpw_func_t func);
+void send_func_list(struct userNode *user);
+
#endif