117ac1f407
ok simon@ and maintainer Andrew Dalgleish; tested by Wiktor Izdebski
151 lines
5.2 KiB
Plaintext
151 lines
5.2 KiB
Plaintext
$OpenBSD: patch-irc_c,v 1.5 2007/11/19 11:44:33 martynas Exp $
|
|
--- irc.c.orig Mon Aug 20 16:34:05 2007
|
|
+++ irc.c Mon Nov 19 13:39:01 2007
|
|
@@ -59,7 +59,7 @@ irc_t *irc_new( int fd )
|
|
irc->userhash = g_hash_table_new( g_str_hash, g_str_equal );
|
|
irc->watches = g_hash_table_new( g_str_hash, g_str_equal );
|
|
|
|
- strcpy( irc->umode, UMODE );
|
|
+ strlcpy( irc->umode, UMODE, sizeof(irc->umode) );
|
|
irc->mynick = g_strdup( ROOT_NICK );
|
|
irc->channel = g_strdup( ROOT_CHAN );
|
|
|
|
@@ -117,9 +117,9 @@ irc_t *irc_new( int fd )
|
|
set_add( irc, "buddy_sendbuffer_delay", "200", set_eval_int );
|
|
set_add( irc, "charset", "iso8859-1", set_eval_charset );
|
|
set_add( irc, "debug", "false", set_eval_bool );
|
|
- set_add( irc, "default_target", "root", NULL );
|
|
+ set_add( irc, "default_target", ROOT_NICK, NULL );
|
|
set_add( irc, "display_namechanges", "false", set_eval_bool );
|
|
- set_add( irc, "handle_unknown", "root", NULL );
|
|
+ set_add( irc, "handle_unknown", ROOT_NICK, NULL );
|
|
set_add( irc, "lcnicks", "true", set_eval_bool );
|
|
set_add( irc, "ops", "both", set_eval_ops );
|
|
set_add( irc, "private", "true", set_eval_bool );
|
|
@@ -617,7 +617,7 @@ int irc_exec( irc_t *irc, char **cmd )
|
|
|
|
if( g_strcasecmp( t, "last" ) == 0 && irc->last_target )
|
|
cmd[1] = irc->last_target;
|
|
- else if( g_strcasecmp( t, "root" ) == 0 )
|
|
+ else if( g_strcasecmp( t, ROOT_NICK ) == 0 || g_strcasecmp( t, "root" ) == 0 )
|
|
cmd[1] = irc->mynick;
|
|
|
|
for( i = 0; i < strlen( cmd[2] ); i ++ )
|
|
@@ -704,8 +704,8 @@ int irc_exec( irc_t *irc, char **cmd )
|
|
if( lenleft < 0 )
|
|
break;
|
|
|
|
- strcat( buff, u->nick );
|
|
- strcat( buff, " " );
|
|
+ strlcat( buff, u->nick, sizeof(buff) );
|
|
+ strlcat( buff, " ", sizeof(buff) );
|
|
}
|
|
|
|
if( next )
|
|
@@ -865,7 +865,7 @@ void irc_reply( irc_t *irc, int code, char *format, ..
|
|
va_list params;
|
|
|
|
va_start( params, format );
|
|
- g_vsnprintf( text, IRC_MAX_LINE, format, params );
|
|
+ g_vsnprintf( text, sizeof(text), format, params );
|
|
va_end( params );
|
|
irc_write( irc, ":%s %03d %s %s", irc->myhost, code, irc->nick?irc->nick:"*", text );
|
|
|
|
@@ -919,14 +919,14 @@ void irc_vawrite( irc_t *irc, char *format, va_list pa
|
|
|
|
conv[IRC_MAX_LINE] = 0;
|
|
if( do_iconv( "UTF-8", cs, line, conv, 0, IRC_MAX_LINE - 2 ) != -1 )
|
|
- strcpy( line, conv );
|
|
+ strlcpy( line, conv, sizeof(line) );
|
|
}
|
|
- strcat( line, "\r\n" );
|
|
+ strlcat( line, "\r\n", sizeof(line) );
|
|
|
|
if( irc->sendbuffer != NULL ) {
|
|
- size = strlen( irc->sendbuffer ) + strlen( line );
|
|
- irc->sendbuffer = g_renew ( char, irc->sendbuffer, size + 1 );
|
|
- strcpy( ( irc->sendbuffer + strlen( irc->sendbuffer ) ), line );
|
|
+ size = strlen( irc->sendbuffer ) + strlen( line ) + 1;
|
|
+ irc->sendbuffer = g_renew ( char, irc->sendbuffer, size );
|
|
+ strlcat( irc->sendbuffer, line, size);
|
|
}
|
|
else
|
|
irc->sendbuffer = g_strdup(line);
|
|
@@ -996,7 +996,7 @@ void irc_names( irc_t *irc, char *channel )
|
|
}
|
|
else if( !u->gc )
|
|
{
|
|
- if( strcmp( u->nick, irc->mynick ) == 0 && ( strcmp( set_getstr( irc, "ops" ), "root" ) == 0 || strcmp( set_getstr( irc, "ops" ), "both" ) == 0 ) )
|
|
+ if( strcmp( u->nick, irc->mynick ) == 0 && ( strcmp( set_getstr( irc, "ops" ), ROOT_NICK ) == 0 || strcmp( set_getstr( irc, "ops" ), "root" ) == 0 || strcmp( set_getstr( irc, "ops" ), "both" ) == 0 ) )
|
|
s = "@";
|
|
else if( strcmp( u->nick, irc->nick ) == 0 && ( strcmp( set_getstr( irc, "ops" ), "user" ) == 0 || strcmp( set_getstr( irc, "ops" ), "both" ) == 0 ) )
|
|
s = "@";
|
|
@@ -1116,15 +1116,19 @@ void irc_motd( irc_t *irc )
|
|
irc_reply( irc, 375, ":- %s Message Of The Day - ", irc->myhost );
|
|
while( read( fd, linebuf + len, 1 ) == 1 )
|
|
{
|
|
- if( linebuf[len] == '\n' || len == max )
|
|
+ /* If we have a LF, output the line and START AGAIN */
|
|
+ if( linebuf[len] == '\n')
|
|
{
|
|
linebuf[len] = 0;
|
|
irc_reply( irc, 372, ":- %s", linebuf );
|
|
len = 0;
|
|
+ continue;
|
|
}
|
|
- else if( linebuf[len] == '%' )
|
|
+
|
|
+ if( linebuf[len] == '%' )
|
|
{
|
|
- read( fd, linebuf + len, 1 );
|
|
+ if (read( fd, linebuf + len, 1 ) != 1)
|
|
+ break;
|
|
if( linebuf[len] == 'h' )
|
|
add = irc->myhost;
|
|
else if( linebuf[len] == 'v' )
|
|
@@ -1133,14 +1137,30 @@ void irc_motd( irc_t *irc )
|
|
add = irc->nick;
|
|
else
|
|
add = "%";
|
|
-
|
|
- strncpy( linebuf + len, add, max - len );
|
|
+
|
|
+ /* If the expanded string would be too long, output the line */
|
|
+ if ((len + strlen(add)) > max) {
|
|
+ linebuf[len] = 0;
|
|
+ irc_reply( irc, 372, ":- %s", linebuf );
|
|
+ len = 0;
|
|
+ }
|
|
+
|
|
+ /* Append the string to the line */
|
|
+ strlcpy( linebuf + len, add, max - len );
|
|
while( linebuf[++len] );
|
|
}
|
|
- else if( len < max )
|
|
+ else
|
|
{
|
|
len ++;
|
|
}
|
|
+
|
|
+ /* If we have reached the maximum, output the line */
|
|
+ if( len == max )
|
|
+ {
|
|
+ linebuf[len] = 0;
|
|
+ irc_reply( irc, 372, ":- %s", linebuf );
|
|
+ len = 0;
|
|
+ }
|
|
}
|
|
irc_reply( irc, 376, ":End of MOTD" );
|
|
close( fd );
|
|
@@ -1471,8 +1491,8 @@ int buddy_send_handler( irc_t *irc, user_t *u, char *m
|
|
u->sendbuf = g_renew ( char, u->sendbuf, u->sendbuf_len );
|
|
}
|
|
|
|
- strcat( u->sendbuf, msg );
|
|
- strcat( u->sendbuf, "\n" );
|
|
+ strlcat( u->sendbuf, msg, u->sendbuf_len );
|
|
+ strlcat( u->sendbuf, "\n", u->sendbuf_len );
|
|
|
|
delay = set_getint( irc, "buddy_sendbuffer_delay" );
|
|
if( delay <= 5 )
|