X-Git-Url: http://review.tizen.org/git/?a=blobdiff_plain;f=src%2FCMakeLists.txt;h=f76673f4f95c19625df308c4a9b250c4cbc87b0e;hb=d924ac74a2d82370d095af2056e9d2e30257f2ba;hp=6985e81e5d353def0c206668deae20307fe997f8;hpb=1c8a0877ad0045d7e3cd4c91713324c49e96eb64;p=platform%2Fcore%2Fsecurity%2Fkey-manager.git diff --git a/src/CMakeLists.txt b/src/CMakeLists.txt index 6985e81..f76673f 100644 --- a/src/CMakeLists.txt +++ b/src/CMakeLists.txt @@ -2,32 +2,66 @@ PKG_CHECK_MODULES(KEY_MANAGER_DEP dlog openssl libsmack + libcrypto libsystemd-daemon + capi-base-common + vconf + libxml-2.0 REQUIRED ) +FIND_PACKAGE(Threads REQUIRED) SET(KEY_MANAGER_SRC_PATH ${PROJECT_SOURCE_DIR}/src) SET(KEY_MANAGER_PATH ${PROJECT_SOURCE_DIR}/src/manager) SET(KEY_MANAGER_SOURCES - ${KEY_MANAGER_PATH}/main/key-manager-util.cpp ${KEY_MANAGER_PATH}/main/generic-socket-manager.cpp ${KEY_MANAGER_PATH}/main/socket-manager.cpp ${KEY_MANAGER_PATH}/main/key-manager-main.cpp - ${KEY_MANAGER_PATH}/service/echo.cpp + ${KEY_MANAGER_PATH}/main/smack-check.cpp + ${KEY_MANAGER_PATH}/main/thread-service.cpp + ${KEY_MANAGER_PATH}/service/certificate-store.cpp + ${KEY_MANAGER_PATH}/service/certificate-config.cpp + ${KEY_MANAGER_PATH}/service/digest.cpp + ${KEY_MANAGER_PATH}/service/file-lock.cpp + ${KEY_MANAGER_PATH}/service/access-control.cpp ${KEY_MANAGER_PATH}/service/ckm-service.cpp ${KEY_MANAGER_PATH}/service/ckm-logic.cpp ${KEY_MANAGER_PATH}/service/key-provider.cpp ${KEY_MANAGER_PATH}/service/ocsp.cpp - ${KEY_MANAGER_PATH}/service/DBCryptoModule.cpp - ${KEY_MANAGER_PATH}/service/CryptoService.cpp + ${KEY_MANAGER_PATH}/service/crypto-logic.cpp ${KEY_MANAGER_PATH}/service/file-system.cpp + ${KEY_MANAGER_PATH}/service/db-crypto.cpp + ${KEY_MANAGER_PATH}/service/ocsp-service.cpp + ${KEY_MANAGER_PATH}/service/ocsp-logic.cpp + ${KEY_MANAGER_PATH}/service/encryption-service.cpp + ${KEY_MANAGER_PATH}/service/encryption-logic.cpp + ${KEY_MANAGER_PATH}/initial-values/parser.cpp + ${KEY_MANAGER_PATH}/initial-values/BufferHandler.cpp + ${KEY_MANAGER_PATH}/initial-values/CertHandler.cpp + ${KEY_MANAGER_PATH}/initial-values/DataHandler.cpp + ${KEY_MANAGER_PATH}/initial-values/KeyHandler.cpp + ${KEY_MANAGER_PATH}/initial-values/PermissionHandler.cpp + ${KEY_MANAGER_PATH}/initial-values/InitialValueHandler.cpp + ${KEY_MANAGER_PATH}/initial-values/InitialValuesFile.cpp + ${KEY_MANAGER_PATH}/initial-values/xml-utils.cpp + ${KEY_MANAGER_PATH}/dpl/core/src/assert.cpp + ${KEY_MANAGER_PATH}/dpl/db/src/sql_connection.cpp + ${KEY_MANAGER_PATH}/dpl/db/src/naive_synchronization_object.cpp + ${KEY_MANAGER_PATH}/sqlcipher/sqlcipher.c + ${KEY_MANAGER_PATH}/crypto/sw-backend/key.cpp + ${KEY_MANAGER_PATH}/crypto/sw-backend/internals.cpp + ${KEY_MANAGER_PATH}/crypto/sw-backend/store.cpp + ${KEY_MANAGER_PATH}/crypto/platform/decider.cpp + ${KEY_MANAGER_PATH}/crypto/tz-backend/key.cpp + ${KEY_MANAGER_PATH}/crypto/tz-backend/store.cpp ) +# -fPIE and -pie flag is added for ASLR SET_SOURCE_FILES_PROPERTIES( ${KEY_MANAGER_SOURCES} PROPERTIES - COMPILE_FLAGS "-D_GNU_SOURCE -fvisibility=hidden") + COMPILE_FLAGS "-D_GNU_SOURCE -fvisibility=hidden -fPIE") INCLUDE_DIRECTORIES(SYSTEM ${KEY_MANAGER_DEP_INCLUDE_DIRS} @@ -38,42 +72,59 @@ INCLUDE_DIRECTORIES( ${KEY_MANAGER_PATH}/main ${KEY_MANAGER_PATH}/common ${KEY_MANAGER_PATH}/service + ${KEY_MANAGER_PATH}/initial-values + ${KEY_MANAGER_PATH}/sqlcipher ${KEY_MANAGER_PATH}/dpl/core/include ${KEY_MANAGER_PATH}/dpl/log/include + ${KEY_MANAGER_PATH}/dpl/db/include + ${KEY_MANAGER_PATH}/crypto ) ADD_EXECUTABLE(${TARGET_KEY_MANAGER} ${KEY_MANAGER_SOURCES}) +# pie flag is added for ASLR TARGET_LINK_LIBRARIES(${TARGET_KEY_MANAGER} + ${CMAKE_THREAD_LIBS_INIT} ${KEY_MANAGER_DEP_LIBRARIES} ${TARGET_KEY_MANAGER_COMMON} - ${TARGET_KEY_MANAGER_KEY_PROVIDER} + -ldl -pie ) - - ################################################################################ SET(KEY_MANAGER_CLIENT_VERSION_MAJOR 1) SET(KEY_MANAGER_CLIENT_VERSION ${KEY_MANAGER_CLIENT_VERSION_MAJOR}.0.1) SET(KEY_MANAGER_CLIENT_SRC_PATH ${KEY_MANAGER_PATH}/client) +SET(KEY_MANAGER_CLIENT_ASYNC_SRC_PATH ${KEY_MANAGER_PATH}/client-async) +SET(KEY_MANAGER_CLIENT_CAPI_SRC_PATH ${KEY_MANAGER_PATH}/client-capi) INCLUDE_DIRECTORIES( ${KEY_MANAGER_PATH}/client + ${KEY_MANAGER_PATH}/client-async + ${KEY_MANAGER_PATH}/client-capi ${KEY_MANAGER_PATH}/common ${KEY_MANAGER_PATH}/dpl/core/include ${KEY_MANAGER_PATH}/dpl/log/include ) SET(KEY_MANAGER_CLIENT_SOURCES - ${KEY_MANAGER_CLIENT_SRC_PATH}/client-certificate.cpp - ${KEY_MANAGER_CLIENT_SRC_PATH}/client-control.cpp ${KEY_MANAGER_CLIENT_SRC_PATH}/client-common.cpp - ${KEY_MANAGER_CLIENT_SRC_PATH}/client-echo.cpp - ${KEY_MANAGER_CLIENT_SRC_PATH}/client-key.cpp - ${KEY_MANAGER_CLIENT_SRC_PATH}/client-manager.cpp + ${KEY_MANAGER_CLIENT_SRC_PATH}/client-error.cpp ${KEY_MANAGER_CLIENT_SRC_PATH}/client-manager-impl.cpp + ${KEY_MANAGER_CLIENT_ASYNC_SRC_PATH}/client-manager-async.cpp + ${KEY_MANAGER_CLIENT_ASYNC_SRC_PATH}/client-manager-async-impl.cpp + ${KEY_MANAGER_CLIENT_ASYNC_SRC_PATH}/connection-thread.cpp + ${KEY_MANAGER_CLIENT_ASYNC_SRC_PATH}/async-request.cpp + ${KEY_MANAGER_CLIENT_ASYNC_SRC_PATH}/service.cpp + ${KEY_MANAGER_CLIENT_ASYNC_SRC_PATH}/storage-receiver.cpp + ${KEY_MANAGER_CLIENT_ASYNC_SRC_PATH}/ocsp-receiver.cpp + ${KEY_MANAGER_CLIENT_ASYNC_SRC_PATH}/encryption-receiver.cpp + ${KEY_MANAGER_CLIENT_ASYNC_SRC_PATH}/descriptor-set.cpp + ${KEY_MANAGER_CLIENT_CAPI_SRC_PATH}/ckmc-type.cpp + ${KEY_MANAGER_CLIENT_CAPI_SRC_PATH}/ckmc-error.cpp + ${KEY_MANAGER_CLIENT_CAPI_SRC_PATH}/ckmc-manager.cpp + ${KEY_MANAGER_CLIENT_CAPI_SRC_PATH}/ckmc-type-converter.cpp ) ADD_LIBRARY(${TARGET_KEY_MANAGER_CLIENT} SHARED ${KEY_MANAGER_CLIENT_SOURCES}) @@ -81,7 +132,7 @@ ADD_LIBRARY(${TARGET_KEY_MANAGER_CLIENT} SHARED ${KEY_MANAGER_CLIENT_SOURCES}) SET_TARGET_PROPERTIES( ${TARGET_KEY_MANAGER_CLIENT} PROPERTIES - COMPILE_FLAGS "-D_GNU_SOURCE -fPIC -fvisibility=default" + COMPILE_FLAGS "-D_GNU_SOURCE -fPIC -fvisibility=hidden" SOVERSION ${KEY_MANAGER_CLIENT_VERSION_MAJOR} VERSION ${KEY_MANAGER_CLIENT_VERSION} ) @@ -93,17 +144,71 @@ TARGET_LINK_LIBRARIES(${TARGET_KEY_MANAGER_CLIENT} ################################################################################ +SET(KEY_MANAGER_CONTROL_CLIENT_VERSION_MAJOR 1) +SET(KEY_MANAGER_CONTROL_CLIENT_VERSION ${KEY_MANAGER_CONTROL_CLIENT_VERSION_MAJOR}.0.1) + +SET(KEY_MANAGER_CONTROL_CLIENT_SRC_PATH ${KEY_MANAGER_PATH}/client) +SET(KEY_MANAGER_CONTROL_CLIENT_CAPI_SRC_PATH ${KEY_MANAGER_PATH}/client-capi) + +INCLUDE_DIRECTORIES( + ${KEY_MANAGER_PATH}/client + ${KEY_MANAGER_PATH}/client-capi + ${KEY_MANAGER_PATH}/common + ${KEY_MANAGER_PATH}/dpl/core/include + ${KEY_MANAGER_PATH}/dpl/log/include + ) + +SET(KEY_MANAGER_CONTROL_CLIENT_SOURCES + ${KEY_MANAGER_CONTROL_CLIENT_SRC_PATH}/client-control.cpp + ${KEY_MANAGER_CONTROL_CLIENT_SRC_PATH}/client-common.cpp + ${KEY_MANAGER_CONTROL_CLIENT_CAPI_SRC_PATH}/ckmc-control.cpp + ${KEY_MANAGER_CONTROL_CLIENT_CAPI_SRC_PATH}/ckmc-type-converter.cpp + ) + +ADD_LIBRARY(${TARGET_KEY_MANAGER_CONTROL_CLIENT} SHARED ${KEY_MANAGER_CONTROL_CLIENT_SOURCES}) + +SET_TARGET_PROPERTIES( + ${TARGET_KEY_MANAGER_CONTROL_CLIENT} + PROPERTIES + COMPILE_FLAGS "-D_GNU_SOURCE -fPIC -fvisibility=hidden" + SOVERSION ${KEY_MANAGER_CONTROL_CLIENT_VERSION_MAJOR} + VERSION ${KEY_MANAGER_CONTROL_CLIENT_VERSION} + ) + +TARGET_LINK_LIBRARIES(${TARGET_KEY_MANAGER_CONTROL_CLIENT} + ${KEY_MANAGER_DEP_LIBRARIES} + ${TARGET_KEY_MANAGER_COMMON} + ) + +################################################################################ INSTALL(TARGETS ${TARGET_KEY_MANAGER_CLIENT} DESTINATION ${LIB_INSTALL_DIR}) +INSTALL(TARGETS ${TARGET_KEY_MANAGER_CONTROL_CLIENT} DESTINATION ${LIB_INSTALL_DIR}) INSTALL(TARGETS ${TARGET_KEY_MANAGER} DESTINATION bin) + INSTALL(FILES - ${KEY_MANAGER_SRC_PATH}/include/ckm/key-manager.h + ${KEY_MANAGER_SRC_PATH}/include/ckm/ckm-manager.h + ${KEY_MANAGER_SRC_PATH}/include/ckm/ckm-manager-async.h + ${KEY_MANAGER_SRC_PATH}/include/ckm/ckm-certificate.h + ${KEY_MANAGER_SRC_PATH}/include/ckm/ckm-control.h ${KEY_MANAGER_SRC_PATH}/include/ckm/ckm-error.h + ${KEY_MANAGER_SRC_PATH}/include/ckm/ckm-key.h + ${KEY_MANAGER_SRC_PATH}/include/ckm/ckm-password.h + ${KEY_MANAGER_SRC_PATH}/include/ckm/ckm-pkcs12.h + ${KEY_MANAGER_SRC_PATH}/include/ckm/ckm-raw-buffer.h ${KEY_MANAGER_SRC_PATH}/include/ckm/ckm-type.h DESTINATION /usr/include/ckm/ckm ) - +INSTALL(FILES + ${KEY_MANAGER_SRC_PATH}/include/ckmc/ckmc-manager.h + ${KEY_MANAGER_SRC_PATH}/include/ckmc/ckmc-control.h + ${KEY_MANAGER_SRC_PATH}/include/ckmc/ckmc-error.h + ${KEY_MANAGER_SRC_PATH}/include/ckmc/ckmc-type.h + DESTINATION /usr/include/ckm/ckmc + ) ################################################################################ ADD_SUBDIRECTORY(manager) +ADD_SUBDIRECTORY(listener) +ADD_SUBDIRECTORY(pam_plugin)