#include #include #include #include #include #include #include int main(int argc, char **argv) { struct av_decision avd; security_class_t tclass; int ret; if (argc != 4) { fprintf(stderr, "usage: %s scontext tcontext tclass\n", argv[0]); exit(1); } if (security_check_context(argv[1])) { fprintf(stderr, "%s: invalid source context '%s'\n", argv[0], argv[1]); exit(4); } if (security_check_context(argv[2])) { fprintf(stderr, "%s: invalid target context '%s'\n", argv[0], argv[2]); exit(5); } tclass = string_to_security_class(argv[3]); if (!tclass) { fprintf(stderr, "%s: invalid class '%s'\n", argv[0], argv[3]); exit(2); } ret = security_compute_av(argv[1], argv[2], tclass, 1, &avd); if (ret < 0) { fprintf(stderr, "%s: security_compute_av failed: %s\n", argv[0], strerror(errno)); exit(3); } printf("allowed="); print_access_vector(tclass, avd.allowed); printf("\n"); if (avd.decided != ~0U) { printf("decided="); print_access_vector(tclass, avd.decided); printf("\n"); } if (avd.auditallow) { printf("auditallow="); print_access_vector(tclass, avd.auditallow); printf("\n"); } if (avd.auditdeny != ~0U) { printf("auditdeny"); print_access_vector(tclass, avd.auditdeny); printf("\n"); } exit(EXIT_SUCCESS); }