|
Chris PeBenito |
494e98 |
## <module name="storage" layer="kernel">
|
|
Chris PeBenito |
b16c6b |
## <summary>Policy controlling access to storage devices</summary>
|
|
Chris PeBenito |
b16c6b |
|
|
Chris PeBenito |
494e98 |
########################################
|
|
Chris PeBenito |
c6ebef |
## <interface name="storage_getattr_fixed_disk">
|
|
Chris PeBenito |
b16c6b |
## <description>
|
|
Chris PeBenito |
b16c6b |
## Allow the caller to get the attributes of fixed disk
|
|
Chris PeBenito |
b16c6b |
## device nodes.
|
|
Chris PeBenito |
b16c6b |
## </description>
|
|
Chris PeBenito |
494e98 |
## <parameter name="domain">
|
|
Chris PeBenito |
b16c6b |
## The type of the process performing this action.
|
|
Chris PeBenito |
b16c6b |
## </parameter>
|
|
Chris PeBenito |
b16c6b |
## </interface>
|
|
Chris PeBenito |
b16c6b |
#
|
|
Chris PeBenito |
c6ebef |
define(`storage_getattr_fixed_disk',`
|
|
Chris PeBenito |
d35c62 |
gen_require(`
|
|
Chris PeBenito |
d35c62 |
type fixed_disk_device_t;
|
|
Chris PeBenito |
d35c62 |
class blk_file getattr;
|
|
Chris PeBenito |
d35c62 |
')
|
|
Chris PeBenito |
0c73cd |
|
|
Karl MacMillan |
f0c985 |
dev_list_all_dev_nodes($1)
|
|
Chris PeBenito |
0c73cd |
allow $1 fixed_disk_device_t:blk_file getattr;
|
|
Chris PeBenito |
b16c6b |
')
|
|
Chris PeBenito |
b16c6b |
|
|
Chris PeBenito |
494e98 |
########################################
|
|
Chris PeBenito |
c6ebef |
## <interface name="storage_dontaudit_getattr_fixed_disk">
|
|
Chris PeBenito |
b16c6b |
## <description>
|
|
Chris PeBenito |
b16c6b |
## Do not audit attempts made by the caller to get
|
|
Chris PeBenito |
b16c6b |
## the attributes of fixed disk device nodes.
|
|
Chris PeBenito |
b16c6b |
## </description>
|
|
Chris PeBenito |
494e98 |
## <parameter name="domain">
|
|
Chris PeBenito |
b16c6b |
## The type of the process to not audit.
|
|
Chris PeBenito |
b16c6b |
## </parameter>
|
|
Chris PeBenito |
b16c6b |
## </interface>
|
|
Chris PeBenito |
b16c6b |
#
|
|
Chris PeBenito |
c6ebef |
define(`storage_dontaudit_getattr_fixed_disk',`
|
|
Chris PeBenito |
d35c62 |
gen_require(`
|
|
Chris PeBenito |
d35c62 |
type fixed_disk_device_t;
|
|
Chris PeBenito |
d35c62 |
class blk_file getattr;
|
|
Chris PeBenito |
d35c62 |
')
|
|
Chris PeBenito |
0c73cd |
|
|
Chris PeBenito |
0c73cd |
dontaudit $1 fixed_disk_device_t:blk_file getattr;
|
|
Chris PeBenito |
b16c6b |
')
|
|
Chris PeBenito |
b16c6b |
|
|
Chris PeBenito |
494e98 |
########################################
|
|
Chris PeBenito |
c6ebef |
## <interface name="storage_setattr_fixed_disk">
|
|
Chris PeBenito |
b16c6b |
## <description>
|
|
Chris PeBenito |
b16c6b |
## Allow the caller to set the attributes of fixed disk
|
|
Chris PeBenito |
b16c6b |
## device nodes.
|
|
Chris PeBenito |
b16c6b |
## </description>
|
|
Chris PeBenito |
494e98 |
## <parameter name="domain">
|
|
Chris PeBenito |
b16c6b |
## The type of the process performing this action.
|
|
Chris PeBenito |
b16c6b |
## </parameter>
|
|
Chris PeBenito |
b16c6b |
## </interface>
|
|
Chris PeBenito |
b16c6b |
#
|
|
Chris PeBenito |
c6ebef |
define(`storage_setattr_fixed_disk',`
|
|
Chris PeBenito |
d35c62 |
gen_require(`
|
|
Chris PeBenito |
d35c62 |
type fixed_disk_device_t;
|
|
Chris PeBenito |
d35c62 |
class blk_file setattr;
|
|
Chris PeBenito |
d35c62 |
')
|
|
Chris PeBenito |
0c73cd |
|
|
Karl MacMillan |
f0c985 |
dev_list_all_dev_nodes($1)
|
|
Chris PeBenito |
0c73cd |
allow $1 fixed_disk_device_t:blk_file setattr;
|
|
Chris PeBenito |
b16c6b |
')
|
|
Chris PeBenito |
b16c6b |
|
|
Chris PeBenito |
d35c62 |
########################################
|
|
Chris PeBenito |
d35c62 |
## <interface name="storage_dontaudit_setattr_fixed_disk">
|
|
Chris PeBenito |
d35c62 |
## <description>
|
|
Chris PeBenito |
d35c62 |
## Do not audit attempts made by the caller to set
|
|
Chris PeBenito |
d35c62 |
## the attributes of fixed disk device nodes.
|
|
Chris PeBenito |
d35c62 |
## </description>
|
|
Chris PeBenito |
d35c62 |
## <parameter name="domain">
|
|
Chris PeBenito |
d35c62 |
## The type of the process to not audit.
|
|
Chris PeBenito |
d35c62 |
## </parameter>
|
|
Chris PeBenito |
d35c62 |
## </interface>
|
|
Chris PeBenito |
d35c62 |
#
|
|
Chris PeBenito |
d35c62 |
define(`storage_dontaudit_setattr_fixed_disk',`
|
|
Chris PeBenito |
d35c62 |
gen_require(`
|
|
Chris PeBenito |
d35c62 |
type fixed_disk_device_t;
|
|
Chris PeBenito |
d35c62 |
class blk_file getattr;
|
|
Chris PeBenito |
d35c62 |
')
|
|
Chris PeBenito |
0c73cd |
|
|
Chris PeBenito |
d35c62 |
dontaudit $1 fixed_disk_device_t:blk_file getattr;
|
|
Chris PeBenito |
b16c6b |
')
|
|
Chris PeBenito |
e181fe |
|
|
Chris PeBenito |
494e98 |
########################################
|
|
Chris PeBenito |
b16c6b |
## <interface name="storage_raw_read_fixed_disk">
|
|
Chris PeBenito |
b16c6b |
## <description>
|
|
Chris PeBenito |
b16c6b |
## Allow the caller to directly read from a fixed disk.
|
|
Chris PeBenito |
b16c6b |
## This is extremly dangerous as it can bypass the
|
|
Chris PeBenito |
b16c6b |
## SELinux protections for filesystem objects, and
|
|
Chris PeBenito |
b16c6b |
## should only be used by trusted domains.
|
|
Chris PeBenito |
b16c6b |
## </description>
|
|
Chris PeBenito |
494e98 |
## <parameter name="domain">
|
|
Chris PeBenito |
b16c6b |
## The type of the process performing this action.
|
|
Chris PeBenito |
b16c6b |
## </parameter>
|
|
Chris PeBenito |
b16c6b |
## </interface>
|
|
Chris PeBenito |
b4cd15 |
#
|
|
Chris PeBenito |
b4cd15 |
define(`storage_raw_read_fixed_disk',`
|
|
Chris PeBenito |
d35c62 |
gen_require(`
|
|
Chris PeBenito |
d35c62 |
attribute fixed_disk_raw_read;
|
|
Chris PeBenito |
d35c62 |
type fixed_disk_device_t;
|
|
Chris PeBenito |
d35c62 |
class blk_file r_file_perms;
|
|
Chris PeBenito |
d35c62 |
')
|
|
Chris PeBenito |
0c73cd |
|
|
Karl MacMillan |
f0c985 |
dev_list_all_dev_nodes($1)
|
|
Chris PeBenito |
0c73cd |
allow $1 fixed_disk_device_t:blk_file r_file_perms;
|
|
Chris PeBenito |
0c73cd |
typeattribute $1 fixed_disk_raw_read;
|
|
Chris PeBenito |
b4cd15 |
')
|
|
Chris PeBenito |
b4cd15 |
|
|
Chris PeBenito |
494e98 |
########################################
|
|
Chris PeBenito |
f5c42b |
## <interface name="storage_raw_write_fixed_disk">
|
|
Chris PeBenito |
b16c6b |
## <description>
|
|
Chris PeBenito |
b16c6b |
## Allow the caller to directly write to a fixed disk.
|
|
Chris PeBenito |
b16c6b |
## This is extremly dangerous as it can bypass the
|
|
Chris PeBenito |
b16c6b |
## SELinux protections for filesystem objects, and
|
|
Chris PeBenito |
b16c6b |
## should only be used by trusted domains.
|
|
Chris PeBenito |
b16c6b |
## </description>
|
|
Chris PeBenito |
494e98 |
## <parameter name="domain">
|
|
Chris PeBenito |
b16c6b |
## The type of the process performing this action.
|
|
Chris PeBenito |
b16c6b |
## </parameter>
|
|
Chris PeBenito |
b16c6b |
## </interface>
|
|
Chris PeBenito |
b4cd15 |
#
|
|
Chris PeBenito |
b4cd15 |
define(`storage_raw_write_fixed_disk',`
|
|
Chris PeBenito |
d35c62 |
gen_require(`
|
|
Chris PeBenito |
d35c62 |
attribute fixed_disk_raw_write;
|
|
Chris PeBenito |
d35c62 |
type fixed_disk_device_t;
|
|
Chris PeBenito |
d35c62 |
class blk_file { getattr write ioctl };
|
|
Chris PeBenito |
d35c62 |
')
|
|
Chris PeBenito |
0c73cd |
|
|
Karl MacMillan |
f0c985 |
dev_list_all_dev_nodes($1)
|
|
Chris PeBenito |
0c73cd |
allow $1 fixed_disk_device_t:blk_file { getattr write ioctl };
|
|
Chris PeBenito |
0c73cd |
typeattribute $1 fixed_disk_raw_write;
|
|
Chris PeBenito |
b4cd15 |
')
|
|
Chris PeBenito |
b4cd15 |
|
|
Chris PeBenito |
494e98 |
########################################
|
|
Chris PeBenito |
c6ebef |
## <interface name="storage_create_fixed_disk">
|
|
Chris PeBenito |
f5c42b |
## <description>
|
|
Chris PeBenito |
f5c42b |
## Create block devices in /dev with the fixed disk type.
|
|
Chris PeBenito |
f5c42b |
## </description>
|
|
Chris PeBenito |
f5c42b |
## <parameter name="domain">
|
|
Chris PeBenito |
f5c42b |
## The type of the process performing this action.
|
|
Chris PeBenito |
f5c42b |
## </parameter>
|
|
Chris PeBenito |
f5c42b |
## </interface>
|
|
Chris PeBenito |
f5c42b |
#
|
|
Chris PeBenito |
f5c42b |
define(`storage_create_fixed_disk_dev_entry',`
|
|
Chris PeBenito |
d35c62 |
gen_require(`
|
|
Chris PeBenito |
d35c62 |
attribute fixed_disk_raw_read, fixed_disk_raw_write;
|
|
Chris PeBenito |
d35c62 |
type fixed_disk_device_t;
|
|
Chris PeBenito |
d35c62 |
class blk_file create_file_perms;
|
|
Chris PeBenito |
d35c62 |
')
|
|
Chris PeBenito |
0c73cd |
|
|
Chris PeBenito |
0c73cd |
allow $1 fixed_disk_device_t:blk_file create_file_perms;
|
|
Karl MacMillan |
f0c985 |
dev_create_dev_node($1,fixed_disk_device_t,blk_file)
|
|
Chris PeBenito |
0c73cd |
typeattribute $1 fixed_disk_raw_read, fixed_disk_raw_write;
|
|
Chris PeBenito |
f5c42b |
')
|
|
Chris PeBenito |
f5c42b |
|
|
Chris PeBenito |
f5c42b |
########################################
|
|
Chris PeBenito |
f5c42b |
## <interface name="storage_manage_fixed_disk">
|
|
Chris PeBenito |
f5c42b |
## <description>
|
|
Chris PeBenito |
c6ebef |
## Create, read, write, and delete fixed disk device nodes.
|
|
Chris PeBenito |
f5c42b |
## </description>
|
|
Chris PeBenito |
f5c42b |
## <parameter name="domain">
|
|
Chris PeBenito |
f5c42b |
## The type of the process performing this action.
|
|
Chris PeBenito |
f5c42b |
## </parameter>
|
|
Chris PeBenito |
f5c42b |
## </interface>
|
|
Chris PeBenito |
f5c42b |
#
|
|
Chris PeBenito |
f5c42b |
define(`storage_manage_fixed_disk',`
|
|
Chris PeBenito |
d35c62 |
gen_require(`
|
|
Chris PeBenito |
d35c62 |
attribute fixed_disk_raw_read, fixed_disk_raw_write;
|
|
Chris PeBenito |
d35c62 |
type fixed_disk_device_t;
|
|
Chris PeBenito |
d35c62 |
class blk_file create_file_perms;
|
|
Chris PeBenito |
d35c62 |
')
|
|
Chris PeBenito |
0c73cd |
|
|
Karl MacMillan |
f0c985 |
dev_list_all_dev_nodes($1)
|
|
Chris PeBenito |
0c73cd |
allow $1 fixed_disk_device_t:blk_file create_file_perms;
|
|
Chris PeBenito |
0c73cd |
typeattribute $1 fixed_disk_raw_read, fixed_disk_raw_write;
|
|
Chris PeBenito |
f5c42b |
')
|
|
Chris PeBenito |
f5c42b |
|
|
Chris PeBenito |
f5c42b |
########################################
|
|
Chris PeBenito |
b16c6b |
## <interface name="storage_raw_read_lvm_volume">
|
|
Chris PeBenito |
b16c6b |
## <description>
|
|
Chris PeBenito |
b16c6b |
## Allow the caller to directly read from a logical volume.
|
|
Chris PeBenito |
b16c6b |
## This is extremly dangerous as it can bypass the
|
|
Chris PeBenito |
b16c6b |
## SELinux protections for filesystem objects, and
|
|
Chris PeBenito |
b16c6b |
## should only be used by trusted domains.
|
|
Chris PeBenito |
b16c6b |
## </description>
|
|
Chris PeBenito |
494e98 |
## <parameter name="domain">
|
|
Chris PeBenito |
b16c6b |
## The type of the process performing this action.
|
|
Chris PeBenito |
b16c6b |
## </parameter>
|
|
Chris PeBenito |
b16c6b |
## </interface>
|
|
Chris PeBenito |
8e0280 |
#
|
|
Chris PeBenito |
8e0280 |
define(`storage_raw_read_lvm_volume',`
|
|
Chris PeBenito |
d35c62 |
gen_require(`
|
|
Chris PeBenito |
d35c62 |
attribute fixed_disk_raw_read;
|
|
Chris PeBenito |
d35c62 |
type lvm_vg_t;
|
|
Chris PeBenito |
d35c62 |
class blk_file r_file_perms;
|
|
Chris PeBenito |
d35c62 |
')
|
|
Chris PeBenito |
0c73cd |
|
|
Karl MacMillan |
f0c985 |
dev_list_all_dev_nodes($1)
|
|
Chris PeBenito |
0c73cd |
allow $1 lvm_vg_t:blk_file r_file_perms;
|
|
Chris PeBenito |
0c73cd |
typeattribute $1 fixed_disk_raw_read;
|
|
Chris PeBenito |
8e0280 |
')
|
|
Chris PeBenito |
8e0280 |
|
|
Chris PeBenito |
494e98 |
########################################
|
|
Chris PeBenito |
b16c6b |
## <interface name="storage_raw_write_lvm_volume">
|
|
Chris PeBenito |
b16c6b |
## <description>
|
|
Chris PeBenito |
b16c6b |
## Allow the caller to directly read from a logical volume.
|
|
Chris PeBenito |
b16c6b |
## This is extremly dangerous as it can bypass the
|
|
Chris PeBenito |
b16c6b |
## SELinux protections for filesystem objects, and
|
|
Chris PeBenito |
b16c6b |
## should only be used by trusted domains.
|
|
Chris PeBenito |
b16c6b |
## </description>
|
|
Chris PeBenito |
494e98 |
## <parameter name="domain">
|
|
Chris PeBenito |
b16c6b |
## The type of the process performing this action.
|
|
Chris PeBenito |
b16c6b |
## </parameter>
|
|
Chris PeBenito |
b16c6b |
## </interface>
|
|
Chris PeBenito |
8e0280 |
#
|
|
Chris PeBenito |
8e0280 |
define(`storage_raw_write_lvm_volume',`
|
|
Chris PeBenito |
d35c62 |
gen_require(`
|
|
Chris PeBenito |
d35c62 |
attribute fixed_disk_raw_write;
|
|
Chris PeBenito |
d35c62 |
type lvm_vg_t;
|
|
Chris PeBenito |
d35c62 |
class blk_file { getattr write ioctl };
|
|
Chris PeBenito |
d35c62 |
')
|
|
Chris PeBenito |
0c73cd |
|
|
Karl MacMillan |
f0c985 |
dev_list_all_dev_nodes($1)
|
|
Chris PeBenito |
0c73cd |
allow $1 lvm_vg_t:blk_file { getattr write ioctl };
|
|
Chris PeBenito |
0c73cd |
typeattribute $1 fixed_disk_raw_write;
|
|
Chris PeBenito |
8e0280 |
')
|
|
Chris PeBenito |
8e0280 |
|
|
Chris PeBenito |
494e98 |
########################################
|
|
Chris PeBenito |
b16c6b |
## <interface name="storage_read_scsi_generic">
|
|
Chris PeBenito |
b16c6b |
## <description>
|
|
Chris PeBenito |
b16c6b |
## Allow the caller to directly read, in a
|
|
Chris PeBenito |
b16c6b |
## generic fashion, from any SCSI device.
|
|
Chris PeBenito |
b16c6b |
## This is extremly dangerous as it can bypass the
|
|
Chris PeBenito |
b16c6b |
## SELinux protections for filesystem objects, and
|
|
Chris PeBenito |
b16c6b |
## should only be used by trusted domains.
|
|
Chris PeBenito |
b16c6b |
## </description>
|
|
Chris PeBenito |
494e98 |
## <parameter name="domain">
|
|
Chris PeBenito |
b16c6b |
## The type of the process performing this action.
|
|
Chris PeBenito |
b16c6b |
## </parameter>
|
|
Chris PeBenito |
b16c6b |
## </interface>
|
|
Chris PeBenito |
b4cd15 |
#
|
|
Chris PeBenito |
b4cd15 |
define(`storage_read_scsi_generic',`
|
|
Chris PeBenito |
d35c62 |
gen_require(`
|
|
Chris PeBenito |
d35c62 |
attribute scsi_generic_read;
|
|
Chris PeBenito |
d35c62 |
type scsi_generic_device_t;
|
|
Chris PeBenito |
d35c62 |
class blk_file r_file_perms;
|
|
Chris PeBenito |
d35c62 |
')
|
|
Chris PeBenito |
0c73cd |
|
|
Karl MacMillan |
f0c985 |
dev_list_all_dev_nodes($1)
|
|
Chris PeBenito |
0c73cd |
allow $1 scsi_generic_device_t:blk_file r_file_perms;
|
|
Chris PeBenito |
0c73cd |
typeattribute $1 scsi_generic_read;
|
|
Chris PeBenito |
b4cd15 |
')
|
|
Chris PeBenito |
b4cd15 |
|
|
Chris PeBenito |
494e98 |
########################################
|
|
Chris PeBenito |
b16c6b |
## <interface name="storage_write_scsi_generic">
|
|
Chris PeBenito |
b16c6b |
## <description>
|
|
Chris PeBenito |
b16c6b |
## Allow the caller to directly write, in a
|
|
Chris PeBenito |
b16c6b |
## generic fashion, from any SCSI device.
|
|
Chris PeBenito |
b16c6b |
## This is extremly dangerous as it can bypass the
|
|
Chris PeBenito |
b16c6b |
## SELinux protections for filesystem objects, and
|
|
Chris PeBenito |
b16c6b |
## should only be used by trusted domains.
|
|
Chris PeBenito |
b16c6b |
## </description>
|
|
Chris PeBenito |
494e98 |
## <parameter name="domain">
|
|
Chris PeBenito |
b16c6b |
## The type of the process performing this action.
|
|
Chris PeBenito |
b16c6b |
## </parameter>
|
|
Chris PeBenito |
b16c6b |
## </interface>
|
|
Chris PeBenito |
b4cd15 |
#
|
|
Chris PeBenito |
b4cd15 |
define(`storage_write_scsi_generic',`
|
|
Chris PeBenito |
d35c62 |
gen_require(`
|
|
Chris PeBenito |
d35c62 |
attribute scsi_generic_write;
|
|
Chris PeBenito |
d35c62 |
type scsi_generic_device_t;
|
|
Chris PeBenito |
d35c62 |
class blk_file { getattr write ioctl };
|
|
Chris PeBenito |
d35c62 |
')
|
|
Chris PeBenito |
0c73cd |
|
|
Karl MacMillan |
f0c985 |
dev_list_all_dev_nodes($1)
|
|
Chris PeBenito |
0c73cd |
allow $1 scsi_generic_device_t:blk_file { getattr write ioctl };
|
|
Chris PeBenito |
0c73cd |
typeattribute $1 scsi_generic_write;
|
|
Chris PeBenito |
b4cd15 |
')
|
|
Chris PeBenito |
b4cd15 |
|
|
Chris PeBenito |
b4cd15 |
########################################
|
|
Chris PeBenito |
c6ebef |
## <interface name="storage_getattr_scsi_generic">
|
|
Chris PeBenito |
c6ebef |
## <description>
|
|
Chris PeBenito |
c6ebef |
## Get attributes of the device nodes
|
|
Chris PeBenito |
c6ebef |
## for the SCSI generic inerface.
|
|
Chris PeBenito |
c6ebef |
## </description>
|
|
Chris PeBenito |
c6ebef |
## <parameter name="domain">
|
|
Chris PeBenito |
c6ebef |
## The type of the process performing this action.
|
|
Chris PeBenito |
c6ebef |
## </parameter>
|
|
Chris PeBenito |
c6ebef |
## </interface>
|
|
Chris PeBenito |
b4cd15 |
#
|
|
Chris PeBenito |
c6ebef |
define(`storage_getattr_scsi_generic',`
|
|
Chris PeBenito |
d35c62 |
gen_require(`
|
|
Chris PeBenito |
d35c62 |
type scsi_generic_device_t;
|
|
Chris PeBenito |
d35c62 |
class blk_file getattr;
|
|
Chris PeBenito |
d35c62 |
')
|
|
Chris PeBenito |
0c73cd |
|
|
Karl MacMillan |
f0c985 |
dev_list_all_dev_nodes($1)
|
|
Chris PeBenito |
0c73cd |
allow $1 scsi_generic_device_t:blk_file getattr;
|
|
Chris PeBenito |
8a0da1 |
')
|
|
Chris PeBenito |
8a0da1 |
|
|
Chris PeBenito |
8a0da1 |
########################################
|
|
Chris PeBenito |
c6ebef |
## <interface name="storage_setattr_scsi_generic">
|
|
Chris PeBenito |
c6ebef |
## <description>
|
|
Chris PeBenito |
c6ebef |
## Set attributes of the device nodes
|
|
Chris PeBenito |
c6ebef |
## for the SCSI generic inerface.
|
|
Chris PeBenito |
c6ebef |
## </description>
|
|
Chris PeBenito |
c6ebef |
## <parameter name="domain">
|
|
Chris PeBenito |
c6ebef |
## The type of the process performing this action.
|
|
Chris PeBenito |
c6ebef |
## </parameter>
|
|
Chris PeBenito |
c6ebef |
## </interface>
|
|
Chris PeBenito |
8a0da1 |
#
|
|
Chris PeBenito |
8a0da1 |
define(`storage_set_scsi_generic_attributes',`
|
|
Chris PeBenito |
d35c62 |
gen_require(`
|
|
Chris PeBenito |
d35c62 |
type scsi_generic_device_t;
|
|
Chris PeBenito |
d35c62 |
class blk_file setattr;
|
|
Chris PeBenito |
d35c62 |
')
|
|
Chris PeBenito |
0c73cd |
|
|
Karl MacMillan |
f0c985 |
dev_list_all_dev_nodes($1)
|
|
Chris PeBenito |
0c73cd |
allow $1 scsi_generic_device_t:blk_file setattr;
|
|
Chris PeBenito |
8a0da1 |
')
|
|
Chris PeBenito |
8a0da1 |
|
|
Chris PeBenito |
494e98 |
########################################
|
|
Chris PeBenito |
c6ebef |
## <interface name="storage_getattr_removable_device">
|
|
Chris PeBenito |
b16c6b |
## <description>
|
|
Chris PeBenito |
b16c6b |
## Allow the caller to get the attributes of removable
|
|
Chris PeBenito |
b16c6b |
## devices device nodes.
|
|
Chris PeBenito |
b16c6b |
## </description>
|
|
Chris PeBenito |
494e98 |
## <parameter name="domain">
|
|
Chris PeBenito |
b16c6b |
## The type of the process performing this action.
|
|
Chris PeBenito |
b16c6b |
## </parameter>
|
|
Chris PeBenito |
b16c6b |
## </interface>
|
|
Chris PeBenito |
b4cd15 |
#
|
|
Chris PeBenito |
c6ebef |
define(`storage_getattr_removable_device',`
|
|
Chris PeBenito |
d35c62 |
gen_require(`
|
|
Chris PeBenito |
d35c62 |
type removable_device_t;
|
|
Chris PeBenito |
d35c62 |
class blk_file getattr;
|
|
Chris PeBenito |
d35c62 |
')
|
|
Chris PeBenito |
0c73cd |
|
|
Karl MacMillan |
f0c985 |
dev_list_all_dev_nodes($1)
|
|
Chris PeBenito |
0c73cd |
allow $1 removable_device_t:blk_file getattr;
|
|
Chris PeBenito |
b4cd15 |
')
|
|
Chris PeBenito |
b4cd15 |
|
|
Chris PeBenito |
494e98 |
########################################
|
|
Chris PeBenito |
c6ebef |
## <interface name="storage_dontaudit_getattr_removable_device">
|
|
Chris PeBenito |
b16c6b |
## <description>
|
|
Chris PeBenito |
b16c6b |
## Do not audit attempts made by the caller to get
|
|
Chris PeBenito |
b16c6b |
## the attributes of removable devices device nodes.
|
|
Chris PeBenito |
b16c6b |
## </description>
|
|
Chris PeBenito |
494e98 |
## <parameter name="domain">
|
|
Chris PeBenito |
b16c6b |
## The type of the process to not audit.
|
|
Chris PeBenito |
b16c6b |
## </parameter>
|
|
Chris PeBenito |
b16c6b |
## </interface>
|
|
Chris PeBenito |
b16c6b |
#
|
|
Chris PeBenito |
c6ebef |
define(`storage_dontaudit_getattr_removable_device',`
|
|
Chris PeBenito |
d35c62 |
gen_require(`
|
|
Chris PeBenito |
d35c62 |
type removable_device_t;
|
|
Chris PeBenito |
d35c62 |
class blk_file getattr;
|
|
Chris PeBenito |
d35c62 |
')
|
|
Chris PeBenito |
0c73cd |
|
|
Chris PeBenito |
0c73cd |
dontaudit $1 removable_device_t:blk_file getattr;
|
|
Chris PeBenito |
b16c6b |
')
|
|
Chris PeBenito |
b16c6b |
|
|
Chris PeBenito |
b4cd15 |
########################################
|
|
Chris PeBenito |
c6ebef |
## <interface name="storage_setattr_removable_device">
|
|
Chris PeBenito |
c6ebef |
## <description>
|
|
Chris PeBenito |
c6ebef |
## Allow the caller to set the attributes of removable
|
|
Chris PeBenito |
c6ebef |
## devices device nodes.
|
|
Chris PeBenito |
c6ebef |
## </description>
|
|
Chris PeBenito |
c6ebef |
## <parameter name="domain">
|
|
Chris PeBenito |
c6ebef |
## The type of the process performing this action.
|
|
Chris PeBenito |
c6ebef |
## </parameter>
|
|
Chris PeBenito |
c6ebef |
## </interface>
|
|
Chris PeBenito |
b4cd15 |
#
|
|
Chris PeBenito |
5a45e7 |
define(`storage_setattr_removable_device',`
|
|
Chris PeBenito |
d35c62 |
gen_require(`
|
|
Chris PeBenito |
d35c62 |
type removable_device_t;
|
|
Chris PeBenito |
d35c62 |
class blk_file setattr;
|
|
Chris PeBenito |
d35c62 |
')
|
|
Chris PeBenito |
0c73cd |
|
|
Karl MacMillan |
f0c985 |
dev_list_all_dev_nodes($1)
|
|
Chris PeBenito |
0c73cd |
allow $1 removable_device_t:blk_file setattr;
|
|
Chris PeBenito |
b4cd15 |
')
|
|
Chris PeBenito |
b4cd15 |
|
|
Chris PeBenito |
b4cd15 |
########################################
|
|
Chris PeBenito |
c6ebef |
## <interface name="storage_raw_read_removable_device">
|
|
Chris PeBenito |
c6ebef |
## <description>
|
|
Chris PeBenito |
c6ebef |
## Allow the caller to directly read from
|
|
Chris PeBenito |
c6ebef |
## a removable device.
|
|
Chris PeBenito |
c6ebef |
## This is extremly dangerous as it can bypass the
|
|
Chris PeBenito |
c6ebef |
## SELinux protections for filesystem objects, and
|
|
Chris PeBenito |
c6ebef |
## should only be used by trusted domains.
|
|
Chris PeBenito |
c6ebef |
## </description>
|
|
Chris PeBenito |
c6ebef |
## <parameter name="domain">
|
|
Chris PeBenito |
c6ebef |
## The type of the process performing this action.
|
|
Chris PeBenito |
c6ebef |
## </parameter>
|
|
Chris PeBenito |
c6ebef |
## </interface>
|
|
Chris PeBenito |
8a0da1 |
#
|
|
Chris PeBenito |
b16c6b |
define(`storage_raw_read_removable_device',`
|
|
Chris PeBenito |
d35c62 |
gen_require(`
|
|
Chris PeBenito |
d35c62 |
type removable_device_t;
|
|
Chris PeBenito |
d35c62 |
class blk_file r_file_perms;
|
|
Chris PeBenito |
d35c62 |
')
|
|
Chris PeBenito |
0c73cd |
|
|
Karl MacMillan |
f0c985 |
dev_list_all_dev_nodes($1)
|
|
Chris PeBenito |
0c73cd |
allow $1 removable_device_t:blk_file r_file_perms;
|
|
Chris PeBenito |
8a0da1 |
')
|
|
Chris PeBenito |
8a0da1 |
|
|
Chris PeBenito |
8a0da1 |
########################################
|
|
Chris PeBenito |
c6ebef |
## <interface name="storage_raw_write_removable_device">
|
|
Chris PeBenito |
c6ebef |
## <description>
|
|
Chris PeBenito |
c6ebef |
## Allow the caller to directly write to
|
|
Chris PeBenito |
c6ebef |
## a removable device.
|
|
Chris PeBenito |
c6ebef |
## This is extremly dangerous as it can bypass the
|
|
Chris PeBenito |
c6ebef |
## SELinux protections for filesystem objects, and
|
|
Chris PeBenito |
c6ebef |
## should only be used by trusted domains.
|
|
Chris PeBenito |
c6ebef |
## </description>
|
|
Chris PeBenito |
c6ebef |
## <parameter name="domain">
|
|
Chris PeBenito |
c6ebef |
## The type of the process performing this action.
|
|
Chris PeBenito |
c6ebef |
## </parameter>
|
|
Chris PeBenito |
c6ebef |
## </interface>
|
|
Chris PeBenito |
8a0da1 |
#
|
|
Chris PeBenito |
b16c6b |
define(`storage_raw_write_removable_device',`
|
|
Chris PeBenito |
d35c62 |
gen_require(`
|
|
Chris PeBenito |
d35c62 |
type removable_device_t;
|
|
Chris PeBenito |
d35c62 |
class blk_file { getattr write ioctl };
|
|
Chris PeBenito |
d35c62 |
')
|
|
Chris PeBenito |
0c73cd |
|
|
Karl MacMillan |
f0c985 |
dev_list_all_dev_nodes($1)
|
|
Chris PeBenito |
0c73cd |
allow $1 removable_device_t:blk_file { getattr write ioctl };
|
|
Chris PeBenito |
8a0da1 |
')
|
|
Chris PeBenito |
8a0da1 |
|
|
Chris PeBenito |
8a0da1 |
########################################
|
|
Chris PeBenito |
c6ebef |
## <interface name="storage_read_tape_device">
|
|
Chris PeBenito |
c6ebef |
## <description>
|
|
Chris PeBenito |
c6ebef |
## Allow the caller to directly read
|
|
Chris PeBenito |
c6ebef |
## a tape device.
|
|
Chris PeBenito |
c6ebef |
## </description>
|
|
Chris PeBenito |
c6ebef |
## <parameter name="domain">
|
|
Chris PeBenito |
c6ebef |
## The type of the process performing this action.
|
|
Chris PeBenito |
c6ebef |
## </parameter>
|
|
Chris PeBenito |
c6ebef |
## </interface>
|
|
Chris PeBenito |
b4cd15 |
#
|
|
Chris PeBenito |
b4cd15 |
define(`storage_read_tape_device',`
|
|
Chris PeBenito |
d35c62 |
gen_require(`
|
|
Chris PeBenito |
d35c62 |
type tape_device_t;
|
|
Chris PeBenito |
d35c62 |
class blk_file r_file_perms;
|
|
Chris PeBenito |
d35c62 |
')
|
|
Chris PeBenito |
0c73cd |
|
|
Karl MacMillan |
f0c985 |
dev_list_all_dev_nodes($1)
|
|
Chris PeBenito |
0c73cd |
allow $1 tape_device_t:blk_file r_file_perms;
|
|
Chris PeBenito |
b4cd15 |
')
|
|
Chris PeBenito |
b4cd15 |
|
|
Chris PeBenito |
b4cd15 |
########################################
|
|
Chris PeBenito |
c6ebef |
## <interface name="storage_write_tape_device">
|
|
Chris PeBenito |
c6ebef |
## <description>
|
|
Chris PeBenito |
c6ebef |
## Allow the caller to directly read
|
|
Chris PeBenito |
c6ebef |
## a tape device.
|
|
Chris PeBenito |
c6ebef |
## </description>
|
|
Chris PeBenito |
c6ebef |
## <parameter name="domain">
|
|
Chris PeBenito |
c6ebef |
## The type of the process performing this action.
|
|
Chris PeBenito |
c6ebef |
## </parameter>
|
|
Chris PeBenito |
c6ebef |
## </interface>
|
|
Chris PeBenito |
b4cd15 |
#
|
|
Chris PeBenito |
b4cd15 |
define(`storage_write_tape_device',`
|
|
Chris PeBenito |
d35c62 |
gen_require(`
|
|
Chris PeBenito |
d35c62 |
type tape_device_t;
|
|
Chris PeBenito |
d35c62 |
class blk_file { getattr write ioctl };
|
|
Chris PeBenito |
d35c62 |
')
|
|
Chris PeBenito |
0c73cd |
|
|
Karl MacMillan |
f0c985 |
dev_list_all_dev_nodes($1)
|
|
Chris PeBenito |
0c73cd |
allow $1 tape_device_t:blk_file { getattr write ioctl };
|
|
Chris PeBenito |
b4cd15 |
')
|
|
Chris PeBenito |
b4cd15 |
|
|
Chris PeBenito |
8a0da1 |
########################################
|
|
Chris PeBenito |
c6ebef |
## <interface name="storage_getattr_tape_device">
|
|
Chris PeBenito |
c6ebef |
## <description>
|
|
Chris PeBenito |
c6ebef |
## Allow the caller to get the attributes
|
|
Chris PeBenito |
c6ebef |
## of device nodes of tape devices.
|
|
Chris PeBenito |
c6ebef |
## </description>
|
|
Chris PeBenito |
c6ebef |
## <parameter name="domain">
|
|
Chris PeBenito |
c6ebef |
## The type of the process performing this action.
|
|
Chris PeBenito |
c6ebef |
## </parameter>
|
|
Chris PeBenito |
c6ebef |
## </interface>
|
|
Chris PeBenito |
8a0da1 |
#
|
|
Chris PeBenito |
c6ebef |
define(`storage_getattr_tape_device',`
|
|
Chris PeBenito |
d35c62 |
gen_require(`
|
|
Chris PeBenito |
d35c62 |
type tape_device_t;
|
|
Chris PeBenito |
d35c62 |
class blk_file getattr;
|
|
Chris PeBenito |
d35c62 |
')
|
|
Chris PeBenito |
0c73cd |
|
|
Karl MacMillan |
f0c985 |
dev_list_all_dev_nodes($1)
|
|
Chris PeBenito |
0c73cd |
allow $1 tape_device_t:blk_file getattr;
|
|
Chris PeBenito |
8a0da1 |
')
|
|
Chris PeBenito |
8a0da1 |
|
|
Chris PeBenito |
8a0da1 |
########################################
|
|
Chris PeBenito |
c6ebef |
## <interface name="storage_setattr_tape_device">
|
|
Chris PeBenito |
c6ebef |
## <description>
|
|
Chris PeBenito |
c6ebef |
## Allow the caller to set the attributes
|
|
Chris PeBenito |
c6ebef |
## of device nodes of tape devices.
|
|
Chris PeBenito |
c6ebef |
## </description>
|
|
Chris PeBenito |
c6ebef |
## <parameter name="domain">
|
|
Chris PeBenito |
c6ebef |
## The type of the process performing this action.
|
|
Chris PeBenito |
c6ebef |
## </parameter>
|
|
Chris PeBenito |
c6ebef |
## </interface>
|
|
Chris PeBenito |
8a0da1 |
#
|
|
Chris PeBenito |
c6ebef |
define(`storage_setattr_tape_device',`
|
|
Chris PeBenito |
d35c62 |
gen_require(`
|
|
Chris PeBenito |
d35c62 |
type tape_device_t;
|
|
Chris PeBenito |
d35c62 |
class blk_file setattr;
|
|
Chris PeBenito |
d35c62 |
')
|
|
Chris PeBenito |
0c73cd |
|
|
Karl MacMillan |
f0c985 |
dev_list_all_dev_nodes($1)
|
|
Chris PeBenito |
0c73cd |
allow $1 tape_device_t:blk_file setattr;
|
|
Chris PeBenito |
8a0da1 |
')
|
|
Chris PeBenito |
8a0da1 |
|
|
Chris PeBenito |
494e98 |
## </module>
|