2005-10-27 17:47:28 -04:00
|
|
|
$OpenBSD: patch-src_cfagent_c,v 1.5 2005/10/27 21:47:28 sturm Exp $
|
|
|
|
--- src/cfagent.c.orig Wed Sep 21 16:06:14 2005
|
|
|
|
+++ src/cfagent.c Fri Oct 21 16:35:54 2005
|
|
|
|
@@ -205,7 +205,7 @@ void Initialize(int argc,char *argv[])
|
2004-06-17 07:21:42 -04:00
|
|
|
unsigned char s[16];
|
|
|
|
char ebuff[CF_EXPANDSIZE];
|
|
|
|
|
|
|
|
-strcpy(VDOMAIN,CF_START_DOMAIN);
|
|
|
|
+(void)strlcpy(VDOMAIN,CF_START_DOMAIN,sizeof(VDOMAIN));
|
|
|
|
|
|
|
|
PreLockState();
|
2005-07-21 11:16:46 -04:00
|
|
|
|
2005-10-27 17:47:28 -04:00
|
|
|
@@ -218,7 +218,7 @@ VMAILSERVER[0] = '\0';
|
2004-06-17 07:21:42 -04:00
|
|
|
ALLCLASSBUFFER[0] = '\0';
|
|
|
|
VREPOSITORY = strdup("\0");
|
|
|
|
|
|
|
|
-strcpy(METHODNAME,"cf-nomethod");
|
|
|
|
+(void)strlcpy(METHODNAME,"cf-nomethod",sizeof(METHODNAME));
|
|
|
|
METHODREPLYTO[0] = '\0';
|
2004-08-08 10:02:11 -04:00
|
|
|
METHODFOR[0] = '\0';
|
2004-10-01 17:22:15 -04:00
|
|
|
|
2005-10-27 17:47:28 -04:00
|
|
|
@@ -226,8 +226,8 @@ METHODFOR[0] = '\0';
|
2004-06-17 07:21:42 -04:00
|
|
|
re_syntax_options |= RE_INTERVALS;
|
|
|
|
#endif
|
|
|
|
|
|
|
|
-strcpy(VINPUTFILE,"cfagent.conf");
|
|
|
|
-strcpy(VNFSTYPE,"nfs");
|
|
|
|
+(void)strlcpy(VINPUTFILE,"cfagent.conf",CF_BUFSIZE);
|
|
|
|
+(void)strlcpy(VNFSTYPE,"nfs",sizeof(VNFSTYPE));
|
|
|
|
|
|
|
|
IDClasses();
|
|
|
|
|
2005-10-27 17:47:28 -04:00
|
|
|
@@ -270,27 +270,28 @@ for (i = 1; i < argc; i++)
|
2005-07-21 11:16:46 -04:00
|
|
|
|
|
|
|
/* XXX Initialize workdir for non privileged users */
|
|
|
|
|
|
|
|
- strcpy(CFWORKDIR,WORKDIR);
|
|
|
|
+ (void)strlcpy(CFWORKDIR,WORKDIR,sizeof(CFWORKDIR));
|
|
|
|
|
|
|
|
if (getuid() > 0)
|
|
|
|
{
|
|
|
|
char *homedir;
|
|
|
|
if ((homedir = getenv("HOME")) != NULL)
|
|
|
|
{
|
|
|
|
- strcpy(CFWORKDIR,homedir);
|
|
|
|
- strcat(CFWORKDIR,"/.cfagent");
|
|
|
|
+ (void)strlcpy(CFWORKDIR,homedir,sizeof(CFWORKDIR));
|
|
|
|
+ (void)strlcat(CFWORKDIR,"/.cfagent",sizeof(CFWORKDIR));
|
|
|
|
}
|
|
|
|
}
|
2004-06-17 07:21:42 -04:00
|
|
|
|
2005-07-21 11:16:46 -04:00
|
|
|
- sprintf(ebuff,"%s/state/cf_procs",CFWORKDIR);
|
|
|
|
+ (void)snprintf(ebuff,sizeof(ebuff),"%s/state/cf_procs",CFWORKDIR);
|
2004-06-17 07:21:42 -04:00
|
|
|
|
|
|
|
if (stat(ebuff,&statbuf) == -1)
|
|
|
|
{
|
|
|
|
CreateEmptyFile(ebuff);
|
|
|
|
}
|
|
|
|
|
2005-07-21 11:16:46 -04:00
|
|
|
- strcpy(VLOGDIR,CFWORKDIR);
|
2004-06-17 07:21:42 -04:00
|
|
|
- strcpy(VLOCKDIR,VLOGDIR); /* Same since 2.0.a8 */
|
2005-07-21 11:16:46 -04:00
|
|
|
+ (void)strlcpy(VLOGDIR,CFWORKDIR,CF_BUFSIZE);
|
2004-06-17 07:21:42 -04:00
|
|
|
+ (void)strlcpy(VLOCKDIR,VLOGDIR,CF_BUFSIZE); /* Same since 2.0.a8 */
|
2005-07-21 11:16:46 -04:00
|
|
|
+
|
2004-06-17 07:21:42 -04:00
|
|
|
|
|
|
|
OpenSSL_add_all_algorithms();
|
|
|
|
ERR_load_crypto_strings();
|
2005-10-27 17:47:28 -04:00
|
|
|
@@ -323,8 +324,8 @@ if (NOPRECONFIG)
|
2004-06-17 07:21:42 -04:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
-strcpy(VPREFIX,"cfengine:");
|
|
|
|
-strcat(VPREFIX,VUQNAME);
|
|
|
|
+(void)strlcpy(VPREFIX,"cfengine:",40);
|
|
|
|
+(void)strlcat(VPREFIX,VUQNAME, 40);
|
|
|
|
|
|
|
|
if ((sp=getenv(CF_INPUTSVAR)) != NULL)
|
|
|
|
{
|
2005-10-27 17:47:28 -04:00
|
|
|
@@ -617,8 +618,8 @@ if (strlen(ebuff) != 0)
|
2004-06-17 07:21:42 -04:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
- strcpy(VPREFIX,"cfengine:");
|
|
|
|
- strcat(VPREFIX,VUQNAME);
|
|
|
|
+ (void)strlcpy(VPREFIX,"cfengine:",40);
|
|
|
|
+ (void)strlcat(VPREFIX,VUQNAME,40);
|
|
|
|
}
|
|
|
|
|
2004-08-08 10:02:11 -04:00
|
|
|
p2 = SortItemListNames(VHEAP);
|
2005-10-27 17:47:28 -04:00
|
|
|
@@ -765,7 +766,7 @@ if (VACTIONSEQ == NULL)
|
2004-06-17 07:21:42 -04:00
|
|
|
Warning("perhaps cfagent.conf/update.conf have not yet been set up?");
|
|
|
|
}
|
|
|
|
|
|
|
|
-sprintf(id,"%d",geteuid()); /* get effective user id */
|
|
|
|
+(void)snprintf(id,sizeof(id),"%d",geteuid()); /* get effective user id */
|
|
|
|
|
|
|
|
if (VACCESSLIST != NULL && !IsItemIn(VACCESSLIST,id))
|
|
|
|
{
|
2005-10-27 17:47:28 -04:00
|
|
|
@@ -920,7 +921,7 @@ if (OptionIs(CONTEXTID,"DryRun",true))
|
2004-06-17 07:21:42 -04:00
|
|
|
|
|
|
|
if (GetMacroValue(CONTEXTID,"BinaryPaddingChar"))
|
|
|
|
{
|
|
|
|
- strcpy(ebuff,GetMacroValue(CONTEXTID,"BinaryPaddingChar"));
|
|
|
|
+ (void)strlcpy(ebuff,GetMacroValue(CONTEXTID,"BinaryPaddingChar"),sizeof(ebuff));
|
|
|
|
|
|
|
|
if (ebuff[0] == '\\')
|
|
|
|
{
|
2005-10-27 17:47:28 -04:00
|
|
|
@@ -1520,7 +1521,7 @@ while (*sp != '\0')
|
2004-06-17 07:21:42 -04:00
|
|
|
{
|
|
|
|
VIFELAPSED = VDEFAULTIFELAPSED;
|
|
|
|
VEXPIREAFTER = VDEFAULTEXPIREAFTER;
|
|
|
|
- strcpy(actiontxt,cbuff);
|
|
|
|
+ (void)strlcpy(actiontxt,cbuff,sizeof(actiontxt));
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
else
|
2005-10-27 17:47:28 -04:00
|
|
|
@@ -1861,8 +1862,8 @@ for (ip = VHEAP; ip != NULL; ip=ip->next
|
2004-10-01 17:22:15 -04:00
|
|
|
else
|
2004-06-17 07:21:42 -04:00
|
|
|
{
|
|
|
|
size++; /* Allow for : separator */
|
2004-10-01 17:22:15 -04:00
|
|
|
- strcat(ALLCLASSBUFFER,ip->name);
|
|
|
|
- strcat(ALLCLASSBUFFER,":");
|
|
|
|
+ (void)strlcat(ALLCLASSBUFFER,ip->name,sizeof(ALLCLASSBUFFER));
|
|
|
|
+ (void)strlcat(ALLCLASSBUFFER,":",sizeof(ALLCLASSBUFFER));
|
2004-06-17 07:21:42 -04:00
|
|
|
}
|
2004-10-01 17:22:15 -04:00
|
|
|
|
|
|
|
fprintf(fp,"%s\n",ip->name);
|
2005-10-27 17:47:28 -04:00
|
|
|
@@ -1881,8 +1882,8 @@ for (ip = VHEAP; ip != NULL; ip=ip->next
|
2004-10-01 17:22:15 -04:00
|
|
|
else
|
|
|
|
{
|
2004-06-17 07:21:42 -04:00
|
|
|
size++; /* Allow for : separator */
|
2004-10-01 17:22:15 -04:00
|
|
|
- strcat(ALLCLASSBUFFER,ip->name);
|
|
|
|
- strcat(ALLCLASSBUFFER,":");
|
|
|
|
+ (void)strlcat(ALLCLASSBUFFER,ip->name,sizeof(ALLCLASSBUFFER));
|
|
|
|
+ (void)strlcat(ALLCLASSBUFFER,":",sizeof(ALLCLASSBUFFER));
|
2004-06-17 07:21:42 -04:00
|
|
|
}
|
|
|
|
|
2004-10-01 17:22:15 -04:00
|
|
|
fprintf(fp,"%s\n",ip->name);
|