Ok, here you have it: Code for apx_setuid : #include <unistd.h>
long apx_setsid(void) { return setsid(); } Code for apx_setpgid : #include <unistd.h> int apx_setpgid(const long p, const long g) { return setpgid((pid_t)p, (pid_t)g); } Code for sux (main.c) : (the relevant part is option -s and function do_sid) #include <sys/types.h> #include <grp.h> #include <pwd.h> #include "abf.h" #include "amp.h" #include "apx.h" #include "msc.h" #include "rsc.h" #include "sdb.h" extern int r2e __P((int)); extern void wrn __P((int)), die __P((int)); static int do_env(const xlong f, const char *e) { struct amp a; xlong n, x; int r = 0; if (f) *apx_environ = NULL; if (e) { amp_opn(&a); r = env_h2b(&a, e, apx_strlen(e)); if (!r) for (e = a.b, n = a.s.x; n; e += x, n -= x) { if (!(x = chr(e, n, '+'))) break; if (r = apx_putenv(e + x)) break; } amp_cls(&a); } return r; } static int do_dir(const char * const d) { return d ? apx_chdir(d) : 0; } static long do_fork(const xlong f) { return f ? apx_fork() : 0l; } static int do_sid(const xlong f) { int r; if (r = 0, f & 1) if (f & 2) { if (apx_setsid() == -1) r = -1; } else r = apx_setpgid(0l, apx_getpid()); return r; } static int do_prio(const char * const s) { xlong x; int r; if (r = 0, s) { if (!scn_u(&x, s)) r = 5; if (!r) r = apx_setprio(prio_process, 0l, (int)x); } return r; } static int do_ioe(const char * const s) { xlong x; int r; if (r = 0, s) { if (!scn_x(&x, s)) r = 5; if (!r) r = apx_setioe((int)x, NULL, NULL); } return r; } static int do_rsc(const char * const s) { struct sdb sd; struct rsc rs; xlong i; int r; rsc_opn(&rs); sdb_opn(&sd); r = s ? getrsc(&rs, &sd, s) : 0; if (!r) for (i = 0; i < rs.sze.x; i++) (void)apx_setrlmt(rs.rds[i].idx, &rs.rds[i].val); sdb_cls(&sd); rsc_cls(&rs); return r; } static int do_crd(const char * const u, const char * const g, const char * const G) { struct passwd *pwd = NULL; struct group *grp = NULL; struct amp a; xlong v; xadk32_t s[ngroups_max]; int r = 0; char *p; if (u) if (!(pwd = getpwnam(u))) r = 4; if (!r) if (g) if (!(grp = getgrnam(g))) r = 4; if (!r) { v = grp ? grp->gr_gid : pwd ? pwd->pw_gid : -1ul; if (v + 1) r = apx_setgid(v); } if (!r) if (G) { amp_opn(&a); r = amp_mem(&a, G, apx_strlen(G)); if (!r) r = amp_chr(&a, '\0'); if (!r) { for (p = a.b; *p; p++) if (*p == ',') *p = '\0'; for (v = 0, p = a.b; p - a.b < a.s.x; v++, p++) { if (v == ngroups_max) break; if (!(grp = getgrnam(p))) break; s[v] = grp->gr_gid; while (*p) p++; } if (p - a.b < a.s.x) if (v < ngroups_max) r = 4; } amp_cls(&a); if (!r) if (!v) r = 5; if (!r) r = apx_setgrp(s, v); } if (!r) if (pwd) r = apx_setuid(0ul+pwd->pw_uid); return r; } static int do_exec(char **a) { (void)apx_execve(*a, a + 1, apx_environ); return 2; } static long __chk(char *s[8]) { xlong n; for (n = 8; n; n--) if (s[n - 1]) break; return n; } int main(int argc, char **argv) { xlong i, f; int r; char *s[8], o[] = "fspeu:g:G:d:n:E:x:r:"; apx_memset(s, 0, sizeof s); apx_opterr = 0; i = f = 0; while ((r = apx_getopt(argc, argv, o)) + 1) switch (r) { case 'f' : f |= 1; break; case 's' : f |= 2, f |= 4; break; case 'p' : f |= 2, f &= ~4; break; case 'e' : f |= 8; break; case 'u' : s[0] = apx_optarg; break; case 'g' : s[1] = apx_optarg; break; case 'G' : s[2] = apx_optarg; break; case 'd' : s[3] = apx_optarg; break; case 'n' : s[4] = apx_optarg; break; case 'E' : s[5] = apx_optarg; break; case 'x' : s[6] = apx_optarg; break; case 'r' : s[7] = apx_optarg; break; } argc -= apx_optind, argv += apx_optind; r = f || __chk(s) ? 0 : argc < 3 ? 1 : (s[0] = *argv++, argc--, 0); if (!r) r = do_env(f & 8, s[5]); if (!r) r = do_dir(s[3]); if (!r) if ((i = do_fork(f & 1)) == -1) r = -1; /* from now on, only in the child context if forked */ if (!i) { if (!r) r = do_sid(f & 6 >> 1); if (!r) r = do_prio(s[4]); if (!r) r = do_rsc(s[7]); if (!r) r = do_crd(s[0], s[1], s[2]); if (!r) r = do_ioe(s[6]); if (!r) r = do_exec(argv); } wrn(r); if (abf_cmt()) if (!r || r == 4) r = -1; return r2e(r); } On 7/16/06, Otto Moerbeek <[EMAIL PROTECTED]> wrote:
On Sun, 16 Jul 2006, Gustavo Rios wrote: > Hey folks, > > i am trying to set a process as the session leader of its own. I wrote > a simple program that handles that. It is working when i call it from > my shell command line: > > $ sux -s -e -E \ > PATH==/home/grios/.bin:/bin:/sbin:/usr/bin:/usr/sbin:/usr/X11R6/bin:/usr/local/bin:/usr/local/sbin:/usr/games:/asd/bin:/asd/sbin:/asd/thr=,ASDROOT==/asd= > /asd/sbin/algr algr argm ............ > > But when i write a simple shell script like in : > > #!/bin/sh > sux -s -e -E \ > PATH==/home/grios/.bin:/bin:/sbin:/usr/bin:/usr/sbin:/usr/X11R6/bin:/usr/local/bin:/usr/local/sbin:/usr/games:/asd/bin:/asd/sbin:/asd/thr=,ASDROOT==/asd= > /asd/sbin/algr algr argm ............ > > The process is not put on its own session as a leader the (setsid) > returns no errors. > > Does anybody have any ideia what the behavior problem i am not seeing ? Please show the code. How do you check if the program has become session leader? Any other process group/session stuff being done in your program? -Otto