huangcm
2024-08-23 d76fb8c8c6d079a3cee81da7072347dcb8bbbc70
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
#include <unistd.h>
#include <sys/types.h>
#include <fcntl.h>
#include <stdio.h>
#include <stdlib.h>
#include <errno.h>
#include <string.h>
#include <ctype.h>
#include <selinux/selinux.h>
 
int main(int argc, char **argv)
{
   char **buf, **ptr;
   int ret;
 
   if (argc != 3) {
       fprintf(stderr, "usage:  %s context user\n", argv[0]);
       exit(1);
   }
 
   ret = security_compute_user(argv[1], argv[2], &buf);
   if (ret < 0) {
       fprintf(stderr, "%s:  security_compute_user(%s,%s) failed\n",
           argv[0], argv[1], argv[2]);
       exit(2);
   }
 
   if (!buf[0]) {
       printf("none\n");
       exit(0);
   }
 
   for (ptr = buf; *ptr; ptr++) {
       printf("%s\n", *ptr);
   }
   freeconary(buf);
   exit(0);
}