aboutsummaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
authorJozanLeClerc <JozanLeClerc@noemail.net>2020-11-27 00:49:35 +0000
committerJozanLeClerc <JozanLeClerc@noemail.net>2020-11-27 00:49:35 +0000
commit8b5e87d39cbf588b6d6a6780a089ca29a4578e26 (patch)
tree7ae9da86ab59c084992ff246eb052c69b35c60d5 /src
parentIn progress (diff)
downloadbsdsetsid-8b5e87d39cbf588b6d6a6780a089ca29a4578e26.tar.gz
bsdsetsid-8b5e87d39cbf588b6d6a6780a089ca29a4578e26.tar.bz2
bsdsetsid-8b5e87d39cbf588b6d6a6780a089ca29a4578e26.tar.xz
bsdsetsid-8b5e87d39cbf588b6d6a6780a089ca29a4578e26.tar.zst
bsdsetsid-8b5e87d39cbf588b6d6a6780a089ca29a4578e26.zip
Seems relatively fine to me
FossilOrigin-Name: bc4d8bfab80c3cf24020f79419bf3afea7c03fd4
Diffstat (limited to 'src')
-rw-r--r--src/c_bsdsetsid.h3
-rw-r--r--src/c_fork.c78
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);