selinux-policy/policy/modules/apps/java.if
Chris PeBenito b2648249d9 Fix unconfined_r use of unconfined_java_t.
The unconfined role is running java in the unconfined_java_t.  The current
policy only has a domtrans interface, so the unconfined_java_t domain is not
added to unconfined_r.  Add a run interface and change the unconfined module
to use this new interface.
2009-08-17 13:19:26 -04:00

95 lines
1.9 KiB
Plaintext

## <summary>Java virtual machine</summary>
########################################
## <summary>
## Role access for java
## </summary>
## <param name="role">
## <summary>
## Role allowed access
## </summary>
## </param>
## <param name="domain">
## <summary>
## User domain for the role
## </summary>
## </param>
#
interface(`java_role',`
gen_require(`
type java_t, java_exec_t;
')
role $1 types java_t;
# The user role is authorized for this domain.
domtrans_pattern($2, java_exec_t, java_t)
allow java_t $2:process signull;
# Unrestricted inheritance from the caller.
allow $2 java_t:process { noatsecure siginh rlimitinh };
allow java_t $2:unix_stream_socket connectto;
allow java_t $2:unix_stream_socket { read write };
')
########################################
## <summary>
## Run java in javaplugin domain.
## </summary>
## <param name="domain">
## <summary>
## Domain allowed access.
## </summary>
## </param>
#
template(`java_domtrans',`
gen_require(`
type java_t, java_exec_t;
')
domtrans_pattern($1, java_exec_t, java_t)
')
########################################
## <summary>
## Execute the java program in the unconfined java domain.
## </summary>
## <param name="domain">
## <summary>
## Domain allowed access.
## </summary>
## </param>
#
interface(`java_domtrans_unconfined',`
gen_require(`
type unconfined_java_t, java_exec_t;
')
domtrans_pattern($1, java_exec_t, unconfined_java_t)
corecmd_search_bin($1)
')
########################################
## <summary>
## Execute the java program in the unconfined java domain.
## </summary>
## <param name="domain">
## <summary>
## Domain allowed access.
## </summary>
## </param>
## <param name="role">
## <summary>
## Role allowed access.
## </summary>
## </param>
#
interface(`java_run_unconfined',`
gen_require(`
type unconfined_java_t;
')
java_domtrans_unconfined($1)
role $2 types unconfined_java_t;
')