aboutsummaryrefslogtreecommitdiff
path: root/winsup/utils/setfacl.c
diff options
context:
space:
mode:
authorCorinna Vinschen <corinna@vinschen.de>2014-10-27 10:25:02 +0000
committerCorinna Vinschen <corinna@vinschen.de>2014-10-27 10:25:02 +0000
commitfc58f46dd6135992962a3f6120556f89b1f8b63f (patch)
treea687c0bbd94a5e5bea12b8ca6891ef0b9f89b362 /winsup/utils/setfacl.c
parentb701da7f14e266c6e6182540a104a5b95ee3938f (diff)
downloadnewlib-fc58f46dd6135992962a3f6120556f89b1f8b63f.zip
newlib-fc58f46dd6135992962a3f6120556f89b1f8b63f.tar.gz
newlib-fc58f46dd6135992962a3f6120556f89b1f8b63f.tar.bz2
* setfacl.c (action_t): Add DeleteAll value.
(delacl): New function to remove all ACL entries not representing POSIX permissions. (setfacl): Rearrange conditional expression into switch statement. Add DeleteAll case. (usage): Add and describe -b option. (longopts): Add --remove-all option. (opts): Add -b option. (main): Handle -b option.
Diffstat (limited to 'winsup/utils/setfacl.c')
-rw-r--r--winsup/utils/setfacl.c80
1 files changed, 67 insertions, 13 deletions
diff --git a/winsup/utils/setfacl.c b/winsup/utils/setfacl.c
index 16fa81a..43720ad 100644
--- a/winsup/utils/setfacl.c
+++ b/winsup/utils/setfacl.c
@@ -48,6 +48,7 @@ typedef enum {
Modify,
Delete,
ModNDel,
+ DeleteAll,
SetFromFile
} action_t;
@@ -331,27 +332,66 @@ addmissing (aclent_t *tgt, int tcnt)
}
int
-setfacl (action_t action, char *path, aclent_t *acls, int cnt)
+delacl (aclent_t *tgt, int tcnt)
+{
+ int t;
+
+ /* Remove all extended ACL entries. */
+ for (t = 0; t < tcnt; ++t)
+ if (tgt[t].a_type & (USER | GROUP | CLASS_OBJ))
+ {
+ --tcnt;
+ if (t < tcnt)
+ memmove (&tgt[t], &tgt[t + 1], (tcnt - t) * sizeof (aclent_t));
+ --t;
+ }
+ return tcnt;
+}
+
+int
+setfacl (action_t action, const char *path, aclent_t *acls, int cnt)
{
aclent_t lacl[MAX_ACL_ENTRIES];
int lcnt;
memset (lacl, 0, sizeof lacl);
- if (action == Set)
+ switch (action)
{
+ case Set:
if (acl (path, SETACL, cnt, acls))
{
perror (prog_name);
return 2;
}
- }
- else if ((lcnt = acl (path, GETACL, MAX_ACL_ENTRIES, lacl)) < 0
- || (lcnt = modacl (lacl, lcnt, acls, cnt)) < 0
- || (action != Delete && (lcnt = addmissing (lacl, lcnt)) < 0)
- || (lcnt = acl (path, SETACL, lcnt, lacl)) < 0)
- {
- perror (prog_name);
- return 2;
+ break;
+ case Delete:
+ if ((lcnt = acl (path, GETACL, MAX_ACL_ENTRIES, lacl)) < 0
+ || (lcnt = modacl (lacl, lcnt, acls, cnt)) < 0
+ || (lcnt = acl (path, SETACL, lcnt, lacl)) < 0)
+ {
+ perror (prog_name);
+ return 2;
+ }
+ break;
+ case DeleteAll:
+ if ((lcnt = acl (path, GETACL, MAX_ACL_ENTRIES, lacl)) < 0
+ || (lcnt = delacl (lacl, lcnt)) < 0
+ || (lcnt = acl (path, SETACL, lcnt, lacl)) < 0)
+ {
+ perror (prog_name);
+ return 2;
+ }
+ break;
+ default:
+ if ((lcnt = acl (path, GETACL, MAX_ACL_ENTRIES, lacl)) < 0
+ || (lcnt = modacl (lacl, lcnt, acls, cnt)) < 0
+ || (lcnt = addmissing (lacl, lcnt) < 0)
+ || (lcnt = acl (path, SETACL, lcnt, lacl)) < 0)
+ {
+ perror (prog_name);
+ return 2;
+ }
+ break;
}
return 0;
}
@@ -360,11 +400,12 @@ static void
usage (FILE * stream)
{
fprintf (stream, ""
- "Usage: %s [-r] (-f ACL_FILE | -s acl_entries) FILE...\n"
- " %s [-r] ([-d acl_entries] [-m acl_entries]) FILE...\n"
+ "Usage: %s [-r] {-f ACL_FILE | -s acl_entries} FILE...\n"
+ " %s [-r] {-b|[-d acl_entries] [-m acl_entries]} FILE...\n"
"\n"
"Modify file and directory access control lists (ACLs)\n"
"\n"
+ " -b, --remove-all remove all extended ACL entries\n"
" -d, --delete delete one or more specified ACL entries\n"
" -f, --file set ACL entries for FILE to ACL entries read\n"
" from a ACL_FILE\n"
@@ -410,6 +451,9 @@ usage (FILE * stream)
"\n"
"The following options are supported:\n"
"\n"
+ "-b Remove all extended ACL entries. The base ACL entries of the\n"
+ " owner, group and others are retained.\n"
+ "\n"
"-d Delete one or more specified entries from the file's ACL.\n"
" The owner, group and others entries must not be deleted.\n"
" Acl_entries to be deleted should be specified without\n"
@@ -465,6 +509,7 @@ usage (FILE * stream)
}
struct option longopts[] = {
+ {"remove-all", no_argument, NULL, 'b'},
{"delete", required_argument, NULL, 'd'},
{"file", required_argument, NULL, 'f'},
{"modify", required_argument, NULL, 'm'},
@@ -474,7 +519,7 @@ struct option longopts[] = {
{"version", no_argument, NULL, 'V'},
{0, no_argument, NULL, 0}
};
-const char *opts = "d:f:hm:rs:V";
+const char *opts = "bd:f:hm:rs:V";
static void
print_version ()
@@ -506,6 +551,15 @@ main (int argc, char **argv)
while ((c = getopt_long (argc, argv, opts, longopts, NULL)) != EOF)
switch (c)
{
+ case 'b':
+ if (action == NoAction)
+ action = DeleteAll;
+ else
+ {
+ usage (stderr);
+ return 1;
+ }
+ break;
case 'd':
if (action == NoAction)
action = Delete;