--HG--
branch : shroudtrusts
#else
controlwall(NO_OPER, NL_GLINES, "Destroying G-Line on '%s' lasting %s with reason '%s', created by: %s",
glinetostring(agline), longtoduration(agline->expire-getnettime(), 0),
#else
controlwall(NO_OPER, NL_GLINES, "Destroying G-Line on '%s' lasting %s with reason '%s', created by: %s",
glinetostring(agline), longtoduration(agline->expire-getnettime(), 0),
- agline->reason->content, agline->creator->content);
+ agline->reason ? agline->reason->content : "", agline->creator->content);
#if 1
irc_send("%s GL * %%-%s %lu %lu :%s\r\n", mynumeric->content,
glinetostring(agline), agline->expire - getnettime(),
#if 1
irc_send("%s GL * %%-%s %lu %lu :%s\r\n", mynumeric->content,
glinetostring(agline), agline->expire - getnettime(),
- agline->lastmod, agline->reason->content);
+ agline->lastmod, agline->reason ? agline->reason->content : "");
#else
controlwall(NO_OPER, NL_GLINES, "%s GL * %%-%s %lu %lu :%s\r\n", mynumeric->content,
glinetostring(agline), agline->expire - getnettime(),
#else
controlwall(NO_OPER, NL_GLINES, "%s GL * %%-%s %lu %lu :%s\r\n", mynumeric->content,
glinetostring(agline), agline->expire - getnettime(),
- agline->lastmod, agline->reason->content);
+ agline->lastmod, agline->reason ? agline->reason->content : "");
#endif
#endif /* SNIRCD_VERSION */
} else if (agline->flags & GLINE_ACTIVE) {
controlwall(NO_OPER, NL_GLINES, "Activating G-Line on '%s' lasting %s created by %s with reason '%s'",
glinetostring(agline), longtoduration(agline->expire-getnettime(), 0),
#endif
#endif /* SNIRCD_VERSION */
} else if (agline->flags & GLINE_ACTIVE) {
controlwall(NO_OPER, NL_GLINES, "Activating G-Line on '%s' lasting %s created by %s with reason '%s'",
glinetostring(agline), longtoduration(agline->expire-getnettime(), 0),
- agline->creator->content, agline->reason->content);
+ agline->creator->content, agline->reason ? agline->reason->content : "");
#if 1
irc_send("%s GL * +%s %lu %lu :%s\r\n", mynumeric->content,
glinetostring(agline), agline->expire - getnettime(),
#if 1
irc_send("%s GL * +%s %lu %lu :%s\r\n", mynumeric->content,
glinetostring(agline), agline->expire - getnettime(),
- agline->lastmod, agline->reason->content);
+ agline->lastmod, agline->reason ? agline->reason->content : "");
#else
controlwall(NO_OPER, NL_GLINES, "%s GL * +%s %lu %lu :%s\r\n", mynumeric->content,
glinetostring(agline), agline->expire - getnettime(),
#else
controlwall(NO_OPER, NL_GLINES, "%s GL * +%s %lu %lu :%s\r\n", mynumeric->content,
glinetostring(agline), agline->expire - getnettime(),
- agline->lastmod, agline->reason->content);
+ agline->lastmod, agline->reason ? agline->reason->content : "");
#endif
} else {
controlwall(NO_OPER, NL_GLINES, "Deactivating G-Line on '%s' lasting %s created by %s with reason '%s'",
glinetostring(agline), longtoduration(agline->expire-getnettime(), 0),
#endif
} else {
controlwall(NO_OPER, NL_GLINES, "Deactivating G-Line on '%s' lasting %s created by %s with reason '%s'",
glinetostring(agline), longtoduration(agline->expire-getnettime(), 0),
- agline->creator->content, agline->reason->content);
+ agline->creator->content, agline->reason ? agline->reason->content : "");
#if 1
irc_send("%s GL * -%s %lu %lu :%s\r\n", mynumeric->content,
glinetostring(agline), agline->expire - getnettime(),
#if 1
irc_send("%s GL * -%s %lu %lu :%s\r\n", mynumeric->content,
glinetostring(agline), agline->expire - getnettime(),
- agline->lastmod, agline->reason->content);
+ agline->lastmod, agline->reason ? agline->reason->content : "");
#else
controlwall(NO_OPER, NL_GLINES, "%s GL * -%s %lu %lu :%s\r\n", mynumeric->content,
glinetostring(agline), agline->expire - getnettime(),
#else
controlwall(NO_OPER, NL_GLINES, "%s GL * -%s %lu %lu :%s\r\n", mynumeric->content,
glinetostring(agline), agline->expire - getnettime(),
- agline->lastmod, agline->reason->content);
+ agline->lastmod, agline->reason ? agline->reason->content : "");
trusthost *th;
/* Reason is too short */
trusthost *th;
/* Reason is too short */
- if (strlen(gl->reason->content) < MINGLINEREASONLEN) {
+ if (!gl->reason || strlen(gl->reason->content) < MINGLINEREASONLEN) {
*hint = "G-Line reason is too short.";
return 0;
}
*hint = "G-Line reason is too short.";
return 0;
}
if (gl->host)
sgl->host = getsstring(gl->host->content, 512);
if (gl->host)
sgl->host = getsstring(gl->host->content, 512);
- sgl->reason = getsstring(gl->reason->content, 512);
+ sgl->reason = gl->reason ? getsstring(gl->reason->content, 512) : NULL;
sgl->creator = getsstring(gl->creator->content, 512);
memcpy(&sgl->ip, &gl->ip, sizeof(gl->ip));
sgl->creator = getsstring(gl->creator->content, 512);
memcpy(&sgl->ip, &gl->ip, sizeof(gl->ip));
else
strftime(lastmod, sizeof(lastmod), "%d/%m/%y %H:%M:%S", localtime(&gl->lastmod));
else
strftime(lastmod, sizeof(lastmod), "%d/%m/%y %H:%M:%S", localtime(&gl->lastmod));
- controlreply(spewto, "%-40s %-20s %-20s %-25s %s", glinetostring(gl), timebuf, lastmod, gl->creator->content, gl->reason->content);
+ controlreply(spewto, "%-40s %-20s %-20s %-25s %s", glinetostring(gl), timebuf, lastmod, gl->creator->content, gl->reason ? gl->reason->content : "");
}
controlreply(spewto, "Hits");
}
controlreply(spewto, "Hits");
agline = findgline(mask);
if (agline) {
agline = findgline(mask);
if (agline) {
- Error("debuggline", ERR_WARNING, "Update for existing gline received for %s - old lastmod %lu, expire %lu, lifetime %lu, reason %s, creator %s", mask, agline->lastmod, agline->expire, agline->lifetime, agline->reason->content, agline->creator->content);
+ Error("debuggline", ERR_WARNING, "Update for existing gline received for %s - old lastmod %lu, expire %lu, lifetime %lu, reason %s, creator %s", mask, agline->lastmod, agline->expire, agline->lifetime, agline->reason ? agline->reason->content : "", agline->creator->content);
agline->flags |= GLINE_ACTIVE;
agline->flags |= GLINE_ACTIVE;
fprintf(fp, "%s %jd,%jd,%jd,%d,%s,%s\n",
glinetostring(gl), (intmax_t)gl->expire, (intmax_t)gl->lastmod, (intmax_t)gl->lifetime,
(gl->flags & GLINE_ACTIVE) ? 1 : 0,
fprintf(fp, "%s %jd,%jd,%jd,%d,%s,%s\n",
glinetostring(gl), (intmax_t)gl->expire, (intmax_t)gl->lastmod, (intmax_t)gl->lifetime,
(gl->flags & GLINE_ACTIVE) ? 1 : 0,
- gl->creator->content, gl->reason->content);
+ gl->creator->content, gl->reason ? gl->reason->content : "");