122 |
|
client_p->since = client_p->lasttime = client_p->firsttime = CurrentTime; |
123 |
|
|
124 |
|
client_p->localClient = BlockHeapAlloc(lclient_heap); |
125 |
+ |
client_p->localClient->registration = REG_INIT; |
126 |
|
/* as good a place as any... */ |
127 |
|
dlinkAdd(client_p, make_dlink_node(), &unknown_list); |
128 |
|
} |
149 |
|
assert(client_p != NULL); |
150 |
|
assert(client_p != &me); |
151 |
|
assert(client_p->hnext == client_p); |
151 |
– |
assert(client_p->invited.head == NULL); |
152 |
|
assert(client_p->channel.head == NULL); |
153 |
– |
assert(dlink_list_length(&client_p->invited) == 0); |
153 |
|
assert(dlink_list_length(&client_p->channel) == 0); |
154 |
|
|
155 |
|
MyFree(client_p->away); |
157 |
|
|
158 |
|
if (MyConnect(client_p)) |
159 |
|
{ |
160 |
+ |
assert(client_p->localClient->invited.head == NULL); |
161 |
+ |
assert(dlink_list_length(&client_p->localClient->invited) == 0); |
162 |
|
assert(IsClosing(client_p) && IsDead(client_p)); |
163 |
|
|
164 |
|
MyFree(client_p->localClient->response); |
317 |
|
ilog(L_NOTICE, "No response from %s, closing link", |
318 |
|
get_client_name(client_p, HIDE_IP)); |
319 |
|
} |
320 |
+ |
|
321 |
|
ircsprintf(scratch, "Ping timeout: %d seconds", |
322 |
|
(int)(CurrentTime - client_p->lasttime)); |
321 |
– |
|
323 |
|
exit_client(client_p, &me, scratch); |
324 |
|
} |
325 |
|
else if (!IsPingWarning(client_p) && pingwarn > 0 && |
363 |
|
if (client_p->localClient->reject_delay > 0) |
364 |
|
{ |
365 |
|
if (client_p->localClient->reject_delay <= CurrentTime) |
366 |
< |
exit_client(client_p, &me, "Rejected"); |
366 |
> |
exit_client(client_p, &me, "Rejected"); |
367 |
|
continue; |
368 |
|
} |
369 |
|
|
370 |
< |
/* Check UNKNOWN connections - if they have been in this state |
370 |
> |
/* |
371 |
> |
* Check UNKNOWN connections - if they have been in this state |
372 |
|
* for > 30s, close them. |
373 |
|
*/ |
374 |
< |
if (client_p->firsttime ? ((CurrentTime - client_p->firsttime) > 30) : 0) |
375 |
< |
exit_client(client_p, &me, "Connection timed out"); |
374 |
> |
if (IsAuthFinished(client_p) && (CurrentTime - client_p->firsttime) > 30) |
375 |
> |
exit_client(client_p, &me, "Registration timed out"); |
376 |
|
} |
377 |
|
} |
378 |
|
|
760 |
|
DLINK_FOREACH_SAFE(lp, next_lp, source_p->channel.head) |
761 |
|
remove_user_from_channel(lp->data); |
762 |
|
|
761 |
– |
/* Clean up invitefield */ |
762 |
– |
DLINK_FOREACH_SAFE(lp, next_lp, source_p->invited.head) |
763 |
– |
del_invite(lp->data, source_p); |
764 |
– |
|
763 |
|
/* Clean up allow lists */ |
764 |
|
del_all_accepts(source_p); |
765 |
|
add_history(source_p, 0); |
770 |
|
source_p->from->serv->dep_users--; |
771 |
|
assert(source_p->from->serv->dep_users >= 0); |
772 |
|
} |
773 |
+ |
else |
774 |
+ |
{ |
775 |
+ |
/* Clean up invitefield */ |
776 |
+ |
DLINK_FOREACH_SAFE(lp, next_lp, source_p->localClient->invited.head) |
777 |
+ |
del_invite(lp->data, source_p); |
778 |
+ |
} |
779 |
|
} |
780 |
|
|
781 |
|
/* Remove source_p from the client lists */ |
1057 |
|
} |
1058 |
|
else if (IsClient(source_p) && !IsKilled(source_p)) |
1059 |
|
{ |
1060 |
< |
sendto_server(NULL, source_p, NULL, CAP_TS6, NOCAPS, NOFLAGS, |
1060 |
> |
sendto_server(from->from, source_p, NULL, CAP_TS6, NOCAPS, NOFLAGS, |
1061 |
|
":%s QUIT :%s", ID(source_p), comment); |
1062 |
< |
sendto_server(NULL, source_p, NULL, NOCAPS, CAP_TS6, NOFLAGS, |
1062 |
> |
sendto_server(from->from, source_p, NULL, NOCAPS, CAP_TS6, NOFLAGS, |
1063 |
|
":%s QUIT :%s", source_p->name, comment); |
1064 |
|
} |
1065 |
|
|
1137 |
|
} |
1138 |
|
else |
1139 |
|
{ |
1140 |
< |
report_error(L_ADMIN, "Lost connection to %s: %d", |
1140 |
> |
report_error(L_ADMIN, "Lost connection to %s: %s", |
1141 |
|
get_client_name(client_p, SHOW_IP), current_error); |
1142 |
< |
report_error(L_OPER, "Lost connection to %s: %d", |
1142 |
> |
report_error(L_OPER, "Lost connection to %s: %s", |
1143 |
|
get_client_name(client_p, MASK_IP), current_error); |
1144 |
|
} |
1145 |
|
|
1235 |
|
if (IsSoftCallerId(target)) |
1236 |
|
{ |
1237 |
|
DLINK_FOREACH(ptr, target->channel.head) |
1238 |
< |
if (IsMember(source, ptr->data)) |
1238 |
> |
if (IsMember(source, ((struct Membership *)ptr->data)->chptr)) |
1239 |
|
return (1); |
1240 |
|
} |
1241 |
|
|
1339 |
|
|
1340 |
|
/* This had to be copied here to avoid problems.. */ |
1341 |
|
source_p->tsinfo = CurrentTime; |
1342 |
+ |
source_p->localClient->registration &= ~REG_NEED_NICK; |
1343 |
|
|
1344 |
|
if (source_p->name[0]) |
1345 |
|
hash_del_client(source_p); |
1353 |
|
/* They have the nick they want now.. */ |
1354 |
|
client_p->llname[0] = '\0'; |
1355 |
|
|
1356 |
< |
if (source_p->flags & FLAGS_GOTUSER) |
1356 |
> |
if (!source_p->localClient->registration) |
1357 |
|
{ |
1358 |
|
strlcpy(buf, source_p->username, sizeof(buf)); |
1359 |
|
|