?? svnserve-sgid.c
字號:
/* * 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 + Shift + D
顯示快捷鍵
?
增大字號
Ctrl + =
減小字號
Ctrl + -