Rename source files and improve readability
[src/app-framework-main.git] / src / CMakeLists.txt
index 809d586..3a94d0d 100644 (file)
@@ -1,5 +1,5 @@
 ###########################################################################
-# Copyright 2015 IoT.bzh
+# Copyright (C) 2015-2020 IoT.bzh
 #
 # author: José Bollo <jose.bollo@iot.bzh>
 #
 # limitations under the License.
 ###########################################################################
 
-cmake_minimum_required(VERSION 2.8)
+cmake_minimum_required(VERSION 3.4.3)
 
-include(FindPkgConfig)
+###########################################################################
 
-pkg_check_modules(EXTRAS REQUIRED
-       libxml-2.0
-       openssl
-       xmlsec1 xmlsec1-openssl
-       json-c
-       dbus-1
-       )
+link_libraries(-Wl,--as-needed -Wl,--gc-sections)
+
+add_compile_options(-Wall -Wextra -Wconversion)
+add_compile_options(-Wno-unused-parameter) # frankly not using a parameter does it care?
+add_compile_options(-Werror=maybe-uninitialized)
+add_compile_options(-Werror=implicit-function-declaration)
+add_compile_options(-Wno-pointer-sign) # for XmlChar handling
+add_compile_options(-ffunction-sections -fdata-sections)
+add_compile_options(-Wl,--as-needed -Wl,--gc-sections)
+add_compile_options(-fPIC)
+#add_definitions(-DNDEBUG)
 
+set(CMAKE_C_FLAGS_PROFILING    "-g -O0 -pg -Wp,-U_FORTIFY_SOURCE")
+set(CMAKE_C_FLAGS_DEBUG        "-g -O0 -ggdb -Wp,-U_FORTIFY_SOURCE")
+set(CMAKE_C_FLAGS_RELEASE      "-g -O2")
+set(CMAKE_C_FLAGS_CCOV         "-g -O2 --coverage")
+
+###########################################################################
+
+include(FindPkgConfig)
+
+pkg_check_modules(EXTRAS REQUIRED libxml-2.0 openssl xmlsec1 xmlsec1-openssl json-c)
 add_compile_options(${EXTRAS_CFLAGS})
 include_directories(${EXTRAS_INCLUDE_DIRS})
 link_libraries(${EXTRAS_LIBRARIES})
-
-if(USE_LIBZIP)
-       pkg_check_modules(LIBZIP REQUIRED libzip>=0.11)
-       add_compile_options(${LIBZIP_CFLAGS})
-       include_directories(${LIBZIP_INCLUDE_DIRS})
-       link_libraries(${LIBZIP_LIBRARIES})
+link_directories(${EXTRAS_LIBRARY_DIRS})
+
+pkg_check_modules(libzip libzip>=0.11)
+if(libzip_FOUND AND USE_LIBZIP)
+       add_compile_options(${libzip_CFLAGS})
+       include_directories(${libzip_INCLUDE_DIRS})
+       link_libraries(${libzip_LIBRARIES})
+       link_directories(${libzip_LIBRARY_DIRS})
        add_definitions(-DUSE_LIBZIP=1)
-else(USE_LIBZIP)
+else()
        add_definitions(-DUSE_LIBZIP=0)
-endif(USE_LIBZIP)
+endif()
+
+pkg_check_modules(libsystemd libsystemd>=222)
+if(libsystemd_FOUND)
+       add_compile_options(${libsystemd_CFLAGS})
+       include_directories(${libsystemd_INCLUDE_DIRS})
+       link_libraries(${libsystemd_LIBRARIES})
+       link_directories(${libsystemd_LIBRARY_DIRS})
+else()
+       add_definitions(-DNO_LIBSYSTEMD)
+endif()
+
+pkg_check_modules(AFB afb-daemon>=4.99 libafbwsc>=4.99)
+if(AFB_FOUND)
+       add_compile_options(${AFB_CFLAGS})
+       include_directories(${AFB_INCLUDE_DIRS})
+       link_libraries(${AFB_LIBRARIES})
+       link_directories(${AFB_LIBRARY_DIRS})
+endif()
 
 ###########################################################################
 
-if(USE_SIMULATION)
-       include_directories(simulation)
-else(USE_SIMULATION)
+if(SIMULATE_SECMGR)
+       add_definitions(-DSIMULATE_SECURITY_MANAGER=1)
+else(SIMULATE_SECMGR)
        pkg_check_modules(SECMGR REQUIRED security-manager)
        add_compile_options(${SECMGR_CFLAGS})
        include_directories(${SECMGR_INCLUDE_DIRS})
        link_libraries(${SECMGR_LIBRARIES})
-endif(USE_SIMULATION)
-
-###########################################################################
-
-add_compile_options(-Wall -Wno-pointer-sign)
-add_compile_options(-Werror=maybe-uninitialized -Werror=implicit-function-declaration)
-add_compile_options(-ffunction-sections -fdata-sections)
-add_compile_options(-fPIC)
-add_compile_options(-Wl,--gc-sections)
-
-set(CMAKE_C_FLAGS_PROFILING    "-g -O0 -pg -Wp,-U_FORTIFY_SOURCE")
-set(CMAKE_C_FLAGS_DEBUG        "-g -O0 -ggdb -Wp,-U_FORTIFY_SOURCE")
-set(CMAKE_C_FLAGS_RELEASE      "-g -O2")
-set(CMAKE_C_FLAGS_CCOV         "-g -O2 --coverage")
+       link_directories(${SECMGR_LIBRARY_DIRS})
+       add_definitions(-DSIMULATE_SECURITY_MANAGER=0)
+endif(SIMULATE_SECMGR)
+
+if(SIMULATE_SMACK)
+       add_definitions(-DSIMULATE_LIBSMACK=1)
+else(SIMULATE_SMACK)
+       pkg_check_modules(SMACK REQUIRED libsmack)
+       add_compile_options(${SMACK_CFLAGS})
+       include_directories(${SMACK_INCLUDE_DIRS})
+       link_libraries(${SMACK_LIBRARIES})
+       link_directories(${SMACK_LIBRARY_DIRS})
+       add_definitions(-DSIMULATE_LIBSMACK=0)
+endif(SIMULATE_SMACK)
 
 ###########################################################################
 
