CMakeLists: Fix library directories
[src/app-framework-main.git] / src / CMakeLists.txt
index e7b946b..dacbff2 100644 (file)
@@ -1,5 +1,5 @@
 ###########################################################################
-# Copyright 2015, 2016, 2017 IoT.bzh
+# Copyright (C) 2015-2018 IoT.bzh
 #
 # author: José Bollo <jose.bollo@iot.bzh>
 #
@@ -45,23 +45,36 @@ pkg_check_modules(EXTRAS REQUIRED libxml-2.0 openssl xmlsec1 xmlsec1-openssl jso
 add_compile_options(${EXTRAS_CFLAGS})
 include_directories(${EXTRAS_INCLUDE_DIRS})
 link_libraries(${EXTRAS_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()
        add_definitions(-DUSE_LIBZIP=0)
 endif()
 
 pkg_check_modules(libsystemd libsystemd>=222)
-if(NOT libsystemd_FOUND)
+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()
 
 ###########################################################################
 
@@ -72,6 +85,7 @@ else(SIMULATE_SECMGR)
        add_compile_options(${SECMGR_CFLAGS})
        include_directories(${SECMGR_INCLUDE_DIRS})
        link_libraries(${SECMGR_LIBRARIES})
+       link_directories(${SECMGR_LIBRARY_DIRS})
        add_definitions(-DSIMULATE_SECURITY_MANAGER=0)
 endif(SIMULATE_SECMGR)
 
@@ -82,6 +96,7 @@ else(SIMULATE_SMACK)
        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)
 
@@ -153,14 +168,10 @@ install(TARGETS wgtpkg-sign wgtpkg-pack wgtpkg-info wgtpkg-installer DESTINATION
 if(libsystemd_FOUND AND AFB_FOUND)
        MESSAGE(STATUS "Creating daemons")
 
-       add_compile_options(${libsystemd_CFLAGS} ${AFB_CFLAGS})
-       include_directories(${libsystemd_INCLUDE_DIRS} ${AFB_INCLUDE_DIRS})
-       link_libraries(${libsystemd_LIBRARIES} ${AFB_LIBRARIES})
-
        add_library(jbus STATIC utils-jbus.c)
 
        add_executable(afm-user-daemon afm-user-daemon.c)
-       target_link_libraries(afm-user-daemon jbus utils afbwsc)
+       target_link_libraries(afm-user-daemon jbus utils)
        install(TARGETS afm-user-daemon DESTINATION ${CMAKE_INSTALL_BINDIR})
 
        add_library(afm-binding MODULE afm-binding.c)
@@ -170,6 +181,9 @@ if(libsystemd_FOUND AND AFB_FOUND)
                LINK_FLAGS "-Wl,--version-script=${CMAKE_CURRENT_SOURCE_DIR}/afm-binding.export-map"
        )
        install(TARGETS afm-binding LIBRARY DESTINATION ${CMAKE_INSTALL_LIBEXECDIR}/afm)
+
+       add_executable(afm-user-session afm-user-session.c)
+       install(TARGETS afm-user-session DESTINATION ${CMAKE_INSTALL_BINDIR} PERMISSIONS SETUID OWNER_EXECUTE GROUP_EXECUTE WORLD_EXECUTE)
 else()
        MESSAGE(STATUS "Not creating daemons")
 endif()