Fix userlist
This commit is contained in:
parent
b4f9498525
commit
9576b3233f
@ -113,6 +113,7 @@ extern struct sysconfig CFG; /* System configuration */
|
|||||||
extern int s_bbsopen; /* The BBS open status */
|
extern int s_bbsopen; /* The BBS open status */
|
||||||
#ifdef USE_EXPERIMENT
|
#ifdef USE_EXPERIMENT
|
||||||
extern srv_list *servers; /* Connected servers */
|
extern srv_list *servers; /* Connected servers */
|
||||||
|
extern usr_list *users; /* Connected users */
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|
||||||
@ -435,7 +436,7 @@ char *chat_connect(char *data)
|
|||||||
/*
|
/*
|
||||||
* Register with IBC
|
* Register with IBC
|
||||||
*/
|
*/
|
||||||
add_user(CFG.myfqdn, nick, realname);
|
add_user(&users, CFG.myfqdn, nick, realname);
|
||||||
sprintf(buf, "USER %s@%s %s", nick, CFG.myfqdn, realname);
|
sprintf(buf, "USER %s@%s %s", nick, CFG.myfqdn, realname);
|
||||||
send_all(buf);
|
send_all(buf);
|
||||||
#endif
|
#endif
|
||||||
@ -486,7 +487,7 @@ char *chat_close(char *data)
|
|||||||
* Remove from IBC network
|
* Remove from IBC network
|
||||||
*/
|
*/
|
||||||
#ifdef USE_EXPERIMENT
|
#ifdef USE_EXPERIMENT
|
||||||
del_user(CFG.myfqdn, chat_users[i].realname);
|
del_user(&users, CFG.myfqdn, chat_users[i].realname);
|
||||||
sprintf(buf, "QUIT %s@%s Leaving chat", chat_users[i].nick, CFG.myfqdn);
|
sprintf(buf, "QUIT %s@%s Leaving chat", chat_users[i].nick, CFG.myfqdn);
|
||||||
send_all(buf);
|
send_all(buf);
|
||||||
#endif
|
#endif
|
||||||
|
@ -161,9 +161,9 @@ void dump_ncslist(void)
|
|||||||
|
|
||||||
if (usrchg) {
|
if (usrchg) {
|
||||||
Syslog('+', "IBC: Server User Nick Channel Cop Connect time");
|
Syslog('+', "IBC: Server User Nick Channel Cop Connect time");
|
||||||
Syslog('+', "IBC: ------------------------- ------------------------- --------- -------------------- --- --------------------");
|
Syslog('+', "IBC: -------------------- -------------------- --------- --------------- --- --------------------");
|
||||||
for (usrp = users; usrp; usrp = usrp->next) {
|
for (usrp = users; usrp; usrp = usrp->next) {
|
||||||
Syslog('+', "IBC: %-25s %-25s %-9s %-20s %s %s", usrp->server, usrp->realname, usrp->nick, usrp->channel,
|
Syslog('+', "IBC: %-20s %-20s %-9s %-15s %s %s", usrp->server, usrp->realname, usrp->nick, usrp->channel,
|
||||||
usrp->chanop ? "yes":"no ", rfcdate(usrp->connected));
|
usrp->chanop ? "yes":"no ", rfcdate(usrp->connected));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -191,7 +191,7 @@ void tidy_servers(srv_list ** fdp)
|
|||||||
/*
|
/*
|
||||||
* Add one user to the userlist
|
* Add one user to the userlist
|
||||||
*/
|
*/
|
||||||
void add_user(char *server, char *nick, char *realname)
|
void add_user(usr_list **fap, char *server, char *nick, char *realname)
|
||||||
{
|
{
|
||||||
usr_list *tmp, *ta;
|
usr_list *tmp, *ta;
|
||||||
srv_list *sl;
|
srv_list *sl;
|
||||||
@ -199,7 +199,7 @@ void add_user(char *server, char *nick, char *realname)
|
|||||||
|
|
||||||
Syslog('r', "add_user %s %s %s", server, nick, realname);
|
Syslog('r', "add_user %s %s %s", server, nick, realname);
|
||||||
|
|
||||||
for (ta = users; ta; ta = ta->next) {
|
for (ta = *fap; ta; ta = ta->next) {
|
||||||
if ((strcmp(ta->server, server) == 0) && (strcmp(ta->realname, realname) == 0)) {
|
if ((strcmp(ta->server, server) == 0) && (strcmp(ta->realname, realname) == 0)) {
|
||||||
Syslog('r', "duplicate, ignore");
|
Syslog('r', "duplicate, ignore");
|
||||||
return;
|
return;
|
||||||
@ -217,10 +217,10 @@ void add_user(char *server, char *nick, char *realname)
|
|||||||
strncpy(tmp->realname, realname, 36);
|
strncpy(tmp->realname, realname, 36);
|
||||||
tmp->connected = now;
|
tmp->connected = now;
|
||||||
|
|
||||||
if (users == NULL) {
|
if (*fap == NULL) {
|
||||||
users = tmp;
|
*fap = tmp;
|
||||||
} else {
|
} else {
|
||||||
for (ta = users; ta; ta = ta->next)
|
for (ta = *fap; ta; ta = ta->next)
|
||||||
if (ta->next == NULL) {
|
if (ta->next == NULL) {
|
||||||
ta->next = (usr_list *)tmp;
|
ta->next = (usr_list *)tmp;
|
||||||
break;
|
break;
|
||||||
@ -245,7 +245,7 @@ void add_user(char *server, char *nick, char *realname)
|
|||||||
/*
|
/*
|
||||||
* Delete one user.
|
* Delete one user.
|
||||||
*/
|
*/
|
||||||
void del_user(char *server, char *realname)
|
void del_user(usr_list **fap, char *server, char *realname)
|
||||||
{
|
{
|
||||||
usr_list *ta, *tan;
|
usr_list *ta, *tan;
|
||||||
srv_list *sl;
|
srv_list *sl;
|
||||||
@ -253,13 +253,13 @@ void del_user(char *server, char *realname)
|
|||||||
|
|
||||||
Syslog('r', "deluser %s %s", server, realname);
|
Syslog('r', "deluser %s %s", server, realname);
|
||||||
|
|
||||||
if (users == NULL)
|
if (*fap == NULL)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
if ((rc = pthread_mutex_lock(&b_mutex)))
|
if ((rc = pthread_mutex_lock(&b_mutex)))
|
||||||
Syslog('!', "del_user() mutex_lock failed rc=%d", rc);
|
Syslog('!', "del_user() mutex_lock failed rc=%d", rc);
|
||||||
|
|
||||||
for (ta = users; ta; ta = ta->next) {
|
for (ta = *fap; ta; ta = ta->next) {
|
||||||
while ((tan = ta->next) && (strcmp(tan->server, server) == 0) && (strcmp(tan->realname, realname) == 0)) {
|
while ((tan = ta->next) && (strcmp(tan->server, server) == 0) && (strcmp(tan->realname, realname) == 0)) {
|
||||||
ta->next = tan->next;
|
ta->next = tan->next;
|
||||||
free(tan);
|
free(tan);
|
||||||
|
@ -76,8 +76,8 @@ typedef struct _chn_list {
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
void add_user(char *, char *, char *);
|
void add_user(usr_list **, char *, char *, char *);
|
||||||
void del_user(char *, char *);
|
void del_user(usr_list **, char *, char *);
|
||||||
|
|
||||||
void send_all(char *);
|
void send_all(char *);
|
||||||
void *ibc_thread(void *);
|
void *ibc_thread(void *);
|
||||||
|
Reference in New Issue
Block a user