0d0fb883f7
git-svn-id: svn://svn.openwrt.org/openwrt/packages@16690 3c298f89-4303-0410-b956-a3cf2f4a3e73
1665 lines
50 KiB
Diff
1665 lines
50 KiB
Diff
--- 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 */
|