From: Martin Pool Date: Mon, 8 Apr 2002 03:10:01 +0000 (+0000) Subject: Document unsafe_symlink(). X-Git-Url: https://mattmccutchen.net/rsync/rsync.git/commitdiff_plain/036e70b0241a795e516e2b104f7bb982fe29fe9b Document unsafe_symlink(). --- diff --git a/util.c b/util.c index 940bf28a..db625876 100644 --- a/util.c +++ b/util.c @@ -985,6 +985,18 @@ void show_progress(OFF_T ofs, OFF_T size) /** * Determine if a symlink points outside the current directory tree. + * This is considered "unsafe" because e.g. when mirroring somebody + * else's machine it might allow them to establish a symlink to + * /etc/passwd, and then read it through a web server. + * + * @param dest Target of the symlink in question. + * + * @src src Top source directory currently applicable. Basically this + * is the first parameter to rsync in a simple invocation, but it's + * modified as topsrcname in slightly complex ways. + * + * @retval True if unsafe + * @retval False is unsafe **/ int unsafe_symlink(char *dest, char *src) {