-add_library(wgtpkg
+add_library(wgtpkg STATIC
        wgtpkg-base64.c
        wgtpkg-certs.c
        wgtpkg-digsig.c
        wgtpkg-files.c
        wgtpkg-install.c
+       wgtpkg-mustach.c
        wgtpkg-permissions.c
        wgtpkg-uninstall.c
+       wgtpkg-unit.c
        wgtpkg-workdir.c
        wgtpkg-xmlsec.c
        wgtpkg-zip.c
        )
 
-add_library(utils
+add_library(utils STATIC
+       mustach.c
        utils-dir.c
-       utils-jbus.c
+       utils-file.c
        utils-json.c
+       utils-systemd.c
        verbose.c
        )
 
-add_library(wgt
+add_library(wgt STATIC
        wgt-config.c
        wgt-info.c
+       wgt-strings.c
+       wgt-json.c
        wgt.c
        )
 
-add_library(secwrp
+add_library(secwrp STATIC
        secmgr-wrap.c
        )
 
-add_library(afm
-       afm-db.c
-       afm-launch.c
-       afm-launch-mode.c
-       afm-run.c
+add_library(afm STATIC
+       afm-udb.c
+       afm-urun.c
        )
 
-add_executable(wgtpkg-sign wgtpkg-sign.c)
+###########################################################################
+# off line tools tools
+
+MESSAGE(STATUS "Creating packaging tools")
+
+add_executable(wgtpkg-sign main-wgtpkg-sign.c)
 target_link_libraries(wgtpkg-sign wgtpkg utils)
 
-add_executable(wgtpkg-pack wgtpkg-pack.c)
+add_executable(wgtpkg-pack main-wgtpkg-pack.c)
 target_link_libraries(wgtpkg-pack wgtpkg utils)
 
-add_executable(wgtpkg-info wgtpkg-info.c)
+add_executable(wgtpkg-info main-wgtpkg-info.c)
 target_link_libraries(wgtpkg-info wgtpkg wgt utils)
 
-add_executable(wgtpkg-installer wgtpkg-installer.c)
-target_link_libraries(wgtpkg-installer wgtpkg wgt secwrp utils)
+add_executable(wgtpkg-install main-wgtpkg-install.c)
+target_link_libraries(wgtpkg-install wgtpkg wgt secwrp utils)
 
-add_executable(afm-user-daemon afm-user-daemon.c)
-target_link_libraries(afm-user-daemon afm secwrp wgt utils)
+install(TARGETS wgtpkg-sign wgtpkg-pack wgtpkg-info wgtpkg-install DESTINATION ${CMAKE_INSTALL_BINDIR})
 
-add_executable(afm-system-daemon afm-system-daemon.c)
-target_link_libraries(afm-system-daemon wgtpkg afm secwrp wgt utils)
+###########################################################################
+# dynamic tool daemons
+
+if(libsystemd_FOUND AND AFB_FOUND)
+       MESSAGE(STATUS "Creating daemons")
+
+       add_library(jbus STATIC utils-jbus.c)
+
+       if(LEGACY_USER_DAEMON)
+               add_executable(afm-user-daemon afm-user-daemon.c)
+               target_link_libraries(afm-user-daemon jbus utils)
+               install(TARGETS afm-user-daemon DESTINATION ${CMAKE_INSTALL_BINDIR})
+       endif()
+
+       add_library(afm-binding MODULE afm-binding.c)
+       target_link_libraries(afm-binding wgtpkg wgt secwrp utils afm)
+       set_target_properties(afm-binding PROPERTIES
+               PREFIX ""
+               LINK_FLAGS "-Wl,--version-script=${CMAKE_CURRENT_SOURCE_DIR}/afm-binding.export-map"
+       )
+       install(TARGETS afm-binding LIBRARY DESTINATION ${afm_libexecdir})
+
+       add_executable(afm-user-session afm-user-session.c)
+       install(TARGETS afm-user-session DESTINATION ${afm_libexecdir}
+                       PERMISSIONS SETUID OWNER_READ OWNER_WRITE OWNER_EXECUTE
+                                       GROUP_READ GROUP_EXECUTE WORLD_READ WORLD_EXECUTE)
+else()
+       MESSAGE(STATUS "Not creating daemons")
+endif()
+
+###########################################################################
+# the tests
 
-install(TARGETS wgtpkg-sign wgtpkg-pack wgtpkg-info wgtpkg-installer DESTINATION ${CMAKE_INSTALL_FULL_BINDIR})
-install(TARGETS afm-user-daemon DESTINATION ${CMAKE_INSTALL_FULL_BINDIR})
-install(TARGETS afm-system-daemon DESTINATION ${CMAKE_INSTALL_FULL_BINDIR})
+add_subdirectory(tests)