113cd4c8960688af11ad23b4c946149015c80d54Joshua Brindle#ifndef _SEPOL_MODULE_H_ 213cd4c8960688af11ad23b4c946149015c80d54Joshua Brindle#define _SEPOL_MODULE_H_ 313cd4c8960688af11ad23b4c946149015c80d54Joshua Brindle 413cd4c8960688af11ad23b4c946149015c80d54Joshua Brindle#include <stddef.h> 513cd4c8960688af11ad23b4c946149015c80d54Joshua Brindle#include <stdio.h> 613cd4c8960688af11ad23b4c946149015c80d54Joshua Brindle#include <stdint.h> 713cd4c8960688af11ad23b4c946149015c80d54Joshua Brindle 813cd4c8960688af11ad23b4c946149015c80d54Joshua Brindle#include <sepol/handle.h> 913cd4c8960688af11ad23b4c946149015c80d54Joshua Brindle#include <sepol/policydb.h> 10ed7a6ba24ad3241e696fa7bc9bb56bb4f373147bdcashman#include <sys/cdefs.h> 11ed7a6ba24ad3241e696fa7bc9bb56bb4f373147bdcashman 12ed7a6ba24ad3241e696fa7bc9bb56bb4f373147bdcashman__BEGIN_DECLS 1313cd4c8960688af11ad23b4c946149015c80d54Joshua Brindle 1413cd4c8960688af11ad23b4c946149015c80d54Joshua Brindlestruct sepol_module_package; 1513cd4c8960688af11ad23b4c946149015c80d54Joshua Brindletypedef struct sepol_module_package sepol_module_package_t; 1613cd4c8960688af11ad23b4c946149015c80d54Joshua Brindle 1713cd4c8960688af11ad23b4c946149015c80d54Joshua Brindle/* Module package public interfaces. */ 1813cd4c8960688af11ad23b4c946149015c80d54Joshua Brindle 1913cd4c8960688af11ad23b4c946149015c80d54Joshua Brindleextern int sepol_module_package_create(sepol_module_package_t ** p); 2013cd4c8960688af11ad23b4c946149015c80d54Joshua Brindle 2113cd4c8960688af11ad23b4c946149015c80d54Joshua Brindleextern void sepol_module_package_free(sepol_module_package_t * p); 2213cd4c8960688af11ad23b4c946149015c80d54Joshua Brindle 2313cd4c8960688af11ad23b4c946149015c80d54Joshua Brindleextern char *sepol_module_package_get_file_contexts(sepol_module_package_t * p); 2413cd4c8960688af11ad23b4c946149015c80d54Joshua Brindle 2513cd4c8960688af11ad23b4c946149015c80d54Joshua Brindleextern size_t sepol_module_package_get_file_contexts_len(sepol_module_package_t 2613cd4c8960688af11ad23b4c946149015c80d54Joshua Brindle * p); 2713cd4c8960688af11ad23b4c946149015c80d54Joshua Brindle 2813cd4c8960688af11ad23b4c946149015c80d54Joshua Brindleextern int sepol_module_package_set_file_contexts(sepol_module_package_t * p, 2913cd4c8960688af11ad23b4c946149015c80d54Joshua Brindle char *data, size_t len); 3013cd4c8960688af11ad23b4c946149015c80d54Joshua Brindle 3113cd4c8960688af11ad23b4c946149015c80d54Joshua Brindleextern char *sepol_module_package_get_seusers(sepol_module_package_t * p); 3213cd4c8960688af11ad23b4c946149015c80d54Joshua Brindle 3313cd4c8960688af11ad23b4c946149015c80d54Joshua Brindleextern size_t sepol_module_package_get_seusers_len(sepol_module_package_t * p); 3413cd4c8960688af11ad23b4c946149015c80d54Joshua Brindle 3513cd4c8960688af11ad23b4c946149015c80d54Joshua Brindleextern int sepol_module_package_set_seusers(sepol_module_package_t * p, 3613cd4c8960688af11ad23b4c946149015c80d54Joshua Brindle char *data, size_t len); 3713cd4c8960688af11ad23b4c946149015c80d54Joshua Brindle 3813cd4c8960688af11ad23b4c946149015c80d54Joshua Brindleextern char *sepol_module_package_get_user_extra(sepol_module_package_t * p); 3913cd4c8960688af11ad23b4c946149015c80d54Joshua Brindle 4013cd4c8960688af11ad23b4c946149015c80d54Joshua Brindleextern size_t sepol_module_package_get_user_extra_len(sepol_module_package_t * 4113cd4c8960688af11ad23b4c946149015c80d54Joshua Brindle p); 4213cd4c8960688af11ad23b4c946149015c80d54Joshua Brindle 4313cd4c8960688af11ad23b4c946149015c80d54Joshua Brindleextern int sepol_module_package_set_user_extra(sepol_module_package_t * p, 4413cd4c8960688af11ad23b4c946149015c80d54Joshua Brindle char *data, size_t len); 4513cd4c8960688af11ad23b4c946149015c80d54Joshua Brindle 4613cd4c8960688af11ad23b4c946149015c80d54Joshua Brindleextern char *sepol_module_package_get_netfilter_contexts(sepol_module_package_t 4713cd4c8960688af11ad23b4c946149015c80d54Joshua Brindle * p); 4813cd4c8960688af11ad23b4c946149015c80d54Joshua Brindle 4913cd4c8960688af11ad23b4c946149015c80d54Joshua Brindleextern size_t 5013cd4c8960688af11ad23b4c946149015c80d54Joshua Brindlesepol_module_package_get_netfilter_contexts_len(sepol_module_package_t * p); 5113cd4c8960688af11ad23b4c946149015c80d54Joshua Brindle 5213cd4c8960688af11ad23b4c946149015c80d54Joshua Brindleextern int sepol_module_package_set_netfilter_contexts(sepol_module_package_t * 5313cd4c8960688af11ad23b4c946149015c80d54Joshua Brindle p, char *data, 5413cd4c8960688af11ad23b4c946149015c80d54Joshua Brindle size_t len); 5513cd4c8960688af11ad23b4c946149015c80d54Joshua Brindle 5613cd4c8960688af11ad23b4c946149015c80d54Joshua Brindleextern sepol_policydb_t *sepol_module_package_get_policy(sepol_module_package_t 5713cd4c8960688af11ad23b4c946149015c80d54Joshua Brindle * p); 5813cd4c8960688af11ad23b4c946149015c80d54Joshua Brindle 5913cd4c8960688af11ad23b4c946149015c80d54Joshua Brindleextern int sepol_link_packages(sepol_handle_t * handle, 6013cd4c8960688af11ad23b4c946149015c80d54Joshua Brindle sepol_module_package_t * base, 6113cd4c8960688af11ad23b4c946149015c80d54Joshua Brindle sepol_module_package_t ** modules, 6213cd4c8960688af11ad23b4c946149015c80d54Joshua Brindle int num_modules, int verbose); 6313cd4c8960688af11ad23b4c946149015c80d54Joshua Brindle 6413cd4c8960688af11ad23b4c946149015c80d54Joshua Brindleextern int sepol_module_package_read(sepol_module_package_t * mod, 6513cd4c8960688af11ad23b4c946149015c80d54Joshua Brindle struct sepol_policy_file *file, 6613cd4c8960688af11ad23b4c946149015c80d54Joshua Brindle int verbose); 6713cd4c8960688af11ad23b4c946149015c80d54Joshua Brindle 6813cd4c8960688af11ad23b4c946149015c80d54Joshua Brindleextern int sepol_module_package_info(struct sepol_policy_file *file, 6913cd4c8960688af11ad23b4c946149015c80d54Joshua Brindle int *type, char **name, char **version); 7013cd4c8960688af11ad23b4c946149015c80d54Joshua Brindle 7113cd4c8960688af11ad23b4c946149015c80d54Joshua Brindleextern int sepol_module_package_write(sepol_module_package_t * p, 7213cd4c8960688af11ad23b4c946149015c80d54Joshua Brindle struct sepol_policy_file *file); 7313cd4c8960688af11ad23b4c946149015c80d54Joshua Brindle 7413cd4c8960688af11ad23b4c946149015c80d54Joshua Brindle/* Module linking/expanding public interfaces. */ 7513cd4c8960688af11ad23b4c946149015c80d54Joshua Brindle 7613cd4c8960688af11ad23b4c946149015c80d54Joshua Brindleextern int sepol_link_modules(sepol_handle_t * handle, 7713cd4c8960688af11ad23b4c946149015c80d54Joshua Brindle sepol_policydb_t * base, 7813cd4c8960688af11ad23b4c946149015c80d54Joshua Brindle sepol_policydb_t ** modules, 7913cd4c8960688af11ad23b4c946149015c80d54Joshua Brindle size_t len, int verbose); 8013cd4c8960688af11ad23b4c946149015c80d54Joshua Brindle 8113cd4c8960688af11ad23b4c946149015c80d54Joshua Brindleextern int sepol_expand_module(sepol_handle_t * handle, 8213cd4c8960688af11ad23b4c946149015c80d54Joshua Brindle sepol_policydb_t * base, 8313cd4c8960688af11ad23b4c946149015c80d54Joshua Brindle sepol_policydb_t * out, int verbose, int check); 8413cd4c8960688af11ad23b4c946149015c80d54Joshua Brindle 85ed7a6ba24ad3241e696fa7bc9bb56bb4f373147bdcashman__END_DECLS 8613cd4c8960688af11ad23b4c946149015c80d54Joshua Brindle#endif 87