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