0f650e0dc5
Signed-off-by: Kenton Groombridge <me@concord.sh>
329 lines
7.1 KiB
Plaintext
329 lines
7.1 KiB
Plaintext
## <summary>Java virtual machine</summary>
|
|
|
|
########################################
|
|
## <summary>
|
|
## Role access for java.
|
|
## </summary>
|
|
## <param name="role_prefix">
|
|
## <summary>
|
|
## The prefix of the user role (e.g., user
|
|
## is the prefix for user_r).
|
|
## </summary>
|
|
## </param>
|
|
## <param name="user_domain">
|
|
## <summary>
|
|
## User domain for the role.
|
|
## </summary>
|
|
## </param>
|
|
## <param name="user_exec_domain">
|
|
## <summary>
|
|
## User exec domain for execute and transition access.
|
|
## </summary>
|
|
## </param>
|
|
## <param name="role">
|
|
## <summary>
|
|
## Role allowed access
|
|
## </summary>
|
|
## </param>
|
|
#
|
|
template(`java_role',`
|
|
gen_require(`
|
|
attribute_role java_roles;
|
|
type java_t, java_exec_t, java_tmp_t;
|
|
type java_tmpfs_t;
|
|
')
|
|
|
|
########################################
|
|
#
|
|
# Declarations
|
|
#
|
|
|
|
roleattribute $4 java_roles;
|
|
|
|
########################################
|
|
#
|
|
# Policy
|
|
#
|
|
|
|
domtrans_pattern($3, java_exec_t, java_t)
|
|
|
|
allow $3 java_t:process { noatsecure siginh rlimitinh ptrace signal_perms };
|
|
ps_process_pattern($3, java_t)
|
|
|
|
allow $2 java_tmp_t:dir { manage_dir_perms relabel_dir_perms };
|
|
allow $2 { java_tmp_t java_tmpfs_t }:file { manage_file_perms relabel_file_perms };
|
|
allow $2 java_tmpfs_t:fifo_file { manage_fifo_file_perms relabel_fifo_file_perms };
|
|
allow $2 java_tmpfs_t:lnk_file { manage_lnk_file_perms relabel_lnk_file_perms };
|
|
allow $2 java_tmpfs_t:sock_file { manage_sock_file_perms relabel_sock_file_perms };
|
|
|
|
allow java_t $3:process signull;
|
|
allow java_t $3:unix_stream_socket connectto;
|
|
allow java_t $3:unix_stream_socket { read write };
|
|
allow java_t $3:tcp_socket { read write };
|
|
|
|
optional_policy(`
|
|
systemd_user_app_status($1, java_t)
|
|
')
|
|
')
|
|
|
|
#######################################
|
|
## <summary>
|
|
## The role template for the java module.
|
|
## </summary>
|
|
## <desc>
|
|
## <p>
|
|
## This template creates a derived domains which are used
|
|
## for java applications.
|
|
## </p>
|
|
## </desc>
|
|
## <param name="role_prefix">
|
|
## <summary>
|
|
## The prefix of the user role (e.g., user
|
|
## is the prefix for user_r).
|
|
## </summary>
|
|
## </param>
|
|
## <param name="user_domain">
|
|
## <summary>
|
|
## User domain for the role.
|
|
## </summary>
|
|
## </param>
|
|
## <param name="user_exec_domain">
|
|
## <summary>
|
|
## User exec domain for execute and transition access.
|
|
## </summary>
|
|
## </param>
|
|
## <param name="role">
|
|
## <summary>
|
|
## Role allowed access
|
|
## </summary>
|
|
## </param>
|
|
#
|
|
template(`java_role_template',`
|
|
gen_require(`
|
|
attribute java_domain;
|
|
type java_exec_t, java_tmp_t, java_tmpfs_t;
|
|
type java_home_t;
|
|
')
|
|
|
|
########################################
|
|
#
|
|
# Declarations
|
|
#
|
|
|
|
type $1_java_t, java_domain;
|
|
userdom_user_application_domain($1_java_t, java_exec_t)
|
|
|
|
role $2 types $1_java_t;
|
|
|
|
########################################
|
|
#
|
|
# Policy
|
|
#
|
|
|
|
domtrans_pattern($3, java_exec_t, $1_java_t)
|
|
|
|
allow $3 $1_java_t:process { ptrace noatsecure siginh rlimitinh signal_perms };
|
|
ps_process_pattern($3, $1_java_t)
|
|
|
|
allow $3 { java_home_t java_tmp_t }:dir { manage_dir_perms relabel_dir_perms };
|
|
allow $3 { java_tmp_t java_tmpfs_t java_home_t }:file { manage_file_perms relabel_file_perms };
|
|
allow $3 java_tmpfs_t:fifo_file { manage_fifo_file_perms relabel_fifo_file_perms };
|
|
allow $3 java_tmpfs_t:lnk_file { manage_lnk_file_perms relabel_lnk_file_perms };
|
|
allow $3 java_tmpfs_t:sock_file { manage_sock_file_perms relabel_sock_file_perms };
|
|
userdom_user_home_dir_filetrans($3, java_home_t, dir, ".java")
|
|
|
|
allow $1_java_t $3:process signull;
|
|
allow $1_java_t $3:unix_stream_socket connectto;
|
|
allow $1_java_t $3:unix_stream_socket { read write };
|
|
allow $1_java_t $3:tcp_socket { read write };
|
|
|
|
corecmd_bin_domtrans($1_java_t, $3)
|
|
|
|
auth_use_nsswitch($1_java_t)
|
|
|
|
optional_policy(`
|
|
xserver_role($1, $1_java_t, $3, $4)
|
|
')
|
|
')
|
|
|
|
########################################
|
|
## <summary>
|
|
## Execute the java program in the java domain.
|
|
## </summary>
|
|
## <param name="domain">
|
|
## <summary>
|
|
## Domain allowed to transition.
|
|
## </summary>
|
|
## </param>
|
|
#
|
|
interface(`java_domtrans',`
|
|
gen_require(`
|
|
type java_t, java_exec_t;
|
|
')
|
|
|
|
corecmd_search_bin($1)
|
|
domtrans_pattern($1, java_exec_t, java_t)
|
|
')
|
|
|
|
########################################
|
|
## <summary>
|
|
## Execute java in the java domain, and
|
|
## allow the specified role the java domain.
|
|
## </summary>
|
|
## <param name="domain">
|
|
## <summary>
|
|
## Domain allowed to transition.
|
|
## </summary>
|
|
## </param>
|
|
## <param name="role">
|
|
## <summary>
|
|
## Role allowed access.
|
|
## </summary>
|
|
## </param>
|
|
#
|
|
interface(`java_run',`
|
|
gen_require(`
|
|
attribute_role java_roles;
|
|
')
|
|
|
|
java_domtrans($1)
|
|
roleattribute $2 java_roles;
|
|
')
|
|
|
|
########################################
|
|
## <summary>
|
|
## Execute the java program in the
|
|
## unconfined java domain.
|
|
## </summary>
|
|
## <param name="domain">
|
|
## <summary>
|
|
## Domain allowed to transition.
|
|
## </summary>
|
|
## </param>
|
|
#
|
|
interface(`java_domtrans_unconfined',`
|
|
gen_require(`
|
|
type unconfined_java_t, java_exec_t;
|
|
')
|
|
|
|
corecmd_search_bin($1)
|
|
domtrans_pattern($1, java_exec_t, unconfined_java_t)
|
|
')
|
|
|
|
########################################
|
|
## <summary>
|
|
## Execute the java program in the
|
|
## unconfined java domain and allow the
|
|
## specified role the java domain.
|
|
## </summary>
|
|
## <param name="domain">
|
|
## <summary>
|
|
## Domain allowed to transition.
|
|
## </summary>
|
|
## </param>
|
|
## <param name="role">
|
|
## <summary>
|
|
## Role allowed access.
|
|
## </summary>
|
|
## </param>
|
|
#
|
|
interface(`java_run_unconfined',`
|
|
gen_require(`
|
|
attribute_role unconfined_java_roles;
|
|
')
|
|
|
|
java_domtrans_unconfined($1)
|
|
roleattribute $2 unconfined_java_roles;
|
|
')
|
|
|
|
########################################
|
|
## <summary>
|
|
## Execute the java program in
|
|
## the callers domain.
|
|
## </summary>
|
|
## <param name="domain">
|
|
## <summary>
|
|
## Domain allowed access.
|
|
## </summary>
|
|
## </param>
|
|
#
|
|
interface(`java_exec',`
|
|
gen_require(`
|
|
type java_exec_t;
|
|
')
|
|
|
|
corecmd_search_bin($1)
|
|
can_exec($1, java_exec_t)
|
|
')
|
|
|
|
########################################
|
|
## <summary>
|
|
## Create, read, write, and delete
|
|
## generic java home content.
|
|
## </summary>
|
|
## <param name="domain">
|
|
## <summary>
|
|
## Domain allowed access.
|
|
## </summary>
|
|
## </param>
|
|
#
|
|
interface(`java_manage_generic_home_content',`
|
|
gen_require(`
|
|
type java_home_t;
|
|
')
|
|
|
|
userdom_search_user_home_dirs($1)
|
|
allow $1 java_home_t:dir manage_dir_perms;
|
|
allow $1 java_home_t:file manage_file_perms;
|
|
')
|
|
|
|
######################################
|
|
## <summary>
|
|
## Create, read, write, and delete
|
|
## temporary java content.
|
|
## </summary>
|
|
## <param name="domain">
|
|
## <summary>
|
|
## Domain allowed access.
|
|
## </summary>
|
|
## </param>
|
|
#
|
|
interface(`java_manage_java_tmp',`
|
|
gen_require(`
|
|
type java_tmp_t;
|
|
')
|
|
|
|
allow $1 java_tmp_t:dir manage_dir_perms;
|
|
allow $1 java_tmp_t:file manage_file_perms;
|
|
')
|
|
|
|
########################################
|
|
## <summary>
|
|
## Create specified objects in user home
|
|
## directories with the generic java
|
|
## home type.
|
|
## </summary>
|
|
## <param name="domain">
|
|
## <summary>
|
|
## Domain allowed access.
|
|
## </summary>
|
|
## </param>
|
|
## <param name="object_class">
|
|
## <summary>
|
|
## Class of the object being created.
|
|
## </summary>
|
|
## </param>
|
|
## <param name="name" optional="true">
|
|
## <summary>
|
|
## The name of the object being created.
|
|
## </summary>
|
|
## </param>
|
|
#
|
|
interface(`java_home_filetrans_java_home',`
|
|
gen_require(`
|
|
type java_home_t;
|
|
')
|
|
|
|
userdom_user_home_dir_filetrans($1, java_home_t, $2, $3)
|
|
')
|