diff --git a/net/uhub/patches/100-user_struct.patch b/net/uhub/patches/100-user_struct.patch new file mode 100644 index 000000000..62fb99276 --- /dev/null +++ b/net/uhub/patches/100-user_struct.patch @@ -0,0 +1,1664 @@ +--- a/src/auth.c ++++ b/src/auth.c +@@ -70,7 +70,7 @@ + { + char* data; + char* data_extra; +- struct user_access_info* info = 0; ++ struct uhub_user_access_info* info = 0; + + if (!strncmp(line, cmd, strlen(cmd))) + { +@@ -86,7 +86,7 @@ + return -1; + } + +- info = hub_malloc_zero(sizeof(struct user_access_info)); ++ info = hub_malloc_zero(sizeof(struct uhub_user_access_info)); + + if (!info) + { +@@ -340,7 +340,7 @@ + + static void acl_free_access_info(void* ptr) + { +- struct user_access_info* info = (struct user_access_info*) ptr; ++ struct uhub_user_access_info* info = (struct uhub_user_access_info*) ptr; + if (info) + { + hub_free(info->username); +@@ -404,16 +404,16 @@ + } + + +-struct user_access_info* acl_get_access_info(struct acl_handle* handle, const char* name) ++struct uhub_user_access_info* acl_get_access_info(struct acl_handle* handle, const char* name) + { +- struct user_access_info* info = (struct user_access_info*) list_get_first(handle->users); ++ struct uhub_user_access_info* info = (struct uhub_user_access_info*) list_get_first(handle->users); + while (info) + { + if (strcasecmp(info->username, name) == 0) + { + return info; + } +- info = (struct user_access_info*) list_get_next(handle->users); ++ info = (struct uhub_user_access_info*) list_get_next(handle->users); + } + return NULL; + } +@@ -492,7 +492,7 @@ + * seconds since the unix epoch (modulus 1 million) + * and the SID of the user (0-1 million). + */ +-const char* password_generate_challenge(struct user* user) ++const char* password_generate_challenge(struct uhub_user* user) + { + char buf[32]; + uint64_t tiger_res[3]; +@@ -511,10 +511,10 @@ + } + + +-int password_verify(struct user* user, const char* password) ++int password_verify(struct uhub_user* user, const char* password) + { + char buf[1024]; +- struct user_access_info* access; ++ struct uhub_user_access_info* access; + const char* challenge; + char raw_challenge[64]; + char password_calc[64]; +--- a/src/auth.h ++++ b/src/auth.h +@@ -21,7 +21,7 @@ + #define HAVE_UHUB_ACL_H + + struct hub_config; +-struct user; ++struct uhub_user; + struct ip_addr_encap; + + enum password_status +@@ -50,7 +50,7 @@ + + const char* get_user_credential_string(enum user_credentials cred); + +-struct user_access_info ++struct uhub_user_access_info + { + char* username; /* name of user, cid or IP range */ + char* password; /* password */ +@@ -77,7 +77,7 @@ + extern int acl_initialize(struct hub_config* config, struct acl_handle* handle); + extern int acl_shutdown(struct acl_handle* handle); + +-extern struct user_access_info* acl_get_access_info(struct acl_handle* handle, const char* name); ++extern struct uhub_user_access_info* acl_get_access_info(struct acl_handle* handle, const char* name); + extern int acl_is_cid_banned(struct acl_handle* handle, const char* cid); + extern int acl_is_ip_banned(struct acl_handle* handle, const char* ip_address); + extern int acl_is_ip_nat_override(struct acl_handle* handle, const char* ip_address); +@@ -87,7 +87,7 @@ + + extern int acl_check_ip_range(struct ip_addr_encap* addr, struct ip_ban_record* info); + +-extern const char* password_generate_challenge(struct user* user); +-extern int password_verify(struct user* user, const char* password); ++extern const char* password_generate_challenge(struct uhub_user* user); ++extern int password_verify(struct uhub_user* user, const char* password); + + #endif /* HAVE_UHUB_ACL_H */ +--- a/src/commands.c ++++ b/src/commands.c +@@ -19,7 +19,7 @@ + + #include "uhub.h" + +-typedef int (*command_handler)(struct user* user, const char* message); ++typedef int (*command_handler)(struct uhub_user* user, const char* message); + + struct commands_handler + { +@@ -32,7 +32,7 @@ + + static struct commands_handler command_handlers[]; + +-static void send_message(struct user* user, const char* message) ++static void send_message(struct uhub_user* user, const char* message) + { + char* buffer = adc_msg_escape(message); + struct adc_message* command = adc_msg_construct(ADC_CMD_IMSG, strlen(buffer) + 6); +@@ -42,7 +42,7 @@ + hub_free(buffer); + } + +-static int command_access_denied(struct user* user, const char* command) ++static int command_access_denied(struct uhub_user* user, const char* command) + { + char temp[64]; + snprintf(temp, 64, "*** Access denied: \"%s\"", command); +@@ -51,7 +51,7 @@ + } + + +-static int command_stats(struct user* user, const char* message) ++static int command_stats(struct uhub_user* user, const char* message) + { + char temp[128]; + snprintf(temp, 128, "*** Stats: %zu users, peak: %zu. Network (up/down): %d/%d KB/s, peak: %d/%d KB/s", +@@ -67,7 +67,7 @@ + } + + +-static int command_help(struct user* user, const char* message) ++static int command_help(struct uhub_user* user, const char* message) + { + #define MAX_HELP_MSG 1024 + size_t n; +@@ -89,7 +89,7 @@ + return 0; + } + +-static int command_uptime(struct user* user, const char* message) ++static int command_uptime(struct uhub_user* user, const char* message) + { + char tmp[128]; + size_t d; +@@ -124,20 +124,20 @@ + return 0; + } + +-static int command_kick(struct user* user, const char* message) ++static int command_kick(struct uhub_user* user, const char* message) + { + send_message(user, "*** Kick not implemented!"); + return 0; + } + +-static int command_reload(struct user* user, const char* message) ++static int command_reload(struct uhub_user* user, const char* message) + { + send_message(user, "*** Reloading configuration"); + user->hub->status = hub_status_restart; + return 0; + } + +-static int command_shutdown(struct user* user, const char* message) ++static int command_shutdown(struct uhub_user* user, const char* message) + { + send_message(user, "*** Hub shuting down..."); + user->hub->status = hub_status_shutdown; +@@ -145,13 +145,13 @@ + } + + +-static int command_version(struct user* user, const char* message) ++static int command_version(struct uhub_user* user, const char* message) + { + send_message(user, "*** Powered by " PRODUCT "/" VERSION); + return 0; + } + +-static int command_myip(struct user* user, const char* message) ++static int command_myip(struct uhub_user* user, const char* message) + { + char tmp[128]; + snprintf(tmp, 128, "*** Your IP: %s", ip_convert_to_string(&user->ipaddr)); +@@ -159,7 +159,7 @@ + return 0; + } + +-int command_dipatcher(struct user* user, const char* message) ++int command_dipatcher(struct uhub_user* user, const char* message) + { + size_t n = 0; + for (n = 0; command_handlers[n].prefix; n++) +--- a/src/commands.h ++++ b/src/commands.h +@@ -23,7 +23,7 @@ + #define CHAT_MSG_IGNORED 0 + #define CHAT_MSG_INVALID -1 + +-typedef int (*plugin_event_chat_message)(struct hub_info*, struct user*, struct adc_message*); ++typedef int (*plugin_event_chat_message)(struct hub_info*, struct uhub_user*, struct adc_message*); + + struct command_info + { +@@ -32,4 +32,4 @@ + plugin_event_chat_message function; + }; + +-int command_dipatcher(struct user* user, const char* message); ++int command_dipatcher(struct uhub_user* user, const char* message); +--- a/src/hub.c ++++ b/src/hub.c +@@ -19,7 +19,7 @@ + + #include "uhub.h" + +-int hub_handle_message(struct user* u, const char* line, size_t length) ++int hub_handle_message(struct uhub_user* u, const char* line, size_t length) + { + int ret = 0; + struct adc_message* cmd = 0; +@@ -96,7 +96,7 @@ + } + + +-int hub_handle_support(struct user* u, struct adc_message* cmd) ++int hub_handle_support(struct uhub_user* u, struct adc_message* cmd) + { + int ret = 0; + int index = 0; +@@ -161,7 +161,7 @@ + } + + +-int hub_handle_password(struct user* u, struct adc_message* cmd) ++int hub_handle_password(struct uhub_user* u, struct adc_message* cmd) + { + char* password = adc_msg_get_argument(cmd, 0); + int ret = 0; +@@ -184,7 +184,7 @@ + } + + +-int hub_handle_chat_message(struct user* u, struct adc_message* cmd) ++int hub_handle_chat_message(struct uhub_user* u, struct adc_message* cmd) + { + char* message = adc_msg_get_argument(cmd, 0); + int ret = 0; +@@ -206,14 +206,14 @@ + return ret; + } + +-int on_kick(struct user* u, struct adc_message* cmd) ++int on_kick(struct uhub_user* u, struct adc_message* cmd) + { + hub_log(log_error, "on_kick() not implemented"); + return -1; + } + + #ifdef ADC_UDP_OPERATION +-int hub_handle_autocheck(struct user* u, struct adc_message* cmd) ++int hub_handle_autocheck(struct uhub_user* u, struct adc_message* cmd) + { + char* port_str = adc_msg_get_argument(cmd, 0); + char* token = adc_msg_get_argument(cmd, 1); +@@ -245,13 +245,13 @@ + #endif + + +-void hub_send_autocheck(struct user* u, uint16_t port, const char* token) ++void hub_send_autocheck(struct uhub_user* u, uint16_t port, const char* token) + { + + } + + +-void hub_send_support(struct user* u) ++void hub_send_support(struct uhub_user* u) + { + if (user_is_connecting(u) || user_is_logged_in(u)) + { +@@ -260,7 +260,7 @@ + } + + +-void hub_send_sid(struct user* u) ++void hub_send_sid(struct uhub_user* u) + { + struct adc_message* command; + if (user_is_connecting(u)) +@@ -274,7 +274,7 @@ + } + + +-void hub_send_ping(struct user* user) ++void hub_send_ping(struct uhub_user* user) + { + /* This will just send a newline, despite appearing to do more below. */ + struct adc_message* ping = adc_msg_construct(0, 0); +@@ -287,7 +287,7 @@ + } + + +-void hub_send_hubinfo(struct user* u) ++void hub_send_hubinfo(struct uhub_user* u) + { + struct adc_message* info = adc_msg_copy(u->hub->command_info); + int value = 0; +@@ -356,7 +356,7 @@ + } + + +-void hub_send_handshake(struct user* u) ++void hub_send_handshake(struct uhub_user* u) + { + hub_send_support(u); + hub_send_sid(u); +@@ -369,7 +369,7 @@ + } + + +-void hub_send_motd(struct user* u) ++void hub_send_motd(struct uhub_user* u) + { + if (u->hub->command_motd) + { +@@ -378,7 +378,7 @@ + } + + +-void hub_send_password_challenge(struct user* u) ++void hub_send_password_challenge(struct uhub_user* u) + { + struct adc_message* igpa; + igpa = adc_msg_construct(ADC_CMD_IGPA, 38); +@@ -399,33 +399,33 @@ + { + case UHUB_EVENT_USER_JOIN: + { +- if (user_is_disconnecting((struct user*) message->ptr)) ++ if (user_is_disconnecting((struct uhub_user*) message->ptr)) + break; + + if (message->flags) + { +- hub_send_password_challenge((struct user*) message->ptr); ++ hub_send_password_challenge((struct uhub_user*) message->ptr); + } + else + { +- on_login_success((struct user*) message->ptr); ++ on_login_success((struct uhub_user*) message->ptr); + } + break; + } + + case UHUB_EVENT_USER_QUIT: + { +- user_manager_remove((struct user*) message->ptr); +- send_quit_message((struct user*) message->ptr); +- on_logout_user((struct user*) message->ptr); +- user_schedule_destroy((struct user*) message->ptr); ++ user_manager_remove((struct uhub_user*) message->ptr); ++ send_quit_message((struct uhub_user*) message->ptr); ++ on_logout_user((struct uhub_user*) message->ptr); ++ user_schedule_destroy((struct uhub_user*) message->ptr); + break; + } + + case UHUB_EVENT_USER_DESTROY: + { + hub_log(log_trace, "hub_event_dispatcher: UHUB_EVENT_USER_DESTROY (ptr=%p)", message->ptr); +- user_destroy((struct user*) message->ptr); ++ user_destroy((struct uhub_user*) message->ptr); + break; + } + +@@ -757,7 +757,7 @@ + */ + static inline int is_nick_in_use(struct hub_info* hub, const char* nick) + { +- struct user* lookup = get_user_by_nick(hub, nick); ++ struct uhub_user* lookup = get_user_by_nick(hub, nick); + if (lookup) + { + return 1; +@@ -771,7 +771,7 @@ + */ + static inline int is_cid_in_use(struct hub_info* hub, const char* cid) + { +- struct user* lookup = get_user_by_cid(hub, cid); ++ struct uhub_user* lookup = get_user_by_cid(hub, cid); + if (lookup) + { + return 1; +@@ -796,7 +796,7 @@ + * @param msg See enum status_message + * @param level See enum status_level + */ +-void hub_send_status(struct user* user, enum status_message msg, enum msg_status_level level) ++void hub_send_status(struct uhub_user* user, enum status_message msg, enum msg_status_level level) + { + struct hub_config* cfg = user->hub->config; + struct adc_message* cmd = adc_msg_construct(ADC_CMD_ISTA, 6); +--- a/src/hubevent.c ++++ b/src/hubevent.c +@@ -19,27 +19,27 @@ + + #include "uhub.h" + +-static void log_user_login(struct user* u) ++static void log_user_login(struct uhub_user* u) + { + const char* cred = get_user_credential_string(u->credentials); + const char* addr = ip_convert_to_string(&u->ipaddr); + hub_log(log_user, "LoginOK %s/%s %s \"%s\" (%s) \"%s\"", sid_to_string(u->id.sid), u->id.cid, addr, u->id.nick, cred, u->user_agent); + } + +-static void log_user_login_error(struct user* u, enum status_message msg) ++static void log_user_login_error(struct uhub_user* u, enum status_message msg) + { + const char* addr = ip_convert_to_string(&u->ipaddr); + const char* message = hub_get_status_message_log(u->hub, msg); + hub_log(log_user, "LoginError %s/%s %s \"%s\" (%s) \"%s\"", sid_to_string(u->id.sid), u->id.cid, addr, u->id.nick, message, u->user_agent); + } + +-static void log_user_logout(struct user* u, const char* message) ++static void log_user_logout(struct uhub_user* u, const char* message) + { + const char* addr = ip_convert_to_string(&u->ipaddr); + hub_log(log_user, "Logout %s/%s %s \"%s\" (%s)", sid_to_string(u->id.sid), u->id.cid, addr, u->id.nick, message); + } + +-static void log_user_nick_change(struct user* u, const char* nick) ++static void log_user_nick_change(struct uhub_user* u, const char* nick) + { + const char* addr = ip_convert_to_string(&u->ipaddr); + hub_log(log_user, "NickChange %s/%s %s \"%s\" -> \"%s\"", sid_to_string(u->id.sid), u->id.cid, addr, u->id.nick, nick); +@@ -47,7 +47,7 @@ + + + /* Send MOTD, do logging etc */ +-void on_login_success(struct user* u) ++void on_login_success(struct uhub_user* u) + { + struct timeval timeout = { TIMEOUT_IDLE, 0 }; + +@@ -75,14 +75,14 @@ + event_add(u->ev_read, &timeout); + } + +-void on_login_failure(struct user* u, enum status_message msg) ++void on_login_failure(struct uhub_user* u, enum status_message msg) + { + log_user_login_error(u, msg); + hub_send_status(u, msg, status_level_fatal); + user_disconnect(u, quit_logon_error); + } + +-void on_nick_change(struct user* u, const char* nick) ++void on_nick_change(struct uhub_user* u, const char* nick) + { + if (user_is_logged_in(u)) + { +@@ -90,7 +90,7 @@ + } + } + +-void on_logout_user(struct user* user) ++void on_logout_user(struct uhub_user* user) + { + const char* reason = ""; + +--- a/src/hubevent.h ++++ b/src/hubevent.h +@@ -23,22 +23,22 @@ + /** + * This event is triggered whenever a user successfully logs in to the hub. + */ +-extern void on_login_success(struct user* u); ++extern void on_login_success(struct uhub_user* u); + + /** + * This event is triggered whenever a user failed to log in to the hub. + */ +-extern void on_login_failure(struct user* u, enum status_message msg); ++extern void on_login_failure(struct uhub_user* u, enum status_message msg); + + /** + * This event is triggered whenever a previously logged in user leaves the hub. + */ +-extern void on_logout_user(struct user* u); ++extern void on_logout_user(struct uhub_user* u); + + /** + * This event is triggered whenever a user changes his/her nickname. + */ +-extern void on_nick_change(struct user* u, const char* nick); ++extern void on_nick_change(struct uhub_user* u, const char* nick); + + + #endif /* HAVE_UHUB_HUB_EVENT_H */ +--- a/src/hub.h ++++ b/src/hub.h +@@ -94,7 +94,7 @@ + struct event_queue* queue; + struct event_base* evbase; + struct hub_config* config; +- struct user_manager* users; ++ struct uhub_user_manager* users; + struct acl_handle* acl; + struct adc_message* command_info; /* The hub's INF command */ + struct adc_message* command_support; /* The hub's SUP command */ +@@ -116,103 +116,103 @@ + * + * @return 0 on success, -1 on error + */ +-extern int hub_handle_message(struct user* u, const char* message, size_t length); ++extern int hub_handle_message(struct uhub_user* u, const char* message, size_t length); + + /** + * Handle protocol support/subscription messages received clients. + * + * @return 0 on success, -1 on error + */ +-extern int hub_handle_support(struct user* u, struct adc_message* cmd); ++extern int hub_handle_support(struct uhub_user* u, struct adc_message* cmd); + + /** + * Handle password messages received from clients. + * + * @return 0 on success, -1 on error + */ +-extern int hub_handle_password(struct user* u, struct adc_message* cmd); ++extern int hub_handle_password(struct uhub_user* u, struct adc_message* cmd); + + /** + * Handle chat messages received from clients. + * @return 0 on success, -1 on error. + */ +-extern int hub_handle_chat_message(struct user* u, struct adc_message* cmd); ++extern int hub_handle_chat_message(struct uhub_user* u, struct adc_message* cmd); + + /** + * Used internally by hub_handle_info + * @return 1 if nickname is OK, or 0 if nickname is not accepted. + */ +-extern int hub_handle_info_check_nick(struct user* u, struct adc_message* cmd); ++extern int hub_handle_info_check_nick(struct uhub_user* u, struct adc_message* cmd); + + /** + * Used internally by hub_handle_info + * @return 1 if CID/PID is OK, or 0 if not valid. + */ +-extern int hub_handle_info_check_cid(struct user* u, struct adc_message* cmd); ++extern int hub_handle_info_check_cid(struct uhub_user* u, struct adc_message* cmd); + + /** + * Can only be used by administrators or operators. + * + * @return 0 on success, -1 on error + */ +-extern int hub_handle_kick(struct user* u, struct adc_message* cmd); ++extern int hub_handle_kick(struct uhub_user* u, struct adc_message* cmd); + + #ifdef ADC_UDP_OPERATION + /** + * Handle incoming autocheck message. + */ +-extern int hub_handle_autocheck(struct user* u, struct adc_message* cmd); ++extern int hub_handle_autocheck(struct uhub_user* u, struct adc_message* cmd); + #endif + + /** + * Send the support line for the hub to a particular user. + * Only used during the initial handshake. + */ +-extern void hub_send_support(struct user* u); ++extern void hub_send_support(struct uhub_user* u); + + /** + * Send a message assigning a SID for a user. + * This is only sent after hub_send_support() during initial handshake. + */ +-extern void hub_send_sid(struct user* u); ++extern void hub_send_sid(struct uhub_user* u); + + /** + * Send a 'ping' message to user. + */ +-extern void hub_send_ping(struct user* user); ++extern void hub_send_ping(struct uhub_user* user); + + /** + * Send a message containing hub information to a particular user. + * This is sent during user connection, but can safely be sent at any + * point later. + */ +-extern void hub_send_hubinfo(struct user* u); ++extern void hub_send_hubinfo(struct uhub_user* u); + + /** + * Send handshake. This basically calls + * hub_send_support() and hub_send_sid() + */ +-extern void hub_send_handshake(struct user* u); ++extern void hub_send_handshake(struct uhub_user* u); + + /** + * Send a welcome message containing the message of the day to + * one particular user. This can be sent in any point in time. + */ +-extern void hub_send_motd(struct user* u); ++extern void hub_send_motd(struct uhub_user* u); + + /** + * Send a password challenge to a user. + * This is only used if the user tries to access the hub using a + * password protected nick name. + */ +-extern void hub_send_password_challenge(struct user* u); ++extern void hub_send_password_challenge(struct uhub_user* u); + + /** + * Send an autocheck message to a user. + * This is basically a UDP message. The user's client can then determine + * if UDP communication works by either hole punching or configuring UPnP. + */ +-extern void hub_send_autocheck(struct user* u, uint16_t port, const char* token); ++extern void hub_send_autocheck(struct uhub_user* u, uint16_t port, const char* token); + + /** + * This starts the hub. +@@ -244,7 +244,7 @@ + /** + * Sends a status_message to a user. + */ +-extern void hub_send_status(struct user* user, enum status_message msg, enum msg_status_level level); ++extern void hub_send_status(struct uhub_user* user, enum status_message msg, enum msg_status_level level); + + /** + * Returns the number of logged in users on the hub. +--- a/src/inf.c ++++ b/src/inf.c +@@ -39,9 +39,9 @@ + adc_msg_remove_named_argument(cmd, ADC_INF_FLAG_REFERER); + } + +-static int user_is_protected(struct user* user); ++static int user_is_protected(struct uhub_user* user); + +-static int set_feature_cast_supports(struct user* u, struct adc_message* cmd) ++static int set_feature_cast_supports(struct uhub_user* u, struct adc_message* cmd) + { + char *it, *tmp; + +@@ -89,7 +89,7 @@ + /* + * FIXME: Only works for tiger hash. If a client doesnt support tiger we cannot let it in! + */ +-static int check_cid(struct user* user, struct adc_message* cmd) ++static int check_cid(struct uhub_user* user, struct adc_message* cmd) + { + size_t pos; + char* cid = adc_msg_get_named_argument(cmd, ADC_INF_FLAG_CLIENT_ID); +@@ -150,7 +150,7 @@ + } + + +-static int check_required_login_flags(struct user* user, struct adc_message* cmd) ++static int check_required_login_flags(struct uhub_user* user, struct adc_message* cmd) + { + int num = 0; + +@@ -186,7 +186,7 @@ + * remove any wrong address, and replace it with the correct one + * as seen by the hub. + */ +-int check_network(struct user* user, struct adc_message* cmd) ++int check_network(struct uhub_user* user, struct adc_message* cmd) + { + const char* address = ip_convert_to_string(&user->ipaddr); + +@@ -269,7 +269,7 @@ + } + + +-static int check_nick(struct user* user, struct adc_message* cmd) ++static int check_nick(struct uhub_user* user, struct adc_message* cmd) + { + char* nick; + char* tmp; +@@ -317,10 +317,10 @@ + } + + +-static int check_logged_in(struct user* user, struct adc_message* cmd) ++static int check_logged_in(struct uhub_user* user, struct adc_message* cmd) + { +- struct user* lookup1 = get_user_by_nick(user->hub, user->id.nick); +- struct user* lookup2 = get_user_by_cid(user->hub, user->id.cid); ++ struct uhub_user* lookup1 = get_user_by_nick(user->hub, user->id.nick); ++ struct uhub_user* lookup2 = get_user_by_cid(user->hub, user->id.cid); + + if (lookup1 == user) + { +@@ -358,7 +358,7 @@ + * But this is not something we want to do, and is deprecated in the ADC specification. + * One should rather look at capabilities/features. + */ +-static int check_user_agent(struct user* user, struct adc_message* cmd) ++static int check_user_agent(struct uhub_user* user, struct adc_message* cmd) + { + char* ua_encoded = 0; + char* ua = 0; +@@ -379,7 +379,7 @@ + } + + +-static int check_acl(struct user* user, struct adc_message* cmd) ++static int check_acl(struct uhub_user* user, struct adc_message* cmd) + { + if (acl_is_cid_banned(user->hub->acl, user->id.cid)) + { +@@ -399,7 +399,7 @@ + return 0; + } + +-static int check_limits(struct user* user, struct adc_message* cmd) ++static int check_limits(struct uhub_user* user, struct adc_message* cmd) + { + char* arg = adc_msg_get_named_argument(cmd, ADC_INF_FLAG_SHARED_SIZE); + if (arg) +@@ -525,10 +525,10 @@ + * If the hub is configured to allow only registered users and the user + * is not recognized this will return 1. + */ +-static int set_credentials(struct user* user, struct adc_message* cmd) ++static int set_credentials(struct uhub_user* user, struct adc_message* cmd) + { + int ret = 0; +- struct user_access_info* info = acl_get_access_info(user->hub->acl, user->id.nick); ++ struct uhub_user_access_info* info = acl_get_access_info(user->hub->acl, user->id.nick); + + if (info) + { +@@ -580,7 +580,7 @@ + /** + * Determines if a user is to be let into the hub even if the hub is "full". + */ +-static int user_is_protected(struct user* user) ++static int user_is_protected(struct uhub_user* user) + { + switch (user->credentials) + { +@@ -601,7 +601,7 @@ + * Only registered users will be let in if the hub is configured for registered + * users only. + */ +-static int user_is_registered(struct user* user) ++static int user_is_registered(struct uhub_user* user) + { + switch (user->credentials) + { +@@ -619,7 +619,7 @@ + } + + +-void update_user_info(struct user* u, struct adc_message* cmd) ++void update_user_info(struct uhub_user* u, struct adc_message* cmd) + { + char prefix[2]; + char* argument; +@@ -649,7 +649,7 @@ + } + + +-static int check_is_hub_full(struct user* user) ++static int check_is_hub_full(struct uhub_user* user) + { + /* + * If hub is full, don't let users in, but we still want to allow +@@ -663,7 +663,7 @@ + } + + +-static int check_registered_users_only(struct user* user) ++static int check_registered_users_only(struct uhub_user* user) + { + if (user->hub->config->registered_users_only && !user_is_registered(user)) + { +@@ -679,7 +679,7 @@ + return ret; \ + } while(0) + +-static int hub_handle_info_common(struct user* user, struct adc_message* cmd) ++static int hub_handle_info_common(struct uhub_user* user, struct adc_message* cmd) + { + /* Remove server restricted flags */ + remove_server_restricted_flags(cmd); +@@ -690,7 +690,7 @@ + return 0; + } + +-static int hub_handle_info_low_bandwidth(struct user* user, struct adc_message* cmd) ++static int hub_handle_info_low_bandwidth(struct uhub_user* user, struct adc_message* cmd) + { + if (user->hub->config->low_bandwidth_mode) + { +@@ -711,7 +711,7 @@ + return 0; + } + +-int hub_handle_info_login(struct user* user, struct adc_message* cmd) ++int hub_handle_info_login(struct uhub_user* user, struct adc_message* cmd) + { + int need_auth = 0; + +@@ -765,7 +765,7 @@ + * - CID/PID (valid, not taken, etc). + * - IP addresses (IPv4 and IPv6) + */ +-int hub_handle_info(struct user* user, const struct adc_message* cmd_unmodified) ++int hub_handle_info(struct uhub_user* user, const struct adc_message* cmd_unmodified) + { + struct adc_message* cmd = adc_msg_copy(cmd_unmodified); + if (!cmd) return -1; /* OOM */ +--- a/src/inf.h ++++ b/src/inf.h +@@ -47,7 +47,7 @@ + * + * @return 0 on success, -1 on error + */ +-extern int hub_handle_info(struct user* u, const struct adc_message* cmd); ++extern int hub_handle_info(struct uhub_user* u, const struct adc_message* cmd); + + + #endif /* HAVE_UHUB_INF_PARSER_H */ +--- a/src/message.c ++++ b/src/message.c +@@ -234,7 +234,7 @@ + } + + +-struct adc_message* adc_msg_parse_verify(struct user* u, const char* line, size_t length) ++struct adc_message* adc_msg_parse_verify(struct uhub_user* u, const char* line, size_t length) + { + struct adc_message* command = adc_msg_parse(line, length); + +--- a/src/message.h ++++ b/src/message.h +@@ -20,7 +20,7 @@ + #ifndef HAVE_UHUB_COMMAND_H + #define HAVE_UHUB_COMMAND_H + +-struct user; ++struct uhub_user; + + struct adc_message + { +@@ -70,7 +70,7 @@ + * The message is only considered valid if the user who sent it + * is the rightful origin of the message. + */ +-extern struct adc_message* adc_msg_parse_verify(struct user* u, const char* string, size_t length); ++extern struct adc_message* adc_msg_parse_verify(struct uhub_user* u, const char* string, size_t length); + + /** + * This will parse 'string' and return it as a adc_message struct, or +--- a/src/netevent.c ++++ b/src/netevent.c +@@ -23,7 +23,7 @@ + void net_on_read(int fd, short ev, void *arg) + { + static char buf[MAX_RECV_BUF]; +- struct user* user = (struct user*) arg; ++ struct uhub_user* user = (struct uhub_user*) arg; + char* pos; + size_t offset; + size_t buflen; +@@ -168,7 +168,7 @@ + + void net_on_write(int fd, short ev, void *arg) + { +- struct user* user = (struct user*) arg; ++ struct uhub_user* user = (struct uhub_user*) arg; + struct adc_message* msg; + int ret; + int length; +@@ -259,7 +259,7 @@ + void net_on_accept(int server_fd, short ev, void *arg) + { + struct hub_info* hub = (struct hub_info*) arg; +- struct user* user = 0; ++ struct uhub_user* user = 0; + struct ip_addr_encap ipaddr; + const char* addr; + struct timeval timeout = { TIMEOUT_CONNECTED, 0 }; +@@ -320,7 +320,7 @@ + { + static char buffer[1024] = {0,}; + // struct hub_info* hub = (struct hub_info*) arg; +- // struct user* user = 0; ++ // struct uhub_user* user = 0; + ssize_t size; + struct sockaddr_storage from; + socklen_t fromlen; +--- a/src/plugin.h ++++ b/src/plugin.h +@@ -19,12 +19,12 @@ + + typedef void (*plugin_event_startup)(struct hub*); + typedef void (*plugin_event_shutdown)(struct hub*); +-typedef void (*plugin_event_user_login)(struct hub*, struct user*); +-typedef void (*plugin_event_user_logout)(struct hub*, struct user*); ++typedef void (*plugin_event_user_login)(struct hub*, struct uhub_user*); ++typedef void (*plugin_event_user_logout)(struct hub*, struct uhub_user*); + typedef int (*plugin_event_connect)(struct hub*, struct ip_addr_encap); +-typedef void (*plugin_event_disconnect)(struct hub*, struct user*); +-typedef int (*plugin_event_message)(struct hub*, struct user*, struct adc_message*); +-typedef void (*plugin_event_support)(struct hub*, struct user*, int); ++typedef void (*plugin_event_disconnect)(struct hub*, struct uhub_user*); ++typedef int (*plugin_event_message)(struct hub*, struct uhub_user*, struct adc_message*); ++typedef void (*plugin_event_support)(struct hub*, struct uhub_user*, int); + + struct uhub_plugin + { +--- a/src/route.c ++++ b/src/route.c +@@ -20,9 +20,9 @@ + #include "uhub.h" + + +-int route_message(struct user* u, struct adc_message* msg) ++int route_message(struct uhub_user* u, struct adc_message* msg) + { +- struct user* target = NULL; ++ struct uhub_user* target = NULL; + + switch (msg->cache[0]) + { +@@ -59,7 +59,7 @@ + } + + +-static void queue_command(struct user* user, struct adc_message* msg__, int offset) ++static void queue_command(struct uhub_user* user, struct adc_message* msg__, int offset) + { + struct adc_message* msg = adc_msg_incref(msg__); + list_append(user->send_queue, msg); +@@ -97,7 +97,7 @@ + * -1 if send queue is overflowed + * 0 if soft send queue is overflowed (not implemented at the moment) + */ +-static int check_send_queue(struct user* user, struct adc_message* msg) ++static int check_send_queue(struct uhub_user* user, struct adc_message* msg) + { + if (user_flag_get(user, flag_user_list)) + return 1; +@@ -111,7 +111,7 @@ + return 1; + } + +-int route_to_user(struct user* user, struct adc_message* msg) ++int route_to_user(struct uhub_user* user, struct adc_message* msg) + { + int ret; + +@@ -174,11 +174,11 @@ + + int route_to_all(struct hub_info* hub, struct adc_message* command) /* iterate users */ + { +- struct user* user = (struct user*) list_get_first(hub->users->list); ++ struct uhub_user* user = (struct uhub_user*) list_get_first(hub->users->list); + while (user) + { + route_to_user(user, command); +- user = (struct user*) list_get_next(hub->users->list); ++ user = (struct uhub_user*) list_get_next(hub->users->list); + } + + return 0; +@@ -190,7 +190,7 @@ + int do_send; + char* tmp; + +- struct user* user = (struct user*) list_get_first(hub->users->list); ++ struct uhub_user* user = (struct uhub_user*) list_get_first(hub->users->list); + while (user) + { + if (user->feature_cast) +@@ -209,7 +209,7 @@ + } + + if (!do_send) { +- user = (struct user*) list_get_next(hub->users->list); ++ user = (struct uhub_user*) list_get_next(hub->users->list); + continue; + } + +@@ -229,13 +229,13 @@ + route_to_user(user, command); + } + } +- user = (struct user*) list_get_next(hub->users->list); ++ user = (struct uhub_user*) list_get_next(hub->users->list); + } + + return 0; + } + +-int route_info_message(struct user* u) ++int route_info_message(struct uhub_user* u) + { + if (!user_is_nat_override(u)) + { +@@ -245,12 +245,12 @@ + { + struct adc_message* cmd = adc_msg_copy(u->info); + const char* address = ip_convert_to_string(&u->ipaddr); +- struct user* user = 0; ++ struct uhub_user* user = 0; + + adc_msg_remove_named_argument(cmd, ADC_INF_FLAG_IPV4_ADDR); + adc_msg_add_named_argument(cmd, ADC_INF_FLAG_IPV4_ADDR, address); + +- user = (struct user*) list_get_first(u->hub->users->list); ++ user = (struct uhub_user*) list_get_first(u->hub->users->list); + while (user) + { + if (user_is_nat_override(user)) +@@ -258,7 +258,7 @@ + else + route_to_user(user, u->info); + +- user = (struct user*) list_get_next(u->hub->users->list); ++ user = (struct uhub_user*) list_get_next(u->hub->users->list); + } + adc_msg_free(cmd); + } +--- a/src/route.h ++++ b/src/route.h +@@ -23,12 +23,12 @@ + /** + * Route a message by sending it to it's final destination. + */ +-extern int route_message(struct user* u, struct adc_message* msg); ++extern int route_message(struct uhub_user* u, struct adc_message* msg); + + /** + * Transmit message directly to one user. + */ +-extern int route_to_user(struct user*, struct adc_message* command); ++extern int route_to_user(struct uhub_user*, struct adc_message* command); + + /** + * Broadcast message to all users. +@@ -45,7 +45,7 @@ + * This will ensure the correct IP is seen by other users + * in case nat override is in use. + */ +-extern int route_info_message(struct user* user); ++extern int route_info_message(struct uhub_user* user); + + + #endif /* HAVE_UHUB_ROUTE_H */ +--- a/src/sid.h ++++ b/src/sid.h +@@ -28,7 +28,7 @@ + + struct sid_map + { +- struct user* ptr; ++ struct uhub_user* ptr; + struct sid_map* next; + }; + +@@ -58,7 +58,7 @@ + + + extern void sid_initialize(struct sid_pool*); +-extern sid_t sid_alloc(struct sid_pool*, struct user*); ++extern sid_t sid_alloc(struct sid_pool*, struct uhub_user*); + extern void sid_free(struct sid_pool*, sid_t); + + +--- a/src/user.c ++++ b/src/user.c +@@ -19,13 +19,13 @@ + + #include "uhub.h" + +-struct user* user_create(struct hub_info* hub, int sd) ++struct uhub_user* user_create(struct hub_info* hub, int sd) + { +- struct user* user = NULL; ++ struct uhub_user* user = NULL; + + hub_log(log_trace, "user_create(), hub=%p, sd=%d", hub, sd); + +- user = (struct user*) hub_malloc_zero(sizeof(struct user)); ++ user = (struct uhub_user*) hub_malloc_zero(sizeof(struct uhub_user)); + + if (user == NULL) + return NULL; /* OOM */ +@@ -61,7 +61,7 @@ + adc_msg_free((struct adc_message*) ptr); + } + +-void user_destroy(struct user* user) ++void user_destroy(struct uhub_user* user) + { + hub_log(log_trace, "user_destroy(), user=%p", user); + +@@ -98,7 +98,7 @@ + hub_free(user); + } + +-void user_set_state(struct user* user, enum user_state state) ++void user_set_state(struct uhub_user* user, enum user_state state) + { + if ((user->state == state_cleanup && state != state_disconnected) || (user->state == state_disconnected)) + { +@@ -109,7 +109,7 @@ + user->state = state; + } + +-void user_set_info(struct user* user, struct adc_message* cmd) ++void user_set_info(struct uhub_user* user, struct adc_message* cmd) + { + adc_msg_free(user->info); + user->info = adc_msg_incref(cmd); +@@ -156,44 +156,44 @@ + } + } + +-void user_support_add(struct user* user, int fourcc) ++void user_support_add(struct uhub_user* user, int fourcc) + { + int feature_mask = convert_support_fourcc(fourcc); + user->flags |= feature_mask; + } + +-int user_flag_get(struct user* user, enum user_flags flag) ++int user_flag_get(struct uhub_user* user, enum user_flags flag) + { + return user->flags & flag; + } + +-void user_flag_set(struct user* user, enum user_flags flag) ++void user_flag_set(struct uhub_user* user, enum user_flags flag) + { + user->flags |= flag; + } + +-void user_flag_unset(struct user* user, enum user_flags flag) ++void user_flag_unset(struct uhub_user* user, enum user_flags flag) + { + user->flags &= ~flag; + } + +-void user_set_nat_override(struct user* user) ++void user_set_nat_override(struct uhub_user* user) + { + user_flag_set(user, flag_nat); + } + +-int user_is_nat_override(struct user* user) ++int user_is_nat_override(struct uhub_user* user) + { + return user_flag_get(user, flag_nat); + } + +-void user_support_remove(struct user* user, int fourcc) ++void user_support_remove(struct uhub_user* user, int fourcc) + { + int feature_mask = convert_support_fourcc(fourcc); + user->flags &= ~feature_mask; + } + +-void user_schedule_destroy(struct user* user) ++void user_schedule_destroy(struct uhub_user* user) + { + struct event_data post; + memset(&post, 0, sizeof(post)); +@@ -202,7 +202,7 @@ + event_queue_post(user->hub->queue, &post); + } + +-void user_disconnect(struct user* user, int reason) ++void user_disconnect(struct uhub_user* user, int reason) + { + struct event_data post; + int need_notify = 0; +@@ -242,7 +242,7 @@ + + } + +-int user_have_feature_cast_support(struct user* user, char feature[4]) ++int user_have_feature_cast_support(struct uhub_user* user, char feature[4]) + { + char* tmp = list_get_first(user->feature_cast); + while (tmp) +@@ -256,7 +256,7 @@ + return 0; + } + +-int user_set_feature_cast_support(struct user* u, char feature[4]) ++int user_set_feature_cast_support(struct uhub_user* u, char feature[4]) + { + if (!u->feature_cast) + { +@@ -272,7 +272,7 @@ + return 1; + } + +-void user_clear_feature_cast_support(struct user* u) ++void user_clear_feature_cast_support(struct uhub_user* u) + { + if (u->feature_cast) + { +@@ -282,21 +282,21 @@ + } + } + +-int user_is_logged_in(struct user* user) ++int user_is_logged_in(struct uhub_user* user) + { + if (user->state == state_normal) + return 1; + return 0; + } + +-int user_is_connecting(struct user* user) ++int user_is_connecting(struct uhub_user* user) + { + if (user->state == state_protocol || user->state == state_identify || user->state == state_verify) + return 1; + return 0; + } + +-int user_is_disconnecting(struct user* user) ++int user_is_disconnecting(struct uhub_user* user) + { + if (user->state == state_cleanup || user->state == state_disconnected) + return 1; +--- a/src/user.h ++++ b/src/user.h +@@ -73,7 +73,7 @@ + }; + + +-struct user_info ++struct uhub_user_info + { + sid_t sid; /** session ID */ + char cid[MAX_CID_LEN+1]; /** global client ID */ +@@ -85,7 +85,7 @@ + * as the number of bytes and files shared, and the number of hubs the + * user is connected to, etc. + */ +-struct user_counts ++struct uhub_user_counts + { + uint64_t shared_size; /** Shared size in bytes */ + size_t shared_files; /** The number of shared files */ +@@ -96,14 +96,14 @@ + size_t hub_count_total; /** The number of hubs connected to in total */ + }; + +-struct user ++struct uhub_user + { + int sd; /** socket descriptor */ + struct event* ev_read; /** libevent struct for read events */ + struct event* ev_write; /** libevent struct for write events */ + enum user_state state; /** see enum user_state */ + enum user_credentials credentials; /** see enum user_credentials */ +- struct user_info id; /** Contains nick name and CID */ ++ struct uhub_user_info id; /** Contains nick name and CID */ + int flags; /** see enum user_features */ + char user_agent[MAX_UA_LEN+1];/** User agent string */ + time_t tm_connected; /** time when user connected */ +@@ -120,7 +120,7 @@ + struct hub_info* hub; /** The hub instance this user belong to */ + int quit_reason; /** Quit reason (see user_quit_reason) */ + struct ip_addr_encap ipaddr; /** IP address of connected user */ +- struct user_counts limits; /** Data used for limitation */ ++ struct uhub_user_counts limits; /** Data used for limitation */ + #ifdef SSL_SUPPORT + SSL* ssl; /** SSL handle */ + #endif /* SSL_SUPPORT */ +@@ -137,19 +137,19 @@ + * @param sd socket descriptor associated with the user + * @return User object or NULL if not enough memory is available. + */ +-extern struct user* user_create(struct hub_info* hub, int sd); ++extern struct uhub_user* user_create(struct hub_info* hub, int sd); + + /** + * Delete a user. + * + * !WRONG! If the user is logged in a quit message is issued. + */ +-extern void user_destroy(struct user* user); ++extern void user_destroy(struct uhub_user* user); + + /** + * Will post a message that will delete the user later. + */ +-extern void user_schedule_destroy(struct user* user); ++extern void user_schedule_destroy(struct uhub_user* user); + + /** + * Disconnect a user. +@@ -165,36 +165,36 @@ + * @param user User to disconnect + * @param reason See enum user_quit_reason + */ +-extern void user_disconnect(struct user* user, int reason); ++extern void user_disconnect(struct uhub_user* user, int reason); + + /** + * This associates a INF message to the user. + * If the user already has a INF message associated, then this is + * released before setting the new one. + */ +-extern void user_set_info(struct user* user, struct adc_message* info); ++extern void user_set_info(struct uhub_user* user, struct adc_message* info); + + /** + * Specify a user's state. + * NOTE: DON'T, unless you know what you are doing. + */ +-extern void user_set_state(struct user* user, enum user_state); ++extern void user_set_state(struct uhub_user* user, enum user_state); + + /** + * Returns 1 if the user is in state state_normal, or 0 otherwise. + */ +-extern int user_is_logged_in(struct user* user); ++extern int user_is_logged_in(struct uhub_user* user); + + /** + * Returns 1 if the user is in state_protocol, state_identify or state_verify. + * Returns 0 otherwise. + */ +-extern int user_is_connecting(struct user* user); ++extern int user_is_connecting(struct uhub_user* user); + + /** + * Returns 1 only if the user is in state_cleanup or state_disconnected. + */ +-extern int user_is_disconnecting(struct user* user); ++extern int user_is_disconnecting(struct uhub_user* user); + + /** + * User supports the protocol extension as given in fourcc. +@@ -204,7 +204,7 @@ + * + * @see enum user_flags + */ +-extern void user_support_add(struct user* user, int fourcc); ++extern void user_support_add(struct uhub_user* user, int fourcc); + + /** + * User no longer supports the protocol extension as given in fourcc. +@@ -212,26 +212,26 @@ + * the hub. + * @see enum user_flags + */ +-extern void user_support_remove(struct user* user, int fourcc); ++extern void user_support_remove(struct uhub_user* user, int fourcc); + + /** + * Sets the nat override flag for a user, this allows users on the same + * subnet as a natted hub to spoof their IP in order to use active mode + * on a natted hub. + */ +-extern void user_set_nat_override(struct user* user); +-extern int user_is_nat_override(struct user* user); ++extern void user_set_nat_override(struct uhub_user* user); ++extern int user_is_nat_override(struct uhub_user* user); + + /** + * Set a flag. @see enum user_flags + */ +-extern void user_flag_set(struct user* user, enum user_flags flag); +-extern void user_flag_unset(struct user* user, enum user_flags flag); ++extern void user_flag_set(struct uhub_user* user, enum user_flags flag); ++extern void user_flag_unset(struct uhub_user* user, enum user_flags flag); + + /** + * Get a flag. @see enum user_flags + */ +-extern int user_flag_get(struct user* user, enum user_flags flag); ++extern int user_flag_get(struct uhub_user* user, enum user_flags flag); + + /** + * Check if a user supports 'feature' for feature casting (basis for 'Fxxx' messages) +@@ -241,7 +241,7 @@ + * @param feature a feature to lookup (example: 'TCP4' or 'UDP4') + * @return 1 if 'feature' supported, or 0 otherwise + */ +-extern int user_have_feature_cast_support(struct user* user, char feature[4]); ++extern int user_have_feature_cast_support(struct uhub_user* user, char feature[4]); + + /** + * Set feature cast support for feature. +@@ -249,12 +249,12 @@ + * @param feature a feature to lookup (example: 'TCP4' or 'UDP4') + * @return 1 if 'feature' supported, or 0 otherwise + */ +-extern int user_set_feature_cast_support(struct user* u, char feature[4]); ++extern int user_set_feature_cast_support(struct uhub_user* u, char feature[4]); + + /** + * Remove all feature cast support features. + */ +-extern void user_clear_feature_cast_support(struct user* u); ++extern void user_clear_feature_cast_support(struct uhub_user* u); + + + +--- a/src/usermanager.c ++++ b/src/usermanager.c +@@ -27,7 +27,7 @@ + { + if (ptr) + { +- struct user* u = (struct user*) ptr; ++ struct uhub_user* u = (struct uhub_user*) ptr; + + /* Mark the user as already being disconnected. + * This prevents the hub from trying to send +@@ -81,10 +81,10 @@ + + int user_manager_init(struct hub_info* hub) + { +- struct user_manager* users = NULL; ++ struct uhub_user_manager* users = NULL; + struct timeval timeout = { TIMEOUT_STATS, 0 }; + +- users = (struct user_manager*) hub_malloc_zero(sizeof(struct user_manager)); ++ users = (struct uhub_user_manager*) hub_malloc_zero(sizeof(struct uhub_user_manager)); + + users->list = list_create(); + users->free_sid = 1; +@@ -106,7 +106,7 @@ + + void user_manager_shutdown(struct hub_info* hub) + { +- struct user_manager* users = hub->users; ++ struct uhub_user_manager* users = hub->users; + event_del(&hub->ev_timer); + + list_clear(users->list, &clear_user_list_callback); +@@ -115,7 +115,7 @@ + } + + +-void user_manager_add(struct user* user) ++void user_manager_add(struct uhub_user* user) + { + list_append(user->hub->users->list, user); + user->hub->users->count++; +@@ -125,7 +125,7 @@ + user->hub->users->shared_files += user->limits.shared_files; + } + +-void user_manager_remove(struct user* user) ++void user_manager_remove(struct uhub_user* user) + { + list_remove(user->hub->users->list, user); + user->hub->users->count--; +@@ -135,50 +135,50 @@ + } + + +-struct user* get_user_by_sid(struct hub_info* hub, sid_t sid) ++struct uhub_user* get_user_by_sid(struct hub_info* hub, sid_t sid) + { +- struct user* user = (struct user*) list_get_first(hub->users->list); /* iterate users */ ++ struct uhub_user* user = (struct uhub_user*) list_get_first(hub->users->list); /* iterate users */ + while (user) + { + if (user->id.sid == sid) + return user; +- user = (struct user*) list_get_next(hub->users->list); ++ user = (struct uhub_user*) list_get_next(hub->users->list); + } + return NULL; + } + + +-struct user* get_user_by_cid(struct hub_info* hub, const char* cid) ++struct uhub_user* get_user_by_cid(struct hub_info* hub, const char* cid) + { +- struct user* user = (struct user*) list_get_first(hub->users->list); /* iterate users - only on incoming INF msg */ ++ struct uhub_user* user = (struct uhub_user*) list_get_first(hub->users->list); /* iterate users - only on incoming INF msg */ + while (user) + { + if (strcmp(user->id.cid, cid) == 0) + return user; +- user = (struct user*) list_get_next(hub->users->list); ++ user = (struct uhub_user*) list_get_next(hub->users->list); + } + return NULL; + } + + +-struct user* get_user_by_nick(struct hub_info* hub, const char* nick) ++struct uhub_user* get_user_by_nick(struct hub_info* hub, const char* nick) + { +- struct user* user = (struct user*) list_get_first(hub->users->list); /* iterate users - only on incoming INF msg */ ++ struct uhub_user* user = (struct uhub_user*) list_get_first(hub->users->list); /* iterate users - only on incoming INF msg */ + while (user) + { + if (strcmp(user->id.nick, nick) == 0) + return user; +- user = (struct user*) list_get_next(hub->users->list); ++ user = (struct uhub_user*) list_get_next(hub->users->list); + } + return NULL; + } + + +-int send_user_list(struct user* target) ++int send_user_list(struct uhub_user* target) + { + int ret = 1; + user_flag_set(target, flag_user_list); +- struct user* user = (struct user*) list_get_first(target->hub->users->list); /* iterate users - only on INF or PAS msg */ ++ struct uhub_user* user = (struct uhub_user*) list_get_first(target->hub->users->list); /* iterate users - only on INF or PAS msg */ + while (user) + { + if (user_is_logged_in(user)) +@@ -187,7 +187,7 @@ + if (!ret) + break; + } +- user = (struct user*) list_get_next(user->hub->users->list); ++ user = (struct uhub_user*) list_get_next(user->hub->users->list); + } + + if (!target->send_queue_size) +@@ -198,7 +198,7 @@ + } + + +-void send_quit_message(struct user* leaving) ++void send_quit_message(struct uhub_user* leaving) + { + struct adc_message* command = adc_msg_construct(ADC_CMD_IQUI, 6); + adc_msg_add_argument(command, (const char*) sid_to_string(leaving->id.sid)); +@@ -216,8 +216,8 @@ + sid_t user_manager_get_free_sid(struct hub_info* hub) + { + #if 0 +- struct user* user; +- user = (struct user*) list_get_first(hub->users->list); /* iterate normal users */ ++ struct uhub_user* user; ++ user = (struct uhub_user*) list_get_first(hub->users->list); /* iterate normal users */ + while (user) + { + if (user->sid == hub->users->free_sid) +@@ -226,7 +226,7 @@ + if (hub->users->free_sid >= SID_MAX) hub->users->free_sid = 1; + break; + } +- user = (struct user*) list_get_next(hub->users->list); ++ user = (struct uhub_user*) list_get_next(hub->users->list); + } + #endif + return hub->users->free_sid++; +--- a/src/usermanager.h ++++ b/src/usermanager.h +@@ -20,7 +20,7 @@ + #ifndef HAVE_UHUB_USER_MANAGER_H + #define HAVE_UHUB_USER_MANAGER_H + +-struct user_manager ++struct uhub_user_manager + { + size_t count; /**<< "Number of all fully connected and logged in users" */ + size_t count_peak; /**<< "Peak number of users" */ +@@ -51,14 +51,14 @@ + /** + * Add a new user to the user manager. + */ +-extern void user_manager_add(struct user* user); ++extern void user_manager_add(struct uhub_user* user); + + /** + * Remove a user from the user manager. + * This user is connected, and will be moved to the leaving queue, pending + * all messages in the message queue, and resource cleanup. + */ +-extern void user_manager_remove(struct user* user); ++extern void user_manager_remove(struct uhub_user* user); + + /** + * Returns a free sid for a new user. +@@ -70,19 +70,19 @@ + * NOTE: This will only search connected users. + * @return a user if found, or NULL if not found + */ +-extern struct user* get_user_by_sid(struct hub_info* hub, sid_t sid); ++extern struct uhub_user* get_user_by_sid(struct hub_info* hub, sid_t sid); + + /** + * Lookup a user based on the client ID (cid). + * @return a user if found, or NULL if not found + */ +-extern struct user* get_user_by_cid(struct hub_info* hub, const char* cid); ++extern struct uhub_user* get_user_by_cid(struct hub_info* hub, const char* cid); + + /** + * Lookup a user based on the nick name. + * @return a user if found, or NULL if not found + */ +-extern struct user* get_user_by_nick(struct hub_info* hub, const char* nick); ++extern struct uhub_user* get_user_by_nick(struct hub_info* hub, const char* nick); + + /** + * Send the user list of connected clients to 'user'. +@@ -90,13 +90,13 @@ + * + * @return 1 if sending the user list succeeded, 0 otherwise. + */ +-extern int send_user_list(struct user* user); ++extern int send_user_list(struct uhub_user* user); + + /** + * Send a quit message to all connected users when 'user' is + * leaving the hub (for whatever reason). + */ +-extern void send_quit_message(struct user* user); ++extern void send_quit_message(struct uhub_user* user); + + + #endif /* HAVE_UHUB_USER_MANAGER_H */