[nginx] Core: ngx_conf_set_access_slot() user access (ticket #1096).
Maxim Dounin
mdounin at mdounin.ru
Fri Oct 7 16:19:05 UTC 2016
details: http://hg.nginx.org/nginx/rev/1606a817c1d4
branches:
changeset: 6730:1606a817c1d4
user: Maxim Dounin <mdounin at mdounin.ru>
date: Fri Oct 07 16:59:14 2016 +0300
description:
Core: ngx_conf_set_access_slot() user access (ticket #1096).
Previously, user access bits were always set to "rw" unconditionally,
even with "user:r" explicitly specified. With this change we only add
default user access bits (0600) if they weren't set explicitly.
diffstat:
src/core/ngx_file.c | 8 ++++++--
1 files changed, 6 insertions(+), 2 deletions(-)
diffs (39 lines):
diff --git a/src/core/ngx_file.c b/src/core/ngx_file.c
--- a/src/core/ngx_file.c
+++ b/src/core/ngx_file.c
@@ -441,7 +441,7 @@ ngx_conf_set_access_slot(ngx_conf_t *cf,
u_char *p;
ngx_str_t *value;
- ngx_uint_t i, right, shift, *access;
+ ngx_uint_t i, right, shift, *access, user;
access = (ngx_uint_t *) (confp + cmd->offset);
@@ -451,7 +451,8 @@ ngx_conf_set_access_slot(ngx_conf_t *cf,
value = cf->args->elts;
- *access = 0600;
+ *access = 0;
+ user = 0600;
for (i = 1; i < cf->args->nelts; i++) {
@@ -460,6 +461,7 @@ ngx_conf_set_access_slot(ngx_conf_t *cf,
if (ngx_strncmp(p, "user:", sizeof("user:") - 1) == 0) {
shift = 6;
p += sizeof("user:") - 1;
+ user = 0;
} else if (ngx_strncmp(p, "group:", sizeof("group:") - 1) == 0) {
shift = 3;
@@ -486,6 +488,8 @@ ngx_conf_set_access_slot(ngx_conf_t *cf,
*access |= right << shift;
}
+ *access |= user;
+
return NGX_CONF_OK;
invalid:
More information about the nginx-devel
mailing list