[nginx] svn commit: r4494 - trunk/src/core
vbart at nginx.com
vbart at nginx.com
Mon Feb 27 16:46:57 UTC 2012
Author: vbart
Date: 2012-02-27 16:46:57 +0000 (Mon, 27 Feb 2012)
New Revision: 4494
Modified:
trunk/src/core/ngx_open_file_cache.c
trunk/src/core/ngx_open_file_cache.h
Log:
Disable symlinks: added the "from" parameter support to the open file cache.
Modified: trunk/src/core/ngx_open_file_cache.c
===================================================================
--- trunk/src/core/ngx_open_file_cache.c 2012-02-27 16:23:44 UTC (rev 4493)
+++ trunk/src/core/ngx_open_file_cache.c 2012-02-27 16:46:57 UTC (rev 4494)
@@ -229,6 +229,7 @@
&& now - file->created < of->valid
#if (NGX_HAVE_OPENAT)
&& of->disable_symlinks == file->disable_symlinks
+ && of->disable_symlinks_from == file->disable_symlinks_from
#endif
))
{
@@ -395,6 +396,7 @@
file->err = of->err;
#if (NGX_HAVE_OPENAT)
file->disable_symlinks = of->disable_symlinks;
+ file->disable_symlinks_from = of->disable_symlinks_from;
#endif
if (of->err == 0) {
@@ -583,7 +585,28 @@
at_name = *name;
- if (*p == '/') {
+ if (of->disable_symlinks_from) {
+
+ cp = p + of->disable_symlinks_from;
+
+ *cp = '\0';
+
+ at_fd = ngx_open_file(p, NGX_FILE_SEARCH|NGX_FILE_NONBLOCK,
+ NGX_FILE_OPEN, 0);
+
+ *cp = '/';
+
+ if (at_fd == NGX_INVALID_FILE) {
+ of->err = ngx_errno;
+ of->failed = ngx_open_file_n;
+ return NGX_INVALID_FILE;
+ }
+
+ at_name.len = of->disable_symlinks_from;
+ p = cp + 1;
+
+ } else if (*p == '/') {
+
at_fd = ngx_open_file("/",
NGX_FILE_SEARCH|NGX_FILE_NONBLOCK,
NGX_FILE_OPEN, 0);
Modified: trunk/src/core/ngx_open_file_cache.h
===================================================================
--- trunk/src/core/ngx_open_file_cache.h 2012-02-27 16:23:44 UTC (rev 4493)
+++ trunk/src/core/ngx_open_file_cache.h 2012-02-27 16:46:57 UTC (rev 4494)
@@ -33,6 +33,7 @@
ngx_uint_t min_uses;
#if (NGX_HAVE_OPENAT)
+ size_t disable_symlinks_from;
unsigned disable_symlinks:2;
#endif
@@ -69,6 +70,7 @@
uint32_t uses;
#if (NGX_HAVE_OPENAT)
+ size_t disable_symlinks_from;
unsigned disable_symlinks:2;
#endif
More information about the nginx-devel
mailing list