mirror of
https://gitlab.com/apparmor/apparmor.git
synced 2025-03-04 08:24:42 +01:00

The post_process() method is misnamed, it fires when the profile is finished parsing but fires before variable expansion. Rename it to better reflect what it does and move the trigger code into profile as a start of cleaning this stage up. Also document the order the hooks fire in Signed-off-by: John Johansen <john.johansen@canonical.com>
69 lines
2 KiB
C++
69 lines
2 KiB
C++
/*
|
|
* Copyright (c) 2014
|
|
* Canonical Ltd. (All rights reserved)
|
|
*
|
|
* This program is free software; you can redistribute it and/or
|
|
* modify it under the terms of version 2 of the GNU General Public
|
|
* License published by the Free Software Foundation.
|
|
*
|
|
* This program is distributed in the hope that it will be useful,
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
* GNU General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU General Public License
|
|
* along with this program; if not, contact Novell, Inc. or Canonical
|
|
* Ltd.
|
|
*/
|
|
#ifndef __AA_AF_UNIX_H
|
|
#define __AA_AF_UNIX_H
|
|
|
|
#include "immunix.h"
|
|
#include "network.h"
|
|
#include "parser.h"
|
|
#include "profile.h"
|
|
#include "af_rule.h"
|
|
|
|
int parse_unix_perms(const char *str_mode, perms_t *perms, int fail);
|
|
|
|
class unix_rule: public af_rule {
|
|
void write_to_prot(std::ostringstream &buffer);
|
|
bool write_addr(std::ostringstream &buffer, const char *addr);
|
|
bool write_label(std::ostringstream &buffer, const char *label);
|
|
void move_conditionals(struct cond_entry *conds);
|
|
void move_peer_conditionals(struct cond_entry *conds);
|
|
void downgrade_rule(Profile &prof);
|
|
public:
|
|
char *addr;
|
|
char *peer_addr;
|
|
|
|
unix_rule(unsigned int type_p, audit_t audit_p, bool denied);
|
|
unix_rule(perms_t perms, struct cond_entry *conds,
|
|
struct cond_entry *peer_conds);
|
|
virtual ~unix_rule()
|
|
{
|
|
free(addr);
|
|
free(peer_addr);
|
|
};
|
|
|
|
virtual bool valid_prefix(prefixes &p, const char *&error) {
|
|
if (p.owner) {
|
|
error = "owner prefix not allowed on unix rules";
|
|
return false;
|
|
}
|
|
return true;
|
|
};
|
|
virtual bool has_peer_conds(void) {
|
|
return af_rule::has_peer_conds() || peer_addr;
|
|
}
|
|
|
|
virtual ostream &dump_local(ostream &os);
|
|
virtual ostream &dump_peer(ostream &os);
|
|
virtual int expand_variables(void);
|
|
virtual int gen_policy_re(Profile &prof);
|
|
|
|
protected:
|
|
virtual void warn_once(const char *name) override;
|
|
};
|
|
|
|
#endif /* __AA_AF_UNIX_H */
|