1*2d543d20SAndroid Build Coastguard Worker /* Copyright (C) 2005 Red Hat, Inc. */
2*2d543d20SAndroid Build Coastguard Worker
3*2d543d20SAndroid Build Coastguard Worker struct semanage_user_extra;
4*2d543d20SAndroid Build Coastguard Worker struct semanage_user_key;
5*2d543d20SAndroid Build Coastguard Worker typedef struct semanage_user_extra record_t;
6*2d543d20SAndroid Build Coastguard Worker typedef struct semanage_user_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 #include <strings.h>
16*2d543d20SAndroid Build Coastguard Worker
17*2d543d20SAndroid Build Coastguard Worker #include "user_internal.h"
18*2d543d20SAndroid Build Coastguard Worker #include "database_file.h"
19*2d543d20SAndroid Build Coastguard Worker #include "parse_utils.h"
20*2d543d20SAndroid Build Coastguard Worker #include "debug.h"
21*2d543d20SAndroid Build Coastguard Worker #include "handle.h"
22*2d543d20SAndroid Build Coastguard Worker
user_extra_print(semanage_handle_t * handle,semanage_user_extra_t * user_extra,FILE * str)23*2d543d20SAndroid Build Coastguard Worker static int user_extra_print(semanage_handle_t * handle,
24*2d543d20SAndroid Build Coastguard Worker semanage_user_extra_t * user_extra, FILE * str)
25*2d543d20SAndroid Build Coastguard Worker {
26*2d543d20SAndroid Build Coastguard Worker
27*2d543d20SAndroid Build Coastguard Worker const char *name = semanage_user_extra_get_name(user_extra);
28*2d543d20SAndroid Build Coastguard Worker const char *prefix = semanage_user_extra_get_prefix(user_extra);
29*2d543d20SAndroid Build Coastguard Worker
30*2d543d20SAndroid Build Coastguard Worker if (fprintf(str, "user %s prefix %s;\n", name, prefix) < 0)
31*2d543d20SAndroid Build Coastguard Worker goto err;
32*2d543d20SAndroid Build Coastguard Worker
33*2d543d20SAndroid Build Coastguard Worker return STATUS_SUCCESS;
34*2d543d20SAndroid Build Coastguard Worker
35*2d543d20SAndroid Build Coastguard Worker err:
36*2d543d20SAndroid Build Coastguard Worker ERR(handle, "could not print user extra data "
37*2d543d20SAndroid Build Coastguard Worker "for %s to stream", name);
38*2d543d20SAndroid Build Coastguard Worker return STATUS_ERR;
39*2d543d20SAndroid Build Coastguard Worker }
40*2d543d20SAndroid Build Coastguard Worker
user_extra_parse(semanage_handle_t * handle,parse_info_t * info,semanage_user_extra_t * user_extra)41*2d543d20SAndroid Build Coastguard Worker static int user_extra_parse(semanage_handle_t * handle,
42*2d543d20SAndroid Build Coastguard Worker parse_info_t * info,
43*2d543d20SAndroid Build Coastguard Worker semanage_user_extra_t * user_extra)
44*2d543d20SAndroid Build Coastguard Worker {
45*2d543d20SAndroid Build Coastguard Worker
46*2d543d20SAndroid Build Coastguard Worker char *str = NULL;
47*2d543d20SAndroid Build Coastguard Worker
48*2d543d20SAndroid Build Coastguard Worker if (parse_skip_space(handle, info) < 0)
49*2d543d20SAndroid Build Coastguard Worker goto err;
50*2d543d20SAndroid Build Coastguard Worker if (!info->ptr)
51*2d543d20SAndroid Build Coastguard Worker goto last;
52*2d543d20SAndroid Build Coastguard Worker
53*2d543d20SAndroid Build Coastguard Worker /* User string */
54*2d543d20SAndroid Build Coastguard Worker if (parse_assert_str(handle, info, "user") < 0)
55*2d543d20SAndroid Build Coastguard Worker goto err;
56*2d543d20SAndroid Build Coastguard Worker if (parse_assert_space(handle, info) < 0)
57*2d543d20SAndroid Build Coastguard Worker goto err;
58*2d543d20SAndroid Build Coastguard Worker
59*2d543d20SAndroid Build Coastguard Worker /* Extract name */
60*2d543d20SAndroid Build Coastguard Worker if (parse_fetch_string(handle, info, &str, ' ', 0) < 0)
61*2d543d20SAndroid Build Coastguard Worker goto err;
62*2d543d20SAndroid Build Coastguard Worker if (semanage_user_extra_set_name(handle, user_extra, str) < 0)
63*2d543d20SAndroid Build Coastguard Worker goto err;
64*2d543d20SAndroid Build Coastguard Worker free(str);
65*2d543d20SAndroid Build Coastguard Worker str = NULL;
66*2d543d20SAndroid Build Coastguard Worker
67*2d543d20SAndroid Build Coastguard Worker /* Prefix string */
68*2d543d20SAndroid Build Coastguard Worker if (parse_assert_space(handle, info) < 0)
69*2d543d20SAndroid Build Coastguard Worker goto err;
70*2d543d20SAndroid Build Coastguard Worker if (parse_assert_str(handle, info, "prefix") < 0)
71*2d543d20SAndroid Build Coastguard Worker goto err;
72*2d543d20SAndroid Build Coastguard Worker if (parse_assert_space(handle, info) < 0)
73*2d543d20SAndroid Build Coastguard Worker goto err;
74*2d543d20SAndroid Build Coastguard Worker
75*2d543d20SAndroid Build Coastguard Worker /* Extract prefix */
76*2d543d20SAndroid Build Coastguard Worker if (parse_fetch_string(handle, info, &str, ';', 1) < 0)
77*2d543d20SAndroid Build Coastguard Worker goto err;
78*2d543d20SAndroid Build Coastguard Worker if (semanage_user_extra_set_prefix(handle, user_extra, str) < 0)
79*2d543d20SAndroid Build Coastguard Worker goto err;
80*2d543d20SAndroid Build Coastguard Worker free(str);
81*2d543d20SAndroid Build Coastguard Worker str = NULL;
82*2d543d20SAndroid Build Coastguard Worker
83*2d543d20SAndroid Build Coastguard Worker /* Semicolon */
84*2d543d20SAndroid Build Coastguard Worker if (parse_skip_space(handle, info) < 0)
85*2d543d20SAndroid Build Coastguard Worker goto err;
86*2d543d20SAndroid Build Coastguard Worker if (parse_assert_ch(handle, info, ';') < 0)
87*2d543d20SAndroid Build Coastguard Worker goto err;
88*2d543d20SAndroid Build Coastguard Worker
89*2d543d20SAndroid Build Coastguard Worker return STATUS_SUCCESS;
90*2d543d20SAndroid Build Coastguard Worker
91*2d543d20SAndroid Build Coastguard Worker last:
92*2d543d20SAndroid Build Coastguard Worker parse_dispose_line(info);
93*2d543d20SAndroid Build Coastguard Worker return STATUS_NODATA;
94*2d543d20SAndroid Build Coastguard Worker
95*2d543d20SAndroid Build Coastguard Worker err:
96*2d543d20SAndroid Build Coastguard Worker ERR(handle, "could not parse user extra data");
97*2d543d20SAndroid Build Coastguard Worker free(str);
98*2d543d20SAndroid Build Coastguard Worker parse_dispose_line(info);
99*2d543d20SAndroid Build Coastguard Worker return STATUS_ERR;
100*2d543d20SAndroid Build Coastguard Worker }
101*2d543d20SAndroid Build Coastguard Worker
102*2d543d20SAndroid Build Coastguard Worker /* USER EXTRA RECORD: FILE extension: method table */
103*2d543d20SAndroid Build Coastguard Worker record_file_table_t SEMANAGE_USER_EXTRA_FILE_RTABLE = {
104*2d543d20SAndroid Build Coastguard Worker .parse = user_extra_parse,
105*2d543d20SAndroid Build Coastguard Worker .print = user_extra_print,
106*2d543d20SAndroid Build Coastguard Worker };
107*2d543d20SAndroid Build Coastguard Worker
user_extra_file_dbase_init(semanage_handle_t * handle,const char * path_ro,const char * path_rw,dbase_config_t * dconfig)108*2d543d20SAndroid Build Coastguard Worker int user_extra_file_dbase_init(semanage_handle_t * handle,
109*2d543d20SAndroid Build Coastguard Worker const char *path_ro,
110*2d543d20SAndroid Build Coastguard Worker const char *path_rw,
111*2d543d20SAndroid Build Coastguard Worker dbase_config_t * dconfig)
112*2d543d20SAndroid Build Coastguard Worker {
113*2d543d20SAndroid Build Coastguard Worker
114*2d543d20SAndroid Build Coastguard Worker if (dbase_file_init(handle,
115*2d543d20SAndroid Build Coastguard Worker path_ro,
116*2d543d20SAndroid Build Coastguard Worker path_rw,
117*2d543d20SAndroid Build Coastguard Worker &SEMANAGE_USER_EXTRA_RTABLE,
118*2d543d20SAndroid Build Coastguard Worker &SEMANAGE_USER_EXTRA_FILE_RTABLE,
119*2d543d20SAndroid Build Coastguard Worker &dconfig->dbase) < 0)
120*2d543d20SAndroid Build Coastguard Worker return STATUS_ERR;
121*2d543d20SAndroid Build Coastguard Worker
122*2d543d20SAndroid Build Coastguard Worker dconfig->dtable = &SEMANAGE_FILE_DTABLE;
123*2d543d20SAndroid Build Coastguard Worker return STATUS_SUCCESS;
124*2d543d20SAndroid Build Coastguard Worker }
125*2d543d20SAndroid Build Coastguard Worker
user_extra_file_dbase_release(dbase_config_t * dconfig)126*2d543d20SAndroid Build Coastguard Worker void user_extra_file_dbase_release(dbase_config_t * dconfig)
127*2d543d20SAndroid Build Coastguard Worker {
128*2d543d20SAndroid Build Coastguard Worker
129*2d543d20SAndroid Build Coastguard Worker dbase_file_release(dconfig->dbase);
130*2d543d20SAndroid Build Coastguard Worker }
131