Rev 7676 | Rev 11133 | Go to most recent revision | Show entire file | Ignore whitespace | Details | Blame | Last modification | View Log | RSS feed
Rev 7676 | Rev 11128 | ||
---|---|---|---|
Line 17... | Line 17... | ||
17 | 17 | ||
18 | /* Wrap uid and exec */ |
18 | /* Wrap uid and exec */ |
19 | 19 | ||
20 | #include <unistd.h> |
20 | #include <unistd.h> |
21 | #include <string.h> |
21 | #include <string.h> |
- | 22 | #include <assert.h> |
|
22 | 23 | ||
23 | int main(int argc,char *argv[]) |
24 | int main(int argc,char *argv[]) |
24 | { |
25 | { |
25 | char *args[1024]; |
26 | char *args[1024]; |
26 | int i, uid1, uid2, gid1, gid2; |
27 | int i, uid1, uid2, gid1, gid2; |
Line 28... | Line 29... | ||
28 | if(argc<2) return 0; |
29 | if(argc<2) return 0; |
29 | for(i=0;i<1000 && i<argc; i++) args[i]=argv[i+1]; |
30 | for(i=0;i<1000 && i<argc; i++) args[i]=argv[i+1]; |
30 | args[i]=NULL; |
31 | args[i]=NULL; |
31 | uid1=geteuid(); uid2=getuid(); gid1=getegid(); gid2=getgid(); |
32 | uid1=geteuid(); uid2=getuid(); gid1=getegid(); gid2=getgid(); |
32 | if(strchr(args[0],'/')) { |
33 | if(strchr(args[0],'/')) { |
- | 34 | assert(setreuid(uid1,uid2)==0); |
|
33 |
|
35 | assert(setregid(gid1,gid2)==0); |
34 | execv(args[0],args); |
36 | execv(args[0],args); |
35 | } |
37 | } |
36 | else { |
38 | else { |
- | 39 | assert(setreuid(uid1,uid1)==0); |
|
37 |
|
40 | assert(setregid(gid1,gid1)==0); |
38 | execvp(args[0],args); |
41 | execvp(args[0],args); |
39 | } |
42 | } |
40 | return 127; |
43 | return 127; |
41 | } |
44 | } |
42 | 45 |