15 #ifndef CONCEALER__SERVICE_HPP_
16 #define CONCEALER__SERVICE_HPP_
18 #include <autoware_adapi_v1_msgs/msg/response_status.hpp>
21 #include <rclcpp/rclcpp.hpp>
24 #include <tier4_external_api_msgs/msg/response_status.hpp>
25 #include <tier4_rtc_msgs/srv/auto_mode_with_module.hpp>
26 #include <type_traits>
35 rclcpp::Logger logger;
37 typename rclcpp::Client<T>::SharedPtr client;
39 rclcpp::WallRate validation_rate;
42 template <
typename Node>
45 const std::chrono::nanoseconds validation_interval = std::chrono::seconds(1))
46 : service_name(service_name),
47 logger(node.get_logger()),
48 client(node.template create_client<T>(service_name, rmw_qos_profile_default)),
49 validation_rate(validation_interval)
53 auto operator()(
const typename T::Request::SharedPtr & request, std::size_t attempts_count)
56 while (!client->service_is_ready()) {
57 RCLCPP_INFO_STREAM(logger, service_name <<
" service is not ready.");
58 validation_rate.sleep();
61 auto send = [
this](
const auto & request) {
62 if (
auto future = client->async_send_request(request);
63 future.wait_for(validation_rate.period()) == std::future_status::ready) {
64 return std::optional<typename rclcpp::Client<T>::SharedFuture>(future);
66 RCLCPP_ERROR_STREAM(logger, service_name <<
" service request has timed out.");
67 return std::optional<typename rclcpp::Client<T>::SharedFuture>();
71 for (std::size_t attempt = 0; attempt < attempts_count; ++attempt, validation_rate.sleep()) {
72 if (
const auto & service_call_result = send(request)) {
73 if constexpr (DetectMember_status<typename T::Response>::value) {
74 if constexpr (std::is_same_v<
75 tier4_external_api_msgs::msg::ResponseStatus,
76 decltype(T::Response::status)>) {
77 if (
const auto & service_call_status = service_call_result->get()->status;
80 logger, service_name <<
" service request has been accepted"
81 << (service_call_status.message.empty()
83 :
" (" + service_call_status.message +
")."));
88 <<
" service request was accepted, but ResponseStatus is FAILURE"
89 << (service_call_status.message.empty()
91 :
" (" + service_call_status.message +
")"));
93 }
else if constexpr (std::is_same_v<
94 autoware_adapi_v1_msgs::msg::ResponseStatus,
95 decltype(T::Response::status)>) {
96 if (
const auto & service_call_status = service_call_result->get()->status;
97 service_call_status.success) {
99 logger, service_name <<
" service request has been accepted"
100 << (service_call_status.message.empty()
102 :
" (" + service_call_status.message +
")."));
106 logger, service_name <<
" service request was accepted, but "
107 "ResponseStatus::success is false with error code: "
108 << service_call_status.code <<
", and message: "
109 << (service_call_status.message.empty()
111 :
" (" + service_call_status.message +
")"));
114 RCLCPP_INFO_STREAM(logger, service_name <<
" service request has been accepted.");
117 }
else if constexpr (DetectMember_success<typename T::Response>::value) {
118 if constexpr (std::is_same_v<
bool, decltype(T::Response::success)>) {
119 if (service_call_result->get()->success) {
120 RCLCPP_INFO_STREAM(logger, service_name <<
" service request has been accepted.");
125 <<
" service request has been accepted, but Response::success is false.");
128 RCLCPP_INFO_STREAM(logger, service_name <<
" service request has been accepted.");
132 RCLCPP_INFO_STREAM(logger, service_name <<
" service request has been accepted.");
139 "Requested the service ", std::quoted(service_name),
" ", attempts_count,
140 " times, but was not successful.");
Definition: service.hpp:32
Service(const std::string &service_name, Node &node, const std::chrono::nanoseconds validation_interval=std::chrono::seconds(1))
Definition: service.hpp:43
auto operator()(const typename T::Request::SharedPtr &request, std::size_t attempts_count) -> void
Definition: service.hpp:53
Definition: autoware_universe.hpp:40
constexpr int SUCCESS
Definition: constants.hpp:22
std::string string
Definition: junit5.hpp:26
Autoware encountered some problem that led to a simulation failure.
Definition: exception.hpp:41