init_daemon_domain(incidentd) type incidentd_exec, exec_type, file_type; binder_use(incidentd) wakelock_use(incidentd) # Allow setting process priority, protect from OOM killer, and dropping # privileges by switching UID / GID # TODO allow incidentd self:capability { setuid setgid sys_resource }; # Allow incidentd to scan through /proc/pid for all processes r_dir_file(incidentd, domain) allow incidentd self:capability { # Send signals to processes kill }; # Allow executing files on system, such as: # /system/bin/toolbox # /system/bin/logcat # /system/bin/dumpsys allow incidentd system_file:file execute_no_trans; allow incidentd toolbox_exec:file rx_file_perms; # Create and write into /data/misc/incidents allow incidentd incident_data_file:dir rw_dir_perms; allow incidentd incident_data_file:file create_file_perms; # Get process attributes # TODO allow incidentd domain:process getattr; # Signal java processes to dump their stack and get the results # TODO allow incidentd { appdomain ephemeral_app system_server }:process signal; # TODO allow incidentd anr_data_file:dir rw_dir_perms; # TODO allow incidentd anr_data_file:file create_file_perms; # Signal native processes to dump their stack. # This list comes from native_processes_to_dump in incidentd/utils.c allow incidentd { audioserver cameraserver drmserver inputflinger mediacodec mediadrmserver mediaextractor mediaserver sdcardd surfaceflinger }:process signal; # Allow incidentd to make binder calls to any binder service binder_call(incidentd, binderservicedomain) binder_call(incidentd, appdomain) # Reading /proc/PID/maps of other processes # TODO allow incidentd self:capability sys_ptrace; # Run a shell. allow incidentd shell_exec:file rx_file_perms; # logd access - work to be done is a PII safe log (possibly an event log?) # TODO read_logd(incidentd) # TODO control_logd(incidentd) # Allow incidentd to find these standard groups of services. # Others can be whitelisted individually. allow incidentd { system_server_service app_api_service system_api_service }:service_manager find; # Only incidentd can publish the binder service add_service(incidentd, incident_service) # Allow pipes from (and only from) incident allow incidentd incident:fd use; allow incidentd incident:fifo_file write; # Allow incident to call back to incident with status updates. binder_call(incidentd, incident) ### ### neverallow rules ### # only system_server, system_app and incident command can find the incident service neverallow { domain -system_server -system_app -incident -incidentd } incident_service:service_manager find; # only incidentd and the other root services in limited circumstances # can get to the files in /data/misc/incidents # # write, execute, append are forbidden almost everywhere neverallow { domain -incidentd -init -vold } incident_data_file:file { w_file_perms x_file_perms create rename setattr unlink append }; # read is also allowed by system_server, for when the file is handed to dropbox neverallow { domain -incidentd -init -vold -system_server } incident_data_file:file r_file_perms; # limited access to the directory itself neverallow { domain -incidentd -init -vold } incident_data_file:dir create_dir_perms;