Automated merge with ssh://hg.atheme.org//hg/charybdis
This commit is contained in:
commit
436cf01700
|
@ -69,22 +69,6 @@ struct PreClient;
|
||||||
struct ListClient;
|
struct ListClient;
|
||||||
struct scache_entry;
|
struct scache_entry;
|
||||||
|
|
||||||
/*
|
|
||||||
* Atheme's coding standards require that we use BSD-style user-defined types
|
|
||||||
* for stuff. Fun! --nenolod
|
|
||||||
*/
|
|
||||||
typedef struct User user_t;
|
|
||||||
typedef struct Server server_t;
|
|
||||||
typedef struct Client client_t;
|
|
||||||
typedef struct LocalUser local_user_t;
|
|
||||||
typedef struct Listener listener_t;
|
|
||||||
typedef struct DNSReply dns_reply_t;
|
|
||||||
typedef struct Whowas whowas_entry_t;
|
|
||||||
typedef struct ConfItem conf_item_t;
|
|
||||||
typedef struct AuthRequest auth_request_t;
|
|
||||||
typedef struct PreClient pre_client_t;
|
|
||||||
typedef struct ListClient list_client_t;
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Client structures
|
* Client structures
|
||||||
*/
|
*/
|
||||||
|
@ -100,7 +84,7 @@ struct User
|
||||||
|
|
||||||
struct Server
|
struct Server
|
||||||
{
|
{
|
||||||
user_t *user; /* who activated this connection */
|
struct User *user; /* who activated this connection */
|
||||||
char by[NICKLEN];
|
char by[NICKLEN];
|
||||||
rb_dlink_list servers;
|
rb_dlink_list servers;
|
||||||
rb_dlink_list users;
|
rb_dlink_list users;
|
||||||
|
@ -123,12 +107,12 @@ struct Client
|
||||||
{
|
{
|
||||||
rb_dlink_node node;
|
rb_dlink_node node;
|
||||||
rb_dlink_node lnode;
|
rb_dlink_node lnode;
|
||||||
user_t *user; /* ...defined, if this is a User */
|
struct User *user; /* ...defined, if this is a User */
|
||||||
server_t *serv; /* ...defined, if this is a server */
|
struct Server *serv; /* ...defined, if this is a server */
|
||||||
client_t *servptr; /* Points to server this Client is on */
|
struct Client *servptr; /* Points to server this Client is on */
|
||||||
client_t *from; /* == self, if Local Client, *NEVER* NULL! */
|
struct Client *from; /* == self, if Local Client, *NEVER* NULL! */
|
||||||
|
|
||||||
whowas_entry_t *whowas; /* Pointers to whowas structs */
|
struct Whowas *whowas; /* Pointers to whowas structs */
|
||||||
time_t tsinfo; /* TS on the nick, SVINFO on server */
|
time_t tsinfo; /* TS on the nick, SVINFO on server */
|
||||||
unsigned int umodes; /* opers, normal users subset */
|
unsigned int umodes; /* opers, normal users subset */
|
||||||
unsigned int flags; /* client flags */
|
unsigned int flags; /* client flags */
|
||||||
|
@ -173,8 +157,8 @@ struct Client
|
||||||
int received_number_of_privmsgs;
|
int received_number_of_privmsgs;
|
||||||
int flood_noticed;
|
int flood_noticed;
|
||||||
|
|
||||||
local_user_t *localClient;
|
struct LocalUser *localClient;
|
||||||
pre_client_t *preClient;
|
struct PreClient *preClient;
|
||||||
|
|
||||||
time_t large_ctcp_sent; /* ctcp to large group sent, relax flood checks */
|
time_t large_ctcp_sent; /* ctcp to large group sent, relax flood checks */
|
||||||
};
|
};
|
||||||
|
@ -219,8 +203,8 @@ struct LocalUser
|
||||||
unsigned int receiveK; /* Statistics: total k-bytes received */
|
unsigned int receiveK; /* Statistics: total k-bytes received */
|
||||||
unsigned short sendB; /* counters to count upto 1-k lots of bytes */
|
unsigned short sendB; /* counters to count upto 1-k lots of bytes */
|
||||||
unsigned short receiveB; /* sent and received. */
|
unsigned short receiveB; /* sent and received. */
|
||||||
listener_t *listener; /* listener accepted from */
|
struct Listener *listener; /* listener accepted from */
|
||||||
conf_item_t *att_conf; /* attached conf */
|
struct ConfItem *att_conf; /* attached conf */
|
||||||
struct server_conf *att_sconf;
|
struct server_conf *att_sconf;
|
||||||
|
|
||||||
struct rb_sockaddr_storage ip;
|
struct rb_sockaddr_storage ip;
|
||||||
|
@ -267,14 +251,14 @@ struct LocalUser
|
||||||
int sent_parsed; /* how many messages we've parsed in this second */
|
int sent_parsed; /* how many messages we've parsed in this second */
|
||||||
time_t last_knock; /* time of last knock */
|
time_t last_knock; /* time of last knock */
|
||||||
unsigned long random_ping;
|
unsigned long random_ping;
|
||||||
auth_request_t *auth_request;
|
struct AuthRequest *auth_request;
|
||||||
|
|
||||||
/* target change stuff */
|
/* target change stuff */
|
||||||
uint32_t targets[10]; /* targets were aware of (fnv32(use_id(target_p))) */
|
uint32_t targets[10]; /* targets were aware of (fnv32(use_id(target_p))) */
|
||||||
unsigned int targinfo[2]; /* cyclic array, no in use */
|
unsigned int targinfo[2]; /* cyclic array, no in use */
|
||||||
time_t target_last; /* last time we cleared a slot */
|
time_t target_last; /* last time we cleared a slot */
|
||||||
|
|
||||||
list_client_t *safelist_data;
|
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 */
|
||||||
|
@ -570,7 +554,7 @@ extern const char *get_client_name(struct Client *client, int show_ip);
|
||||||
extern const char *log_client_name(struct Client *, int);
|
extern const char *log_client_name(struct Client *, int);
|
||||||
extern int is_remote_connect(struct Client *);
|
extern int is_remote_connect(struct Client *);
|
||||||
extern void init_client(void);
|
extern void init_client(void);
|
||||||
extern client_t *make_client(struct Client *from);
|
extern struct Client *make_client(struct Client *from);
|
||||||
extern void free_pre_client(struct Client *client);
|
extern void free_pre_client(struct Client *client);
|
||||||
extern void free_client(struct Client *client);
|
extern void free_client(struct Client *client);
|
||||||
|
|
||||||
|
@ -583,10 +567,10 @@ extern void error_exit_client(struct Client *, int);
|
||||||
extern void count_local_client_memory(size_t * count, size_t * memory);
|
extern void count_local_client_memory(size_t * count, size_t * memory);
|
||||||
extern void count_remote_client_memory(size_t * count, size_t * memory);
|
extern void count_remote_client_memory(size_t * count, size_t * memory);
|
||||||
|
|
||||||
extern client_t *find_chasing(struct Client *, const char *, int *);
|
extern struct Client *find_chasing(struct Client *, const char *, int *);
|
||||||
extern client_t *find_person(const char *);
|
extern struct Client *find_person(const char *);
|
||||||
extern client_t *find_named_person(const char *);
|
extern struct Client *find_named_person(const char *);
|
||||||
extern client_t *next_client(struct Client *, const char *);
|
extern struct Client *next_client(struct Client *, const char *);
|
||||||
|
|
||||||
#define accept_message(s, t) ((s) == (t) || (rb_dlinkFind((s), &((t)->localClient->allow_list))))
|
#define accept_message(s, t) ((s) == (t) || (rb_dlinkFind((s), &((t)->localClient->allow_list))))
|
||||||
extern void del_all_accepts(struct Client *client_p);
|
extern void del_all_accepts(struct Client *client_p);
|
||||||
|
@ -597,8 +581,8 @@ extern int show_ip_conf(struct ConfItem *aconf, struct Client *target_p);
|
||||||
|
|
||||||
extern void initUser(void);
|
extern void initUser(void);
|
||||||
extern void free_user(struct User *, struct Client *);
|
extern void free_user(struct User *, struct Client *);
|
||||||
extern user_t *make_user(struct Client *);
|
extern struct User *make_user(struct Client *);
|
||||||
extern server_t *make_server(struct Client *);
|
extern struct Server *make_server(struct Client *);
|
||||||
extern void close_connection(struct Client *);
|
extern void close_connection(struct Client *);
|
||||||
extern void init_uid(void);
|
extern void init_uid(void);
|
||||||
extern char *generate_uid(void);
|
extern char *generate_uid(void);
|
||||||
|
|
|
@ -392,12 +392,6 @@ build_target_list(int p_or_n, const char *command, struct Client *client_p,
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
if(strchr(nick, '@') || (IsOper(source_p) && (*nick == '$')))
|
|
||||||
{
|
|
||||||
handle_special(p_or_n, command, client_p, source_p, nick, text);
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
|
|
||||||
if(IsServer(client_p) && *nick == '=' && nick[1] == '#')
|
if(IsServer(client_p) && *nick == '=' && nick[1] == '#')
|
||||||
{
|
{
|
||||||
nick++;
|
nick++;
|
||||||
|
@ -424,6 +418,12 @@ build_target_list(int p_or_n, const char *command, struct Client *client_p,
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if(strchr(nick, '@') || (IsOper(source_p) && (*nick == '$')))
|
||||||
|
{
|
||||||
|
handle_special(p_or_n, command, client_p, source_p, nick, text);
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
/* no matching anything found - error if not NOTICE */
|
/* no matching anything found - error if not NOTICE */
|
||||||
if(p_or_n != NOTICE)
|
if(p_or_n != NOTICE)
|
||||||
{
|
{
|
||||||
|
|
|
@ -87,6 +87,8 @@ mo_links(struct Client *client_p, struct Client *source_p, int parc, const char
|
||||||
|
|
||||||
if(parc > 2)
|
if(parc > 2)
|
||||||
{
|
{
|
||||||
|
if(strlen(parv[2]) > HOSTLEN)
|
||||||
|
return 0;
|
||||||
if(hunt_server(client_p, source_p, ":%s LINKS %s :%s", 1, parc, parv)
|
if(hunt_server(client_p, source_p, ":%s LINKS %s :%s", 1, parc, parv)
|
||||||
!= HUNTED_ISME)
|
!= HUNTED_ISME)
|
||||||
return 0;
|
return 0;
|
||||||
|
@ -138,19 +140,21 @@ clean_string(char *dest, const unsigned char *src, size_t len)
|
||||||
if(dest == NULL || src == NULL)
|
if(dest == NULL || src == NULL)
|
||||||
return NULL;
|
return NULL;
|
||||||
|
|
||||||
len -= 3; /* allow for worst case, '^A\0' */
|
while (*src && (len > 1))
|
||||||
|
|
||||||
while (*src && (len > 0))
|
|
||||||
{
|
{
|
||||||
if(*src & 0x80) /* if high bit is set */
|
if(*src & 0x80) /* if high bit is set */
|
||||||
{
|
{
|
||||||
*d++ = '.';
|
*d++ = '.';
|
||||||
--len;
|
--len;
|
||||||
|
if(len <= 1)
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
else if(!IsPrint(*src)) /* if NOT printable */
|
else if(!IsPrint(*src)) /* if NOT printable */
|
||||||
{
|
{
|
||||||
*d++ = '^';
|
*d++ = '^';
|
||||||
--len;
|
--len;
|
||||||
|
if(len <= 1)
|
||||||
|
break;
|
||||||
*d++ = 0x40 + *src; /* turn it into a printable */
|
*d++ = 0x40 + *src; /* turn it into a printable */
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
|
|
|
@ -25,7 +25,7 @@ if [ "x$TIP" = "x" ]; then
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# Charybdis wants the hg tip to be in include/serno.h, in its own format.
|
# Charybdis wants the hg tip to be in include/serno.h, in its own format.
|
||||||
MYTIP=`hg parents --template '#date|shortdate#_#node|short#' 2>/dev/null | sed -e s/-//g -e s/_/-/`
|
MYTIP=`hg parents --template '{date|shortdate}_{node|short}' 2>/dev/null | sed -e s/-//g -e s/_/-/`
|
||||||
echo "[charybdis] Generating include/serno.h for tip $MYTIP."
|
echo "[charybdis] Generating include/serno.h for tip $MYTIP."
|
||||||
cat << _EOF_ > include/serno.h
|
cat << _EOF_ > include/serno.h
|
||||||
/* Generated automatically by makepackage. Any changes made here will be lost. */
|
/* Generated automatically by makepackage. Any changes made here will be lost. */
|
||||||
|
|
|
@ -30,7 +30,7 @@ if [ "x$2" = "x--automatic" ]; then
|
||||||
AUTOMATIC="yes"
|
AUTOMATIC="yes"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
TIP=`hg tip --template "#rev#:#node|short#"`
|
TIP=`hg parents --template "{rev}:{node|short}"`
|
||||||
|
|
||||||
WRKDIR=`pwd`
|
WRKDIR=`pwd`
|
||||||
|
|
||||||
|
|
|
@ -253,6 +253,8 @@ load_help(void)
|
||||||
|
|
||||||
while((ldirent = readdir(helpfile_dir)) != NULL)
|
while((ldirent = readdir(helpfile_dir)) != NULL)
|
||||||
{
|
{
|
||||||
|
if(ldirent->d_name[0] == '.')
|
||||||
|
continue;
|
||||||
rb_snprintf(filename, sizeof(filename), "%s/%s", HPATH, ldirent->d_name);
|
rb_snprintf(filename, sizeof(filename), "%s/%s", HPATH, ldirent->d_name);
|
||||||
cacheptr = cache_file(filename, ldirent->d_name, HELP_OPER);
|
cacheptr = cache_file(filename, ldirent->d_name, HELP_OPER);
|
||||||
irc_dictionary_add(help_dict_oper, cacheptr->name, cacheptr);
|
irc_dictionary_add(help_dict_oper, cacheptr->name, cacheptr);
|
||||||
|
@ -266,6 +268,8 @@ load_help(void)
|
||||||
|
|
||||||
while((ldirent = readdir(helpfile_dir)) != NULL)
|
while((ldirent = readdir(helpfile_dir)) != NULL)
|
||||||
{
|
{
|
||||||
|
if(ldirent->d_name[0] == '.')
|
||||||
|
continue;
|
||||||
rb_snprintf(filename, sizeof(filename), "%s/%s", UHPATH, ldirent->d_name);
|
rb_snprintf(filename, sizeof(filename), "%s/%s", UHPATH, ldirent->d_name);
|
||||||
|
|
||||||
#if defined(S_ISLNK) && defined(HAVE_LSTAT)
|
#if defined(S_ISLNK) && defined(HAVE_LSTAT)
|
||||||
|
|
|
@ -231,6 +231,7 @@ free_local_client(struct Client *client_p)
|
||||||
rb_free(client_p->localClient->passwd);
|
rb_free(client_p->localClient->passwd);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
rb_free(client_p->localClient->auth_user);
|
||||||
rb_free(client_p->localClient->challenge);
|
rb_free(client_p->localClient->challenge);
|
||||||
rb_free(client_p->localClient->fullcaps);
|
rb_free(client_p->localClient->fullcaps);
|
||||||
rb_free(client_p->localClient->opername);
|
rb_free(client_p->localClient->opername);
|
||||||
|
@ -1670,14 +1671,14 @@ make_user(struct Client *client_p)
|
||||||
* side effects - add's an Server information block to a client
|
* side effects - add's an Server information block to a client
|
||||||
* if it was not previously allocated.
|
* if it was not previously allocated.
|
||||||
*/
|
*/
|
||||||
server_t *
|
struct Server *
|
||||||
make_server(struct Client *client_p)
|
make_server(struct Client *client_p)
|
||||||
{
|
{
|
||||||
server_t *serv = client_p->serv;
|
struct Server *serv = client_p->serv;
|
||||||
|
|
||||||
if(!serv)
|
if(!serv)
|
||||||
{
|
{
|
||||||
serv = (server_t *) rb_malloc(sizeof(server_t));
|
serv = (struct Server *) rb_malloc(sizeof(struct Server));
|
||||||
client_p->serv = serv;
|
client_p->serv = serv;
|
||||||
}
|
}
|
||||||
return client_p->serv;
|
return client_p->serv;
|
||||||
|
|
|
@ -52,14 +52,14 @@ static const struct in6_addr in6addr_any =
|
||||||
{ { { 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0 } } };
|
{ { { 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0 } } };
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
static listener_t *ListenerPollList = NULL;
|
static struct Listener *ListenerPollList = NULL;
|
||||||
static int accept_precallback(rb_fde_t *F, struct sockaddr *addr, rb_socklen_t addrlen, void *data);
|
static int accept_precallback(rb_fde_t *F, struct sockaddr *addr, rb_socklen_t addrlen, void *data);
|
||||||
static void accept_callback(rb_fde_t *F, int status, struct sockaddr *addr, rb_socklen_t addrlen, void *data);
|
static void accept_callback(rb_fde_t *F, int status, struct sockaddr *addr, rb_socklen_t addrlen, void *data);
|
||||||
|
|
||||||
static listener_t *
|
static struct Listener *
|
||||||
make_listener(struct rb_sockaddr_storage *addr)
|
make_listener(struct rb_sockaddr_storage *addr)
|
||||||
{
|
{
|
||||||
listener_t *listener = (listener_t *) rb_malloc(sizeof(listener_t));
|
struct Listener *listener = (struct Listener *) rb_malloc(sizeof(struct Listener));
|
||||||
s_assert(0 != listener);
|
s_assert(0 != listener);
|
||||||
listener->name = me.name;
|
listener->name = me.name;
|
||||||
listener->F = NULL;
|
listener->F = NULL;
|
||||||
|
@ -70,7 +70,7 @@ make_listener(struct rb_sockaddr_storage *addr)
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
free_listener(listener_t *listener)
|
free_listener(struct Listener *listener)
|
||||||
{
|
{
|
||||||
s_assert(NULL != listener);
|
s_assert(NULL != listener);
|
||||||
if(listener == NULL)
|
if(listener == NULL)
|
||||||
|
@ -82,7 +82,7 @@ free_listener(listener_t *listener)
|
||||||
ListenerPollList = listener->next;
|
ListenerPollList = listener->next;
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
listener_t *prev = ListenerPollList;
|
struct Listener *prev = ListenerPollList;
|
||||||
for (; prev; prev = prev->next)
|
for (; prev; prev = prev->next)
|
||||||
{
|
{
|
||||||
if(listener == prev->next)
|
if(listener == prev->next)
|
||||||
|
@ -104,7 +104,7 @@ free_listener(listener_t *listener)
|
||||||
* returns "host.foo.org:6667" for a given listener
|
* returns "host.foo.org:6667" for a given listener
|
||||||
*/
|
*/
|
||||||
const char *
|
const char *
|
||||||
get_listener_name(const listener_t *listener)
|
get_listener_name(const struct Listener *listener)
|
||||||
{
|
{
|
||||||
static char buf[HOSTLEN + HOSTLEN + PORTNAMELEN + 4];
|
static char buf[HOSTLEN + HOSTLEN + PORTNAMELEN + 4];
|
||||||
int port = 0;
|
int port = 0;
|
||||||
|
@ -133,7 +133,7 @@ get_listener_name(const listener_t *listener)
|
||||||
void
|
void
|
||||||
show_ports(struct Client *source_p)
|
show_ports(struct Client *source_p)
|
||||||
{
|
{
|
||||||
listener_t *listener = 0;
|
struct Listener *listener = 0;
|
||||||
|
|
||||||
for (listener = ListenerPollList; listener; listener = listener->next)
|
for (listener = ListenerPollList; listener; listener = listener->next)
|
||||||
{
|
{
|
||||||
|
@ -165,7 +165,7 @@ show_ports(struct Client *source_p)
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
static int
|
static int
|
||||||
inetport(listener_t *listener)
|
inetport(struct Listener *listener)
|
||||||
{
|
{
|
||||||
rb_fde_t *F;
|
rb_fde_t *F;
|
||||||
int ret;
|
int ret;
|
||||||
|
@ -245,11 +245,11 @@ inetport(listener_t *listener)
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
static listener_t *
|
static struct Listener *
|
||||||
find_listener(struct rb_sockaddr_storage *addr)
|
find_listener(struct rb_sockaddr_storage *addr)
|
||||||
{
|
{
|
||||||
listener_t *listener = NULL;
|
struct Listener *listener = NULL;
|
||||||
listener_t *last_closed = NULL;
|
struct Listener *last_closed = NULL;
|
||||||
|
|
||||||
for (listener = ListenerPollList; listener; listener = listener->next)
|
for (listener = ListenerPollList; listener; listener = listener->next)
|
||||||
{
|
{
|
||||||
|
@ -307,7 +307,7 @@ find_listener(struct rb_sockaddr_storage *addr)
|
||||||
void
|
void
|
||||||
add_listener(int port, const char *vhost_ip, int family, int ssl)
|
add_listener(int port, const char *vhost_ip, int family, int ssl)
|
||||||
{
|
{
|
||||||
listener_t *listener;
|
struct Listener *listener;
|
||||||
struct rb_sockaddr_storage vaddr;
|
struct rb_sockaddr_storage vaddr;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
@ -389,7 +389,7 @@ add_listener(int port, const char *vhost_ip, int family, int ssl)
|
||||||
* close_listener - close a single listener
|
* close_listener - close a single listener
|
||||||
*/
|
*/
|
||||||
void
|
void
|
||||||
close_listener(listener_t *listener)
|
close_listener(struct Listener *listener)
|
||||||
{
|
{
|
||||||
s_assert(listener != NULL);
|
s_assert(listener != NULL);
|
||||||
if(listener == NULL)
|
if(listener == NULL)
|
||||||
|
@ -414,8 +414,8 @@ close_listener(listener_t *listener)
|
||||||
void
|
void
|
||||||
close_listeners()
|
close_listeners()
|
||||||
{
|
{
|
||||||
listener_t *listener;
|
struct Listener *listener;
|
||||||
listener_t *listener_next = 0;
|
struct Listener *listener_next = 0;
|
||||||
/*
|
/*
|
||||||
* close all 'extra' listening ports we have
|
* close all 'extra' listening ports we have
|
||||||
*/
|
*/
|
||||||
|
|
|
@ -892,7 +892,7 @@ conf_begin_auth(struct TopConf *tc)
|
||||||
static int
|
static int
|
||||||
conf_end_auth(struct TopConf *tc)
|
conf_end_auth(struct TopConf *tc)
|
||||||
{
|
{
|
||||||
struct ConfItem *yy_tmp;
|
struct ConfItem *yy_tmp, *found_conf;
|
||||||
rb_dlink_node *ptr;
|
rb_dlink_node *ptr;
|
||||||
rb_dlink_node *next_ptr;
|
rb_dlink_node *next_ptr;
|
||||||
|
|
||||||
|
@ -910,9 +910,11 @@ conf_end_auth(struct TopConf *tc)
|
||||||
collapse(yy_aconf->user);
|
collapse(yy_aconf->user);
|
||||||
collapse(yy_aconf->host);
|
collapse(yy_aconf->host);
|
||||||
conf_add_class_to_conf(yy_aconf);
|
conf_add_class_to_conf(yy_aconf);
|
||||||
if (find_exact_conf_by_address("*", CONF_CLIENT, "*"))
|
if ((found_conf = find_exact_conf_by_address("*", CONF_CLIENT, "*")) && found_conf->spasswd == NULL)
|
||||||
conf_report_error("Ignoring redundant auth block (after *@*)");
|
conf_report_error("Ignoring redundant auth block (after *@*)");
|
||||||
else if (find_exact_conf_by_address(yy_aconf->host, CONF_CLIENT, yy_aconf->user))
|
else if ((found_conf = find_exact_conf_by_address(yy_aconf->host, CONF_CLIENT, yy_aconf->user)) &&
|
||||||
|
(!found_conf->spasswd || (yy_aconf->spasswd &&
|
||||||
|
0 == irccmp(found_conf->spasswd, yy_aconf->spasswd))))
|
||||||
conf_report_error("Ignoring duplicate auth block for %s@%s",
|
conf_report_error("Ignoring duplicate auth block for %s@%s",
|
||||||
yy_aconf->user, yy_aconf->host);
|
yy_aconf->user, yy_aconf->host);
|
||||||
else
|
else
|
||||||
|
|
Loading…
Reference in New Issue