Компонент PackageManager предоставляет API для управления KPA-пакетами в решениях, построенных на базе KasperskyOS.
API компонента PackageManager представляет собой надстройку над IPC, которая позволяет упростить процесс разработки программ. PackageManager является отдельной системной программой, доступ к которой осуществляется через IPC, но при этом разработчикам предоставляется клиентская библиотека, которая скрывает необходимость использования IPC-вызовов напрямую.
Программный интерфейс компонента PackageManager описан в статье "Компонент PackageManager".
Добавление компонента PackageManager в решение на базе KasperskyOS
Здесь и далее клиентом называется программа, использующая API компонента PackageManager для управления KPA-пакетами.
Типовой сценарий использования компонента PackageManager включает следующие шаги:
find_package (package_manager REQUIRED)
include_directories (${package_manager_INCLUDE})
add_subdirectory (package_manager)
create_package_manager_entity()
из CMake-библиотеки package_manager
.Чтобы собрать программу PackageManager, необходимо в корневой директории проекта создать директорию с именем package_manager
, а в ней создать файл CMakeLists.txt
, в котором содержится команда create_package_manager_entity()
.
CMake-команда create_package_manager_entity()
принимает следующие параметры:
Обязательный параметр ENTITY
, в котором указывается имя исполняемого файла для программы PackageManager.
Опциональные параметры:
DEPENDS
- дополнительные зависимости для сборки программы PackageManager.MAIN_CONN_NAME
- имя IPC-канала для соединения с процессом PackageManager. Должно совпадать со значением переменной mainConnection
при обращении к API PackageManager в коде клиента.ROOT_PATH
- путь к корневой директории для служебных файлов программы PackageManager. значение по умолчанию: "/ROOT"
.PKGS_DIR
- путь к директории c KPA-пакетами для установки.PKG_EXTENSION
- расширение для файла KPA-пакета.DB_PATH
- полное имя файла базы данных SQLite в образе решения на базе KasperskyOS, которая содержит данные об установленных KPA-пакетах.APPS_DIR
- путь к директории, в которую будут устанавливаться KPA-пакеты.VFS_CLIENT_LIB
- имя клиентской транспортной библиотеки для подключения программы PackageManager к программе VFS
.NK_MODULE_NAME
- путь установки заголовочных файлов компонента PackageManager в SDK относительно директории /opt/KasperskyOS-Community-Edition-<version>/sysroot-*-kos/include/
. Значение по умолчанию: kl/package_manager
.AUDIT_CONN_NAME
- имя IPC-канала для соединения с процессом AuditStorage
.WITHOUT_SIGN_MODE
- режим учета внешней подписи: true
- отсутствие внешней подписи не считается ошибкой, false
- отсутствие внешней подписи считается ошибкой. Значение по умолчанию: false
. MANIFEST_SCHEMA_BUILD_STORE
- путь к директории сборки образа решения на базе KasperskyOS со схемой манифеста.MANIFEST_SCHEMA_RUNTIME_PATH
- путь к директории запущенного решения на базе KasperskyOS со схемой манифеста.PATH_TO_ADDITIONAL_EXTENSIONS_SCHEMAS
- путь к директории с дополнительными схемами манифестов для объектов произвольного формата, заданных в значении ключа extentions
манифеста KPA-пакета.CUSTOM_LAYOUT
- полное имя файла формата JSON, который используется для переопределения путей установки компонентов KPA-пакета.include (package_manager/create_package_manager_entity)
create_package_manager_entity(
ENTITY PkgMgrEntity
NK_MODULE_NAME "package_manager"
MAIN_CONN_NAME "PkgMgrEntity"
ROOT_PATH "/"
PKGS_DIR "/packages"
PKG_EXTENSION "kpa"
DB_PATH "${DB_PATH}"
APPS_DIR "${APPS_PATH}"
MANIFEST_SCHEMA_BUILD_STORE "${CMAKE_BINARY_DIR}/rootdir/schema"
MANIFEST_SCHEMA_RUNTIME_PATH "/schema"
PATH_TO_ADDITIONAL_EXTENSIONS_SCHEMAS "${CMAKE_SOURCE_DIR}/resources/additional_extensions/"
CUSTOM_LAYOUT "/custom_layout_schema.json"
VFS_CLIENT_LIB vfs::client
AUDIT_CONN_NAME "audit_storage"
WITHOUT_SIGN_MODE TRUE)
CMakeLists.txt
для сборки клиента добавить следующую команду:target_link_libraries (<имя CMake-цели для сборки клиента> ${package_manager_CLIENT_LIBS})
package_manager.PkgMgrEntity
:VFS
.Sync
, VMM
, Thread
, HAL
, Handle
, FS
, Notice
, CM
и Profiler
(их описания находятся в директории sysroot-*-kos/include/kl/core
из состава SDK).sysroot-*-kos/include/kl/package_manager
из состава SDK).Для этого необходимо использовать заголовочный файл component/package_manager/kos_ipc/package_manager_proxy.h
. Подробнее см. "Компонент PackageManager".