Skip to content

Commit

Permalink
Add enclave to liveliness token and fix return expectation in get_ent…
Browse files Browse the repository at this point in the history
…ity_names_and_types_by_node

Signed-off-by: Yadunund <[email protected]>
  • Loading branch information
Yadunund committed Jun 22, 2024
1 parent 8d5c271 commit 319de64
Show file tree
Hide file tree
Showing 5 changed files with 42 additions and 13 deletions.
8 changes: 3 additions & 5 deletions rmw_zenoh_cpp/src/detail/graph_cache.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -1040,15 +1040,15 @@ rmw_ret_t GraphCache::get_entity_names_and_types_by_node(
// Check if namespace exists.
NamespaceMap::const_iterator ns_it = graph_.find(node_namespace);
if (ns_it == graph_.end()) {
return RMW_RET_OK;
return RMW_RET_NODE_NAME_NON_EXISTENT;
}

// Check if node exists.
// Since NodeMap is a multimap, this will return the first node with the same
// name that is found.
NodeMap::const_iterator node_it = ns_it->second.find(node_name);
if (node_it == ns_it->second.end()) {
return RMW_RET_OK;
return RMW_RET_NODE_NAME_NON_EXISTENT;
}

// TODO(Yadunund): Support service and client when ready.
Expand All @@ -1061,10 +1061,8 @@ rmw_ret_t GraphCache::get_entity_names_and_types_by_node(
} else if (entity_type == EntityType::Client) {
return fill_names_and_types(node_it->second->clients_, allocator, names_and_types);
} else {
return RMW_RET_OK;
return RMW_RET_UNSUPPORTED;
}

return RMW_RET_OK;
}


Expand Down
10 changes: 7 additions & 3 deletions rmw_zenoh_cpp/src/detail/liveliness_utils.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -72,6 +72,7 @@ enum KeyexprIndex
Nid,
Id,
EntityStr,
Enclave,
Namespace,
NodeName,
TopicName,
Expand Down Expand Up @@ -266,6 +267,7 @@ Entity::Entity(
// An empty namespace from rcl will contain "/" but zenoh does not allow keys with "//".
// Hence we mangle the empty namespace such that splitting the key
// will always result in 5 parts.
keyexpr_parts[KeyexprIndex::Enclave] = mangle_name(node_info_.enclave_);
keyexpr_parts[KeyexprIndex::Namespace] = mangle_name(node_info_.ns_);
keyexpr_parts[KeyexprIndex::NodeName] = mangle_name(node_info_.name_);
// If this entity has a topic info, append it to the token.
Expand Down Expand Up @@ -340,14 +342,15 @@ std::shared_ptr<Entity> Entity::make(const std::string & keyexpr)
if (parts.size() < KEYEXPR_INDEX_MIN + 1) {
RCUTILS_LOG_ERROR_NAMED(
"rmw_zenoh_cpp",
"Received invalid liveliness token");
"Received invalid liveliness token with %lu/%d parts: %s", parts.size(),
KEYEXPR_INDEX_MIN + 1, keyexpr.c_str());
return nullptr;
}
for (const std::string & p : parts) {
if (p.empty()) {
RCUTILS_LOG_ERROR_NAMED(
"rmw_zenoh_cpp",
"Received invalid liveliness token");
"Received invalid liveliness token with empty parts: %s", keyexpr.c_str());
return nullptr;
}
}
Expand Down Expand Up @@ -375,6 +378,7 @@ std::shared_ptr<Entity> Entity::make(const std::string & keyexpr)
std::string & zid = parts[KeyexprIndex::Zid];
std::string & nid = parts[KeyexprIndex::Nid];
std::string & id = parts[KeyexprIndex::Id];
std::string enclave = demangle_name(std::move(parts[KeyexprIndex::Enclave]));
std::string ns = demangle_name(std::move(parts[KeyexprIndex::Namespace]));
std::string node_name = demangle_name(std::move(parts[KeyexprIndex::NodeName]));
std::optional<TopicInfo> topic_info = std::nullopt;
Expand Down Expand Up @@ -408,7 +412,7 @@ std::shared_ptr<Entity> Entity::make(const std::string & keyexpr)
std::move(nid),
std::move(id),
std::move(entity_type),
NodeInfo{std::move(domain_id), std::move(ns), std::move(node_name), ""},
NodeInfo{std::move(domain_id), std::move(ns), std::move(node_name), std::move(enclave)},
std::move(topic_info)});
}

Expand Down
3 changes: 3 additions & 0 deletions rmw_zenoh_cpp/src/detail/rmw_data_types.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -45,6 +45,9 @@
class rmw_context_impl_s final
{
public:
// Enclave, name used to find security artifacts in a sros2 keystore.
char * enclave;

// An owned session.
z_owned_session_t session;

Expand Down
3 changes: 3 additions & 0 deletions rmw_zenoh_cpp/src/rmw_init.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -144,6 +144,9 @@ rmw_init(const rmw_init_options_t * options, rmw_context_t * context)
}
});

// Set the enclave.
context->impl->enclave = options->enclave;

// Initialize context's implementation
context->impl->is_shutdown = false;

