summaryrefslogtreecommitdiffstats
path: root/txr.c
diff options
context:
space:
mode:
authorKaz Kylheku <kaz@kylheku.com>2016-01-23 10:06:53 -0800
committerKaz Kylheku <kaz@kylheku.com>2016-01-23 10:06:53 -0800
commite080b5acbbe235d3ac32ccaf19826a8fd67e2eaf (patch)
treeb6abd783f6a63dabefc4f6c4174b0c10089c05df /txr.c
parent7d250092d842e502bf5a571cefad999838997313 (diff)
downloadtxr-e080b5acbbe235d3ac32ccaf19826a8fd67e2eaf.tar.gz
txr-e080b5acbbe235d3ac32ccaf19826a8fd67e2eaf.tar.bz2
txr-e080b5acbbe235d3ac32ccaf19826a8fd67e2eaf.zip
Support setuid operation.
* sysif.c (orig_euid, real_uid, repress_called, is_setuid): New static variables. (repress_privilege, drop_privilage, simulate_setuid): New functions. (RC_MAGIC): New preprocessor symbol. * sysif.c (repress_privilege, drop_privilage, simulate_setuid): Declared. * txr.c (txr_main): Call repress_privilege to check and remember whether we are in setuid mode, and temporarily drop the effective uid to the real one. (txr_main): Permanently drop privileges in all cases except script execution. In script execution cases, go through simulate_setuid to either set or preserve the effective user ID, or else drop privs. * txr.1: Documented setuid operation in new section.
Diffstat (limited to 'txr.c')
-rw-r--r--txr.c29
1 files changed, 28 insertions, 1 deletions
diff --git a/txr.c b/txr.c
index 36703b2f..476362ae 100644
--- a/txr.c
+++ b/txr.c
@@ -327,6 +327,7 @@ int txr_main(int argc, char **argv);
int main(int argc, char **argv)
{
val stack_bottom = nil;
+ repress_privilege();
progname = argv[0] ? utf8_dup_from(argv[0]) : progname;
progname_u8 = argv[0];
init(progname, oom_realloc_handler, &stack_bottom);
@@ -436,6 +437,7 @@ int txr_main(int argc, char **argv)
}
if (argc <= 1) {
+ drop_privilege();
#if HAVE_TERMIOS
banner();
goto repl;
@@ -510,6 +512,7 @@ int txr_main(int argc, char **argv)
/* Long opts with no arguments */
if (org) {
+ drop_privilege();
format(std_error,
lit("~a: option --~a takes no argument, ~a given\n"),
prog_string, opt, org, nao);
@@ -517,23 +520,29 @@ int txr_main(int argc, char **argv)
}
if (equal(opt, lit("version"))) {
+ drop_privilege();
format(std_output, lit("~a: version ~a\n"),
prog_string, static_str(version), nao);
return 0;
}
if (equal(opt, lit("help"))) {
+ drop_privilege();
help();
return 0;
}
- if (equal(opt, lit("license")))
+ if (equal(opt, lit("license"))) {
+ drop_privilege();
return license();
+ }
if (equal(opt, lit("gc-debug"))) {
+ drop_privilege();
opt_gc_debug = 1;
continue;
} else if (equal(opt, lit("vg-debug"))) {
+ drop_privilege();
#if HAVE_VALGRIND
opt_vg_debug = 1;
continue;
@@ -554,6 +563,7 @@ int txr_main(int argc, char **argv)
txr_lisp_p = t;
continue;
} else if (equal(opt, lit("debugger"))) {
+ drop_privilege();
#if CONFIG_DEBUG_SUPPORT
opt_debugger = 1;
continue;
@@ -562,6 +572,7 @@ int txr_main(int argc, char **argv)
return EXIT_FAILURE;
#endif
} else if (equal(opt, lit("debug-autoload"))) {
+ drop_privilege();
#if CONFIG_DEBUG_SUPPORT
opt_debugger = 1;
opt_dbg_autoload = 1;
@@ -571,6 +582,7 @@ int txr_main(int argc, char **argv)
return EXIT_FAILURE;
#endif
} else if (equal(opt, lit("debug-expansion"))) {
+ drop_privilege();
#if CONFIG_DEBUG_SUPPORT
opt_debugger = 1;
opt_dbg_expansion = 1;
@@ -580,6 +592,7 @@ int txr_main(int argc, char **argv)
return EXIT_FAILURE;
#endif
} else if (equal(opt, lit("yydebug"))) {
+ drop_privilege();
if (have_yydebug) {
yydebug_onoff(1);
format(std_error,
@@ -627,6 +640,7 @@ int txr_main(int argc, char **argv)
spec_file = arg;
break;
case 'e':
+ drop_privilege();
reg_varl(self_path_s, lit("cmdline-expr"));
reg_var(args_s, arg_list);
@@ -645,6 +659,7 @@ int txr_main(int argc, char **argv)
if3(c_chr(opt) == 'P',
pprinl,
tprint));
+ drop_privilege();
reg_varl(self_path_s, lit("cmdline-expr"));
reg_var(args_s, arg_list);
pf(eval_intrinsic(lisp_parse(arg, std_error, colon_k,
@@ -683,6 +698,7 @@ int txr_main(int argc, char **argv)
opt_print_bindings = 1;
break;
case 'i':
+ drop_privilege();
#if HAVE_TERMIOS
enter_repl = t;
break;
@@ -693,6 +709,7 @@ int txr_main(int argc, char **argv)
return EXIT_FAILURE;
#endif
case 'd':
+ drop_privilege();
#if CONFIG_DEBUG_SUPPORT
opt_debugger = 1;
#else
@@ -713,14 +730,17 @@ int txr_main(int argc, char **argv)
case 'C':
case 't':
case 'D':
+ drop_privilege();
format(std_error, lit("~a: option -~a does not clump\n"),
prog_string, opch, nao);
return EXIT_FAILURE;
case '-':
+ drop_privilege();
format(std_error, lit("~a: unrecognized long option: --~a\n"),
prog_string, cdr(optchars), nao);
return EXIT_FAILURE;
default:
+ drop_privilege();
format(std_error, lit("~a: unrecognized option: -~a\n"),
prog_string, opch, nao);
return EXIT_FAILURE;
@@ -730,12 +750,14 @@ int txr_main(int argc, char **argv)
}
if (specstring && spec_file) {
+ drop_privilege();
format(std_error, lit("~a: cannot specify both -f and -c\n"),
prog_string, nao);
return EXIT_FAILURE;
}
if (specstring) {
+ drop_privilege();
spec_file_str = lit("cmdline");
if (gt(length_str(specstring), zero) &&
chr_str(specstring, minus(length_str(specstring), one)) != chr('\n'))
@@ -746,13 +768,16 @@ int txr_main(int argc, char **argv)
} else if (spec_file) {
if (wcscmp(c_str(spec_file), L"-") != 0) {
open_txr_file(spec_file, &txr_lisp_p, &spec_file_str, &parse_stream);
+ simulate_setuid(parse_stream);
} else {
+ drop_privilege();
spec_file_str = lit("stdin");
}
if (arg)
arg_list = arg_undo;
} else {
if (!arg) {
+ drop_privilege();
if (enter_repl)
goto repl;
if (evaled)
@@ -768,7 +793,9 @@ int txr_main(int argc, char **argv)
if (!equal(arg, lit("-"))) {
open_txr_file(arg, &txr_lisp_p, &spec_file_str, &parse_stream);
+ simulate_setuid(parse_stream);
} else {
+ drop_privilege();
spec_file_str = lit("stdin");
}
}