Daftar izin tanda tangan yang diizinkan

Aplikasi yang ditandatangani platform adalah aplikasi yang berbagi sertifikat penandatanganan yang sama (atau kompatibel) dengan paket platform (android). Aplikasi yang ditandatangani platform dapat berupa aplikasi sistem (terletak di partisi gambar sistem), atau aplikasi nonsistem. Izin tanda tangan platform adalah izin yang ditentukan oleh paket platform yang juga memiliki tingkat perlindungan signature. Build yang dapat di-debug adalah build yang android.os.Build.isDebuggable() menampilkan true, seperti build userdebug atau eng.

Secara historis, produsen perangkat hanya memiliki sedikit kontrol atas izin signature platform yang dapat diberikan ke aplikasi nonsistem yang ditandatangani platform. Mulai Android 15, produsen dapat secara eksplisit memberikan izin tanda tangan platform dalam file XML konfigurasi sistem di direktori /etc/permissions. Jika aplikasi nonsistem yang ditandatangani platform tidak ditambahkan ke daftar yang diizinkan untuk izin tanda tangan platform, izin tersebut akan bertindak seolah-olah aplikasi tidak ditandatangani platform pada build yang tidak dapat di-debug.

Menambahkan daftar yang diizinkan

Anda dapat mencantumkan daftar izin yang diizinkan untuk aplikasi dalam satu file XML atau dalam beberapa file XML yang berada di direktori frameworks/base/etc/permissions:

  • /etc/permissions/signature-permissions-OEM_NAME.xml
  • /etc/permissions/signature-permissions-DEVICE_NAME.xml

Tidak ada aturan ketat yang berlaku pada cara pengaturan konten. Implementer perangkat dapat menentukan struktur konten selama aplikasi yang sesuai dan izinnya ditambahkan ke daftar yang diizinkan.

Menyesuaikan daftar yang diizinkan

AOSP menyertakan implementasi daftar yang diizinkan yang dapat Anda sesuaikan sesuai kebutuhan, serupa dengan daftar izin dengan hak istimewa yang diizinkan. Contoh:

<!--
  ~ This XML file declares which platform signature permissions to grant to
  ~ platform signed nonsystem apps.
  -->

<permissions>
    <signature-permissions package="com.android.example">
        <permission name="android.permission.READ_DEVICE_CONFIG"/>
        ...
    </signature-permissions>
    ...
</permissions>

Menemukan izin yang tidak ada

Untuk menemukan izin yang tidak ada, instal aplikasi yang ditandatangani platform dan periksa log perangkat untuk menemukan format pesan peringatan berikut:

Signature permission {PERMISSION_NAME} for package {PACKAGE_NAME} ({PACKAGE_PATH}) not in signature permission allowlist

Sistem masih dapat memberikan izin pada build yang dapat di-debug, tetapi tidak pada build yang tidak dapat di-debug seperti build user.