cp: fix -i for POSIX mode. Closes 9106

Signed-off-by: Denys Vlasenko <vda.linux@googlemail.com>
This commit is contained in:
Denys Vlasenko 2016-08-13 23:23:48 +02:00
parent 150dc7a2b4
commit 98c50f93fe

View File

@ -296,11 +296,16 @@ int FAST_FUNC copy_file(const char *source, const char *dest, int flags)
if (!S_ISREG(source_stat.st_mode)) if (!S_ISREG(source_stat.st_mode))
new_mode = 0666; new_mode = 0666;
// POSIX way is a security problem versus (sym)link attacks if (ENABLE_FEATURE_NON_POSIX_CP || (flags & FILEUTILS_INTERACTIVE)) {
if (!ENABLE_FEATURE_NON_POSIX_CP) { /*
dst_fd = open(dest, O_WRONLY|O_CREAT|O_TRUNC, new_mode); * O_CREAT|O_EXCL: require that file did not exist before creation
} else { /* safe way: */ */
dst_fd = open(dest, O_WRONLY|O_CREAT|O_EXCL, new_mode); dst_fd = open(dest, O_WRONLY|O_CREAT|O_EXCL, new_mode);
} else { /* POSIX, and not "cp -i" */
/*
* O_CREAT|O_TRUNC: create, or truncate (security problem versus (sym)link attacks)
*/
dst_fd = open(dest, O_WRONLY|O_CREAT|O_TRUNC, new_mode);
} }
if (dst_fd == -1) { if (dst_fd == -1) {
ovr = ask_and_unlink(dest, flags); ovr = ask_and_unlink(dest, flags);