1ec3d1a
policy_module(chrome,1.0.0)
1ec3d1a
1ec3d1a
########################################
1ec3d1a
#
1ec3d1a
# Declarations
1ec3d1a
#
1ec3d1a
1ec3d1a
type chrome_sandbox_t;
1ec3d1a
type chrome_sandbox_exec_t;
1ec3d1a
application_domain(chrome_sandbox_t, chrome_sandbox_exec_t)
1ec3d1a
role system_r types chrome_sandbox_t;
1ec3d1a
ubac_constrained(chrome_sandbox_t)
1ec3d1a
1ec3d1a
type chrome_sandbox_tmp_t;
1ec3d1a
files_tmp_file(chrome_sandbox_tmp_t)
1ec3d1a
1ec3d1a
type chrome_sandbox_tmpfs_t;
1ec3d1a
files_tmpfs_file(chrome_sandbox_tmpfs_t)
1ec3d1a
ubac_constrained(chrome_sandbox_tmpfs_t)
1ec3d1a
1ec3d1a
type chrome_sandbox_nacl_t;
1ec3d1a
type chrome_sandbox_nacl_exec_t;
1ec3d1a
application_domain(chrome_sandbox_nacl_t, chrome_sandbox_nacl_exec_t)
1ec3d1a
role system_r types chrome_sandbox_nacl_t;
1ec3d1a
ubac_constrained(chrome_sandbox_nacl_t)
1ec3d1a
1ec3d1a
########################################
1ec3d1a
#
1ec3d1a
# chrome_sandbox local policy
1ec3d1a
#
1ec3d1a
allow chrome_sandbox_t self:capability { chown dac_override fsetid setgid setuid sys_admin sys_chroot sys_ptrace };
1ec3d1a
allow chrome_sandbox_t self:process { signal_perms setrlimit execmem execstack };
1ec3d1a
allow chrome_sandbox_t self:process setsched;
1ec3d1a
allow chrome_sandbox_t self:fifo_file manage_file_perms;
1ec3d1a
allow chrome_sandbox_t self:unix_stream_socket create_stream_socket_perms;
1ec3d1a
allow chrome_sandbox_t self:unix_dgram_socket { create_socket_perms sendto };
1ec3d1a
allow chrome_sandbox_t self:shm create_shm_perms;
1ec3d1a
allow chrome_sandbox_t self:netlink_route_socket r_netlink_socket_perms;
1ec3d1a
dontaudit chrome_sandbox_t self:memprotect mmap_zero;
1ec3d1a
1ec3d1a
manage_dirs_pattern(chrome_sandbox_t, chrome_sandbox_tmp_t, chrome_sandbox_tmp_t)
1ec3d1a
manage_files_pattern(chrome_sandbox_t, chrome_sandbox_tmp_t, chrome_sandbox_tmp_t)
1ec3d1a
files_tmp_filetrans(chrome_sandbox_t, chrome_sandbox_tmp_t, { dir file })
1ec3d1a
1ec3d1a
manage_files_pattern(chrome_sandbox_t, chrome_sandbox_tmpfs_t, chrome_sandbox_tmpfs_t)
1ec3d1a
fs_tmpfs_filetrans(chrome_sandbox_t, chrome_sandbox_tmpfs_t, file)
1ec3d1a
1ec3d1a
kernel_read_system_state(chrome_sandbox_t)
1ec3d1a
kernel_read_kernel_sysctls(chrome_sandbox_t)
1ec3d1a
1ec3d1a
fs_manage_cgroup_dirs(chrome_sandbox_t)
1ec3d1a
fs_manage_cgroup_files(chrome_sandbox_t)
1ec3d1a
1ec3d1a
corecmd_exec_bin(chrome_sandbox_t)
1ec3d1a
1ec3d1a
corenet_all_recvfrom_unlabeled(chrome_sandbox_t)
1ec3d1a
corenet_all_recvfrom_netlabel(chrome_sandbox_t)
1ec3d1a
corenet_tcp_connect_flash_port(chrome_sandbox_t)
1ec3d1a
corenet_tcp_connect_streaming_port(chrome_sandbox_t)
1ec3d1a
corenet_tcp_connect_pulseaudio_port(chrome_sandbox_t)
1ec3d1a
corenet_tcp_connect_http_port(chrome_sandbox_t)
1ec3d1a
corenet_tcp_connect_http_cache_port(chrome_sandbox_t)
1ec3d1a
corenet_tcp_connect_squid_port(chrome_sandbox_t)
1ec3d1a
corenet_tcp_sendrecv_generic_if(chrome_sandbox_t)
1ec3d1a
corenet_tcp_sendrecv_generic_node(chrome_sandbox_t)
1ec3d1a
corenet_tcp_connect_ipp_port(chrome_sandbox_t)
1ec3d1a
corenet_tcp_connect_speech_port(chrome_sandbox_t)
1ec3d1a
1ec3d1a
domain_dontaudit_read_all_domains_state(chrome_sandbox_t)
1ec3d1a
1ec3d1a
dev_read_urand(chrome_sandbox_t)
1ec3d1a
dev_read_sysfs(chrome_sandbox_t)
1ec3d1a
dev_rwx_zero(chrome_sandbox_t)
1ec3d1a
dev_dontaudit_getattr_all_chr_files(chrome_sandbox_t)
1ec3d1a
1ec3d1a
files_read_etc_files(chrome_sandbox_t)
1ec3d1a
files_read_usr_files(chrome_sandbox_t)
1ec3d1a
1ec3d1a
fs_dontaudit_getattr_all_fs(chrome_sandbox_t)
1ec3d1a
1ec3d1a
userdom_rw_inherited_user_tmpfs_files(chrome_sandbox_t)
1ec3d1a
userdom_execute_user_tmpfs_files(chrome_sandbox_t)
1ec3d1a
1ec3d1a
userdom_use_user_ptys(chrome_sandbox_t)
1ec3d1a
userdom_write_inherited_user_tmp_files(chrome_sandbox_t)
1ec3d1a
userdom_read_inherited_user_home_content_files(chrome_sandbox_t)
1ec3d1a
userdom_dontaudit_use_user_terminals(chrome_sandbox_t)
1ec3d1a
userdom_search_user_home_content(chrome_sandbox_t)
1ec3d1a
# This one we should figure a way to make it more secure
1ec3d1a
userdom_manage_home_certs(chrome_sandbox_t)
1ec3d1a
1ec3d1a
miscfiles_read_localization(chrome_sandbox_t)
1ec3d1a
miscfiles_read_fonts(chrome_sandbox_t)
1ec3d1a
1ec3d1a
sysnet_dns_name_resolve(chrome_sandbox_t)
1ec3d1a
1ec3d1a
optional_policy(`
1ec3d1a
	gnome_rw_inherited_config(chrome_sandbox_t)
1ec3d1a
	gnome_read_home_config(chrome_sandbox_t)
1ec3d1a
')
1ec3d1a
1ec3d1a
optional_policy(`
1ec3d1a
	xserver_use_user_fonts(chrome_sandbox_t)
1ec3d1a
	xserver_user_x_domain_template(chrome_sandbox, chrome_sandbox_t, chrome_sandbox_tmpfs_t)
1ec3d1a
')
1ec3d1a
1ec3d1a
tunable_policy(`use_nfs_home_dirs',`
1ec3d1a
	fs_search_nfs(chrome_sandbox_t)
1ec3d1a
	fs_exec_nfs_files(chrome_sandbox_t)
1ec3d1a
	fs_read_nfs_files(chrome_sandbox_t)
1ec3d1a
	fs_rw_inherited_nfs_files(chrome_sandbox_t)
1ec3d1a
	fs_read_nfs_symlinks(chrome_sandbox_t)
1ec3d1a
	fs_dontaudit_append_nfs_files(chrome_sandbox_t)
1ec3d1a
')
1ec3d1a
1ec3d1a
tunable_policy(`use_samba_home_dirs',`
1ec3d1a
	fs_search_cifs(chrome_sandbox_t)
1ec3d1a
	fs_exec_cifs_files(chrome_sandbox_t)
1ec3d1a
	fs_rw_inherited_cifs_files(chrome_sandbox_t)
1ec3d1a
	fs_read_cifs_files(chrome_sandbox_t)
1ec3d1a
	fs_read_cifs_symlinks(chrome_sandbox_t)
1ec3d1a
	fs_dontaudit_append_cifs_files(chrome_sandbox_t)
1ec3d1a
')
1ec3d1a
1ec3d1a
tunable_policy(`use_fusefs_home_dirs',`
1ec3d1a
    fs_search_fusefs(chrome_sandbox_t)
1ec3d1a
    fs_read_fusefs_files(chrome_sandbox_t)
1ec3d1a
    fs_exec_fusefs_files(chrome_sandbox_t)
1ec3d1a
	fs_read_fusefs_symlinks(chrome_sandbox_t)
1ec3d1a
')
1ec3d1a
1ec3d1a
optional_policy(`
1ec3d1a
	sandbox_use_ptys(chrome_sandbox_t)
1ec3d1a
')
1ec3d1a
1ec3d1a
1ec3d1a
########################################
1ec3d1a
#
1ec3d1a
# chrome_sandbox_nacl local policy
1ec3d1a
#
1ec3d1a
1ec3d1a
allow chrome_sandbox_nacl_t self:process { execmem setsched };
1ec3d1a
allow chrome_sandbox_nacl_t self:fifo_file manage_fifo_file_perms;
1ec3d1a
allow chrome_sandbox_nacl_t self:unix_stream_socket create_stream_socket_perms;
1ec3d1a
allow chrome_sandbox_nacl_t self:shm create_shm_perms;
1ec3d1a
allow chrome_sandbox_nacl_t self:unix_dgram_socket { create_socket_perms sendto };
1ec3d1a
allow chrome_sandbox_nacl_t chrome_sandbox_t:unix_stream_socket { getattr write read };
1ec3d1a
allow chrome_sandbox_t chrome_sandbox_nacl_t:unix_stream_socket { getattr write read };
1ec3d1a
1ec3d1a
allow chrome_sandbox_nacl_t chrome_sandbox_t:shm rw_shm_perms;
1ec3d1a
allow chrome_sandbox_nacl_t chrome_sandbox_tmpfs_t:file rw_inherited_file_perms;
1ec3d1a
allow chrome_sandbox_t chrome_sandbox_nacl_t:process { sigkill sigstop signull signal share };
1ec3d1a
1ec3d1a
manage_files_pattern(chrome_sandbox_nacl_t, chrome_sandbox_tmpfs_t, chrome_sandbox_tmpfs_t)
1ec3d1a
fs_tmpfs_filetrans(chrome_sandbox_nacl_t, chrome_sandbox_tmpfs_t, file)
1ec3d1a
1ec3d1a
domain_use_interactive_fds(chrome_sandbox_nacl_t)
1ec3d1a
1ec3d1a
dontaudit chrome_sandbox_nacl_t self:memprotect mmap_zero;
1ec3d1a
1ec3d1a
domtrans_pattern(chrome_sandbox_t, chrome_sandbox_nacl_exec_t, chrome_sandbox_nacl_t)
1ec3d1a
ps_process_pattern(chrome_sandbox_t, chrome_sandbox_nacl_t)
1ec3d1a
1ec3d1a
kernel_read_system_state(chrome_sandbox_nacl_t)
1ec3d1a
1ec3d1a
dev_read_urand(chrome_sandbox_nacl_t)
1ec3d1a
dev_read_sysfs(chrome_sandbox_nacl_t)
1ec3d1a
1ec3d1a
files_read_etc_files(chrome_sandbox_nacl_t)
1ec3d1a
1ec3d1a
miscfiles_read_localization(chrome_sandbox_nacl_t)
1ec3d1a
1ec3d1a
corecmd_sbin_entry_type(chrome_sandbox_nacl_t)
1ec3d1a
1ec3d1a
userdom_use_inherited_user_ptys(chrome_sandbox_nacl_t)
1ec3d1a
userdom_rw_inherited_user_tmpfs_files(chrome_sandbox_nacl_t)
1ec3d1a
userdom_execute_user_tmpfs_files(chrome_sandbox_nacl_t)
1ec3d1a
userdom_rw_inherited_user_tmp_files(chrome_sandbox_nacl_t)
1ec3d1a
userdom_dontaudit_read_user_home_content_files(chrome_sandbox_nacl_t)
1ec3d1a
1ec3d1a
optional_policy(`
1ec3d1a
	gnome_dontaudit_write_config_files(chrome_sandbox_nacl_t)
1ec3d1a
')
1ec3d1a