xref: /aosp_15_r20/external/selinux/libselinux/src/lsetfilecon.c (revision 2d543d20722ada2425b5bdab9d0d1d29470e7bba)
1*2d543d20SAndroid Build Coastguard Worker #include <unistd.h>
2*2d543d20SAndroid Build Coastguard Worker #include <fcntl.h>
3*2d543d20SAndroid Build Coastguard Worker #include <string.h>
4*2d543d20SAndroid Build Coastguard Worker #include <stdlib.h>
5*2d543d20SAndroid Build Coastguard Worker #include <errno.h>
6*2d543d20SAndroid Build Coastguard Worker #include <sys/xattr.h>
7*2d543d20SAndroid Build Coastguard Worker #include "selinux_internal.h"
8*2d543d20SAndroid Build Coastguard Worker #include "policy.h"
9*2d543d20SAndroid Build Coastguard Worker 
lsetfilecon_raw(const char * path,const char * context)10*2d543d20SAndroid Build Coastguard Worker int lsetfilecon_raw(const char *path, const char * context)
11*2d543d20SAndroid Build Coastguard Worker {
12*2d543d20SAndroid Build Coastguard Worker 	int rc = lsetxattr(path, XATTR_NAME_SELINUX, context, strlen(context) + 1,
13*2d543d20SAndroid Build Coastguard Worker 			 0);
14*2d543d20SAndroid Build Coastguard Worker 	if (rc < 0 && errno == ENOTSUP) {
15*2d543d20SAndroid Build Coastguard Worker 		char * ccontext = NULL;
16*2d543d20SAndroid Build Coastguard Worker 		int err = errno;
17*2d543d20SAndroid Build Coastguard Worker 		if ((lgetfilecon_raw(path, &ccontext) >= 0) &&
18*2d543d20SAndroid Build Coastguard Worker 		    (strcmp(context,ccontext) == 0)) {
19*2d543d20SAndroid Build Coastguard Worker 			rc = 0;
20*2d543d20SAndroid Build Coastguard Worker 		} else {
21*2d543d20SAndroid Build Coastguard Worker 			errno = err;
22*2d543d20SAndroid Build Coastguard Worker 		}
23*2d543d20SAndroid Build Coastguard Worker 		freecon(ccontext);
24*2d543d20SAndroid Build Coastguard Worker 	}
25*2d543d20SAndroid Build Coastguard Worker 	return rc;
26*2d543d20SAndroid Build Coastguard Worker }
27*2d543d20SAndroid Build Coastguard Worker 
28*2d543d20SAndroid Build Coastguard Worker 
lsetfilecon(const char * path,const char * context)29*2d543d20SAndroid Build Coastguard Worker int lsetfilecon(const char *path, const char *context)
30*2d543d20SAndroid Build Coastguard Worker {
31*2d543d20SAndroid Build Coastguard Worker 	int ret;
32*2d543d20SAndroid Build Coastguard Worker 	char * rcontext;
33*2d543d20SAndroid Build Coastguard Worker 
34*2d543d20SAndroid Build Coastguard Worker 	if (selinux_trans_to_raw_context(context, &rcontext))
35*2d543d20SAndroid Build Coastguard Worker 		return -1;
36*2d543d20SAndroid Build Coastguard Worker 
37*2d543d20SAndroid Build Coastguard Worker 	ret = lsetfilecon_raw(path, rcontext);
38*2d543d20SAndroid Build Coastguard Worker 
39*2d543d20SAndroid Build Coastguard Worker 	freecon(rcontext);
40*2d543d20SAndroid Build Coastguard Worker 
41*2d543d20SAndroid Build Coastguard Worker 	return ret;
42*2d543d20SAndroid Build Coastguard Worker }
43