From fcdf327c18b9faeea5409fde689158e47f92b186 Mon Sep 17 00:00:00 2001 From: kn Date: Thu, 9 Nov 2023 18:18:59 +0000 Subject: [PATCH] -C/resume without "proc exec" ftp(1) has "proc exec" to run sh(1) on interactive ! commands and filenames starting with "|"; this is orthogonal to continuing transfers using the existing file size as offsets. There seems to be no case where a) the argument is an URL, i.e. we pledge, and b) a shell is spawned somehow, so avoid these promises when resuming. bsd.port.mk(5) FETCH_CMD uses -C by default. OK millert --- usr.bin/ftp/main.c | 12 +++++++----- 1 file changed, 7 insertions(+), 5 deletions(-) diff --git a/usr.bin/ftp/main.c b/usr.bin/ftp/main.c index decebcb995c..2d6265bd128 100644 --- a/usr.bin/ftp/main.c +++ b/usr.bin/ftp/main.c @@ -1,4 +1,4 @@ -/* $OpenBSD: main.c,v 1.138 2021/07/14 13:33:57 kn Exp $ */ +/* $OpenBSD: main.c,v 1.139 2023/11/09 18:18:59 kn Exp $ */ /* $NetBSD: main.c,v 1.24 1997/08/18 10:20:26 lukem Exp $ */ /* @@ -617,24 +617,26 @@ main(volatile int argc, char *argv[]) if (isurl(argv[0])) { if (pipeout) { #ifndef SMALL + if (!resume) { if (pledge("stdio rpath dns tty inet proc exec fattr", NULL) == -1) err(1, "pledge"); -#else + } else +#endif /* !SMALL */ if (pledge("stdio rpath dns tty inet fattr", NULL) == -1) err(1, "pledge"); -#endif } else { #ifndef SMALL + if (!resume) { if (pledge("stdio rpath wpath cpath dns tty inet proc exec fattr", NULL) == -1) err(1, "pledge"); -#else + } else +#endif /* !SMALL */ if (pledge("stdio rpath wpath cpath dns tty inet fattr", NULL) == -1) err(1, "pledge"); -#endif } rval = auto_fetch(argc, argv, outfile); -- 2.20.1