2
0
mirror of https://gitlab.com/apparmor/apparmor synced 2025-09-01 14:55:10 +00:00

parser: Move policy cache initialization code into its own function

This patch moves the logic that sets up the policy into a new function
in policy_cache.c

Signed-off-by: Tyler Hicks <tyhicks@canonical.com>
Acked-by: John Johansen <john.johansen@canonical.com>
This commit is contained in:
Tyler Hicks
2015-03-25 17:09:26 -05:00
parent 2a082ee543
commit 0f12effabf
4 changed files with 54 additions and 47 deletions

View File

@@ -240,7 +240,7 @@ common_optarg.o: common_optarg.c common_optarg.h parser.h libapparmor_re/apparmo
features.o: features.c features.h parser.h libapparmor_re/apparmor_re.h features.o: features.c features.h parser.h libapparmor_re/apparmor_re.h
$(CXX) $(EXTRA_CFLAGS) -c -o $@ $< $(CXX) $(EXTRA_CFLAGS) -c -o $@ $<
policy_cache.o: policy_cache.c policy_cache.h parser.h lib.h policy_cache.o: policy_cache.c policy_cache.h parser.h lib.h features.h
$(CXX) $(EXTRA_CFLAGS) -c -o $@ $< $(CXX) $(EXTRA_CFLAGS) -c -o $@ $<
kernel_interface.o: kernel_interface.c kernel_interface.h kernel_interface.o: kernel_interface.c kernel_interface.h

View File

