a9d240f4bf
We already handle foreign routing policy rules correctly by the previous commit. So, the serialization/deserialization of rules are not necessary anymore.
82 lines
2.8 KiB
C
82 lines
2.8 KiB
C
/* SPDX-License-Identifier: LGPL-2.1-or-later */
|
|
#pragma once
|
|
|
|
#include <inttypes.h>
|
|
#include <linux/fib_rules.h>
|
|
#include <stdbool.h>
|
|
#include <stdio.h>
|
|
|
|
#include "conf-parser.h"
|
|
#include "in-addr-util.h"
|
|
#include "networkd-util.h"
|
|
#include "set.h"
|
|
|
|
typedef struct Network Network;
|
|
typedef struct Link Link;
|
|
typedef struct Manager Manager;
|
|
|
|
typedef struct RoutingPolicyRule {
|
|
Manager *manager;
|
|
Network *network;
|
|
NetworkConfigSection *section;
|
|
|
|
bool invert_rule;
|
|
|
|
uint8_t tos;
|
|
uint8_t type;
|
|
uint8_t ipproto; /* FRA_IP_PROTO */
|
|
uint8_t protocol; /* FRA_PROTOCOL */
|
|
uint8_t to_prefixlen;
|
|
uint8_t from_prefixlen;
|
|
uint8_t l3mdev; /* FRA_L3MDEV */
|
|
|
|
uint32_t table;
|
|
uint32_t fwmark;
|
|
uint32_t fwmask;
|
|
uint32_t priority;
|
|
|
|
AddressFamily address_family; /* Specified by Family= */
|
|
int family; /* Automatically determined by From= or To= */
|
|
|
|
char *iif;
|
|
char *oif;
|
|
|
|
union in_addr_union to;
|
|
union in_addr_union from;
|
|
|
|
struct fib_rule_port_range sport;
|
|
struct fib_rule_port_range dport;
|
|
struct fib_rule_uid_range uid_range;
|
|
|
|
int suppress_prefixlen;
|
|
} RoutingPolicyRule;
|
|
|
|
RoutingPolicyRule *routing_policy_rule_free(RoutingPolicyRule *rule);
|
|
|
|
void network_drop_invalid_routing_policy_rules(Network *network);
|
|
|
|
int link_set_routing_policy_rules(Link *link);
|
|
|
|
int manager_rtnl_process_rule(sd_netlink *rtnl, sd_netlink_message *message, Manager *m);
|
|
int manager_drop_routing_policy_rules_internal(Manager *m, bool foreign, const Link *except);
|
|
static inline int manager_drop_foreign_routing_policy_rules(Manager *m) {
|
|
return manager_drop_routing_policy_rules_internal(m, true, NULL);
|
|
}
|
|
static inline int manager_drop_routing_policy_rules(Manager *m, const Link *except) {
|
|
return manager_drop_routing_policy_rules_internal(m, false, except);
|
|
}
|
|
|
|
CONFIG_PARSER_PROTOTYPE(config_parse_routing_policy_rule_tos);
|
|
CONFIG_PARSER_PROTOTYPE(config_parse_routing_policy_rule_table);
|
|
CONFIG_PARSER_PROTOTYPE(config_parse_routing_policy_rule_fwmark_mask);
|
|
CONFIG_PARSER_PROTOTYPE(config_parse_routing_policy_rule_prefix);
|
|
CONFIG_PARSER_PROTOTYPE(config_parse_routing_policy_rule_priority);
|
|
CONFIG_PARSER_PROTOTYPE(config_parse_routing_policy_rule_device);
|
|
CONFIG_PARSER_PROTOTYPE(config_parse_routing_policy_rule_port_range);
|
|
CONFIG_PARSER_PROTOTYPE(config_parse_routing_policy_rule_ip_protocol);
|
|
CONFIG_PARSER_PROTOTYPE(config_parse_routing_policy_rule_invert);
|
|
CONFIG_PARSER_PROTOTYPE(config_parse_routing_policy_rule_family);
|
|
CONFIG_PARSER_PROTOTYPE(config_parse_routing_policy_rule_uid_range);
|
|
CONFIG_PARSER_PROTOTYPE(config_parse_routing_policy_rule_suppress_prefixlen);
|
|
CONFIG_PARSER_PROTOTYPE(config_parse_routing_policy_rule_type);
|