mirror of
https://gitlab.com/apparmor/apparmor.git
synced 2025-03-09 19:28:47 +01:00

Based on the existing implementations of aa_change_profile(2) and aa_change_onexec(2). Signed-off-by: Tyler Hicks <tyhicks@canonical.com> Acked-by: John Johansen <john.johansen@canonical.com>
74 lines
2.4 KiB
OpenEdge ABL
74 lines
2.4 KiB
OpenEdge ABL
%module LibAppArmor
|
|
|
|
%{
|
|
#include <aalogparse.h>
|
|
#include <sys/apparmor.h>
|
|
#include <sys/apparmor_private.h>
|
|
|
|
%}
|
|
|
|
%include "typemaps.i"
|
|
%include <aalogparse.h>
|
|
|
|
/**
|
|
* swig doesn't like the macro magic we do in apparmor.h and apparmor_private.h
|
|
* so the function prototypes must be manually inserted.
|
|
*
|
|
* Functions that return a negative int and set errno upon error use a special
|
|
* %exception directive and must be listed after the %exception below. All
|
|
* other functions go here.
|
|
*/
|
|
|
|
/* apparmor.h */
|
|
|
|
extern char *aa_splitcon(char *con, char **mode);
|
|
|
|
/* apparmor_private.h */
|
|
|
|
extern int _aa_is_blacklisted(const char *name);
|
|
|
|
#ifdef SWIGPYTHON
|
|
%exception {
|
|
$action
|
|
if (result < 0) {
|
|
PyErr_SetFromErrno(PyExc_OSError);
|
|
return NULL;
|
|
}
|
|
}
|
|
#endif
|
|
|
|
/* Functions that return a negative int and set errno upon error go here. */
|
|
|
|
/* apparmor.h */
|
|
|
|
extern int aa_is_enabled(void);
|
|
extern int aa_find_mountpoint(char **mnt);
|
|
extern int aa_change_hat(const char *subprofile, unsigned long magic_token);
|
|
extern int aa_change_profile(const char *profile);
|
|
extern int aa_change_onexec(const char *profile);
|
|
extern int aa_change_hatv(const char *subprofiles[], unsigned long token);
|
|
extern int aa_change_hat_vargs(unsigned long token, int count, ...);
|
|
extern int aa_stack_profile(const char *profile);
|
|
extern int aa_stack_onexec(const char *profile);
|
|
extern int aa_getprocattr_raw(pid_t tid, const char *attr, char *buf, int len,
|
|
char **mode);
|
|
extern int aa_getprocattr(pid_t tid, const char *attr, char **buf, char **mode);
|
|
extern int aa_gettaskcon(pid_t target, char **label, char **mode);
|
|
extern int aa_getcon(char **label, char **mode);
|
|
extern int aa_getpeercon_raw(int fd, char *buf, int *len, char **mode);
|
|
extern int aa_getpeercon(int fd, char **label, char **mode);
|
|
extern int aa_query_label(uint32_t mask, char *query, size_t size, int *allow,
|
|
int *audit);
|
|
extern int aa_query_file_path_len(uint32_t mask, const char *label,
|
|
size_t label_len, const char *path,
|
|
size_t path_len, int *allowed, int *audited);
|
|
extern int aa_query_file_path(uint32_t mask, const char *label,
|
|
const char *path, int *allowed, int *audited);
|
|
extern int aa_query_link_path_len(const char *label, size_t label_len,
|
|
const char *target, size_t target_len,
|
|
const char *link, size_t link_len,
|
|
int *allowed, int *audited);
|
|
extern int aa_query_link_path(const char *label, const char *target,
|
|
const char *link, int *allowed, int *audited);
|
|
|
|
%exception;
|