1 find_program(GPERF gperf)
3 message(FATAL_ERROR "Can't find gperf")
6 if(WITH_RADOSGW_SELECT_PARQUET)
7 set(ARROW_LIBRARIES Arrow::Arrow Arrow::Parquet)
8 add_definitions(-D_ARROW_EXIST)
9 message("-- arrow is installed, radosgw/s3select-op is able to process parquet objects")
10 endif(WITH_RADOSGW_SELECT_PARQUET)
12 function(gperf_generate input output)
15 COMMAND ${GPERF} ${input} | sed "s/register //g" > ${output}
17 COMMENT "Generate ${output}"
21 find_package(ICU 52.0 COMPONENTS uc REQUIRED)
23 set(librgw_common_srcs
24 services/svc_finisher.cc
25 services/svc_bi_rados.cc
26 services/svc_bilog_rados.cc
27 services/svc_bucket.cc
28 services/svc_bucket_sobj.cc
29 services/svc_bucket_sync_sobj.cc
31 services/svc_config_key_rados.cc
34 services/svc_meta_be.cc
35 services/svc_meta_be_otp.cc
36 services/svc_meta_be_sobj.cc
37 services/svc_notify.cc
40 services/svc_sync_modules.cc
42 services/svc_sys_obj.cc
43 services/svc_sys_obj_cache.cc
44 services/svc_sys_obj_core.cc
45 services/svc_tier_rados.cc
47 services/svc_user_rados.cc
49 services/svc_zone_utils.cc
89 rgw_sync_error_repo.cc
91 rgw_sync_module_aws.cc
93 rgw_sync_module_es_rest.cc
94 rgw_sync_module_log.cc
95 rgw_sync_module_pubsub.cc
99 rgw_notify_event_type.cc
100 rgw_sync_module_pubsub_rest.cc
105 rgw_period_history.cc
112 rgw_object_expirer_core.cc
118 rgw_putobj_processor.cc
128 rgw_rest_pubsub_common.cc
146 rgw_crypt_sanitize.cc
148 rgw_rest_user_policy.cc
153 rgw_rest_oidc_provider.cc
165 rgw_bucket_encryption.cc
168 if(WITH_RADOSGW_AMQP_ENDPOINT)
169 list(APPEND librgw_common_srcs rgw_amqp.cc)
171 if(WITH_RADOSGW_KAFKA_ENDPOINT)
172 list(APPEND librgw_common_srcs rgw_kafka.cc)
174 if(WITH_RADOSGW_DBSTORE)
175 add_subdirectory(store/dbstore)
176 list(APPEND librgw_common_srcs rgw_sal_dbstore.cc)
179 list(APPEND librgw_common_srcs rgw_tracer.cc)
182 add_library(rgw_common STATIC ${librgw_common_srcs})
184 include(CheckCXXCompilerFlag)
185 check_cxx_compiler_flag("-Wimplicit-const-int-float-conversion"
186 COMPILER_SUPPORTS_WARN_IMPLICIT_CONST_INT_FLOAT_CONVERSION)
187 if(COMPILER_SUPPORTS_WARN_IMPLICIT_CONST_INT_FLOAT_CONVERSION)
188 target_compile_definitions(common-objs PRIVATE
189 HAVE_WARN_IMPLICIT_CONST_INT_FLOAT_CONVERSION)
192 target_link_libraries(rgw_common
218 target_include_directories(rgw_common
219 SYSTEM PUBLIC "services"
220 PUBLIC "${CMAKE_SOURCE_DIR}/src/rgw"
221 PRIVATE "${LUA_INCLUDE_DIR}")
222 if(WITH_RADOSGW_KAFKA_ENDPOINT)
223 # used by rgw_kafka.cc
224 target_link_libraries(rgw_common
228 if(WITH_RADOSGW_AMQP_ENDPOINT)
229 # used by rgw_amqp.cc
230 target_link_libraries(rgw_common
236 target_link_libraries(rgw_common
240 if(WITH_RADOSGW_LUA_PACKAGES)
241 target_link_libraries(rgw_common
242 PRIVATE Boost::filesystem StdFilesystem::filesystem)
246 # rgw/rgw_op.cc includes "tracing/rgw_op.h"
247 # rgw/rgw_rados.cc includes "tracing/rgw_rados.h"
248 add_dependencies(rgw_common rgw_op-tp rgw_rados-tp)
252 add_dependencies(rgw_common ${jaeger_base})
253 target_link_libraries(rgw_common PUBLIC ${jaeger_base})
256 if(WITH_RADOSGW_DBSTORE)
257 target_link_libraries(rgw_common PRIVATE global dbstore)
264 rgw_http_client_curl.cc
268 rgw_realm_reloader.cc
281 rgw_rest_ratelimit.cc
288 gperf_generate(${CMAKE_SOURCE_DIR}/src/rgw/rgw_iam_policy_keywords.gperf
289 rgw_iam_policy_keywords.frag.cc)
290 set_source_files_properties(rgw_iam_policy.cc PROPERTIES
291 OBJECT_DEPENDS ${CMAKE_BINARY_DIR}/src/rgw/rgw_iam_policy_keywords.frag.cc
292 COMPILE_FLAGS -I${CMAKE_BINARY_DIR}/src/rgw)
295 add_library(rgw_a STATIC
298 target_compile_definitions(rgw_a PUBLIC "-DCLS_CLIENT_HIDE_IOCTX")
299 target_include_directories(rgw_a PUBLIC "${CMAKE_SOURCE_DIR}/src/dmclock/support/src")
300 target_include_directories(rgw_a SYSTEM PUBLIC "../rapidjson/include")
301 target_include_directories(rgw_a SYSTEM PUBLIC "${CMAKE_SOURCE_DIR}/src/rgw")
303 if(WITH_RADOSGW_AMQP_ENDPOINT)
304 find_package(RabbitMQ REQUIRED)
306 if(WITH_RADOSGW_KAFKA_ENDPOINT)
307 find_package(RDKafka 0.9.2 REQUIRED)
310 target_link_libraries(rgw_a
321 if(WITH_CURL_OPENSSL)
322 # used by rgw_http_client_curl.cc
323 target_link_libraries(rgw_a PRIVATE OpenSSL::Crypto)
328 list(APPEND rgw_libs ${LUA_LIBRARIES})
330 set(rgw_schedulers_srcs
331 rgw_dmclock_scheduler_ctx.cc
332 rgw_dmclock_sync_scheduler.cc
333 rgw_dmclock_async_scheduler.cc)
335 rgw_loadgen_process.cc
337 rgw_asio_frontend.cc)
339 add_library(rgw_schedulers STATIC ${rgw_schedulers_srcs})
340 target_link_libraries(rgw_schedulers
341 PUBLIC dmclock::dmclock spawn)
343 add_library(radosgw SHARED
347 rgw_kmip_client_impl.cc)
349 target_compile_definitions(radosgw PUBLIC "-DCLS_CLIENT_HIDE_IOCTX")
350 target_include_directories(radosgw
351 PUBLIC "${CMAKE_SOURCE_DIR}/src/dmclock/support/src"
352 PRIVATE "${CMAKE_SOURCE_DIR}/src/libkmip")
353 target_include_directories(radosgw SYSTEM PUBLIC "../rapidjson/include")
355 target_link_libraries(radosgw
356 PRIVATE ${rgw_libs} rgw_schedulers kmip
357 PUBLIC dmclock::dmclock
359 if(WITH_RADOSGW_BEAST_OPENSSL)
360 # used by rgw_asio_frontend.cc
361 target_link_libraries(radosgw PRIVATE OpenSSL::SSL)
363 set_target_properties(radosgw PROPERTIES OUTPUT_NAME radosgw VERSION 2.0.0
365 install(TARGETS radosgw DESTINATION ${CMAKE_INSTALL_LIBDIR})
367 add_executable(radosgwd radosgw.cc)
368 target_link_libraries(radosgwd radosgw librados
369 cls_rgw_client cls_otp_client cls_lock_client cls_refcount_client
370 cls_log_client cls_timeindex_client neorados_cls_fifo
371 cls_version_client cls_user_client
374 ${CURL_LIBRARIES} ${EXPAT_LIBRARIES} ${BLKID_LIBRARIES}
376 set_target_properties(radosgwd PROPERTIES OUTPUT_NAME radosgw)
377 install(TARGETS radosgwd DESTINATION bin)
379 set(radosgw_admin_srcs
381 rgw_sync_checkpoint.cc
383 add_executable(radosgw-admin ${radosgw_admin_srcs})
384 target_link_libraries(radosgw-admin ${rgw_libs} librados
385 cls_rgw_client cls_otp_client cls_lock_client cls_refcount_client
386 cls_log_client cls_timeindex_client neorados_cls_fifo
387 cls_version_client cls_user_client
390 ${CURL_LIBRARIES} ${EXPAT_LIBRARIES} ${BLKID_LIBRARIES})
391 install(TARGETS radosgw-admin DESTINATION bin)
395 add_executable(radosgw-es ${radosgw_es_srcs})
396 target_link_libraries(radosgw-es ${rgw_libs} librados
397 cls_rgw_client cls_otp_client cls_lock_client cls_refcount_client
398 cls_log_client cls_timeindex_client neorados_cls_fifo
399 cls_version_client cls_user_client
401 ${CURL_LIBRARIES} ${EXPAT_LIBRARIES} ${BLKID_LIBRARIES})
402 install(TARGETS radosgw-es DESTINATION bin)
404 set(radosgw_token_srcs
406 add_executable(radosgw-token ${radosgw_token_srcs})
407 target_link_libraries(radosgw-token librados
408 global ${ALLOC_LIBS})
409 install(TARGETS radosgw-token DESTINATION bin)
411 set(radosgw_object_expirer_srcs
412 rgw_object_expirer.cc)
413 add_executable(radosgw-object-expirer ${radosgw_object_expirer_srcs})
414 target_link_libraries(radosgw-object-expirer ${rgw_libs} librados
415 cls_rgw_client cls_otp_client cls_lock_client cls_refcount_client
416 cls_log_client cls_timeindex_client neorados_cls_fifo
417 cls_version_client cls_user_client
419 ${CURL_LIBRARIES} ${EXPAT_LIBRARIES})
420 install(TARGETS radosgw-object-expirer DESTINATION bin)
425 add_library(rgw SHARED ${librgw_srcs})
426 target_link_libraries(rgw
446 if(WITH_RADOSGW_AMQP_ENDPOINT)
447 target_link_libraries(rgw PRIVATE RabbitMQ::RabbitMQ)
448 target_link_libraries(rgw PRIVATE OpenSSL::SSL)
451 if(WITH_RADOSGW_KAFKA_ENDPOINT)
452 target_link_libraries(rgw PRIVATE RDKafka::RDKafka)
455 target_link_libraries(rgw PRIVATE ${LUA_LIBRARIES})
457 set_target_properties(rgw PROPERTIES OUTPUT_NAME rgw VERSION 2.0.0
459 install(TARGETS rgw DESTINATION ${CMAKE_INSTALL_LIBDIR})
462 add_executable(ceph_rgw_jsonparser
464 target_link_libraries(ceph_rgw_jsonparser
468 add_executable(ceph_rgw_multiparser
470 target_link_libraries(ceph_rgw_multiparser
482 rgw-gap-list-comparator