selinux-refpolicy/policy/support/file_patterns.spt
2017-12-13 19:01:45 -05:00

585 lines
13 KiB
Cheetah

#
# Directory patterns (dir)
#
# Parameters:
# 1. domain type
# 2. container (directory) type
# 3. directory type
#
define(`getattr_dirs_pattern',`
allow $1 $2:dir search_dir_perms;
allow $1 $3:dir getattr_dir_perms;
')
define(`setattr_dirs_pattern',`
allow $1 $2:dir search_dir_perms;
allow $1 $3:dir setattr_dir_perms;
')
define(`search_dirs_pattern',`
allow $1 $2:dir search_dir_perms;
allow $1 $3:dir search_dir_perms;
')
define(`list_dirs_pattern',`
allow $1 $2:dir search_dir_perms;
allow $1 $3:dir list_dir_perms;
')
define(`add_entry_dirs_pattern',`
allow $1 $2:dir search_dir_perms;
allow $1 $3:dir add_entry_dir_perms;
')
define(`del_entry_dirs_pattern',`
allow $1 $2:dir search_dir_perms;
allow $1 $3:dir del_entry_dir_perms;
')
define(`rw_dirs_pattern',`
allow $1 $2:dir search_dir_perms;
allow $1 $3:dir { add_entry_dir_perms del_entry_dir_perms };
')
define(`create_dirs_pattern',`
allow $1 $2:dir add_entry_dir_perms;
allow $1 $3:dir create_dir_perms;
')
define(`delete_dirs_pattern',`
allow $1 $2:dir del_entry_dir_perms;
allow $1 $3:dir delete_dir_perms;
')
define(`rename_dirs_pattern',`
allow $1 $2:dir rw_dir_perms;
allow $1 $3:dir rename_dir_perms;
')
define(`manage_dirs_pattern',`
allow $1 $2:dir rw_dir_perms;
allow $1 $3:dir manage_dir_perms;
')
define(`relabelfrom_dirs_pattern',`
allow $1 $2:dir search_dir_perms;
allow $1 $3:dir relabelfrom_dir_perms;
')
define(`relabelto_dirs_pattern',`
allow $1 $2:dir search_dir_perms;
allow $1 $3:dir relabelto_dir_perms;
')
define(`relabel_dirs_pattern',`
allow $1 $2:dir search_dir_perms;
allow $1 $3:dir relabel_dir_perms;
')
#
# Regular file patterns (file)
#
# Parameters:
# 1. domain type
# 2. container (directory) type
# 3. file type
#
define(`getattr_files_pattern',`
allow $1 $2:dir search_dir_perms;
allow $1 $3:file getattr_file_perms;
')
define(`setattr_files_pattern',`
allow $1 $2:dir search_dir_perms;
allow $1 $3:file setattr_file_perms;
')
define(`read_files_pattern',`
allow $1 $2:dir search_dir_perms;
allow $1 $3:file read_file_perms;
')
define(`mmap_read_files_pattern',`
allow $1 $2:dir search_dir_perms;
allow $1 $3:file mmap_read_file_perms;
')
define(`mmap_files_pattern',`
# deprecated 20171213
refpolicywarn(`mmap_files_pattern() is deprecated, please use mmap_exec_files_pattern() instead')
allow $1 $2:dir search_dir_perms;
allow $1 $3:file mmap_exec_file_perms;
')
define(`mmap_exec_files_pattern',`
allow $1 $2:dir search_dir_perms;
allow $1 $3:file mmap_exec_file_perms;
')
define(`exec_files_pattern',`
allow $1 $2:dir search_dir_perms;
allow $1 $3:file exec_file_perms;
')
define(`append_files_pattern',`
allow $1 $2:dir search_dir_perms;
allow $1 $3:file append_file_perms;
')
define(`write_files_pattern',`
allow $1 $2:dir search_dir_perms;
allow $1 $3:file write_file_perms;
')
define(`rw_files_pattern',`
allow $1 $2:dir search_dir_perms;
allow $1 $3:file rw_file_perms;
')
define(`mmap_rw_files_pattern',`
allow $1 $2:dir search_dir_perms;
allow $1 $3:file mmap_rw_file_perms;
')
define(`create_files_pattern',`
allow $1 $2:dir add_entry_dir_perms;
allow $1 $3:file create_file_perms;
')
define(`delete_files_pattern',`
allow $1 $2:dir del_entry_dir_perms;
allow $1 $3:file delete_file_perms;
')
define(`rename_files_pattern',`
allow $1 $2:dir rw_dir_perms;
allow $1 $3:file rename_file_perms;
')
define(`manage_files_pattern',`
allow $1 $2:dir rw_dir_perms;
allow $1 $3:file manage_file_perms;
')
define(`relabelfrom_files_pattern',`
allow $1 $2:dir search_dir_perms;
allow $1 $3:file relabelfrom_file_perms;
')
define(`relabelto_files_pattern',`
allow $1 $2:dir search_dir_perms;
allow $1 $3:file relabelto_file_perms;
')
define(`relabel_files_pattern',`
allow $1 $2:dir search_dir_perms;
allow $1 $3:file relabel_file_perms;
')
#
# Symbolic link patterns (lnk_file)
#
# Parameters:
# 1. domain type
# 2. container (directory) type
# 3. file type
#
define(`getattr_lnk_files_pattern',`
allow $1 $2:dir search_dir_perms;
allow $1 $3:lnk_file getattr_lnk_file_perms;
')
define(`setattr_lnk_files_pattern',`
allow $1 $2:dir search_dir_perms;
allow $1 $3:lnk_file setattr_lnk_file_perms;
')
define(`read_lnk_files_pattern',`
allow $1 $2:dir search_dir_perms;
allow $1 $3:lnk_file read_lnk_file_perms;
')
define(`append_lnk_files_pattern',`
allow $1 $2:dir search_dir_perms;
allow $1 $3:lnk_file append_lnk_file_perms;
')
define(`write_lnk_files_pattern',`
allow $1 $2:dir search_dir_perms;
allow $1 $3:lnk_file write_lnk_file_perms;
')
define(`rw_lnk_files_pattern',`
allow $1 $2:dir search_dir_perms;
allow $1 $3:lnk_file rw_lnk_file_perms;
')
define(`create_lnk_files_pattern',`
allow $1 $2:dir add_entry_dir_perms;
allow $1 $3:lnk_file create_lnk_file_perms;
')
define(`delete_lnk_files_pattern',`
allow $1 $2:dir del_entry_dir_perms;
allow $1 $3:lnk_file delete_lnk_file_perms;
')
define(`rename_lnk_files_pattern',`
allow $1 $2:dir rw_dir_perms;
allow $1 $3:lnk_file rename_lnk_file_perms;
')
define(`manage_lnk_files_pattern',`
allow $1 $2:dir rw_dir_perms;
allow $1 $3:lnk_file manage_lnk_file_perms;
')
define(`relabelfrom_lnk_files_pattern',`
allow $1 $2:dir search_dir_perms;
allow $1 $3:lnk_file relabelfrom_lnk_file_perms;
')
define(`relabelto_lnk_files_pattern',`
allow $1 $2:dir search_dir_perms;
allow $1 $3:lnk_file relabelto_lnk_file_perms;
')
define(`relabel_lnk_files_pattern',`
allow $1 $2:dir search_dir_perms;
allow $1 $3:lnk_file relabel_lnk_file_perms;
')
#
# (Un)named Pipes/FIFO patterns (fifo_file)
#
# Parameters:
# 1. domain type
# 2. container (directory) type
# 3. file type
#
define(`getattr_fifo_files_pattern',`
allow $1 $2:dir search_dir_perms;
allow $1 $3:fifo_file getattr_fifo_file_perms;
')
define(`setattr_fifo_files_pattern',`
allow $1 $2:dir search_dir_perms;
allow $1 $3:fifo_file setattr_fifo_file_perms;
')
define(`read_fifo_files_pattern',`
allow $1 $2:dir search_dir_perms;
allow $1 $3:fifo_file read_fifo_file_perms;
')
define(`append_fifo_files_pattern',`
allow $1 $2:dir search_dir_perms;
allow $1 $3:fifo_file append_fifo_file_perms;
')
define(`write_fifo_files_pattern',`
allow $1 $2:dir search_dir_perms;
allow $1 $3:fifo_file write_fifo_file_perms;
')
define(`rw_fifo_files_pattern',`
allow $1 $2:dir search_dir_perms;
allow $1 $3:fifo_file rw_fifo_file_perms;
')
define(`create_fifo_files_pattern',`
allow $1 $2:dir add_entry_dir_perms;
allow $1 $3:fifo_file create_fifo_file_perms;
')
define(`delete_fifo_files_pattern',`
allow $1 $2:dir del_entry_dir_perms;
allow $1 $3:fifo_file delete_fifo_file_perms;
')
define(`rename_fifo_files_pattern',`
allow $1 $2:dir rw_dir_perms;
allow $1 $3:fifo_file rename_fifo_file_perms;
')
define(`manage_fifo_files_pattern',`
allow $1 $2:dir rw_dir_perms;
allow $1 $3:fifo_file manage_fifo_file_perms;
')
define(`relabelfrom_fifo_files_pattern',`
allow $1 $2:dir search_dir_perms;
allow $1 $3:fifo_file relabelfrom_fifo_file_perms;
')
define(`relabelto_fifo_files_pattern',`
allow $1 $2:dir search_dir_perms;
allow $1 $3:fifo_file relabelto_fifo_file_perms;
')
define(`relabel_fifo_files_pattern',`
allow $1 $2:dir search_dir_perms;
allow $1 $3:fifo_file relabel_fifo_file_perms;
')
#
# (Un)named sockets patterns (sock_file)
#
# Parameters:
# 1. domain type
# 2. container (directory) type
# 3. file type
#
define(`getattr_sock_files_pattern',`
allow $1 $2:dir search_dir_perms;
allow $1 $3:sock_file getattr_sock_file_perms;
')
define(`setattr_sock_files_pattern',`
allow $1 $2:dir search_dir_perms;
allow $1 $3:sock_file setattr_sock_file_perms;
')
define(`read_sock_files_pattern',`
allow $1 $2:dir search_dir_perms;
allow $1 $3:sock_file read_sock_file_perms;
')
define(`write_sock_files_pattern',`
allow $1 $2:dir search_dir_perms;
allow $1 $3:sock_file write_sock_file_perms;
')
define(`rw_sock_files_pattern',`
allow $1 $2:dir search_dir_perms;
allow $1 $3:sock_file rw_sock_file_perms;
')
define(`create_sock_files_pattern',`
allow $1 $2:dir add_entry_dir_perms;
allow $1 $3:sock_file create_sock_file_perms;
')
define(`delete_sock_files_pattern',`
allow $1 $2:dir del_entry_dir_perms;
allow $1 $3:sock_file delete_sock_file_perms;
')
define(`rename_sock_files_pattern',`
allow $1 $2:dir rw_dir_perms;
allow $1 $3:sock_file rename_sock_file_perms;
')
define(`manage_sock_files_pattern',`
allow $1 $2:dir rw_dir_perms;
allow $1 $3:sock_file manage_sock_file_perms;
')
define(`relabelfrom_sock_files_pattern',`
allow $1 $2:dir search_dir_perms;
allow $1 $3:sock_file relabelfrom_sock_file_perms;
')
define(`relabelto_sock_files_pattern',`
allow $1 $2:dir search_dir_perms;
allow $1 $3:sock_file relabelto_sock_file_perms;
')
define(`relabel_sock_files_pattern',`
allow $1 $2:dir search_dir_perms;
allow $1 $3:sock_file relabel_sock_file_perms;
')
#
# Block device node patterns (blk_file)
#
# Parameters:
# 1. domain type
# 2. container (directory) type
# 3. file type
#
define(`getattr_blk_files_pattern',`
allow $1 $2:dir search_dir_perms;
allow $1 $3:blk_file getattr_blk_file_perms;
')
define(`setattr_blk_files_pattern',`
allow $1 $2:dir search_dir_perms;
allow $1 $3:blk_file setattr_blk_file_perms;
')
define(`read_blk_files_pattern',`
allow $1 $2:dir search_dir_perms;
allow $1 $3:blk_file read_blk_file_perms;
')
define(`append_blk_files_pattern',`
allow $1 $2:dir search_dir_perms;
allow $1 $3:blk_file append_blk_file_perms;
')
define(`write_blk_files_pattern',`
allow $1 $2:dir search_dir_perms;
allow $1 $3:blk_file write_blk_file_perms;
')
define(`rw_blk_files_pattern',`
allow $1 $2:dir search_dir_perms;
allow $1 $3:blk_file rw_blk_file_perms;
')
define(`create_blk_files_pattern',`
allow $1 self:capability mknod;
allow $1 $2:dir add_entry_dir_perms;
allow $1 $3:blk_file create_blk_file_perms;
')
define(`delete_blk_files_pattern',`
allow $1 $2:dir del_entry_dir_perms;
allow $1 $3:blk_file delete_blk_file_perms;
')
define(`rename_blk_files_pattern',`
allow $1 $2:dir rw_dir_perms;
allow $1 $3:blk_file rename_blk_file_perms;
')
define(`manage_blk_files_pattern',`
allow $1 self:capability mknod;
allow $1 $2:dir rw_dir_perms;
allow $1 $3:blk_file manage_blk_file_perms;
')
define(`relabelfrom_blk_files_pattern',`
allow $1 $2:dir search_dir_perms;
allow $1 $3:blk_file relabelfrom_blk_file_perms;
')
define(`relabelto_blk_files_pattern',`
allow $1 $2:dir search_dir_perms;
allow $1 $3:blk_file relabelto_blk_file_perms;
')
define(`relabel_blk_files_pattern',`
allow $1 $2:dir search_dir_perms;
allow $1 $3:blk_file relabel_blk_file_perms;
')
#
# Character device node patterns (chr_file)
#
# Parameters:
# 1. domain type
# 2. container (directory) type
# 3. file type
#
define(`getattr_chr_files_pattern',`
allow $1 $2:dir search_dir_perms;
allow $1 $3:chr_file getattr_chr_file_perms;
')
define(`setattr_chr_files_pattern',`
allow $1 $2:dir search_dir_perms;
allow $1 $3:chr_file setattr_chr_file_perms;
')
define(`read_chr_files_pattern',`
allow $1 $2:dir search_dir_perms;
allow $1 $3:chr_file read_chr_file_perms;
')
define(`append_chr_files_pattern',`
allow $1 $2:dir search_dir_perms;
allow $1 $3:chr_file append_chr_file_perms;
')
define(`write_chr_files_pattern',`
allow $1 $2:dir search_dir_perms;
allow $1 $3:chr_file write_chr_file_perms;
')
define(`rw_chr_files_pattern',`
allow $1 $2:dir search_dir_perms;
allow $1 $3:chr_file rw_chr_file_perms;
')
define(`create_chr_files_pattern',`
allow $1 self:capability mknod;
allow $1 $2:dir add_entry_dir_perms;
allow $1 $3:chr_file create_chr_file_perms;
')
define(`delete_chr_files_pattern',`
allow $1 $2:dir del_entry_dir_perms;
allow $1 $3:chr_file delete_chr_file_perms;
')
define(`rename_chr_files_pattern',`
allow $1 $2:dir rw_dir_perms;
allow $1 $3:chr_file rename_chr_file_perms;
')
define(`manage_chr_files_pattern',`
allow $1 self:capability mknod;
allow $1 $2:dir rw_dir_perms;
allow $1 $3:chr_file manage_chr_file_perms;
')
define(`relabelfrom_chr_files_pattern',`
allow $1 $2:dir search_dir_perms;
allow $1 $3:chr_file relabelfrom_chr_file_perms;
')
define(`relabelto_chr_files_pattern',`
allow $1 $2:dir search_dir_perms;
allow $1 $3:chr_file relabelto_chr_file_perms;
')
define(`relabel_chr_files_pattern',`
allow $1 $2:dir search_dir_perms;
allow $1 $3:chr_file relabel_chr_file_perms;
')
#
# File type_transition patterns
#
# Parameters:
# 1. domain type
# 2. container (directory) type
# 3. new object type
# 4. object class(es)
# [optional] 5. filename (c style strcmp ready)
#
# do not grant $2:dir remove_name
define(`filetrans_add_pattern',`
allow $1 $2:dir { list_dir_perms add_entry_dir_perms };
type_transition $1 $2:$4 $3 $5;
')
define(`filetrans_pattern',`
allow $1 $2:dir rw_dir_perms;
type_transition $1 $2:$4 $3 $5;
')
#
# Admin pattern for file_type
#
# Parameters:
# 1. domain type
# 2. source object type
#
define(`admin_pattern',`
manage_dirs_pattern($1,$2,$2)
manage_files_pattern($1,$2,$2)
manage_lnk_files_pattern($1,$2,$2)
manage_fifo_files_pattern($1,$2,$2)
manage_sock_files_pattern($1,$2,$2)
relabel_dirs_pattern($1,$2,$2)
relabel_files_pattern($1,$2,$2)
relabel_lnk_files_pattern($1,$2,$2)
relabel_fifo_files_pattern($1,$2,$2)
relabel_sock_files_pattern($1,$2,$2)
')