diff options
-rw-r--r-- | src/c_bsdsetsid.h | 3 | ||||
-rw-r--r-- | src/c_fork.c | 78 |
2 files changed, 77 insertions, 4 deletions
diff --git a/src/c_bsdsetsid.h b/src/c_bsdsetsid.h index 59469f2..d7f7724 100644 --- a/src/c_bsdsetsid.h +++ b/src/c_bsdsetsid.h @@ -39,7 +39,7 @@ * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. * * bsdsetsid: src/c_bsdsetsid.h -Wed Nov 25 22:46:14 CET 2020 + * Fri Nov 27 01:48:28 CET 2020 * Joe * * This is the entrypoint of the program. @@ -48,6 +48,7 @@ Wed Nov 25 22:46:14 CET 2020 #define __C_BSDSETSID_H__ typedef char bool_t; +typedef void* ptr_t; enum bool_e { FALSE, diff --git a/src/c_fork.c b/src/c_fork.c index b74d8bc..ee754ba 100644 --- a/src/c_fork.c +++ b/src/c_fork.c @@ -39,7 +39,7 @@ * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. * * bsdsetsid: src/c_fork.c - * Thu Nov 26 23:40:15 CET 2020 + * Fri Nov 27 01:48:00 CET 2020 * Joe * * The program's main fork(2). @@ -51,6 +51,7 @@ #include <sys/resource.h> #include <errno.h> +#include <limits.h> #include <stdlib.h> #include <stdio.h> #include <string.h> @@ -59,6 +60,55 @@ #include "c_bsdsetsid.h" #include "c_fork.h" +static char +c_get_path +(const char arg[], + const char* envp[], + ptr_t path) +{ + char** env_path; + char tmp[PATH_MAX]; + char* tmptr; + ptr_t tok; + + if (strchr(arg, '/') != NULL) { + path = (ptr_t)arg; + return (0); + } + env_path = (char**)envp; + while (env_path != NULL && strncmp(*env_path, "PATH=", 5) != 0) { + env_path++; + } + if (env_path == NULL) { + path = NULL; + return (1); + } + strlcpy(tmp, *env_path, PATH_MAX); + tmptr = strchr(tmp, '='); + tmptr += 1; + if (*tmp == 0x00) { + path = NULL; + return (1); + } + tok = strtok(tmptr, ":"); + if (tok == NULL) { + path = NULL; + return (1); + } + while (tok != NULL) { + sprintf(path, "%s/%s", tok, arg); + if (access(path, F_OK) != -1) { + break; + } + tok = strtok(NULL, ":"); + } + if (tok == NULL) { + path = NULL; + return (2); + } + return (0); +} + static void c_fork_child (const char* argv[], @@ -66,6 +116,8 @@ c_fork_child bool_t wopt) { union ret_u u; + ptr_t path; + char mem[PATH_MAX]; u.pid = setsid(); if (u.pid == -1) { @@ -77,16 +129,36 @@ c_fork_child ); exit(EXIT_FAILURE); } + path = mem; + u.ret = c_get_path(argv[1 + wopt], envp, path); + if (u.ret == 1) { + dprintf( + STDERR_FILENO, + "%s: PATH not set\n", + C_PROGNAME + ); + exit(EXIT_FAILURE); + } + else if (u.ret == 2) { + dprintf( + STDERR_FILENO, + "%s: command not found: %s\n", + C_PROGNAME, + argv[1 + wopt] + ); + exit(EXIT_FAILURE); + } u.ret = execve( - argv[1 + wopt], + path, (char* const*)argv + (1 + wopt), (char* const*)envp ); if (u.ret == -1) { dprintf( STDERR_FILENO, - "%s: execve: %s\n", + "%s: execve: %s: %s\n", C_PROGNAME, + argv[1 + wopt], strerror(errno) ); exit(EXIT_FAILURE); |