xref: /aosp_15_r20/external/selinux/libsemanage/src/seusers_file.c (revision 2d543d20722ada2425b5bdab9d0d1d29470e7bba)
1*2d543d20SAndroid Build Coastguard Worker /* Copyright (C) 2005 Red Hat, Inc. */
2*2d543d20SAndroid Build Coastguard Worker 
3*2d543d20SAndroid Build Coastguard Worker struct semanage_seuser;
4*2d543d20SAndroid Build Coastguard Worker struct semanage_seuser_key;
5*2d543d20SAndroid Build Coastguard Worker typedef struct semanage_seuser record_t;
6*2d543d20SAndroid Build Coastguard Worker typedef struct semanage_seuser_key record_key_t;
7*2d543d20SAndroid Build Coastguard Worker #define DBASE_RECORD_DEFINED
8*2d543d20SAndroid Build Coastguard Worker 
9*2d543d20SAndroid Build Coastguard Worker struct dbase_file;
10*2d543d20SAndroid Build Coastguard Worker typedef struct dbase_file dbase_t;
11*2d543d20SAndroid Build Coastguard Worker #define DBASE_DEFINED
12*2d543d20SAndroid Build Coastguard Worker 
13*2d543d20SAndroid Build Coastguard Worker #include <stdlib.h>
14*2d543d20SAndroid Build Coastguard Worker #include <stdio.h>
15*2d543d20SAndroid Build Coastguard Worker 
16*2d543d20SAndroid Build Coastguard Worker #include "seuser_internal.h"
17*2d543d20SAndroid Build Coastguard Worker #include "database_file.h"
18*2d543d20SAndroid Build Coastguard Worker #include "parse_utils.h"
19*2d543d20SAndroid Build Coastguard Worker #include "debug.h"
20*2d543d20SAndroid Build Coastguard Worker #include "handle.h"
21*2d543d20SAndroid Build Coastguard Worker 
seuser_print(semanage_handle_t * handle,semanage_seuser_t * seuser,FILE * str)22*2d543d20SAndroid Build Coastguard Worker static int seuser_print(semanage_handle_t * handle,
23*2d543d20SAndroid Build Coastguard Worker 			semanage_seuser_t * seuser, FILE * str)
24*2d543d20SAndroid Build Coastguard Worker {
25*2d543d20SAndroid Build Coastguard Worker 
26*2d543d20SAndroid Build Coastguard Worker 	const char *name = semanage_seuser_get_name(seuser);
27*2d543d20SAndroid Build Coastguard Worker 	const char *sename = semanage_seuser_get_sename(seuser);
28*2d543d20SAndroid Build Coastguard Worker 	const char *mls = semanage_seuser_get_mlsrange(seuser);
29*2d543d20SAndroid Build Coastguard Worker 
30*2d543d20SAndroid Build Coastguard Worker 	if (fprintf(str, "%s:%s", name, sename) < 0)
31*2d543d20SAndroid Build Coastguard Worker 		goto err;
32*2d543d20SAndroid Build Coastguard Worker 
33*2d543d20SAndroid Build Coastguard Worker 	if (mls != NULL && fprintf(str, ":%s", mls) < 0)
34*2d543d20SAndroid Build Coastguard Worker 		goto err;
35*2d543d20SAndroid Build Coastguard Worker 
36*2d543d20SAndroid Build Coastguard Worker 	fprintf(str, "\n");
37*2d543d20SAndroid Build Coastguard Worker 	return STATUS_SUCCESS;
38*2d543d20SAndroid Build Coastguard Worker 
39*2d543d20SAndroid Build Coastguard Worker       err:
40*2d543d20SAndroid Build Coastguard Worker 	ERR(handle, "could not print seuser %s to stream", name);
41*2d543d20SAndroid Build Coastguard Worker 	return STATUS_ERR;
42*2d543d20SAndroid Build Coastguard Worker }
43*2d543d20SAndroid Build Coastguard Worker 
seuser_parse(semanage_handle_t * handle,parse_info_t * info,semanage_seuser_t * seuser)44*2d543d20SAndroid Build Coastguard Worker static int seuser_parse(semanage_handle_t * handle,
45*2d543d20SAndroid Build Coastguard Worker 			parse_info_t * info, semanage_seuser_t * seuser)
46*2d543d20SAndroid Build Coastguard Worker {
47*2d543d20SAndroid Build Coastguard Worker 
48*2d543d20SAndroid Build Coastguard Worker 	char *str = NULL;
49*2d543d20SAndroid Build Coastguard Worker 
50*2d543d20SAndroid Build Coastguard Worker 	if (parse_skip_space(handle, info) < 0)
51*2d543d20SAndroid Build Coastguard Worker 		goto err;
52*2d543d20SAndroid Build Coastguard Worker 	if (!info->ptr)
53*2d543d20SAndroid Build Coastguard Worker 		goto last;
54*2d543d20SAndroid Build Coastguard Worker 
55*2d543d20SAndroid Build Coastguard Worker 	/* Extract name */
56*2d543d20SAndroid Build Coastguard Worker 	if (parse_fetch_string(handle, info, &str, ':', 1) < 0)
57*2d543d20SAndroid Build Coastguard Worker 		goto err;
58*2d543d20SAndroid Build Coastguard Worker 	if (semanage_seuser_set_name(handle, seuser, str) < 0)
59*2d543d20SAndroid Build Coastguard Worker 		goto err;
60*2d543d20SAndroid Build Coastguard Worker 	free(str);
61*2d543d20SAndroid Build Coastguard Worker 	str = NULL;
62*2d543d20SAndroid Build Coastguard Worker 
63*2d543d20SAndroid Build Coastguard Worker 	if (parse_skip_space(handle, info) < 0)
64*2d543d20SAndroid Build Coastguard Worker 		goto err;
65*2d543d20SAndroid Build Coastguard Worker 	if (parse_assert_ch(handle, info, ':') < 0)
66*2d543d20SAndroid Build Coastguard Worker 		goto err;
67*2d543d20SAndroid Build Coastguard Worker 	if (parse_skip_space(handle, info) < 0)
68*2d543d20SAndroid Build Coastguard Worker 		goto err;
69*2d543d20SAndroid Build Coastguard Worker 
70*2d543d20SAndroid Build Coastguard Worker 	/* Extract sename */
71*2d543d20SAndroid Build Coastguard Worker 	if (parse_fetch_string(handle, info, &str, ':', 1) < 0)
72*2d543d20SAndroid Build Coastguard Worker 		goto err;
73*2d543d20SAndroid Build Coastguard Worker 	if (semanage_seuser_set_sename(handle, seuser, str) < 0)
74*2d543d20SAndroid Build Coastguard Worker 		goto err;
75*2d543d20SAndroid Build Coastguard Worker 	free(str);
76*2d543d20SAndroid Build Coastguard Worker 	str = NULL;
77*2d543d20SAndroid Build Coastguard Worker 
78*2d543d20SAndroid Build Coastguard Worker 	if (parse_skip_space(handle, info) < 0)
79*2d543d20SAndroid Build Coastguard Worker 		goto err;
80*2d543d20SAndroid Build Coastguard Worker 	if (parse_optional_ch(info, ':') == STATUS_NODATA)
81*2d543d20SAndroid Build Coastguard Worker 		goto out;
82*2d543d20SAndroid Build Coastguard Worker 	if (parse_skip_space(handle, info) < 0)
83*2d543d20SAndroid Build Coastguard Worker 		goto err;
84*2d543d20SAndroid Build Coastguard Worker 
85*2d543d20SAndroid Build Coastguard Worker 	/* NOTE: does not allow spaces/multiline */
86*2d543d20SAndroid Build Coastguard Worker 	if (parse_fetch_string(handle, info, &str, ' ', 0) < 0)
87*2d543d20SAndroid Build Coastguard Worker 		goto err;
88*2d543d20SAndroid Build Coastguard Worker 
89*2d543d20SAndroid Build Coastguard Worker 	if (semanage_seuser_set_mlsrange(handle, seuser, str) < 0)
90*2d543d20SAndroid Build Coastguard Worker 		goto err;
91*2d543d20SAndroid Build Coastguard Worker 	free(str);
92*2d543d20SAndroid Build Coastguard Worker 	str = NULL;
93*2d543d20SAndroid Build Coastguard Worker 
94*2d543d20SAndroid Build Coastguard Worker 	if (parse_assert_space(handle, info) < 0)
95*2d543d20SAndroid Build Coastguard Worker 		goto err;
96*2d543d20SAndroid Build Coastguard Worker 
97*2d543d20SAndroid Build Coastguard Worker       out:
98*2d543d20SAndroid Build Coastguard Worker 	return STATUS_SUCCESS;
99*2d543d20SAndroid Build Coastguard Worker 
100*2d543d20SAndroid Build Coastguard Worker       last:
101*2d543d20SAndroid Build Coastguard Worker 	parse_dispose_line(info);
102*2d543d20SAndroid Build Coastguard Worker 	return STATUS_NODATA;
103*2d543d20SAndroid Build Coastguard Worker 
104*2d543d20SAndroid Build Coastguard Worker       err:
105*2d543d20SAndroid Build Coastguard Worker 	ERR(handle, "could not parse seuser record");
106*2d543d20SAndroid Build Coastguard Worker 	free(str);
107*2d543d20SAndroid Build Coastguard Worker 	parse_dispose_line(info);
108*2d543d20SAndroid Build Coastguard Worker 	return STATUS_ERR;
109*2d543d20SAndroid Build Coastguard Worker }
110*2d543d20SAndroid Build Coastguard Worker 
111*2d543d20SAndroid Build Coastguard Worker /* SEUSER RECORD: FILE extension: method table */
112*2d543d20SAndroid Build Coastguard Worker record_file_table_t SEMANAGE_SEUSER_FILE_RTABLE = {
113*2d543d20SAndroid Build Coastguard Worker 	.parse = seuser_parse,
114*2d543d20SAndroid Build Coastguard Worker 	.print = seuser_print,
115*2d543d20SAndroid Build Coastguard Worker };
116*2d543d20SAndroid Build Coastguard Worker 
seuser_file_dbase_init(semanage_handle_t * handle,const char * path_ro,const char * path_rw,dbase_config_t * dconfig)117*2d543d20SAndroid Build Coastguard Worker int seuser_file_dbase_init(semanage_handle_t * handle,
118*2d543d20SAndroid Build Coastguard Worker 			   const char *path_ro,
119*2d543d20SAndroid Build Coastguard Worker 			   const char *path_rw,
120*2d543d20SAndroid Build Coastguard Worker 			   dbase_config_t * dconfig)
121*2d543d20SAndroid Build Coastguard Worker {
122*2d543d20SAndroid Build Coastguard Worker 
123*2d543d20SAndroid Build Coastguard Worker 	if (dbase_file_init(handle,
124*2d543d20SAndroid Build Coastguard Worker 			    path_ro,
125*2d543d20SAndroid Build Coastguard Worker 			    path_rw,
126*2d543d20SAndroid Build Coastguard Worker 			    &SEMANAGE_SEUSER_RTABLE,
127*2d543d20SAndroid Build Coastguard Worker 			    &SEMANAGE_SEUSER_FILE_RTABLE, &dconfig->dbase) < 0)
128*2d543d20SAndroid Build Coastguard Worker 		return STATUS_ERR;
129*2d543d20SAndroid Build Coastguard Worker 
130*2d543d20SAndroid Build Coastguard Worker 	dconfig->dtable = &SEMANAGE_FILE_DTABLE;
131*2d543d20SAndroid Build Coastguard Worker 	return STATUS_SUCCESS;
132*2d543d20SAndroid Build Coastguard Worker }
133*2d543d20SAndroid Build Coastguard Worker 
seuser_file_dbase_release(dbase_config_t * dconfig)134*2d543d20SAndroid Build Coastguard Worker void seuser_file_dbase_release(dbase_config_t * dconfig)
135*2d543d20SAndroid Build Coastguard Worker {
136*2d543d20SAndroid Build Coastguard Worker 
137*2d543d20SAndroid Build Coastguard Worker 	dbase_file_release(dconfig->dbase);
138*2d543d20SAndroid Build Coastguard Worker }
139