SJOIN: remove various TS5 stuff

This commit is contained in:
Jilles Tjoelker 2008-06-13 23:03:52 +02:00
parent 7592f950b2
commit 0a70e15066
1 changed files with 8 additions and 30 deletions

View File

@ -75,7 +75,7 @@ static void set_final_mode(struct Mode *mode, struct Mode *oldmode);
static void remove_our_modes(struct Channel *chptr, struct Client *source_p); static void remove_our_modes(struct Channel *chptr, struct Client *source_p);
static void remove_ban_list(struct Channel *chptr, struct Client *source_p, static void remove_ban_list(struct Channel *chptr, struct Client *source_p,
rb_dlink_list * list, char c, int cap, int mems); rb_dlink_list * list, char c, int mems);
static char modebuf[MODEBUFLEN]; static char modebuf[MODEBUFLEN];
static char parabuf[MODEBUFLEN]; static char parabuf[MODEBUFLEN];
@ -697,10 +697,6 @@ ms_sjoin(struct Client *client_p, struct Client *source_p, int parc, const char
struct membership *msptr; struct membership *msptr;
struct Client *who; struct Client *who;
int l = rb_dlink_list_length(&chptr->members); int l = rb_dlink_list_length(&chptr->members);
int b = rb_dlink_list_length(&chptr->banlist) +
rb_dlink_list_length(&chptr->exceptlist) +
rb_dlink_list_length(&chptr->invexlist) +
rb_dlink_list_length(&chptr->quietlist);
RB_DLINK_FOREACH_SAFE(ptr, next_ptr, chptr->locmembers.head) RB_DLINK_FOREACH_SAFE(ptr, next_ptr, chptr->locmembers.head)
{ {
@ -723,14 +719,6 @@ ms_sjoin(struct Client *client_p, struct Client *source_p, int parc, const char
if((chptr = get_or_create_channel(source_p, parv[2], &isnew)) == NULL) if((chptr = get_or_create_channel(source_p, parv[2], &isnew)) == NULL)
return 0; /* oops! */ return 0; /* oops! */
/* If the source does not do TS6,
* nontimestamped bans have been sent to it,
* but we have just lost those here. Let's
* warn the channel about this. Because
* of the kicks, any users on the channel
* will be at client_p. -- jilles */
if (!has_id(source_p) && b > 0)
sendto_one(client_p, ":%s NOTICE %s :*** Notice -- possible ban desync on %s, please remove any bans just added by servers", get_id(&me, client_p), parv[2], parv[2]);
oldmode = &chptr->mode; oldmode = &chptr->mode;
} }
} }
@ -982,26 +970,23 @@ ms_sjoin(struct Client *client_p, struct Client *source_p, int parc, const char
sendto_server(client_p->from, NULL, CAP_TS6, NOCAPS, "%s", buf_uid); sendto_server(client_p->from, NULL, CAP_TS6, NOCAPS, "%s", buf_uid);
/* if the source does TS6 we have to remove our bans. Its now safe /* if the source does TS6 we have to remove our bans. */
* to issue -b's to the non-ts6 servers, as the sjoin we've just if(!keep_our_modes)
* sent will kill any ops they have.
*/
if(!keep_our_modes && source_p->id[0] != '\0')
{ {
if(rb_dlink_list_length(&chptr->banlist) > 0) if(rb_dlink_list_length(&chptr->banlist) > 0)
remove_ban_list(chptr, fakesource_p, &chptr->banlist, 'b', NOCAPS, ALL_MEMBERS); remove_ban_list(chptr, fakesource_p, &chptr->banlist, 'b', ALL_MEMBERS);
if(rb_dlink_list_length(&chptr->exceptlist) > 0) if(rb_dlink_list_length(&chptr->exceptlist) > 0)
remove_ban_list(chptr, fakesource_p, &chptr->exceptlist, remove_ban_list(chptr, fakesource_p, &chptr->exceptlist,
'e', CAP_EX, ONLY_CHANOPS); 'e', ONLY_CHANOPS);
if(rb_dlink_list_length(&chptr->invexlist) > 0) if(rb_dlink_list_length(&chptr->invexlist) > 0)
remove_ban_list(chptr, fakesource_p, &chptr->invexlist, remove_ban_list(chptr, fakesource_p, &chptr->invexlist,
'I', CAP_IE, ONLY_CHANOPS); 'I', ONLY_CHANOPS);
if(rb_dlink_list_length(&chptr->quietlist) > 0) if(rb_dlink_list_length(&chptr->quietlist) > 0)
remove_ban_list(chptr, fakesource_p, &chptr->quietlist, remove_ban_list(chptr, fakesource_p, &chptr->quietlist,
'q', NOCAPS, ALL_MEMBERS); 'q', ALL_MEMBERS);
chptr->bants++; chptr->bants++;
} }
@ -1298,11 +1283,10 @@ remove_our_modes(struct Channel *chptr, struct Client *source_p)
* inputs - channel, source, list to remove, char of mode, caps needed * inputs - channel, source, list to remove, char of mode, caps needed
* outputs - * outputs -
* side effects - given list is removed, with modes issued to local clients * side effects - given list is removed, with modes issued to local clients
* and non-TS6 servers.
*/ */
static void static void
remove_ban_list(struct Channel *chptr, struct Client *source_p, remove_ban_list(struct Channel *chptr, struct Client *source_p,
rb_dlink_list * list, char c, int cap, int mems) rb_dlink_list * list, char c, int mems)
{ {
static char lmodebuf[BUFSIZE]; static char lmodebuf[BUFSIZE];
static char lparabuf[BUFSIZE]; static char lparabuf[BUFSIZE];
@ -1332,11 +1316,6 @@ remove_ban_list(struct Channel *chptr, struct Client *source_p,
*(pbuf - 1) = '\0'; *(pbuf - 1) = '\0';
sendto_channel_local(mems, chptr, "%s %s", lmodebuf, lparabuf); sendto_channel_local(mems, chptr, "%s %s", lmodebuf, lparabuf);
/* Tricky tricky. If we changed source_p to &me
* in ms_sjoin(), this still won't send stuff
* where it should not be sent, because the
* real source_p does TS6 -- jilles */
sendto_server(source_p, chptr, cap, CAP_TS6, "%s %s", lmodebuf, lparabuf);
cur_len = mlen; cur_len = mlen;
mbuf = lmodebuf + mlen; mbuf = lmodebuf + mlen;
@ -1355,7 +1334,6 @@ remove_ban_list(struct Channel *chptr, struct Client *source_p,
*mbuf = '\0'; *mbuf = '\0';
*(pbuf - 1) = '\0'; *(pbuf - 1) = '\0';
sendto_channel_local(mems, chptr, "%s %s", lmodebuf, lparabuf); sendto_channel_local(mems, chptr, "%s %s", lmodebuf, lparabuf);
sendto_server(source_p, chptr, cap, CAP_TS6, "%s %s", lmodebuf, lparabuf);
list->head = list->tail = NULL; list->head = list->tail = NULL;
list->length = 0; list->length = 0;