0
0
Fork 0
mirror of https://github.com/matrix-construct/construct synced 2025-01-16 17:46:54 +01:00

LIST: more cleanups

This commit is contained in:
William Pitcock 2016-01-09 23:34:52 -06:00
parent e835592cfc
commit 730b914c17
2 changed files with 19 additions and 25 deletions

View file

@ -71,7 +71,6 @@ struct Server;
struct LocalUser; struct LocalUser;
struct AuthRequest; struct AuthRequest;
struct PreClient; struct PreClient;
struct ListClient;
struct scache_entry; struct scache_entry;
/* /*
@ -270,8 +269,6 @@ struct LocalUser
time_t ratelimit; time_t ratelimit;
unsigned int join_who_credits; unsigned int join_who_credits;
struct ListClient *safelist_data;
char *mangledhost; /* non-NULL if host mangling module loaded and char *mangledhost; /* non-NULL if host mangling module loaded and
applicable to this client */ applicable to this client */
@ -302,14 +299,6 @@ struct PreClient
struct rb_sockaddr_storage lip; /* address of our side of the connection */ struct rb_sockaddr_storage lip; /* address of our side of the connection */
}; };
struct ListClient
{
unsigned int hash_indice;
unsigned int users_min, users_max;
time_t created_min, created_max, topic_min, topic_max;
int operspy;
};
/* /*
* status macros. * status macros.
*/ */

View file

@ -58,10 +58,16 @@ static void _moddeinit(void);
static int m_list(struct Client *, struct Client *, int, const char **); static int m_list(struct Client *, struct Client *, int, const char **);
static int mo_list(struct Client *, struct Client *, int, const char **); static int mo_list(struct Client *, struct Client *, int, const char **);
struct ListOptions
{
unsigned int users_min, users_max;
time_t created_min, created_max, topic_min, topic_max;
int operspy;
};
static void list_one_channel(struct Client *source_p, struct Channel *chptr, int visible); static void list_one_channel(struct Client *source_p, struct Channel *chptr, int visible);
static void safelist_client_instantiate(struct Client *, struct ListClient *); static void safelist_one_channel(struct Client *source_p, struct Channel *chptr, struct ListOptions *params);
static void safelist_one_channel(struct Client *source_p, struct Channel *chptr);
static void safelist_channel_named(struct Client *source_p, const char *name, int operspy); static void safelist_channel_named(struct Client *source_p, const char *name, int operspy);
struct Message list_msgtab = { struct Message list_msgtab = {
@ -126,7 +132,7 @@ static int m_list(struct Client *client_p, struct Client *source_p, int parc, co
*/ */
static int mo_list(struct Client *client_p, struct Client *source_p, int parc, const char *parv[]) static int mo_list(struct Client *client_p, struct Client *source_p, int parc, const char *parv[])
{ {
struct ListClient *params; struct ListOptions *params;
char *p; char *p;
char *args = NULL; char *args = NULL;
int i; int i;
@ -157,7 +163,7 @@ static int mo_list(struct Client *client_p, struct Client *source_p, int parc, c
} }
/* Multiple channels, possibly with parameters. */ /* Multiple channels, possibly with parameters. */
params = rb_malloc(sizeof(struct ListClient)); params = rb_malloc(sizeof(struct ListOptions));
params->users_min = ConfigChannel.displayed_usercount; params->users_min = ConfigChannel.displayed_usercount;
params->users_max = INT_MAX; params->users_max = INT_MAX;
@ -251,7 +257,7 @@ static int mo_list(struct Client *client_p, struct Client *source_p, int parc, c
RB_DLINK_FOREACH(ptr, global_channel_list.head) RB_DLINK_FOREACH(ptr, global_channel_list.head)
{ {
safelist_one_channel(client_p, ptr->data); safelist_one_channel(client_p, ptr->data, params);
if (rb_linebuf_len(&client_p->localClient->buf_sendq) > sendq_limit) if (rb_linebuf_len(&client_p->localClient->buf_sendq) > sendq_limit)
{ {
@ -357,31 +363,30 @@ static void safelist_channel_named(struct Client *source_p, const char *name, in
* side effects - a channel is listed if it meets the * side effects - a channel is listed if it meets the
* requirements * requirements
*/ */
static void safelist_one_channel(struct Client *source_p, struct Channel *chptr) static void safelist_one_channel(struct Client *source_p, struct Channel *chptr, struct ListOptions *params)
{ {
struct ListClient *safelist_data = source_p->localClient->safelist_data;
int visible; int visible;
visible = !SecretChannel(chptr) || IsMember(source_p, chptr); visible = !SecretChannel(chptr) || IsMember(source_p, chptr);
if (!visible && !safelist_data->operspy) if (!visible && !params->operspy)
return; return;
if ((unsigned int)chptr->members.length < safelist_data->users_min if ((unsigned int)chptr->members.length < params->users_min
|| (unsigned int)chptr->members.length > safelist_data->users_max) || (unsigned int)chptr->members.length > params->users_max)
return; return;
if (safelist_data->topic_min && chptr->topic_time < safelist_data->topic_min) if (params->topic_min && chptr->topic_time < params->topic_min)
return; return;
/* If a topic TS is provided, don't show channels without a topic set. */ /* If a topic TS is provided, don't show channels without a topic set. */
if (safelist_data->topic_max && (chptr->topic_time > safelist_data->topic_max if (params->topic_max && (chptr->topic_time > params->topic_max
|| chptr->topic_time == 0)) || chptr->topic_time == 0))
return; return;
if (safelist_data->created_min && chptr->channelts < safelist_data->created_min) if (params->created_min && chptr->channelts < params->created_min)
return; return;
if (safelist_data->created_max && chptr->channelts > safelist_data->created_max) if (params->created_max && chptr->channelts > params->created_max)
return; return;
list_one_channel(source_p, chptr, visible); list_one_channel(source_p, chptr, visible);