Blob Blame History Raw
policy_module(bird, 1.0.2)

########################################
#
# Declarations
#

type bird_t;
type bird_exec_t;
init_daemon_domain(bird_t, bird_exec_t)

type bird_initrc_exec_t;
init_script_file(bird_initrc_exec_t)

type bird_etc_t;
files_config_file(bird_etc_t)

type bird_log_t;
logging_log_file(bird_log_t)

type bird_var_run_t;
files_pid_file(bird_var_run_t)

########################################
#
# Local policy
#

allow bird_t self:capability net_admin;
allow bird_t self:netlink_route_socket create_netlink_socket_perms;
allow bird_t self:tcp_socket create_stream_socket_perms;

allow bird_t bird_etc_t:file read_file_perms;

allow bird_t bird_log_t:file { create_file_perms append_file_perms setattr_file_perms };
logging_log_filetrans(bird_t, bird_log_t, file)

allow bird_t bird_var_run_t:sock_file manage_sock_file_perms;
files_pid_filetrans(bird_t, bird_var_run_t, sock_file)

corenet_all_recvfrom_unlabeled(bird_t)
corenet_all_recvfrom_netlabel(bird_t)
corenet_tcp_sendrecv_generic_if(bird_t)
corenet_tcp_bind_generic_node(bird_t)
corenet_tcp_sendrecv_generic_node(bird_t)

corenet_sendrecv_bgp_client_packets(bird_t)
corenet_sendrecv_bgp_server_packets(bird_t)
corenet_tcp_bind_bgp_port(bird_t)
corenet_tcp_connect_bgp_port(bird_t)
corenet_tcp_sendrecv_bgp_port(bird_t)

# /etc/iproute2/rt_realms

logging_send_syslog_msg(bird_t)

miscfiles_read_localization(bird_t)