Refactor ALLOW_NO_SIGNATURE compile flag
[src/app-framework-main.git] / CMakeLists.txt
index 5796837..191725a 100644 (file)
@@ -1,5 +1,5 @@
 ###########################################################################
-# Copyright 2015, 2016, 2017 IoT.bzh
+# Copyright (C) 2015-2020 IoT.bzh
 #
 # author: José Bollo <jose.bollo@iot.bzh>
 #
 # limitations under the License.
 ###########################################################################
 
-project(afm-main C)
+cmake_minimum_required(VERSION 3.4.3)
 
-cmake_minimum_required(VERSION 2.8)
+project(afm-main C)
 
 include(GNUInstallDirs)
+include(CTest)
 
 set(PROJECT_NAME "AFM Main")
 set(PROJECT_PRETTY_NAME "Application Framework Main")
 set(PROJECT_DESCRIPTION "Secured Application framework for Automotive Grade Linux")
-set(PROJECT_VERSION "1.0")
+set(AGLVERSION "8.0.0" CACHE STRING "Version of AGL")
+set(PROJECT_VERSION ${AGLVERSION} CACHE STRING "Version of the project can override AGLVERSION")
+set(PROJECT_URL "https://gerrit.automotivelinux.org/gerrit/gitweb?p=src/app-framework-main.git;a=summary")
+
+option(DISTINCT_VERSIONS  "Should the version of application be distinguished" OFF)
+option(USE_LIBZIP         "Should try to use libzip?" ON)
+option(USE_SIMULATION     "If set simulates security manager and smack" OFF)
+option(USE_SDK            "If set, avoids installating system runtime files" OFF)
+option(ALLOW_NO_SIGNATURE "If set, widgets without signature are accepted" OFF)
 
-set(USE_LIBZIP     ON  CACHE BOOL "should try to use libzip?")
-set(USE_SIMULATION OFF CACHE BOOL "if set simulates security manager and smack")
-set(USE_SDK        OFF CACHE BOOL "if set, avoids installating system runtime files")
+option(SIMULATE_SECMGR    "If set, the security manager is simulated" OFF)
+option(SIMULATE_SMACK     "If set, the smack environment is simulated"  OFF)
 
-set(SIMULATE_SECMGR OFF CACHE BOOL "if set, the security manager is simulated")
-set(SIMULATE_SMACK  OFF CACHE BOOL "if set, the smack environment is simulated")
+option(LEGACY_USER_DAEMON "compile and install the legacy afm-user-daemon" OFF)
 
 set(afm_name                "afm" CACHE STRING "Name for application framework user")
 set(afm_confdir             "${CMAKE_INSTALL_FULL_SYSCONFDIR}/${afm_name}" CACHE STRING "Directory for configuration files")
 set(afm_datadir             "${CMAKE_INSTALL_FULL_DATADIR}/${afm_name}" CACHE STRING "Root directory for installions")
+set(afm_libexecdir          "${CMAKE_INSTALL_FULL_LIBEXECDIR}/${afm_name}" CACHE STRING "Directory for installing internal binaries")
 set(afm_appdir              "${afm_datadir}/applications" CACHE STRING "Directory for installing applications")
 set(afm_icondir             "${afm_datadir}/icons" CACHE STRING "Directory for installing icons")
 set(afm_prefix              "urn:AGL:" CACHE STRING "Prefix for uniform resource name")
-set(afm_prefix_binding      "${afm_prefix}binding:" CACHE STRING "URN for bindings")
 set(afm_user_appdir         "app-data" CACHE STRING "User subdirectory for applications")
 set(afm_user_appdir_label   "User::App-Shared" CACHE STRING "Smack label of the user subdirectory for applications")
+set(systemd_units_root      "${CMAKE_INSTALL_FULL_LIBDIR}/systemd" CACHE STRING "Place where unit files are to be set")
 set(wgtpkg_trusted_cert_dir "${afm_confdir}/certs" CACHE STRING "Path to internal certificates")
+set(afm_platform_rundir     "/run/platform" CACHE STRING "Path to location of platform runtime sockets")
+set(afm_users_rundir        "/run/user" CACHE STRING "Path to location of users runtime sockets")
+set(afm_scope_platform_dir  "/var/scope-platform" CACHE STRING "Path to home of scope-platform apps")
 
 if(USE_SIMULATION)
     set(SIMULATE_SECMGR ON)
@@ -53,14 +64,24 @@ endif(USE_SIMULATION)
 add_definitions(
        -DFWK_CONFIG_DIR="${afm_confdir}"
        -DFWK_PREFIX="${afm_prefix}"
-       -DFWK_PREFIX_BINDING="${afm_prefix_binding}"
        -DFWK_ICON_DIR="${afm_icondir}"
        -DFWK_APP_DIR="${afm_appdir}"
        -DFWK_USER_APP_DIR="${afm_user_appdir}"
        -DWGTPKG_TRUSTED_CERT_DIR="${wgtpkg_trusted_cert_dir}"
        -DFWK_LAUNCH_CONF="${afm_confdir}/afm-launch.conf"
+       -DFWK_UNIT_CONF="${afm_confdir}/afm-unit.conf"
        -DFWK_USER_APP_DIR_LABEL="${afm_user_appdir_label}"
+       -DSYSTEMD_UNITS_ROOT="${systemd_units_root}"
+       -DAFM_VERSION="${PROJECT_VERSION}"
 )
+if(ALLOW_NO_SIGNATURE)
+       add_definitions(-DALLOW_NO_SIGNATURE=1)
+endif(ALLOW_NO_SIGNATURE)
+if(DISTINCT_VERSIONS)
+       add_definitions(-DDISTINCT_VERSIONS=1)
+else(DISTINCT_VERSIONS)
+       add_definitions(-DDISTINCT_VERSIONS=0)
+endif(DISTINCT_VERSIONS)
 
 add_subdirectory(src)
 add_subdirectory(conf)