1###
2### A domain for android.process.media, which contains both
3### MediaProvider and DownloadProvider and associated services.
4###
5
6typeattribute mediaprovider coredomain;
7app_domain(mediaprovider)
8
9# DownloadProvider accesses the network.
10net_domain(mediaprovider)
11
12# DownloadProvider uses /cache.
13allow mediaprovider cache_file:dir create_dir_perms;
14allow mediaprovider cache_file:file create_file_perms;
15# /cache is a symlink to /data/cache on some devices. Allow reading the link.
16allow mediaprovider cache_file:lnk_file r_file_perms;
17# mediaprovider searches through /cache looking for orphans
18# Ignore denials to /cache/recovery and /cache/backup.
19dontaudit mediaprovider cache_private_backup_file:dir getattr;
20dontaudit mediaprovider cache_recovery_file:dir getattr;
21
22# Access external sdcards through /mnt/media_rw
23allow mediaprovider { mnt_media_rw_file }:dir search;
24
25allow mediaprovider app_api_service:service_manager find;
26allow mediaprovider audioserver_service:service_manager find;
27allow mediaprovider drmserver_service:service_manager find;
28allow mediaprovider mediaextractor_service:service_manager find;
29allow mediaprovider mediaserver_service:service_manager find;
30
31# Allow MediaProvider to read/write cached ringtones (opened by system).
32allow mediaprovider ringtone_file:file { getattr read write };
33
34# MtpServer uses /dev/mtp_usb
35allow mediaprovider mtp_device:chr_file rw_file_perms;
36
37# MtpServer uses /dev/usb-ffs/mtp
38allow mediaprovider functionfs:dir search;
39allow mediaprovider functionfs:file rw_file_perms;
40allowxperm mediaprovider functionfs:file ioctl FUNCTIONFS_ENDPOINT_DESC;
41
42# MtpServer sets sys.usb.ffs.mtp.ready
43set_prop(mediaprovider, ffs_prop)
44set_prop(mediaprovider, exported_ffs_prop)
45
46allow mediaprovider ashmem_device:chr_file { getattr read ioctl lock map append write };
47