summaryrefslogtreecommitdiffstats
path: root/gpsd-devices.te
diff options
context:
space:
mode:
Diffstat (limited to 'gpsd-devices.te')
-rw-r--r--gpsd-devices.te70
1 files changed, 56 insertions, 14 deletions
diff --git a/gpsd-devices.te b/gpsd-devices.te
index 8238355..7a1309f 100644
--- a/gpsd-devices.te
+++ b/gpsd-devices.te
@@ -1,28 +1,70 @@
-
-policy_module(myapp,1.0.0)
+policy_module(gpsd_devices,0.0.1)
########################################
#
# Declarations
#
-type myapp_t;
-type myapp_exec_t;
-domain_type(myapp_t)
-domain_entry_file(myapp_t, myapp_exec_t)
+type gpsd_t;
+type gpsd_exec_t;
+application_domain(gpsd_t, gpsd_exec_t)
+init_daemon_domain(gpsd_t, gpsd_exec_t)
+
+type gpsd_initrc_exec_t;
+init_script_file(gpsd_initrc_exec_t)
-type myapp_log_t;
-logging_log_file(myapp_log_t)
+type gpsd_tmpfs_t;
+files_tmpfs_file(gpsd_tmpfs_t)
-type myapp_tmp_t;
-files_tmp_file(myapp_tmp_t)
+type gpsd_var_run_t;
+files_pid_file(gpsd_var_run_t)
########################################
#
-# Myapp local policy
+# gpsd local policy
#
-allow myapp_t myapp_log_t:file { read_file_perms append_file_perms };
+allow gpsd_t self:capability { setuid sys_nice setgid fowner };
+allow gpsd_t self:process setsched;
+allow gpsd_t self:shm create_shm_perms;
+allow gpsd_t self:unix_dgram_socket { create_socket_perms sendto };
+allow gpsd_t self:tcp_socket create_stream_socket_perms;
+
+manage_dirs_pattern(gpsd_t, gpsd_tmpfs_t, gpsd_tmpfs_t)
+manage_files_pattern(gpsd_t, gpsd_tmpfs_t, gpsd_tmpfs_t)
+fs_tmpfs_filetrans(gpsd_t, gpsd_tmpfs_t, { dir file })
+
+manage_files_pattern(gpsd_t, gpsd_var_run_t, gpsd_var_run_t)
+manage_sock_files_pattern(gpsd_t, gpsd_var_run_t, gpsd_var_run_t)
+files_pid_filetrans(gpsd_t, gpsd_var_run_t, { file sock_file })
+
+corenet_all_recvfrom_unlabeled(gpsd_t)
+corenet_all_recvfrom_netlabel(gpsd_t)
+corenet_tcp_sendrecv_generic_if(gpsd_t)
+corenet_tcp_sendrecv_generic_node(gpsd_t)
+corenet_tcp_sendrecv_all_ports(gpsd_t)
+corenet_tcp_bind_all_nodes(gpsd_t)
+corenet_tcp_bind_gpsd_port(gpsd_t)
+
+term_use_unallocated_ttys(gpsd_t)
+term_setattr_unallocated_ttys(gpsd_t)
+
+auth_use_nsswitch(gpsd_t)
+
+logging_send_syslog_msg(gpsd_t)
+
+miscfiles_read_localization(gpsd_t)
+
+optional_policy(`
+ ntpd_rw_shm(gpsd_t)
+ ntpd_rw_tmpfs_files(gpsd_t)
+')
+
+optional_policy(`
+ dbus_system_bus_client(gpsd_t)
+')
-allow myapp_t myapp_tmp_t:file manage_file_perms;
-files_tmp_filetrans(myapp_t,myapp_tmp_t,file)
+gps_device_getattr_gps_dev(gpsd_t)
+gps_device_setattr_gps_dev(gpsd_t)
+gps_device_read_gps_dev(gpsd_t)
+gps_device_rw_gps_dev(gpsd_t)