15 #include "opennav_docking/dock_database.hpp"
17 namespace opennav_docking
22 dock_loader_(
"opennav_docking_core",
"opennav_docking_core::ChargingDock")
27 dock_instances_.clear();
28 dock_plugins_.clear();
29 reload_db_service_.reset();
33 const nav2::LifecycleNode::WeakPtr & parent,
34 std::shared_ptr<tf2_ros::Buffer> tf)
37 auto node = node_.lock();
42 "An error occurred while getting the dock plugins!");
49 "An error occurred while getting the dock instances!");
55 "Docking Server has %u dock types and %u dock instances available.",
56 this->plugin_size(), this->instance_size());
58 reload_db_service_ = node->create_service<nav2_msgs::srv::ReloadDockDatabase>(
62 std::placeholders::_1, std::placeholders::_2, std::placeholders::_3));
69 DockPluginMap::iterator it;
70 for (it = dock_plugins_.begin(); it != dock_plugins_.end(); ++it) {
71 it->second->activate();
77 DockPluginMap::iterator it;
78 for (it = dock_plugins_.begin(); it != dock_plugins_.end(); ++it) {
79 it->second->deactivate();
84 const std::shared_ptr<rmw_request_id_t>,
85 const std::shared_ptr<nav2_msgs::srv::ReloadDockDatabase::Request> request,
86 std::shared_ptr<nav2_msgs::srv::ReloadDockDatabase::Response> response)
88 if (!mutex_->try_lock()) {
89 RCLCPP_ERROR(node_.lock()->get_logger(),
"Cannot reload database while docking!");
90 response->success =
false;
94 auto node = node_.lock();
95 DockMap dock_instances;
96 if (utils::parseDockFile(request->filepath, node, dock_instances)) {
97 dock_instances_ = dock_instances;
98 response->success =
true;
101 "Dock database reloaded from file %s.", request->filepath.c_str());
105 response->success =
false;
112 ChargingDock::Ptr dock_plugin{
nullptr};
118 dock_instance->plugin = dock_plugin;
119 return dock_instance;
128 auto it = dock_instances_.find(dock_id);
129 if (it != dock_instances_.end()) {
130 return &(it->second);
138 if (type.empty() && dock_plugins_.size() == 1) {
139 return dock_plugins_.begin()->second;
142 auto it = dock_plugins_.find(type);
143 if (it != dock_plugins_.end()) {
150 const nav2::LifecycleNode::SharedPtr & node,
151 std::shared_ptr<tf2_ros::Buffer> tf)
153 std::vector<std::string> docks_plugins;
154 if (!node->has_parameter(
"dock_plugins")) {
155 node->declare_parameter(
"dock_plugins", rclcpp::ParameterType::PARAMETER_STRING_ARRAY);
157 if (!node->get_parameter(
"dock_plugins", docks_plugins)) {
158 RCLCPP_ERROR(node->get_logger(),
"Charging dock plugins not given!");
162 if (docks_plugins.size() < 1u) {
163 RCLCPP_ERROR(node->get_logger(),
"Charging dock plugins empty! Must provide 1.");
167 for (
size_t i = 0; i != docks_plugins.size(); i++) {
169 std::string plugin_type = nav2::get_plugin_type_param(
170 node, docks_plugins[i]);
171 opennav_docking_core::ChargingDock::Ptr dock =
172 dock_loader_.createUniqueInstance(plugin_type);
174 node->get_logger(),
"Created charging dock plugin %s of type %s",
175 docks_plugins[i].c_str(), plugin_type.c_str());
176 dock->configure(node, docks_plugins[i], tf);
177 dock_plugins_.insert({docks_plugins[i], dock});
178 }
catch (
const std::exception & ex) {
180 node->get_logger(),
"Failed to create Charging Dock plugin. Exception: %s",
191 using rclcpp::ParameterType::PARAMETER_STRING;
192 using rclcpp::ParameterType::PARAMETER_STRING_ARRAY;
195 std::string dock_filepath;
196 if (!node->has_parameter(
"dock_database")) {
197 node->declare_parameter(
"dock_database", PARAMETER_STRING);
199 if (node->get_parameter(
"dock_database", dock_filepath)) {
201 node->get_logger(),
"Loading dock from database file %s.", dock_filepath.c_str());
203 return utils::parseDockFile(dock_filepath, node, dock_instances_);
204 }
catch (YAML::BadConversion & e) {
207 "Dock database (%s) is malformed: %s.", dock_filepath.c_str(), e.what());
214 std::vector<std::string> docks_param;
215 if (!node->has_parameter(
"docks")) {
216 node->declare_parameter(
"docks", PARAMETER_STRING_ARRAY);
218 if (node->get_parameter(
"docks", docks_param)) {
219 RCLCPP_INFO(node->get_logger(),
"Loading docks from parameter file.");
220 return utils::parseDockParams(docks_param, node, dock_instances_);
225 "Dock database filepath nor dock parameters set. "
226 "Docking actions can only be executed specifying the dock pose via the action request. "
227 "Or update the dock database via the reload_database service.");
233 return dock_plugins_.size();
238 return dock_instances_.size();
Dock * findDock(const std::string &dock_id)
Find a dock instance & plugin in the databases from ID.
Dock * findDockInstance(const std::string &dock_id)
Find a dock instance in the database from ID.
ChargingDock::Ptr findDockPlugin(const std::string &type)
Find a dock plugin to use for a given type.
void reloadDbCb(const std::shared_ptr< rmw_request_id_t > request_header, const std::shared_ptr< nav2_msgs::srv::ReloadDockDatabase::Request > request, std::shared_ptr< nav2_msgs::srv::ReloadDockDatabase::Response > response)
Service request to reload database of docks.
void deactivate()
An deactivation method.
unsigned int plugin_size() const
Get the number of dock types in the database.
~DockDatabase()
A destructor for opennav_docking::DockDatabase.
unsigned int instance_size() const
Get the number of docks in the database.
bool getDockInstances(const nav2::LifecycleNode::SharedPtr &node)
Populate database of dock instances.
bool getDockPlugins(const nav2::LifecycleNode::SharedPtr &node, std::shared_ptr< tf2_ros::Buffer > tf)
Populate database of dock type plugins.
DockDatabase(std::shared_ptr< std::mutex > mutex=std::make_shared< std::mutex >())
A constructor for opennav_docking::DockDatabase.
void activate()
An activation method.
bool initialize(const nav2::LifecycleNode::WeakPtr &parent, std::shared_ptr< tf2_ros::Buffer > tf)
A setup function to populate database.
Dock was not found in the provided dock database.
Dock plugin provided in the database or action was invalid.