@@ -80,8 +80,6 @@ int mru_skip_cache = 1;
int debug_cache = 0; int debug_cache = 0;
struct timespec mru_tstamp; struct timespec mru_tstamp;
char *cacheloc = NULL;
/* Make sure to update BOTH the short and long_options */ /* Make sure to update BOTH the short and long_options */
static const char *short_options = "adf:h::rRVvI:b:BCD:NSm:M:qQn:XKTWkL:O:po:"; static const char *short_options = "adf:h::rRVvI:b:BCD:NSm:M:qQn:XKTWkL:O:po:";
struct option long_options[] = { struct option long_options[] = {
@@ -856,9 +854,6 @@ static int binary_dir_cb(DIR *dir unused, const char *name, struct stat *st,
static void setup_flags(void) static void setup_flags(void)
{ {
autofree char *cache_features_path = NULL;
autofree char *cache_flags = NULL;
/* Get the match string to determine type of regex support needed */ /* Get the match string to determine type of regex support needed */
set_supported_features(); set_supported_features();
@@ -871,36 +866,6 @@ static void setup_flags(void)
skip_read_cache = 1; skip_read_cache = 1;
return; return;
} }
/*
* Deal with cache directory versioning:
* - If cache/.features is missing, create it if --write-cache.
* - If cache/.features exists, and does not match features_string,
* force cache reading/writing off.
*/
if (asprintf(&cache_features_path, "%s/.features", cacheloc) == -1) {
PERROR(_("Memory allocation error."));
exit(1);
}
cache_flags = load_features_file(cache_features_path);
if (cache_flags) {
if (strcmp(features_string, cache_flags) != 0) {
if (write_cache && cond_clear_cache) {
if (create_cache(cacheloc, cache_features_path,
features_string))
skip_read_cache = 1;
} else {
if (show_cache)
PERROR("Cache read/write disabled: %s does not match %s\n", FEATURES_FILE, cache_features_path);
write_cache = 0;
skip_read_cache = 1;
}
}
} else if (write_cache) {
create_cache(cacheloc, cache_features_path, features_string);
}
} }
int main(int argc, char *argv[]) int main(int argc, char *argv[])
@@ -927,17 +892,6 @@ int main(int argc, char *argv[])
return retval; return retval;
} }
/* create the cacheloc once and use it everywhere */
if (!cacheloc) {
if (asprintf(&cacheloc, "%s/cache", basedir) == -1) {
PERROR(_("Memory allocation error."));
exit(1);
}
}
if (force_clear_cache)
exit(clear_cache_files(cacheloc));
/* Check to make sure there is an interface to load policy */ /* Check to make sure there is an interface to load policy */
if (!(UNPRIVILEGED_OPS) && (subdomainbase == NULL) && if (!(UNPRIVILEGED_OPS) && (subdomainbase == NULL) &&
!find_subdomainfs_mountpoint()) { !find_subdomainfs_mountpoint()) {
@@ -948,6 +902,8 @@ int main(int argc, char *argv[])
setup_flags(); setup_flags();
setup_cache();
retval = last_error = 0; retval = last_error = 0;
for (i = optind; i <= argc; i++) { for (i = optind; i <= argc; i++) {
struct stat stat_file; struct stat stat_file;

View File

@@ -30,9 +30,12 @@
#define _(s) gettext(s) #define _(s) gettext(s)
#include "lib.h" #include "lib.h"
#include "features.h"
#include "parser.h" #include "parser.h"
#include "policy_cache.h" #include "policy_cache.h"
char *cacheloc = NULL;
#define le16_to_cpu(x) ((uint16_t)(le16toh (*(uint16_t *) x))) #define le16_to_cpu(x) ((uint16_t)(le16toh (*(uint16_t *) x)))
const char header_string[] = "\004\010\000version\000\002"; const char header_string[] = "\004\010\000version\000\002";
@@ -226,3 +229,49 @@ void install_cache(const char *cachetmpname, const char *cachename)
} }
} }
} }
void setup_cache(void)
{
autofree char *cache_features_path = NULL;
autofree char *cache_flags = NULL;
/* create the cacheloc once and use it everywhere */
if (!cacheloc) {
if (asprintf(&cacheloc, "%s/cache", basedir) == -1) {
PERROR(_("Memory allocation error."));
exit(1);
}
}
if (force_clear_cache)
exit(clear_cache_files(cacheloc));
/*
* Deal with cache directory versioning:
* - If cache/.features is missing, create it if --write-cache.
* - If cache/.features exists, and does not match features_string,
* force cache reading/writing off.
*/
if (asprintf(&cache_features_path, "%s/.features", cacheloc) == -1) {
PERROR(_("Memory allocation error."));
exit(1);
}
cache_flags = load_features_file(cache_features_path);
if (cache_flags) {
if (strcmp(features_string, cache_flags) != 0) {
if (write_cache && cond_clear_cache) {
if (create_cache(cacheloc, cache_features_path,
features_string))
skip_read_cache = 1;
} else {
if (show_cache)
PERROR("Cache read/write disabled: %s does not match %s\n", FEATURES_FILE, cache_features_path);
write_cache = 0;
skip_read_cache = 1;
}
}
} else if (write_cache) {
create_cache(cacheloc, cache_features_path, features_string);
}
}

View File

@@ -35,6 +35,7 @@ extern int force_clear_cache; /* force clearing regargless of state */
extern int create_cache_dir; /* create the cache dir if missing? */ extern int create_cache_dir; /* create the cache dir if missing? */
extern int mru_skip_cache; extern int mru_skip_cache;
extern int debug_cache; extern int debug_cache;
extern char *cacheloc;
void set_mru_tstamp(struct timespec t); void set_mru_tstamp(struct timespec t);
void update_mru_tstamp(FILE *file, const char *path); void update_mru_tstamp(FILE *file, const char *path);
@@ -46,5 +47,6 @@ void valid_read_cache(const char *cachename);
int cache_hit(const char *cachename); int cache_hit(const char *cachename);
int setup_cache_tmp(const char **cachetmpname, const char *cachename); int setup_cache_tmp(const char **cachetmpname, const char *cachename);
void install_cache(const char *cachetmpname, const char *cachename); void install_cache(const char *cachetmpname, const char *cachename);
void setup_cache(void);
#endif /* __AA_POLICY_CACHE_H */ #endif /* __AA_POLICY_CACHE_H */