summaryrefslogtreecommitdiff
path: root/source3/utils/smbrun.c
diff options
context:
space:
mode:
authorAndrew Tridgell <tridge@samba.org>1999-12-13 13:27:58 +0000
committerAndrew Tridgell <tridge@samba.org>1999-12-13 13:27:58 +0000
commit3db52feb1f3b2c07ce0b06ad4a7099fa6efe3fc7 (patch)
tree866dd15416c3d8554bb207709f433a87ad0c012d /source3/utils/smbrun.c
parentf6276724bafdb6145c0c7b565172d80cb04516ea (diff)
downloadsamba-3db52feb1f3b2c07ce0b06ad4a7099fa6efe3fc7.tar.gz
samba-3db52feb1f3b2c07ce0b06ad4a7099fa6efe3fc7.tar.bz2
samba-3db52feb1f3b2c07ce0b06ad4a7099fa6efe3fc7.zip
first pass at updating head branch to be to be the same as the SAMBA_2_0 branch
(This used to be commit 453a822a76780063dff23526c35408866d0c0154)
Diffstat (limited to 'source3/utils/smbrun.c')
-rw-r--r--source3/utils/smbrun.c28
1 files changed, 5 insertions, 23 deletions
diff --git a/source3/utils/smbrun.c b/source3/utils/smbrun.c
index 2a94ac3235..b7c678411c 100644
--- a/source3/utils/smbrun.c
+++ b/source3/utils/smbrun.c
@@ -48,35 +48,17 @@ It takes 3 arguments as uid,gid,command and runs command after
becoming a non-root user */
int main(int argc,char *argv[])
{
- int uid,gid;
+ uid_t uid;
+ gid_t gid;
close_fds();
if (argc != 4) exit(2);
- uid = atoi(argv[1]);
- gid = atoi(argv[2]);
-
- /* first become root - we may need to do this in order to lose
- our privilages! */
-#ifdef HAVE_SETRESUID
- setresgid(0,0,0);
- setresuid(0,0,0);
-#else
- setuid(0);
- seteuid(0);
-#endif
-
-#ifdef HAVE_SETRESUID
- setresgid(gid,gid,gid);
- setresuid(uid,uid,uid);
-#else
- setgid(gid);
- setegid(gid);
- setuid(uid);
- seteuid(uid);
-#endif
+ uid = (uid_t)atoi(argv[1]);
+ gid = (gid_t)atoi(argv[2]);
+ become_user_permanently( uid, gid);
/* paranoia :-) */
if (getuid() != uid)