#include "client.h"
#include "common.h"
#include "hash.h"
-#include "irc_string.h"
-#include "sprintf_irc.h"
+#include "match.h"
#include "ircd.h"
#include "listener.h"
#include "msg.h"
0, /* W */
0, /* X */
0, /* Y */
- 0, /* Z */
+ UMODE_SSLCLIENT, /* Z */
/* 0x5B */ 0, 0, 0, 0, 0, 0, /* 0x60 */
UMODE_ADMIN, /* a */
0, /* b */
char note[NICKLEN + 10];
del_from_client_hash(source_p->name, source_p);
- strlcpy(source_p->name, source_p->preClient->spoofnick, NICKLEN + 1);
+ rb_strlcpy(source_p->name, source_p->preClient->spoofnick, NICKLEN + 1);
add_to_client_hash(source_p->name, source_p);
rb_snprintf(note, NICKLEN + 10, "Nick: %s", source_p->name);
{
sendto_one_notice(source_p, ":*** Notice -- You have an illegal character in your hostname");
- strlcpy(source_p->host, source_p->sockhost, sizeof(source_p->host));
+ rb_strlcpy(source_p->host, source_p->sockhost, sizeof(source_p->host));
}
/* end of valid user name check */
/* Store original hostname -- jilles */
- strlcpy(source_p->orighost, source_p->host, HOSTLEN + 1);
+ rb_strlcpy(source_p->orighost, source_p->host, HOSTLEN + 1);
/* Spoof user@host */
if(*source_p->preClient->spoofuser)
- strlcpy(source_p->username, source_p->preClient->spoofuser, USERLEN + 1);
+ rb_strlcpy(source_p->username, source_p->preClient->spoofuser, USERLEN + 1);
if(*source_p->preClient->spoofhost)
{
- strlcpy(source_p->host, source_p->preClient->spoofhost, HOSTLEN + 1);
+ rb_strlcpy(source_p->host, source_p->preClient->spoofhost, HOSTLEN + 1);
if (irccmp(source_p->host, source_p->orighost))
SetDynSpoof(source_p);
}
/* To avoid inconsistencies, do not abort the registration
* starting from this point -- jilles
*/
- inetntop_sock((struct sockaddr *)&source_p->localClient->ip, ipaddr, sizeof(ipaddr));
+ rb_inet_ntop_sock((struct sockaddr *)&source_p->localClient->ip, ipaddr, sizeof(ipaddr));
sendto_realops_snomask(SNO_CCONN, L_ALL,
"Client connecting: %s (%s@%s) [%s] {%s} [%s]",
add_to_id_hash(source_p->id, source_p);
}
+ if (IsSSL(source_p))
+ source_p->umodes |= UMODE_SSLCLIENT;
+
if (source_p->umodes & UMODE_INVISIBLE)
Count.invisi++;
char *p;
hook_data_umode_changed hdata;
hook_data_client hdata2;
+ char sockhost[HOSTLEN];
if(MyClient(source_p))
send_umode(source_p, source_p, 0, 0, ubuf);
ubuf[1] = '\0';
}
- /* if it has an ID, introduce it with its id to TS6 servers,
- * otherwise introduce it normally to all.
- */
- if(has_id(source_p))
+ s_assert(has_id(source_p));
+
+ if(source_p->sockhost[0] == ':')
{
- char sockhost[HOSTLEN];
- if(source_p->sockhost[0] == ':')
- {
- sockhost[0] = '0';
- sockhost[1] = '\0';
- strlcat(sockhost, source_p->sockhost, sizeof(sockhost));
- } else
- strcpy(sockhost, source_p->sockhost);
+ sockhost[0] = '0';
+ sockhost[1] = '\0';
+ rb_strlcat(sockhost, source_p->sockhost, sizeof(sockhost));
+ } else
+ strcpy(sockhost, source_p->sockhost);
- if (use_euid)
- sendto_server(client_p, NULL, CAP_EUID | CAP_TS6, NOCAPS,
- ":%s EUID %s %d %ld %s %s %s %s %s %s %s :%s",
- source_p->servptr->id, nick,
- source_p->hopcount + 1,
- (long) source_p->tsinfo, ubuf,
- source_p->username, source_p->host,
- IsIPSpoof(source_p) ? "0" : sockhost,
- source_p->id,
- IsDynSpoof(source_p) ? source_p->orighost : "*",
- EmptyString(source_p->user->suser) ? "*" : source_p->user->suser,
- source_p->info);
-
- sendto_server(client_p, NULL, CAP_TS6, use_euid ? CAP_EUID : NOCAPS,
- ":%s UID %s %d %ld %s %s %s %s %s :%s",
- source_p->servptr->id, nick,
- source_p->hopcount + 1,
- (long) source_p->tsinfo, ubuf,
- source_p->username, source_p->host,
- IsIPSpoof(source_p) ? "0" : sockhost,
- source_p->id, source_p->info);
-
- sendto_server(client_p, NULL, NOCAPS, CAP_TS6,
- "NICK %s %d %ld %s %s %s %s :%s",
- nick, source_p->hopcount + 1,
- (long) source_p->tsinfo,
- ubuf, source_p->username, source_p->host,
- source_p->servptr->name, source_p->info);
- }
- else
- sendto_server(client_p, NULL, NOCAPS, NOCAPS,
- "NICK %s %d %ld %s %s %s %s :%s",
- nick, source_p->hopcount + 1,
- (long) source_p->tsinfo,
- ubuf, source_p->username, source_p->host,
- source_p->servptr->name, source_p->info);
+ if (use_euid)
+ sendto_server(client_p, NULL, CAP_EUID | CAP_TS6, NOCAPS,
+ ":%s EUID %s %d %ld %s %s %s %s %s %s %s :%s",
+ source_p->servptr->id, nick,
+ source_p->hopcount + 1,
+ (long) source_p->tsinfo, ubuf,
+ source_p->username, source_p->host,
+ IsIPSpoof(source_p) ? "0" : sockhost,
+ source_p->id,
+ IsDynSpoof(source_p) ? source_p->orighost : "*",
+ EmptyString(source_p->user->suser) ? "*" : source_p->user->suser,
+ source_p->info);
+
+ sendto_server(client_p, NULL, CAP_TS6, use_euid ? CAP_EUID : NOCAPS,
+ ":%s UID %s %d %ld %s %s %s %s %s :%s",
+ source_p->servptr->id, nick,
+ source_p->hopcount + 1,
+ (long) source_p->tsinfo, ubuf,
+ source_p->username, source_p->host,
+ IsIPSpoof(source_p) ? "0" : sockhost,
+ source_p->id, source_p->info);
if (IsDynSpoof(source_p))
{
sendto_server(client_p, NULL, CAP_TS6, use_euid ? CAP_EUID : NOCAPS, ":%s ENCAP * REALHOST %s",
use_id(source_p), source_p->orighost);
- sendto_server(client_p, NULL, NOCAPS, CAP_TS6, ":%s ENCAP * REALHOST %s",
- source_p->name, source_p->orighost);
}
+
if (!EmptyString(source_p->user->suser))
{
sendto_server(client_p, NULL, CAP_TS6, use_euid ? CAP_EUID : NOCAPS, ":%s ENCAP * LOGIN %s",
use_id(source_p), source_p->user->suser);
- sendto_server(client_p, NULL, NOCAPS, CAP_TS6, ":%s ENCAP * LOGIN %s",
- source_p->name, source_p->user->suser);
}
if(MyConnect(source_p) && source_p->localClient->passwd)
if(IsConfExemptKline(aconf))
{
SetExemptKline(source_p);
- sendto_one_notice(source_p, ":*** You are exempt from K/G/X lines. congrats.");
- }
-
- if(IsConfExemptGline(aconf))
- {
- SetExemptGline(source_p);
-
- /* dont send both a kline and gline exempt notice */
- if(!IsConfExemptKline(aconf))
- sendto_one_notice(source_p, ":*** You are exempt from G lines.");
+ sendto_one_notice(source_p, ":*** You are exempt from K/X lines. congrats.");
}
if(IsConfExemptDNSBL(aconf))
/* can only be set on burst */
case 'S':
+ case 'Z':
case ' ':
case '\n':
case '\r':
void
change_nick_user_host(struct Client *target_p, const char *nick, const char *user,
- const char *host, int newts, char *format, ...)
+ const char *host, int newts, const char *format, ...)
{
rb_dlink_node *ptr;
struct Channel *chptr;
target_p->host, nick);
}
- strlcpy(target_p->username, user, sizeof target_p->username);
- strlcpy(target_p->host, host, sizeof target_p->host);
+ rb_strlcpy(target_p->username, user, sizeof target_p->username);
+ rb_strlcpy(target_p->host, host, sizeof target_p->host);
if (changed)
add_history(target_p, 1);
del_from_client_hash(target_p->name, target_p);
- strlcpy(target_p->name, nick, NICKLEN);
+ rb_strlcpy(target_p->name, nick, NICKLEN);
add_to_client_hash(target_p->name, target_p);
if(changed)