| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283 |
- #ifndef _SEPOL_MODULE_H_
- #define _SEPOL_MODULE_H_
- #include <stddef.h>
- #include <stdio.h>
- #include <stdint.h>
- #include <sepol/handle.h>
- #include <sepol/policydb.h>
- struct sepol_module_package;
- typedef struct sepol_module_package sepol_module_package_t;
- /* Module package public interfaces. */
- extern int sepol_module_package_create(sepol_module_package_t ** p);
- extern void sepol_module_package_free(sepol_module_package_t * p);
- extern char *sepol_module_package_get_file_contexts(sepol_module_package_t * p);
- extern size_t sepol_module_package_get_file_contexts_len(sepol_module_package_t
- * p);
- extern int sepol_module_package_set_file_contexts(sepol_module_package_t * p,
- char *data, size_t len);
- extern char *sepol_module_package_get_seusers(sepol_module_package_t * p);
- extern size_t sepol_module_package_get_seusers_len(sepol_module_package_t * p);
- extern int sepol_module_package_set_seusers(sepol_module_package_t * p,
- char *data, size_t len);
- extern char *sepol_module_package_get_user_extra(sepol_module_package_t * p);
- extern size_t sepol_module_package_get_user_extra_len(sepol_module_package_t *
- p);
- extern int sepol_module_package_set_user_extra(sepol_module_package_t * p,
- char *data, size_t len);
- extern char *sepol_module_package_get_netfilter_contexts(sepol_module_package_t
- * p);
- extern size_t
- sepol_module_package_get_netfilter_contexts_len(sepol_module_package_t * p);
- extern int sepol_module_package_set_netfilter_contexts(sepol_module_package_t *
- p, char *data,
- size_t len);
- extern sepol_policydb_t *sepol_module_package_get_policy(sepol_module_package_t
- * p);
- extern int sepol_link_packages(sepol_handle_t * handle,
- sepol_module_package_t * base,
- sepol_module_package_t ** modules,
- int num_modules, int verbose);
- extern int sepol_module_package_read(sepol_module_package_t * mod,
- struct sepol_policy_file *file,
- int verbose);
- extern int sepol_module_package_info(struct sepol_policy_file *file,
- int *type, char **name, char **version);
- extern int sepol_module_package_write(sepol_module_package_t * p,
- struct sepol_policy_file *file);
- /* Module linking/expanding public interfaces. */
- extern int sepol_link_modules(sepol_handle_t * handle,
- sepol_policydb_t * base,
- sepol_policydb_t ** modules,
- size_t len, int verbose);
- extern int sepol_expand_module(sepol_handle_t * handle,
- sepol_policydb_t * base,
- sepol_policydb_t * out, int verbose, int check);
- #endif
|