diff options
Diffstat (limited to 'libglusterfs')
| -rw-r--r-- | libglusterfs/src/glusterfs.h | 1 | ||||
| -rw-r--r-- | libglusterfs/src/graph.c | 23 | 
2 files changed, 24 insertions, 0 deletions
diff --git a/libglusterfs/src/glusterfs.h b/libglusterfs/src/glusterfs.h index ba5619d0f0a..78af68c0081 100644 --- a/libglusterfs/src/glusterfs.h +++ b/libglusterfs/src/glusterfs.h @@ -275,6 +275,7 @@ struct _cmd_args {  	char            *run_id;  	int              debug_mode;          int              read_only; +        int              acl;          int              mac_compat;  	struct list_head xlator_options;  /* list of xlator_option_t */ diff --git a/libglusterfs/src/graph.c b/libglusterfs/src/graph.c index 990e96e2fd8..2cfed066919 100644 --- a/libglusterfs/src/graph.c +++ b/libglusterfs/src/graph.c @@ -232,6 +232,23 @@ glusterfs_graph_readonly (glusterfs_graph_t *graph, glusterfs_ctx_t *ctx)  int +glusterfs_graph_acl (glusterfs_graph_t *graph, glusterfs_ctx_t *ctx) +{ +        int ret = 0; +        cmd_args_t      *cmd_args = NULL; + +        cmd_args = &ctx->cmd_args; + +        if (!cmd_args->acl) +                return 0; + +        ret = glusterfs_graph_insert (graph, ctx, "system/posix-acl", +                                      "posix-acl-autoload"); +        return ret; +} + + +int  glusterfs_graph_mac_compat (glusterfs_graph_t *graph, glusterfs_ctx_t *ctx)  {          int ret = 0; @@ -458,6 +475,12 @@ glusterfs_graph_prepare (glusterfs_graph_t *graph, glusterfs_ctx_t *ctx)                  return -1;          } +        ret = glusterfs_graph_acl (graph, ctx); +        if (ret) { +                gf_log ("graph", GF_LOG_ERROR, "glusterfs graph ACL failed"); +                return -1; +        } +          /* XXX: MAC COMPAT */          ret = glusterfs_graph_mac_compat (graph, ctx);          if (ret) {  | 
