forked from openssl/openssl
-
Notifications
You must be signed in to change notification settings - Fork 13
/
Copy pathCMakeLists.txt
executable file
·370 lines (333 loc) · 12.5 KB
/
CMakeLists.txt
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
cmake_minimum_required(VERSION 3.7)
project(libcmp)
set(LIBCMP_NAME cmp)
if(NOT DEFINED LIBCMP_VERSION)
set(LIBCMP_VERSION_MAJOR 2)
set(LIBCMP_VERSION_MINOR 0)
set(LIBCMP_VERSION ${LIBCMP_VERSION_MAJOR}.${LIBCMP_VERSION_MINOR})
endif()
message(STATUS "CMPforOpenSSL version ${LIBCMP_VERSION}")
# set(CMAKE_VERBOSE_MAKEFILE ON)
# improved from https://cmake.org/cmake/help/v3.6/module/FindOpenSSL.html
if(NOT DEFINED OPENSSL_ROOT_DIR AND NOT "$ENV{OPENSSL_DIR}" STREQUAL "")
get_filename_component(OPENSSL_ROOT_DIR "$ENV{OPENSSL_DIR}" ABSOLUTE)
set(OPENSSL_INCLUDE_DIR "${OPENSSL_ROOT_DIR}/include")
endif()
if(NOT DEFINED OPENSSL_FOUND) # not already done by superordinate module
set(OPENSSL_VERSION "(unknown)")
set(OPENSSL_COMPONENTS COMPONENTS Crypto) # SSL not needed for this library
if(DEFINED OPENSSL_ROOT_DIR)
find_package(OpenSSL HINTS "${OPENSSL_ROOT_DIR}" NO_DEFAULT_PATH ${OPENSSL_COMPONENTS})
else()
find_package(OpenSSL ${OPENSSL_COMPONENTS})
endif()
STRING(REGEX REPLACE "/libcrypto\..*" "" OPENSSL_LIB "${OPENSSL_CRYPTO_LIBRARY}")
endif()
message(STATUS "using OpenSSL version ${OPENSSL_VERSION}")
message(STATUS "using OpenSSL inc dir ${OPENSSL_INCLUDE_DIR}")
STRING(REGEX REPLACE ";.*" "" OPENSSL_INCLUDE_DIR "${OPENSSL_INCLUDE_DIR}")
if(NOT EXISTS "${OPENSSL_INCLUDE_DIR}/openssl")
message(FATAL_ERROR "OpenSSL include directory does not exist: ${OPENSSL_INCLUDE_DIR}/openssl")
endif()
if("$ENV{OPENSSL_LIB}" STREQUAL "" AND NOT "$ENV{OPENSSL_DIR}" STREQUAL "")
set(ENV{OPENSSL_LIB} $ENV{OPENSSL_DIR})
endif()
if(NOT DEFINED OPENSSL_LIB_SET AND NOT "$ENV{OPENSSL_LIB}" STREQUAL "")
set(OPENSSL_LIB_SET 1)
get_filename_component(OPENSSL_LIB "$ENV{OPENSSL_LIB}" ABSOLUTE)
if(NOT EXISTS "${OPENSSL_LIB}")
message(FATAL_ERROR "directory OPENSSL_LIB does not exist: ${OPENSSL_LIB}")
endif()
if(NOT DEFINED OPENSSL_FOUND)
set(OPENSSL_CRYPTO_LIBRARY "${OPENSSL_LIB}/libcrypto${CMAKE_SHARED_LIBRARY_SUFFIX}")
endif()
endif()
set(OPENSSL_LIBRARIES ${OPENSSL_CRYPTO_LIBRARY}) # do not reference libssl
message(STATUS "using OpenSSL lib dir ${OPENSSL_LIB}")
message(STATUS "using OpenSSL crypto library ${OPENSSL_CRYPTO_LIBRARY}")
if(NOT EXISTS "${OPENSSL_CRYPTO_LIBRARY}")
message(FATAL_ERROR "OpenSSL crypto library file does not exist: ${OPENSSL_CRYPTO_LIBRARY}")
endif()
# workaround for using local OpenSSL builds by default expecting that
# its dynamic libs have been installed in ./${LIB} when using the libs
# see for binaries dynamically linked to OpenSSL the output of ${LDD} <binary>
if(CMAKE_SYSTEM_NAME MATCHES "Windows")
set(USERS "^(\w:)?\\Users\\")
set(LIB "bin")
else()
set(USERS "^/(home|Users)/")
set(LIB "lib")
endif()
string(REGEX MATCH ${USERS} MATCHED "${OPENSSL_LIB}")
if(NOT "${MATCHED}" STREQUAL "" AND NOT EXISTS "${OPENSSL_LIB}/${LIB}")
execute_process(COMMAND ${CMAKE_COMMAND} -E create_symlink "." "${OPENSSL_LIB}/${LIB}")
# since CMake 3.13, this works also for Windows
endif()
set(SRC_DIR ${PROJECT_SOURCE_DIR}/crypto)
set(LIBCMP_SRC
"${PROJECT_SOURCE_DIR}/.github/workflows/build.yml"
${SRC_DIR}/crmf/crmf_asn.c
${SRC_DIR}/crmf/crmf_err.c
${SRC_DIR}/crmf/crmf_lib.c
${SRC_DIR}/crmf/crmf_pbm.c
${SRC_DIR}/cmp/cmp_asn.c
${SRC_DIR}/cmp/cmp_ctx.c
${SRC_DIR}/cmp/cmp_err.c
${SRC_DIR}/cmp/cmp_http.c
${SRC_DIR}/cmp/cmp_hdr.c
${SRC_DIR}/cmp/cmp_msg.c
${SRC_DIR}/cmp/cmp_protect.c
${SRC_DIR}/cmp/cmp_client.c
${SRC_DIR}/cmp/cmp_server.c
${SRC_DIR}/cmp/cmp_status.c
${SRC_DIR}/cmp/cmp_vfy.c
${SRC_DIR}/cmp/cmp_util.c
${SRC_DIR}/cmp/openssl_backport.c
${SRC_DIR}/http/http_client.c
${SRC_DIR}/http/http_err.c
${SRC_DIR}/http/http_lib.c
)
set(INC_DIR "${PROJECT_SOURCE_DIR}/include/${LIBCMP_NAME}")
set(INC_PUBLIC_HDRS
${INC_DIR}/openssl/cmp.h
${INC_DIR}/openssl/cmperr.h
${INC_DIR}/openssl/cmp_util.h
${INC_DIR}/openssl/crmf.h
${INC_DIR}/openssl/crmferr.h
${INC_DIR}/openssl/cryptoerr_legacy.h
${INC_DIR}/openssl/safestack_backport.h
${INC_DIR}/openssl/openssl_backport.h
${INC_DIR}/openssl/http.h
${INC_DIR}/openssl/httperr.h
)
add_library(${LIBCMP_NAME} SHARED ${LIBCMP_SRC})
target_link_libraries(${LIBCMP_NAME} ${OPENSSL_LIBRARIES})
# target_include_directories(${LIBCMP_NAME} PRIVATE ${INC_DIR})
include_directories(SYSTEM ${INC_DIR})
include_directories(SYSTEM ${CMAKE_SYSROOT}/usr/include/cmp)
# must not add the system OpenSSL include dir before ${INC_DIR} etc.
include_directories(SYSTEM ${OPENSSL_INCLUDE_DIR})
if(DEFINED ENV{NDEBUG} OR NOT CMAKE_BUILD_TYPE MATCHES Debug)
set(CMAKE_BUILD_TYPE Release # automatically leads to CFLAGS += -DNDEBUG -O3
CACHE STRING "Choose the type of build." FORCE)
else()
set(CMAKE_BUILD_TYPE Debug # automatically leads to CFLAGS += -g # -O0 not added by default
CACHE STRING "Choose the type of build." FORCE)
target_compile_options(${LIBCMP_NAME} PRIVATE -O0)
set(SANITIZER_FLAGS -fsanitize=address,undefined -fno-sanitize-recover=all)
target_compile_options(${LIBCMP_NAME} PRIVATE ${SANITIZER_FLAGS})
target_link_options (${LIBCMP_NAME} PRIVATE ${SANITIZER_FLAGS})
endif()
message(STATUS "build mode: ${CMAKE_BUILD_TYPE}")
target_compile_options(${LIBCMP_NAME} PRIVATE
-include ${INC_DIR}/openssl/openssl_backport.h -DCMP_STANDALONE
-DDEBUG_UNUSED -DPEDANTIC -pedantic
-Wall -Woverflow -Wextra -Wswitch -Wmissing-prototypes -Wstrict-prototypes
-Wformat -Wformat-security -Wtype-limits -Wundef -Wconversion
-Wsign-compare -Wpointer-arith -Wunused-parameter -Wshadow
-Wno-sign-conversion -Wno-shorten-64-to-32)
# -pedantic
# -Werror is enabled only for development and CI, using Makefile_v1 without NDEBUG
set_property(TARGET ${LIBCMP_NAME} PROPERTY C_STANDARD 90)
# target_compile_features(${LIBGENCMP_NAME} PRIVATE c_std_90) # would have no effect
set_target_properties(${LIBCMP_NAME} PROPERTIES
VERSION ${LIBCMP_VERSION} SOVERSION ${LIBCMP_VERSION_MAJOR}
PUBLIC_HEADER "${INC_PUBLIC_HDRS}"
)
if(NOT TARGET build)
add_custom_target(build COMMAND make all)
endif()
# installation and uninstall
# default destination on Linux and macOS: "/usr/local"
#if(UNIX AND NOT APPLE)
# set(CMAKE_INSTALL_PREFIX "/usr")
#else()
# set(CMAKE_INSTALL_PREFIX "tmp")
#endif()
if(DEFINED ENV{ROOTFS})
set(CMAKE_INSTALL_PREFIX $ENV{ROOTFS} CACHE PATH "comment" FORCE)
endif()
include(GNUInstallDirs) # CMAKE_INSTALL_PREFIX must be set before
install(TARGETS ${LIBCMP_NAME}
LIBRARY
DESTINATION "${CMAKE_INSTALL_LIBDIR}"
COMPONENT lib
PUBLIC_HEADER
DESTINATION "${CMAKE_INSTALL_INCLUDEDIR}/${LIBCMP_NAME}/openssl"
COMPONENT dev
)
include(./Pod2Man)
set(pages
OSSL_CMP_ATAV_set0
OSSL_CRMF_MSG_set1_regCtrl_regToken
OSSL_CMP_MSG_get0_header
OSSL_CMP_CTX_new
OSSL_CMP_MSG_http_perform
OSSL_CRMF_MSG_set1_regInfo_certReq
OSSL_CMP_exec_certreq
OSSL_CMP_SRV_CTX_new
OSSL_CRMF_pbmp_new
OSSL_CMP_HDR_get0_transactionID
OSSL_CMP_STATUSINFO_new
OSSL_HTTP_parse_url
OSSL_CMP_ITAV_new_caCerts
OSSL_CMP_validate_msg
OSSL_HTTP_REQ_CTX
OSSL_CMP_ITAV_set0
OSSL_CRMF_MSG_get0_tmpl
OSSL_HTTP_transfer
OSSL_CMP_log_open
OSSL_CRMF_MSG_set0_validity
)
foreach(page ${pages})
POD2MAN("${CMAKE_CURRENT_SOURCE_DIR}/doc/man3" ${page} 3 "${CMAKE_INSTALL_MANDIR}" dev)
endforeach()
if(NOT TARGET uninstall)
add_custom_target(uninstall
COMMAND xargs -I% rm -vf \${DESTDIR}% <install_manifest.txt
COMMAND rm -vfr "\${DESTDIR}${CMAKE_INSTALL_PREFIX}/${CMAKE_INSTALL_INCLUDEDIR}/cmp"
)
endif()
# cleaning
# https://stackoverflow.com/questions/9680420/looking-for-a-cmake-clean-command-to-clear-up-cmake-output/78133906#78133906
set_property(
DIRECTORY ${CMAKE_CURRENT_BINARY_DIR}
APPEND
PROPERTY ADDITIONAL_CLEAN_FILES
# only works for predefined names as globbing would be done on cmake run
install_manifest.txt install_manifest_dev.txt install_manifest_lib.txt
_CPack_Packages changelog.gz debian/.debhelper/
)
if(NOT TARGET clean_all)
add_custom_target(clean_all
COMMAND ${CMAKE_BUILD_TOOL} clean
# cowardly not doing rm -r ${CMAKE_CURRENT_BINARY_DIR} ${CMAKE_BINARY_DIR}
COMMAND find . -name "*.o" -o -regex "./libcmp-.*" | xargs rm
# after the following, cannot call this target again:
COMMAND find . ( -name "*.cmake" -o -name Makefile ) | xargs rm
COMMAND find . -name CMakeFiles | xargs rm -r
COMMAND rm CMakeCache.txt
VERBATIM
)
endif()
if(NOT DEFINED CPACK_PACKAGE_NAME)
# generate Debian etc. packages using CPack, relying on installation defined above
SET(CPACK_PACKAGE_NAME ${PROJECT_NAME})
SET(CPACK_PACKAGE_HOMEPAGE_URL "https://github.com/mpeylo/cmpossl")
SET(CPACK_RESOURCE_FILE_README "${CMAKE_SOURCE_DIR}/README.md")
SET(CPACK_RESOURCE_FILE_LICENSE "${CMAKE_SOURCE_DIR}/LICENSE.txt")
SET(CPACK_PACKAGE_VENDOR "Siemens")
set(CPACK_PACKAGE_CONTACT "David von Oheimb <[email protected]>")
set(CPACK_PACKAGE_VERSION ${LIBCMP_VERSION})
set(CPACK_PACKAGE_VERSION_MAJOR ${LIBCMP_VERSION_MAJOR})
set(CPACK_PACKAGE_VERSION_MINOR ${LIBCMP_VERSION_MINOR})
set(CPACK_STRIP_FILES ON)
set(CPACK_COMPONENT_LIB_DESCRIPTION "Certificate Management Prototocl (CMP) library
Adds CMP support to OpenSSL in the form of an extra library")
set(CPACK_COMPONENT_DEV_DESCRIPTION "libcmp C headers and documentation
Development support for standalone CMP library")
if(CMAKE_SYSTEM_NAME MATCHES "Linux")
set(CPACK_GENERATOR "DEB")
set(EXT "deb")
# see also https://gitlab.kitware.com/cmake/cmake/-/issues/24929 and
# https://stackoverflow.com/questions/46490448/how-i-can-add-a-changelog-in-deb-with-cmake
add_custom_command(
DEPENDS "${CMAKE_CURRENT_SOURCE_DIR}/debian/changelog"
COMMAND gzip -cn9 "${CMAKE_CURRENT_SOURCE_DIR}/debian/changelog"
> "${CMAKE_CURRENT_BINARY_DIR}/changelog.gz"
OUTPUT "${CMAKE_CURRENT_BINARY_DIR}/changelog.gz"
)
if(NOT TARGET changelog)
add_custom_target(changelog ALL DEPENDS "${CMAKE_CURRENT_BINARY_DIR}/changelog.gz")
endif()
set(CPACK_DEB_COMPONENT_INSTALL ON)
set(CPACK_DEBIAN_FILE_NAME DEB-DEFAULT)
set(CPACK_DEBIAN_LIB_PACKAGE_NAME "${PROJECT_NAME}")
set(CPACK_DEBIAN_DEV_PACKAGE_ARCHITECTURE "all")
set(CPACK_DEBIAN_LIB_PACKAGE_SECTION "libs")
set(CPACK_DEBIAN_DEV_PACKAGE_SECTION "devel")
set(CPACK_DEBIAN_PACKAGE_GENERATE_SHLIBS ON)
set(CPACK_DEBIAN_ENABLE_COMPONENT_DEPENDS ON)
set(CPACK_DEBIAN_PACKAGE_SHLIBDEPS ON)
set(CPACK_DEBIAN_PACKAGE_SHLIBDEPS_PRIVATE_DIRS "${CMAKE_CURRENT_BINARY_DIR}")
set(CPACK_DEBIAN_DEV_PACKAGE_DEPENDS "libcmp (>= ${CPACK_PACKAGE_VERSION})")
set(CPACK_DEBIAN_DEV_PACKAGE_SUGGESTS "libssl-dev")
# see also https://gitlab.kitware.com/cmake/cmake/-/issues/21834
# CPack Deb does not create postinst when installing to /usr/lib/x86_64-linux-gnu
set(CPACK_DEBIAN_LIB_PACKAGE_CONTROL_EXTRA "${CMAKE_CURRENT_SOURCE_DIR}/debian /extra/triggers")
set(CPACK_DEBIAN_LIB_PACKAGE_CONTROL_STRICT_PERMISSION TRUE)
else()
#if(APPLE)
# set(CPACK_GENERATOR "Bundle")
# set(EXT "bundle")
# set(CPACK_BUNDLE_NAME "${PROJECT_NAME}")
#else()
set(CPACK_GENERATOR "ZIP")
set(EXT "zip")
#endif(APPLE)
endif()
set(CPACK_SOURCE_GENERATOR "TGZ")
#set(CPACK_SET_DESTDIR TRUE) # prevents package creation error when using cpack
set(CPACK_VERBATIM_VARIABLES YES)
set(CPACK_SOURCE_IGNORE_FILES
${CPACK_IGNORE_FILES}
~$
/\\.git/
\\.git$
\\.deb$
\\.gz$
\\.zip$
\\.so
\\.dylib$
/attic/
/tmp/
/Makefile$
CMakeFiles/
_CPack_Packages/
\\.cmake$
/CMakeCache.txt$
/compile_commands.json$
/install_manifest.*\\.txt$
/changelog\.gz$
/debian/tmp/
\\.substvars$
\\.log$
/debian/\\.debhelper/
/debian/files$
/debian/debhelper-build-stamp$
/debian/${PROJECT_NAME}/
/debian/${PROJECT_NAME}-dev/
\\.3$
\\.3\.gz$
)
include(CPack)
# see also https://gitlab.kitware.com/cmake/cmake/-/issues/21832
# CPack Deb lacks a way to configure copyright files by component
foreach(component IN LISTS CPACK_COMPONENTS_ALL)
if(${component} STREQUAL "lib")
set(suffix "")
else()
set(suffix "-${component}")
endif()
if(CMAKE_SYSTEM_NAME MATCHES "Linux")
install(FILES
"${CMAKE_CURRENT_SOURCE_DIR}/debian/copyright"
"${CMAKE_CURRENT_BINARY_DIR}/changelog.gz"
DESTINATION "${CMAKE_INSTALL_DOCDIR}${suffix}"
COMPONENT ${component}
)
endif()
endforeach()
if(NOT TARGET ${EXT})
set (pack_full_name
"${CMAKE_CURRENT_BINARY_DIR}/${CPACK_PACKAGE_NAME}-dev_${CPACK_PACKAGE_VERSION}_all.${EXT}")
add_custom_command(
OUTPUT "${pack_full_name}"
DEPENDS build
COMMENT "Building packages possibly including doxygen run"
COMMAND cpack # --config CPackConfig.cmake
COMMAND cpack --config CPackSourceConfig.cmake
)
add_custom_target(${EXT} DEPENDS ${pack_full_name})
endif()
endif(NOT DEFINED CPACK_PACKAGE_NAME)