2
0
mirror of https://github.com/sudo-project/sudo.git synced 2025-08-23 10:27:45 +00:00
sudo/goodpath.c

86 lines
2.6 KiB
C
Raw Normal View History

1995-03-26 05:04:11 +00:00
/*
1999-07-22 12:49:28 +00:00
* Copyright (c) 1996, 1998, 1999 Todd C. Miller <Todd.Miller@courtesan.com>
* All rights reserved.
1995-03-26 05:04:11 +00:00
*
1999-07-22 12:49:28 +00:00
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions
* are met:
* 1. Redistributions of source code must retain the above copyright
* notice, this list of conditions and the following disclaimer.
* 2. Redistributions in binary form must reproduce the above copyright
* notice, this list of conditions and the following disclaimer in the
* documentation and/or other materials provided with the distribution.
* 3. The name of the author may not be used to endorse or promote products
* derived from this software without specific prior written permission.
1995-03-26 05:04:11 +00:00
*
1999-07-22 12:49:28 +00:00
* THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES,
* INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY
* AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL
* THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
* EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
* PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS;
* OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
* WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR
* OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF
* ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
1995-03-26 05:04:11 +00:00
*/
#include "config.h"
#include <stdio.h>
#ifdef HAVE_UNISTD_H
#include <unistd.h>
#endif /* HAVE_UNISTD_H */
#ifdef HAVE_STRING_H
#include <string.h>
#endif /* HAVE_STRING_H */
#ifdef HAVE_STRINGS_H
#include <strings.h>
#endif /* HAVE_STRINGS_H */
#include <errno.h>
#include <sys/types.h>
#include <sys/stat.h>
#include <sys/param.h>
#include "sudo.h"
#ifndef STDC_HEADERS
extern int stat __P((const char *, struct stat *));
#endif /* !STDC_HEADERS */
1998-11-18 04:16:13 +00:00
#ifndef lint
1999-01-17 23:16:20 +00:00
static const char rcsid[] = "$Sudo$";
1998-11-18 04:16:13 +00:00
#endif /* lint */
1995-03-26 05:04:11 +00:00
1999-07-22 12:49:28 +00:00
/*
* Verify that path is a normal file and executable by root.
1995-03-26 05:04:11 +00:00
*/
char *
sudo_goodpath(path)
1999-07-22 12:49:28 +00:00
const char *path;
1995-03-26 05:04:11 +00:00
{
1999-07-22 12:49:28 +00:00
struct stat sb;
int err;
1995-03-26 05:04:11 +00:00
1999-07-22 12:49:28 +00:00
/* Check for brain damage */
1995-03-26 05:04:11 +00:00
if (path == NULL || path[0] == '\0')
return(NULL);
1999-07-22 12:49:28 +00:00
/* Do the stat() as root. */
1996-10-07 05:05:33 +00:00
set_perms(PERM_ROOT, 0);
1999-07-22 12:49:28 +00:00
err = stat(path, &sb);
1996-10-07 05:05:33 +00:00
set_perms(PERM_USER, 0);
1995-03-26 05:04:11 +00:00
1999-07-22 12:49:28 +00:00
/* stat() failed */
1995-09-01 04:49:48 +00:00
if (err)
return(NULL);
1999-07-22 12:49:28 +00:00
/* Make sure path describes an executable regular file. */
if (!S_ISREG(sb.st_mode) || !(sb.st_mode & 0000111)) {
errno = EACCES;
1995-03-26 05:04:11 +00:00
return(NULL);
}
1999-07-22 12:49:28 +00:00
return((char *)path);
1995-03-26 05:04:11 +00:00
}