Expand Down
31 changes: 26 additions & 5 deletions rmw_zenoh_cpp/src/rmw_zenoh.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -218,6 +218,10 @@ rmw_create_node(
context->impl,
"expected initialized context",
return nullptr);
RMW_CHECK_FOR_NULL_WITH_MSG(
context->impl->enclave,
"expected initialized enclave",
return nullptr);
if (context->impl->is_shutdown) {
RCUTILS_SET_ERROR_MSG("context has been shutdown");
return nullptr;
Expand Down Expand Up @@ -302,7 +306,8 @@ rmw_create_node(
std::to_string(node_data->id),
std::to_string(node_data->id),
rmw_zenoh_cpp::liveliness::EntityType::Node,
rmw_zenoh_cpp::liveliness::NodeInfo{context->actual_domain_id, namespace_, name, ""});
rmw_zenoh_cpp::liveliness::NodeInfo{context->actual_domain_id, namespace_, name,
context->impl->enclave});
if (node_data->entity == nullptr) {
RCUTILS_LOG_ERROR_NAMED(
"rmw_zenoh_cpp",
Expand Down Expand Up @@ -493,6 +498,10 @@ rmw_create_publisher(
context_impl,
"unable to get rmw_context_impl_s",
return nullptr);
RMW_CHECK_FOR_NULL_WITH_MSG(
context_impl->enclave,
"expected initialized enclave",
return nullptr);
if (!z_check(context_impl->session)) {
RMW_SET_ERROR_MSG("zenoh session is invalid");
return nullptr;
Expand Down Expand Up @@ -673,7 +682,7 @@ rmw_create_publisher(
context_impl->get_next_entity_id()),
rmw_zenoh_cpp::liveliness::EntityType::Publisher,
rmw_zenoh_cpp::liveliness::NodeInfo{
node->context->actual_domain_id, node->namespace_, node->name, ""},
node->context->actual_domain_id, node->namespace_, node->name, context_impl->enclave},
rmw_zenoh_cpp::liveliness::TopicInfo{
rmw_publisher->topic_name,
publisher_data->type_support->get_name(),
Expand Down Expand Up @@ -1304,6 +1313,10 @@ rmw_create_subscription(
context_impl,
"unable to get rmw_context_impl_s",
return nullptr);
RMW_CHECK_FOR_NULL_WITH_MSG(
context_impl->enclave,
"expected initialized enclave",
return nullptr);
if (!z_check(context_impl->session)) {
RMW_SET_ERROR_MSG("zenoh session is invalid");
return nullptr;
Expand Down Expand Up @@ -1505,7 +1518,7 @@ rmw_create_subscription(
context_impl->get_next_entity_id()),
rmw_zenoh_cpp::liveliness::EntityType::Subscription,
rmw_zenoh_cpp::liveliness::NodeInfo{
node->context->actual_domain_id, node->namespace_, node->name, ""},
node->context->actual_domain_id, node->namespace_, node->name, context_impl->enclave},
rmw_zenoh_cpp::liveliness::TopicInfo{
rmw_subscription->topic_name,
sub_data->type_support->get_name(),
Expand Down Expand Up @@ -1970,6 +1983,10 @@ rmw_create_client(
context_impl,
"unable to get rmw_context_impl_s",
return nullptr);
RMW_CHECK_FOR_NULL_WITH_MSG(
context_impl->enclave,
"expected initialized enclave",
return nullptr);
if (!z_check(context_impl->session)) {
RMW_SET_ERROR_MSG("zenoh session is invalid");
return nullptr;
Expand Down Expand Up @@ -2176,7 +2193,7 @@ rmw_create_client(
context_impl->get_next_entity_id()),
rmw_zenoh_cpp::liveliness::EntityType::Client,
rmw_zenoh_cpp::liveliness::NodeInfo{
node->context->actual_domain_id, node->namespace_, node->name, ""},
node->context->actual_domain_id, node->namespace_, node->name, context_impl->enclave},
rmw_zenoh_cpp::liveliness::TopicInfo{
rmw_client->service_name,
std::move(service_type),
Expand Down Expand Up @@ -2556,6 +2573,10 @@ rmw_create_service(
context_impl,
"unable to get rmw_context_impl_s",
return nullptr);
RMW_CHECK_FOR_NULL_WITH_MSG(
context_impl->enclave,
"expected initialized enclave",
return nullptr);
if (!z_check(context_impl->session)) {
RMW_SET_ERROR_MSG("zenoh session is invalid");
return nullptr;
Expand Down Expand Up @@ -2759,7 +2780,7 @@ rmw_create_service(
context_impl->get_next_entity_id()),
rmw_zenoh_cpp::liveliness::EntityType::Service,
rmw_zenoh_cpp::liveliness::NodeInfo{
node->context->actual_domain_id, node->namespace_, node->name, ""},
node->context->actual_domain_id, node->namespace_, node->name, context_impl->enclave},
rmw_zenoh_cpp::liveliness::TopicInfo{
rmw_service->service_name,
std::move(service_type),
Expand Down

0 comments on commit 319de64

Please sign in to comment.