| #include <unistd.h> |
| #include <stdlib.h> |
| #include <stdio.h> |
| #include <getopt.h> |
| #include <errno.h> |
| #include <string.h> |
| #include <selinux/selinux.h> |
| |
| static void usage(const char *progname) |
| { |
| fprintf(stderr, "usage: %s -a or %s boolean...\n", progname, progname); |
| exit(1); |
| } |
| |
| int getsebool_main(int argc, char **argv) |
| { |
| int i, get_all = 0, rc = 0, active, pending, len = 0, opt; |
| char **names; |
| |
| while ((opt = getopt(argc, argv, "a")) > 0) { |
| switch (opt) { |
| case 'a': |
| if (argc > 2) |
| usage(argv[0]); |
| if (is_selinux_enabled() <= 0) { |
| fprintf(stderr, "%s: SELinux is disabled\n", |
| argv[0]); |
| return 1; |
| } |
| errno = 0; |
| rc = security_get_boolean_names(&names, &len); |
| if (rc) { |
| fprintf(stderr, |
| "%s: Unable to get boolean names: %s\n", |
| argv[0], strerror(errno)); |
| return 1; |
| } |
| if (!len) { |
| printf("No booleans\n"); |
| return 0; |
| } |
| get_all = 1; |
| break; |
| default: |
| usage(argv[0]); |
| } |
| } |
| |
| if (is_selinux_enabled() <= 0) { |
| fprintf(stderr, "%s: SELinux is disabled\n", argv[0]); |
| return 1; |
| } |
| if (!len) { |
| if (argc < 2) |
| usage(argv[0]); |
| len = argc - 1; |
| names = malloc(sizeof(char *) * len); |
| if (!names) { |
| fprintf(stderr, "%s: out of memory\n", argv[0]); |
| return 2; |
| } |
| for (i = 0; i < len; i++) { |
| names[i] = strdup(argv[i + 1]); |
| if (!names[i]) { |
| fprintf(stderr, "%s: out of memory\n", |
| argv[0]); |
| return 2; |
| } |
| } |
| } |
| |
| for (i = 0; i < len; i++) { |
| active = security_get_boolean_active(names[i]); |
| if (active < 0) { |
| if (get_all && errno == EACCES) |
| continue; |
| fprintf(stderr, "Error getting active value for %s\n", |
| names[i]); |
| rc = -1; |
| goto out; |
| } |
| pending = security_get_boolean_pending(names[i]); |
| if (pending < 0) { |
| fprintf(stderr, "Error getting pending value for %s\n", |
| names[i]); |
| rc = -1; |
| goto out; |
| } |
| if (pending != active) { |
| printf("%s --> %s pending: %s\n", names[i], |
| (active ? "on" : "off"), |
| (pending ? "on" : "off")); |
| } else { |
| printf("%s --> %s\n", names[i], |
| (active ? "on" : "off")); |
| } |
| } |
| |
| out: |
| for (i = 0; i < len; i++) |
| free(names[i]); |
| free(names); |
| return rc; |
| } |