Удаленная подготовка ключей (RKP) является частью AOSP, начиная с Android 12. В Android 14 представлен обновляемый модуль удаленной подготовки, который повышает отказоустойчивость функций за счет улучшения надежности API сервиса и сокращения времени на внесение в него каких-либо улучшений.
Мотивация
Упростите услугу RKP, упаковав все в APEX.
До Android 14 RKP был разделён на приложение RemoteProvisioner
и Keystore 2.0. Приложение RemoteProvisioner
отвечало за взаимодействие с бэкендом RKP, а Keystore 2.0 — за хранение ключей и взаимодействие с HAL. Такая архитектура была неудачной, поскольку ключи RKP существенно отличались от ключей Keystore с точки зрения прикреплённых метаданных. Кроме того, это требовало неудобных изменений в коде фреймворка Keystore, чтобы предупреждать RemoteProvisioner
о потенциальном дефиците ресурсов.
RKP как основной модуль призван улучшить эти моменты, аккуратно упаковав все в APEX.
Граница модуля
RKP Mainline APEX, com.android.rkpd
, содержит приложение Remote Key Provisioning Daemon (RKPD) и компонент сервера удаленной системы подготовки (создан с помощью Java).
Архитектура стека
На рисунке 1 показана архитектура стека RKP.
Рисунок 1. Архитектура стека RKP.
Внутренняя архитектура
На рисунке 2 показана внутренняя архитектура RKP.
Рисунок 2. Внутренняя архитектура RKP.
Дополнительная информация о внутренней архитектуре RKP:
Магистральная линия РКПД APEX —
com.android.rkpd
- Приложение RKPD (Java)
-
packages/modules/RemoteKeyProvisioning/app
-
- Фрагмент сервера системы РКПД (Java)
-
packages/modules/RemoteKeyProvisioning/system-server
-
- Приложение RKPD (Java)
Интерфейс/реализация HAL (Rust/C++)
-
IRemotelyProvisionedComponent
-
hardware/interfaces/security/keymint
-
-
Формат упаковки
Приложение и другие функции модуля упакованы в файл APEX com.android.rkpd
.
Зависимости
Модуль RKP по-прежнему зависит от существования реализаций IRemotelyProvisionedComponent
для предоставления ключей аттестации и запросов на сертификаты.
Стратегия тестирования
Версия AOSP приложения APEX содержит модульные тесты, которые могут запускать OEM-производители.