svnserve-sgid.c

来自「subversion-1.4.5.tar.gz 配置svn的源码」· C语言 代码 · 共 40 行

C
40
字号
/* * Wrapper to run the svnserve process setgid. * The idea is to avoid the problem that some interpreters like bash * invoked by svnserve in hook scripts will reset the effective gid to * the real gid, nuking the effect of an ordinary setgid svnserve binary. * Sadly, to set the real gid portably, you need to be root, if only * for a moment. * Also smashes the environment to something known, so that games * can't be played to try to break the security of the hook scripts, * by setting IFS, PATH, and similar means. *//* * Written by Perry Metzger, and placed into the public domain. */#include <stdio.h>#include <unistd.h>#define REAL_PATH "/usr/bin/svnserve.real"char *newenv[] = { "PATH=/bin:/usr/bin", "SHELL=/bin/sh", NULL };intmain(int argc, char **argv){	if (setgid(getegid()) == -1) {		perror("setgid(getegid())");		return 1;	}	if (seteuid(getuid()) == -1) {		perror("seteuid(getuid())");		return 1;	}	execve(REAL_PATH, argv, newenv);	perror("attempting to exec " REAL_PATH " failed");	return 1;}

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?