diff options
Diffstat (limited to 'mail/postsrsd/files/patch-CMakeLists.txt')
-rw-r--r-- | mail/postsrsd/files/patch-CMakeLists.txt | 160 |
1 files changed, 79 insertions, 81 deletions
diff --git a/mail/postsrsd/files/patch-CMakeLists.txt b/mail/postsrsd/files/patch-CMakeLists.txt index c4e43dfaf237..551653c47e84 100644 --- a/mail/postsrsd/files/patch-CMakeLists.txt +++ b/mail/postsrsd/files/patch-CMakeLists.txt @@ -1,88 +1,86 @@ ---- CMakeLists.txt.orig 2020-12-12 09:55:17 UTC +--- CMakeLists.txt.orig 2023-08-25 21:10:07 UTC +++ CMakeLists.txt -@@ -7,12 +7,15 @@ include(CTest) - - option(GENERATE_SRS_SECRET "Generate a random SRS secret if none exists during install" ON) - option(USE_APPARMOR "Enable AppArmor profile" OFF) +@@ -49,7 +49,7 @@ set(POSTSRSD_CONFIGDIR + "The default directory where PostSRSd should look for configuration files" + ) + set(POSTSRSD_DATADIR +- "${CMAKE_INSTALL_FULL_LOCALSTATEDIR}/lib/${PROJECT_NAME}" ++ "${CMAKE_INSTALL_FULL_LOCALSTATEDIR}/db/${PROJECT_NAME}" + CACHE PATH "The default directory where PostSRSd should put runtime data" + ) + set(POSTSRSD_CHROOTDIR +@@ -73,24 +73,21 @@ option(WITH_REDIS + OFF + ) + add_feature_info(WITH_REDIS WITH_REDIS "use Redis as database backend") ++set(DOC_DIR "share/doc/${PROJECT_NAME}" CACHE PATH "Path for documentation files") +option(MK_CHROOT_DIR "Chroot jail for daemon" OFF) - option(USE_SELINUX "Enable SELinux policy module" OFF) - -+if(MK_CHROOT_DIR) - set(CHROOT_DIR "${CMAKE_INSTALL_PREFIX}/lib/${PROJECT_NAME}" CACHE PATH "Chroot jail for daemon") -+endif() - set(SYSCONF_DIR "/etc" CACHE PATH "Global system configuration folder") - set(SYSD_UNIT_DIR "${SYSCONF_DIR}/systemd/system" CACHE PATH "Systemd unit file folder") --set(CONFIG_DIR "${SYSCONF_DIR}/default" CACHE PATH "Location of startup configuration file") -+set(CONFIG_DIR "${CMAKE_INSTALL_PREFIX}/etc" CACHE PATH "Location of startup configuration file") - set(DOC_DIR "share/doc/${PROJECT_NAME}" CACHE PATH "Path for documentation files") - mark_as_advanced(CHROOT_DIR SYSCONF_DIR SYSD_UNIT_DIR CONFIG_DIR DOC_DIR) - -@@ -20,8 +23,6 @@ find_program(HELP2MAN help2man DOC "path to help2man e - find_program(DD dd DOC "path to dd executable") - find_program(BASE64 base64 DOC "path to base64 executable") - find_program(OPENSSL openssl DOC "path to OpenSSL executable") --find_program(INSSERV insserv DOC "path to insserv executable") --find_program(CHKCONFIG chkconfig DOC "path to chkconfig executable") - find_program(SYSTEMCTL systemctl DOC "path to systemctl executable") - - if(CMAKE_SYSTEM_NAME MATCHES "SunOS") -@@ -69,23 +70,6 @@ endif() - check_type_size("unsigned long" SIZEOF_UNSIGNED_LONG) - add_definitions(-DSIZEOF_UNSIGNED_LONG=${SIZEOF_UNSIGNED_LONG}) - --if(NOT DEFINED INIT_FLAVOR) -- if(SYSTEMCTL) -- message(STATUS "Detected init flavor: systemd") -- set(INIT_FLAVOR "systemd" CACHE STRING "Init daemon of this system") -- elseif(IS_DIRECTORY "${SYSCONF_DIR}/init.d" AND EXISTS "${SYSCONF_DIR}/init.d/functions") -- message(STATUS "Detected init flavor: sysv-redhat") -- set(INIT_FLAVOR "sysv-redhat" CACHE STRING "Init daemon of this system") -- elseif(IS_DIRECTORY "${SYSCONF_DIR}/init.d" AND EXISTS "/lib/lsb/init-functions") -- message(STATUS "Detected init flavor: sysv-lsb") -- set(INIT_FLAVOR "sysv-lsb" CACHE STRING "Init daemon of this system") -- else() -- message(STATUS "Detected init flavor: none") -- message(STATUS "System startup files will not be installed") -- set(INIT_FLAVOR "" CACHE STRING "Init daemon of this system") -- endif() --endif() -- - add_definitions(-DPOSTSRSD_VERSION=\"${PROJECT_VERSION}\") - add_executable(${PROJECT_NAME} postsrsd.c sha1.c srs2.c) - -@@ -95,16 +79,8 @@ if(CMAKE_SYSTEM_NAME MATCHES "SunOS") - endif() - - set(POSTSRSD "${PROJECT_NAME}${CMAKE_EXECUTABLE_SUFFIX}") --set(APPARMOR_PROFILE "${CMAKE_INSTALL_PREFIX}/sbin/${POSTSRSD}") --string(REGEX REPLACE "^/+" "" APPARMOR_PROFILE "${APPARMOR_PROFILE}") --string(REPLACE "/" "." APPARMOR_PROFILE "${APPARMOR_PROFILE}") - --configure_file(init/${PROJECT_NAME}.sysv-lsb.in ${PROJECT_NAME}.sysv-lsb @ONLY) --configure_file(init/${PROJECT_NAME}.sysv-redhat.in ${PROJECT_NAME}.sysv-redhat @ONLY) --configure_file(init/${PROJECT_NAME}.apparmor.in ${PROJECT_NAME}.apparmor @ONLY) --configure_file(init/${PROJECT_NAME}.systemd.in ${PROJECT_NAME}.systemd @ONLY) - configure_file(init/${PROJECT_NAME}.default.in ${PROJECT_NAME}.default @ONLY) --configure_file(init/${PROJECT_NAME}-systemd-launcher.in ${PROJECT_NAME}-systemd-launcher @ONLY) + option(TESTS_WITH_ASAN "Run test suite with AddressSanitizer" ON) + option(DEVELOPER_BUILD "Add strict compiler options for development only" OFF) +-option(GENERATE_SRS_SECRET "Generate and install a postsrsd.secret" ON) ++option(GENERATE_SRS_SECRET "Generate and install a postsrsd.secret" OFF) + add_feature_info( + GENERATE_SRS_SECRET + GENERATE_SRS_SECRET + "generate missing ${CMAKE_INSTALL_FULL_SYSCONFDIR}/${PROJECT_NAME}.secret on install" + ) +-option(INSTALL_SYSTEMD_SERVICE "Install the systemd postsrsd.service unit" ON) ++option(INSTALL_SYSTEMD_SERVICE "Install the systemd postsrsd.service unit" OFF) + add_feature_info( + INSTALL_SYSTEMD_SERVICE INSTALL_SYSTEMD_SERVICE + "install the systemd postsrsd.service unit" + ) +-find_systemd_unit_destination(DETECTED_SYSTEMD_UNITDIR) +-set(SYSTEMD_UNITDIR +- "${DETECTED_SYSTEMD_UNITDIR}" +- CACHE PATH "Install destination for the systemd postsrsd.service unit" +-) + find_systemd_sysusers_destination(DETECTED_SYSTEMD_SYSUSERSDIR) + set(SYSTEMD_SYSUSERSDIR + "${DETECTED_SYSTEMD_SYSUSERSDIR}" +@@ -118,7 +115,6 @@ mark_as_advanced( + TESTS_WITH_ASAN + GENERATE_SRS_SECRET + DEVELOPER_BUILD +- SYSTEMD_UNITDIR + POSTSRSD_CONFIGDIR + POSTSRSD_CHROOTDIR + POSTSRSD_DATADIR +@@ -200,11 +196,7 @@ endif() + set(THREADS_PREFER_PTHREAD_FLAG TRUE) + find_package(Threads QUIET) - configure_file(postinstall.cmake.in postinstall.cmake @ONLY) +-add_autotools_dependency( +- Confuse +- LIBRARY_NAME confuse +- EXPORTED_TARGET Confuse::Confuse +-) ++find_package(Confuse REQUIRED) -@@ -118,7 +94,7 @@ add_custom_command(TARGET ${PROJECT_NAME} POST_BUILD - COMMAND ${HELP2MAN} ARGS -s8 -o${PROJECT_NAME}.8 -n "Postfix Sender Rewriting Scheme daemon" -N -h-h -v-v ${CMAKE_CURRENT_BINARY_DIR}/${POSTSRSD} - VERBATIM + if(WITH_REDIS) + set(DISABLE_TESTS +@@ -221,6 +213,7 @@ if(WITH_REDIS) + DIRECTORY "${hiredis_SOURCE_DIR}" PROPERTY EXCLUDE_FROM_ALL TRUE + ) + endif() ++ find_package(Hiredis REQUIRED) + if(TARGET hiredis::hiredis_static) + set(HIREDIS_TARGET hiredis::hiredis_static) + elseif(TARGET hiredis::hiredis) +@@ -364,13 +357,9 @@ install(TARGETS postsrsd RUNTIME DESTINATION ${CMAKE_I + install(FILES "${CMAKE_CURRENT_BINARY_DIR}/${PROJECT_NAME}.conf" + DESTINATION "${CMAKE_INSTALL_DATADIR}/doc/${PROJECT_NAME}" ) --install(FILES ${CMAKE_CURRENT_BINARY_DIR}/${PROJECT_NAME}.8 DESTINATION "share/man/man8") -+install(FILES ${CMAKE_CURRENT_BINARY_DIR}/${PROJECT_NAME}.8 DESTINATION "man/man8") - endif() - - if(USE_APPARMOR) -@@ -135,6 +111,8 @@ if(USE_SELINUX) +-if(INSTALL_SYSTEMD_SERVICE) +- install(FILES "${CMAKE_CURRENT_BINARY_DIR}/${PROJECT_NAME}.service" +- DESTINATION "${SYSTEMD_UNITDIR}" +- ) +- install(FILES "${CMAKE_CURRENT_BINARY_DIR}/sysusers.d/${PROJECT_NAME}.conf" +- DESTINATION "${SYSTEMD_SYSUSERSDIR}" +- ) ++ ++if(ENABLE_DOCS) ++ install(FILES README.rst CHANGELOG.rst doc/postsrsd.conf DESTINATION "${DOC_DIR}" ) endif() - install(TARGETS ${PROJECT_NAME} DESTINATION "sbin") --install(PROGRAMS ${CMAKE_CURRENT_BINARY_DIR}/${PROJECT_NAME}-systemd-launcher DESTINATION "share/${PROJECT_NAME}") -+if(ENABLE_DOCS) -+ install(FILES README.md README_UPGRADE.md main.cf.ex DESTINATION "${DOC_DIR}") -+endif() - install(FILES README.md README_UPGRADE.md main.cf.ex DESTINATION "${DOC_DIR}") - install(SCRIPT "${CMAKE_CURRENT_BINARY_DIR}/postinstall.cmake") + if(GENERATE_SRS_SECRET) |