-
Notifications
You must be signed in to change notification settings - Fork 177
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Add QoS configuration overwrites for publication messages (#1613)
* Initial implementation of publisher builder config overwrites * Add publisher builder overwrite test * Remove unnecessary return * Fix default config spacing * Change config format to publishers/default_builders * Update QoS test config * Move new PublisherBuilder logic * Log warning when multiple builder configs can apply for the same keyexpr * Rename builders module to publishers * Change config format to qos/put * Rename publishers module to qos * Get QoS config from runtime instead of drilling through session API * Update QoS config test * Remove unnecessary lifetime * Overwrite PublisherBuilder API calls with config * Update QoS config test * Remove encoding from QoS config * Allow API to change non-overwritten QoS config * Rename config qos/put to qos/publication * Enforce 1-to-1 mapping between config and zenoh enums at compile time * Add session API tests * Fix case-sensitive parameter * Mark destination QoS config as unstable * Apply QoS overwrites at resolution of PublisherBuilder and PublicationBuilder * Remove impl lifetimes * Remove unicity check of keyexpr in qos config * Add copyright header
- Loading branch information
Showing
11 changed files
with
434 additions
and
6 deletions.
There are no files selected for viewing
Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.
Oops, something went wrong.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,119 @@ | ||
// | ||
// Copyright (c) 2024 ZettaScale Technology | ||
// | ||
// This program and the accompanying materials are made available under the | ||
// terms of the Eclipse Public License 2.0 which is available at | ||
// http://www.eclipse.org/legal/epl-2.0, or the Apache License, Version 2.0 | ||
// which is available at https://www.apache.org/licenses/LICENSE-2.0. | ||
// | ||
// SPDX-License-Identifier: EPL-2.0 OR Apache-2.0 | ||
// | ||
// Contributors: | ||
// ZettaScale Zenoh Team, <[email protected]> | ||
// | ||
use serde::{Deserialize, Serialize}; | ||
use zenoh_keyexpr::keyexpr_tree::{IKeyExprTreeMut, KeBoxTree}; | ||
use zenoh_protocol::core::{key_expr::OwnedKeyExpr, CongestionControl, Reliability}; | ||
|
||
#[derive(Debug, Deserialize, Default, Serialize, Clone)] | ||
pub struct PublisherQoSConfList(pub(crate) Vec<PublisherQoSConf>); | ||
|
||
impl From<PublisherQoSConfList> for KeBoxTree<PublisherQoSConfig> { | ||
fn from(value: PublisherQoSConfList) -> KeBoxTree<PublisherQoSConfig> { | ||
let mut tree = KeBoxTree::new(); | ||
for conf in value.0 { | ||
for key_expr in conf.key_exprs { | ||
// NOTE: we don't check key_expr unicity | ||
tree.insert(&key_expr, conf.config.clone()); | ||
} | ||
} | ||
tree | ||
} | ||
} | ||
|
||
#[derive(Debug, Deserialize, Serialize, Clone)] | ||
pub(crate) struct PublisherQoSConf { | ||
pub key_exprs: Vec<OwnedKeyExpr>, | ||
pub config: PublisherQoSConfig, | ||
} | ||
|
||
#[derive(Debug, Default, Deserialize, Serialize, Clone)] | ||
pub struct PublisherQoSConfig { | ||
pub congestion_control: Option<PublisherCongestionControlConf>, | ||
pub priority: Option<PublisherPriorityConf>, | ||
pub express: Option<bool>, | ||
#[cfg(feature = "unstable")] | ||
pub reliability: Option<PublisherReliabilityConf>, | ||
#[cfg(feature = "unstable")] | ||
pub allowed_destination: Option<PublisherLocalityConf>, | ||
} | ||
|
||
#[derive(Debug, Deserialize, Serialize, Clone, Copy)] | ||
#[serde(rename_all = "lowercase")] | ||
pub enum PublisherCongestionControlConf { | ||
Drop, | ||
Block, | ||
} | ||
|
||
impl From<PublisherCongestionControlConf> for CongestionControl { | ||
fn from(value: PublisherCongestionControlConf) -> Self { | ||
match value { | ||
PublisherCongestionControlConf::Drop => Self::Drop, | ||
PublisherCongestionControlConf::Block => Self::Block, | ||
} | ||
} | ||
} | ||
|
||
impl From<CongestionControl> for PublisherCongestionControlConf { | ||
fn from(value: CongestionControl) -> Self { | ||
match value { | ||
CongestionControl::Drop => Self::Drop, | ||
CongestionControl::Block => Self::Block, | ||
} | ||
} | ||
} | ||
|
||
#[derive(Debug, Deserialize, Serialize, Clone, Copy)] | ||
#[serde(rename_all = "snake_case")] | ||
pub enum PublisherPriorityConf { | ||
RealTime = 1, | ||
InteractiveHigh = 2, | ||
InteractiveLow = 3, | ||
DataHigh = 4, | ||
Data = 5, | ||
DataLow = 6, | ||
Background = 7, | ||
} | ||
|
||
#[derive(Debug, Deserialize, Serialize, Clone, Copy)] | ||
#[serde(rename_all = "snake_case")] | ||
pub enum PublisherReliabilityConf { | ||
BestEffort, | ||
Reliable, | ||
} | ||
|
||
impl From<PublisherReliabilityConf> for Reliability { | ||
fn from(value: PublisherReliabilityConf) -> Self { | ||
match value { | ||
PublisherReliabilityConf::BestEffort => Self::BestEffort, | ||
PublisherReliabilityConf::Reliable => Self::Reliable, | ||
} | ||
} | ||
} | ||
|
||
impl From<Reliability> for PublisherReliabilityConf { | ||
fn from(value: Reliability) -> Self { | ||
match value { | ||
Reliability::BestEffort => Self::BestEffort, | ||
Reliability::Reliable => Self::Reliable, | ||
} | ||
} | ||
} | ||
|
||
#[derive(Debug, Deserialize, Serialize, Clone, Copy)] | ||
#[serde(rename_all = "snake_case")] | ||
pub enum PublisherLocalityConf { | ||
SessionLocal, | ||
Remote, | ||
Any, | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.