hackedteam/core-android-native

View on GitHub
selinux_native/jni/libsepol/include/sepol/module.h

Summary

Maintainability
Test Coverage
#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