diff options
Diffstat (limited to 'src/rgw/CMakeLists.txt')
-rw-r--r-- | src/rgw/CMakeLists.txt | 407 |
1 files changed, 407 insertions, 0 deletions
diff --git a/src/rgw/CMakeLists.txt b/src/rgw/CMakeLists.txt new file mode 100644 index 00000000..12f831fb --- /dev/null +++ b/src/rgw/CMakeLists.txt @@ -0,0 +1,407 @@ +add_custom_target(civetweb_h + COMMAND ${CMAKE_COMMAND} -E make_directory + "${CMAKE_BINARY_DIR}/src/include/civetweb" + COMMAND ${CMAKE_COMMAND} -E copy_if_different + "${CMAKE_SOURCE_DIR}/src/civetweb/include/civetweb.h" + "${CMAKE_BINARY_DIR}/src/include/civetweb" + COMMENT "keep civetweb.h up-to-date") + +find_program(GPERF gperf) +if(NOT GPERF) + message(FATAL_ERROR "Can't find gperf") +endif() +function(gperf_generate input output) + add_custom_command( + OUTPUT ${output} + COMMAND ${GPERF} ${input} | sed "s/register //g" > ${output} + DEPENDS ${input} + COMMENT "Generate ${output}" + ) +endfunction() + +if(Boost_VERSION VERSION_GREATER 1.73) + add_definitions(-DBOOST_ASIO_USE_TS_EXECUTOR_AS_DEFAULT) +endif() + +set(librgw_common_srcs + services/svc_finisher.cc + services/svc_notify.cc + services/svc_quota.cc + services/svc_sync_modules.cc + services/svc_rados.cc + services/svc_sys_obj.cc + services/svc_sys_obj_cache.cc + services/svc_sys_obj_core.cc + services/svc_zone.cc + services/svc_zone_utils.cc + rgw_service.cc + rgw_acl.cc + rgw_acl_s3.cc + rgw_acl_swift.cc + rgw_aio_throttle.cc + rgw_auth.cc + rgw_auth_s3.cc + rgw_arn.cc + rgw_basic_types.cc + rgw_bucket.cc + rgw_cache.cc + rgw_common.cc + rgw_compression.cc + rgw_etag_verifier.cc + rgw_cors.cc + rgw_cors_s3.cc + rgw_dencoder.cc + rgw_env.cc + rgw_es_query.cc + rgw_formats.cc + rgw_gc.cc + rgw_http_client.cc + rgw_json_enc.cc + rgw_keystone.cc + rgw_ldap.cc + rgw_lc.cc + rgw_lc_s3.cc + rgw_metadata.cc + rgw_multi.cc + rgw_multi_del.cc + rgw_pubsub.cc + rgw_sync.cc + rgw_data_sync.cc + rgw_sync_counters.cc + rgw_sync_module.cc + rgw_sync_module_aws.cc + rgw_sync_module_es.cc + rgw_sync_module_es_rest.cc + rgw_sync_module_log.cc + rgw_sync_module_pubsub.cc + rgw_pubsub_push.cc + rgw_notify.cc + rgw_notify_event_type.cc + rgw_sync_module_pubsub_rest.cc + rgw_sync_log_trim.cc + rgw_sync_trace.cc + rgw_period_history.cc + rgw_period_puller.cc + rgw_reshard.cc + rgw_coroutine.cc + rgw_cr_rados.cc + rgw_cr_rest.cc + rgw_cr_tools.cc + rgw_object_expirer_core.cc + rgw_op.cc + rgw_otp.cc + rgw_policy_s3.cc + rgw_putobj.cc + rgw_putobj_processor.cc + rgw_quota.cc + rgw_rados.cc + rgw_resolve.cc + rgw_rest.cc + rgw_rest_client.cc + rgw_rest_conn.cc + rgw_rest_log.cc + rgw_rest_metadata.cc + rgw_rest_pubsub.cc + rgw_rest_pubsub_common.cc + rgw_rest_realm.cc + rgw_rest_role.cc + rgw_rest_s3.cc + rgw_role.cc + rgw_string.cc + rgw_tag.cc + rgw_tag_s3.cc + rgw_tools.cc + rgw_user.cc + rgw_website.cc + rgw_xml.cc + rgw_xml_enc.cc + rgw_torrent.cc + rgw_crypt.cc + rgw_crypt_sanitize.cc + rgw_iam_policy.cc + rgw_rest_user_policy.cc + rgw_zone.cc + rgw_sts.cc + rgw_rest_sts.cc + rgw_perf_counters.cc + rgw_object_lock.cc + rgw_rest_iam.cc + rgw_url.cc) + +if(WITH_RADOSGW_AMQP_ENDPOINT) + find_package(RabbitMQ REQUIRED) +endif() +if(WITH_RADOSGW_KAFKA_ENDPOINT) + find_package(RDKafka 1.9.2) + if(NOT RDKafka_FOUND) + set(WITH_RADOSGW_KAFKA_ENDPOINT OFF CACHE BOOL "Rados Gateway's pubsub support for Kafka push endpoint" FORCE) + message(STATUS "Disabling Kafka endpoint support") + endif() +endif() + +if(WITH_RADOSGW_AMQP_ENDPOINT) + list(APPEND librgw_common_srcs rgw_amqp.cc) +endif() +if(WITH_RADOSGW_KAFKA_ENDPOINT) + list(APPEND librgw_common_srcs rgw_kafka.cc) +endif() + +add_library(rgw_common OBJECT ${librgw_common_srcs}) + +target_include_directories(rgw_common SYSTEM PUBLIC "services") +target_include_directories(rgw_common PUBLIC "${CMAKE_SOURCE_DIR}/src/dmclock/support/src") + +if(WITH_LTTNG) + # rgw/rgw_op.cc includes "tracing/rgw_op.h" + # rgw/rgw_rados.cc includes "tracing/rgw_rados.h" + add_dependencies(rgw_common rgw_op-tp rgw_rados-tp) +endif() + +set(rgw_a_srcs + rgw_auth_keystone.cc + rgw_client_io.cc + rgw_frontend.cc + rgw_http_client_curl.cc + rgw_loadgen.cc + rgw_log.cc + rgw_period_pusher.cc + rgw_realm_reloader.cc + rgw_realm_watcher.cc + rgw_os_lib.cc + rgw_process.cc + rgw_rest_bucket.cc + rgw_rest_config.cc + rgw_rest_log.cc + rgw_rest_metadata.cc + rgw_rest_realm.cc + rgw_rest_swift.cc + rgw_rest_usage.cc + rgw_rest_user.cc + rgw_swift_auth.cc + rgw_usage.cc + rgw_opa.cc + rgw_sts.cc + rgw_rest_sts.cc) + +gperf_generate(${CMAKE_SOURCE_DIR}/src/rgw/rgw_iam_policy_keywords.gperf + rgw_iam_policy_keywords.frag.cc) +set_source_files_properties(rgw_iam_policy.cc PROPERTIES + OBJECT_DEPENDS ${CMAKE_BINARY_DIR}/src/rgw/rgw_iam_policy_keywords.frag.cc + COMPILE_FLAGS -I${CMAKE_BINARY_DIR}/src/rgw) + + +if (WITH_RADOSGW_FCGI_FRONTEND) + list(APPEND rgw_a_srcs rgw_fcgi.cc) +endif() + +add_library(rgw_a STATIC + ${rgw_a_srcs} + $<TARGET_OBJECTS:rgw_common>) + +add_dependencies(rgw_a civetweb_h) + +target_include_directories(rgw_a PUBLIC "${CMAKE_SOURCE_DIR}/src/dmclock/support/src") +target_include_directories(rgw_a SYSTEM PUBLIC "../rapidjson/include") + +target_link_libraries(rgw_a + PRIVATE + librados cls_otp_client cls_lock_client cls_rgw_client cls_refcount_client + cls_log_client cls_timeindex_client cls_version_client + cls_user_client ceph-common common_utf8 global + ${CURL_LIBRARIES} + ${EXPAT_LIBRARIES} + ${OPENLDAP_LIBRARIES} ${CRYPTO_LIBS} + OATH::OATH) + +if(WITH_CURL_OPENSSL) + # used by rgw_http_client_curl.cc + target_link_libraries(rgw_a PRIVATE OpenSSL::Crypto) +endif() + +if(WITH_BOOST_CONTEXT) + target_link_libraries(rgw_a PRIVATE Boost::coroutine Boost::context) +endif() + +set(rgw_libs rgw_a) +if(WITH_RADOSGW_AMQP_ENDPOINT) + # used by rgw_amqp.cc + list(APPEND rgw_libs RabbitMQ::RabbitMQ) +endif() +if(WITH_RADOSGW_KAFKA_ENDPOINT) + # used by rgw_kafka.cc + list(APPEND rgw_libs RDKafka::RDKafka) +endif() + +set(radosgw_srcs + rgw_loadgen_process.cc + rgw_civetweb.cc + rgw_civetweb_frontend.cc + rgw_civetweb_log.cc + rgw_dmclock_scheduler_ctx.cc + rgw_dmclock_sync_scheduler.cc) + +if (WITH_RADOSGW_FCGI_FRONTEND) + list(APPEND radosgw_srcs rgw_fcgi_process.cc) +endif() + +if(WITH_RADOSGW_BEAST_FRONTEND) + list(APPEND radosgw_srcs + rgw_asio_client.cc + rgw_asio_frontend.cc + rgw_dmclock_async_scheduler.cc) +endif() + +add_library(radosgw_a STATIC ${radosgw_srcs} + $<TARGET_OBJECTS:civetweb_common_objs>) +target_link_libraries(radosgw_a PRIVATE ${rgw_libs}) +if(WITH_RADOSGW_BEAST_FRONTEND AND WITH_RADOSGW_BEAST_OPENSSL) + # used by rgw_asio_frontend.cc + target_link_libraries(radosgw_a PRIVATE OpenSSL::SSL) +endif() + +add_executable(radosgw rgw_main.cc) +target_link_libraries(radosgw radosgw_a librados + cls_rgw_client cls_otp_client cls_lock_client cls_refcount_client + cls_log_client cls_timeindex_client + cls_version_client cls_user_client + global dmclock::dmclock + ${FCGI_LIBRARY} ${LIB_RESOLV} + ${CURL_LIBRARIES} ${EXPAT_LIBRARIES} ${BLKID_LIBRARIES} + ${ALLOC_LIBS}) +install(TARGETS radosgw DESTINATION bin) + +set(radosgw_admin_srcs + rgw_admin.cc + rgw_orphan.cc) +add_executable(radosgw-admin ${radosgw_admin_srcs}) +target_link_libraries(radosgw-admin ${rgw_libs} librados + cls_rgw_client cls_otp_client cls_lock_client cls_refcount_client + cls_log_client cls_timeindex_client + cls_version_client cls_user_client + global ${FCGI_LIBRARY} ${LIB_RESOLV} + ${CURL_LIBRARIES} ${EXPAT_LIBRARIES} ${BLKID_LIBRARIES}) +install(TARGETS radosgw-admin DESTINATION bin) + +set(radosgw_es_srcs + rgw_es_main.cc) +add_executable(radosgw-es ${radosgw_es_srcs}) +target_link_libraries(radosgw-es ${rgw_libs} librados + cls_rgw_client cls_otp_client cls_lock_client cls_refcount_client + cls_log_client cls_timeindex_client + cls_version_client cls_user_client + global ${FCGI_LIBRARY} ${LIB_RESOLV} + ${CURL_LIBRARIES} ${EXPAT_LIBRARIES} ${BLKID_LIBRARIES}) +install(TARGETS radosgw-es DESTINATION bin) + +set(radosgw_token_srcs + rgw_token.cc) +add_executable(radosgw-token ${radosgw_token_srcs}) +target_link_libraries(radosgw-token librados + global ${ALLOC_LIBS}) +install(TARGETS radosgw-token DESTINATION bin) + +set(radosgw_object_expirer_srcs + rgw_object_expirer.cc) +add_executable(radosgw-object-expirer ${radosgw_object_expirer_srcs}) +target_link_libraries(radosgw-object-expirer ${rgw_libs} librados + cls_rgw_client cls_otp_client cls_lock_client cls_refcount_client + cls_log_client cls_timeindex_client + cls_version_client cls_user_client + global ${FCGI_LIBRARY} ${LIB_RESOLV} + ${CURL_LIBRARIES} ${EXPAT_LIBRARIES}) +install(TARGETS radosgw-object-expirer DESTINATION bin) + +set(librgw_srcs + librgw.cc + rgw_file.cc) +add_library(rgw SHARED ${librgw_srcs}) +target_link_libraries(rgw + PRIVATE + ${rgw_libs} + librados + cls_rgw_client + cls_otp_client + cls_lock_client + cls_refcount_client + cls_log_client + cls_timeindex_client + cls_version_client + cls_user_client + global + ${LIB_RESOLV} + ${CURL_LIBRARIES} + ${EXPAT_LIBRARIES} + PUBLIC + dmclock::dmclock) + +if(WITH_RADOSGW_AMQP_ENDPOINT) + target_link_libraries(rgw PRIVATE RabbitMQ::RabbitMQ) +endif() + +if(WITH_RADOSGW_KAFKA_ENDPOINT) + target_link_libraries(rgw PRIVATE RDKafka::RDKafka) +endif() + +set_target_properties(rgw PROPERTIES OUTPUT_NAME rgw VERSION 2.0.0 + SOVERSION 2) +install(TARGETS rgw DESTINATION ${CMAKE_INSTALL_LIBDIR}) + +set(librgw_admin_user_srcs + librgw_admin_user.cc + rgw_admin_user.cc +) +add_library(rgw_admin_user SHARED + ${librgw_admin_user_srcs} + $<TARGET_OBJECTS:rgw_common>) + +add_dependencies(rgw_admin_user civetweb_h) + +target_link_libraries(rgw_admin_user PRIVATE + librados + cls_rgw_client + cls_otp_client + cls_lock_client + cls_refcount_client + cls_log_client + cls_timeindex_client + cls_version_client + cls_user_client + global + ${CURL_LIBRARIES} + ${EXPAT_LIBRARIES} + ${OPENLDAP_LIBRARIES} + dmclock::dmclock) +set_target_properties(rgw_admin_user PROPERTIES OUTPUT_NAME rgw_admin_user VERSION 1.0.0 + SOVERSION 0) +install(TARGETS rgw_admin_user DESTINATION ${CMAKE_INSTALL_LIBDIR}) +if(WITH_RADOSGW_AMQP_ENDPOINT) + target_link_libraries(rgw_admin_user PRIVATE RabbitMQ::RabbitMQ) +endif() +if(WITH_RADOSGW_KAFKA_ENDPOINT) + target_link_libraries(rgw_admin_user PRIVATE RDKafka::RDKafka) +endif() +if(WITH_BOOST_CONTEXT) + target_link_libraries(rgw_admin_user PRIVATE Boost::coroutine Boost::context) +endif() + +if(WITH_TESTS) + add_executable(ceph_rgw_jsonparser + rgw_jsonparser.cc) + target_link_libraries(ceph_rgw_jsonparser + ${rgw_libs} + global) + + add_executable(ceph_rgw_multiparser + rgw_multiparser.cc) + target_link_libraries(ceph_rgw_multiparser + ${rgw_libs} + global) + + install(TARGETS + ceph_rgw_jsonparser + ceph_rgw_multiparser + DESTINATION bin) +endif(WITH_TESTS) + +install(PROGRAMS rgw-orphan-list + DESTINATION bin) |