Enum tether_agent::plugs::definitions::PlugDefinition
source · pub enum PlugDefinition {
InputPlug(InputPlugDefinition),
OutputPlug(OutputPlugDefinition),
}Variants§
InputPlug(InputPlugDefinition)
OutputPlug(OutputPlugDefinition)
Implementations§
source§impl PlugDefinition
impl PlugDefinition
sourcepub fn name(&self) -> &str
pub fn name(&self) -> &str
Examples found in repository?
examples/subscribe.rs (line 36)
20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137
fn main() {
println!("Rust Tether Agent subscribe example");
let mut builder = Builder::from_env(Env::default().default_filter_or("debug"));
builder.init();
debug!("Debugging is enabled; could be verbose");
let tether_agent = TetherAgentOptionsBuilder::new("RustDemoAgent")
.id(Some("example"))
.build()
.expect("failed to init Tether agent");
let input_one = PlugOptionsBuilder::create_input("one")
.build(&tether_agent)
.expect("failed to create input");
debug!("input one {} = {}", input_one.name(), input_one.topic());
let input_two = PlugOptionsBuilder::create_input("two")
.role(Some("specific"))
.build(&tether_agent)
.expect("failed to create input");
debug!("input two {} = {}", input_two.name(), input_two.topic());
let input_empty = PlugOptionsBuilder::create_input("nothing")
.build(&tether_agent)
.expect("failed to create input");
let input_everything = PlugOptionsBuilder::create_input("everything")
.topic(Some("#"))
.build(&tether_agent)
.expect("failed to create input");
let input_specify_id = PlugOptionsBuilder::create_input("groupMessages")
.id(Some("someGroup"))
.name(None)
.build(&tether_agent)
.expect("failed to create input");
debug!(
"input everything {} = {}",
input_everything.name(),
input_everything.topic()
);
info!("Checking messages every 1s, 10x...");
for i in 1..10 {
info!("#{i}: Checking for messages...");
while let Some((topic, message)) = tether_agent.check_messages() {
debug!(
"........ Received a message topic {} => topic parts {:?}",
message.topic(),
topic
);
if input_one.matches(&topic) {
info!(
"******** INPUT ONE:\n Received a message for plug named \"{}\" on topic {} with length {} bytes",
input_one.name(),
message.topic(),
message.payload().len()
);
assert_eq!(parse_plug_name(message.topic()), Some("one"));
}
if input_two.matches(&topic) {
info!(
"******** INPUT TWO:\n Received a message for plug named \"{}\" on topic {} with length {} bytes",
input_two.name(),
message.topic(),
message.payload().len()
);
assert_eq!(parse_plug_name(message.topic()), Some("two"));
assert_ne!(parse_plug_name(message.topic()), Some("one"));
// Notice how you must give the from_slice function a type so it knows what to expect
let decoded = from_slice::<CustomMessage>(&message.payload());
match decoded {
Ok(d) => {
info!("Yes, we decoded the MessagePack payload as: {:?}", d);
let CustomMessage { name, id } = d;
debug!("Name is {} and ID is {}", name, id);
}
Err(e) => {
warn!("Failed to decode the payload: {}", e)
}
};
}
if input_empty.matches(&topic) {
info!(
"******** EMPTY MESSAGE:\n Received a message for plug named \"{}\" on topic {} with length {} bytes",
input_empty.name(),
message.topic(),
message.payload().len()
);
assert_eq!(parse_plug_name(message.topic()), Some("nothing"));
}
if input_everything.matches(&topic) {
info!(
"******** EVERYTHING MATCHES HERE:\n Received a message for plug named \"{}\" on topic {} with length {} bytes",
input_everything.name(),
message.topic(),
message.payload().len()
);
}
if input_specify_id.matches(&topic) {
info!("******** ID MATCH:\n Should match any role and plug name, but only messages with ID \"groupMessages\"");
info!(
"\n Received a message from plug named \"{}\" on topic {} with length {} bytes",
input_specify_id.name(),
message.topic(),
message.payload().len()
);
assert_eq!(parse_agent_id(message.topic()), Some("groupMessages"));
}
}
thread::sleep(Duration::from_millis(1000))
}
}sourcepub fn topic(&self) -> &str
pub fn topic(&self) -> &str
Examples found in repository?
examples/subscribe.rs (line 36)
20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137
fn main() {
println!("Rust Tether Agent subscribe example");
let mut builder = Builder::from_env(Env::default().default_filter_or("debug"));
builder.init();
debug!("Debugging is enabled; could be verbose");
let tether_agent = TetherAgentOptionsBuilder::new("RustDemoAgent")
.id(Some("example"))
.build()
.expect("failed to init Tether agent");
let input_one = PlugOptionsBuilder::create_input("one")
.build(&tether_agent)
.expect("failed to create input");
debug!("input one {} = {}", input_one.name(), input_one.topic());
let input_two = PlugOptionsBuilder::create_input("two")
.role(Some("specific"))
.build(&tether_agent)
.expect("failed to create input");
debug!("input two {} = {}", input_two.name(), input_two.topic());
let input_empty = PlugOptionsBuilder::create_input("nothing")
.build(&tether_agent)
.expect("failed to create input");
let input_everything = PlugOptionsBuilder::create_input("everything")
.topic(Some("#"))
.build(&tether_agent)
.expect("failed to create input");
let input_specify_id = PlugOptionsBuilder::create_input("groupMessages")
.id(Some("someGroup"))
.name(None)
.build(&tether_agent)
.expect("failed to create input");
debug!(
"input everything {} = {}",
input_everything.name(),
input_everything.topic()
);
info!("Checking messages every 1s, 10x...");
for i in 1..10 {
info!("#{i}: Checking for messages...");
while let Some((topic, message)) = tether_agent.check_messages() {
debug!(
"........ Received a message topic {} => topic parts {:?}",
message.topic(),
topic
);
if input_one.matches(&topic) {
info!(
"******** INPUT ONE:\n Received a message for plug named \"{}\" on topic {} with length {} bytes",
input_one.name(),
message.topic(),
message.payload().len()
);
assert_eq!(parse_plug_name(message.topic()), Some("one"));
}
if input_two.matches(&topic) {
info!(
"******** INPUT TWO:\n Received a message for plug named \"{}\" on topic {} with length {} bytes",
input_two.name(),
message.topic(),
message.payload().len()
);
assert_eq!(parse_plug_name(message.topic()), Some("two"));
assert_ne!(parse_plug_name(message.topic()), Some("one"));
// Notice how you must give the from_slice function a type so it knows what to expect
let decoded = from_slice::<CustomMessage>(&message.payload());
match decoded {
Ok(d) => {
info!("Yes, we decoded the MessagePack payload as: {:?}", d);
let CustomMessage { name, id } = d;
debug!("Name is {} and ID is {}", name, id);
}
Err(e) => {
warn!("Failed to decode the payload: {}", e)
}
};
}
if input_empty.matches(&topic) {
info!(
"******** EMPTY MESSAGE:\n Received a message for plug named \"{}\" on topic {} with length {} bytes",
input_empty.name(),
message.topic(),
message.payload().len()
);
assert_eq!(parse_plug_name(message.topic()), Some("nothing"));
}
if input_everything.matches(&topic) {
info!(
"******** EVERYTHING MATCHES HERE:\n Received a message for plug named \"{}\" on topic {} with length {} bytes",
input_everything.name(),
message.topic(),
message.payload().len()
);
}
if input_specify_id.matches(&topic) {
info!("******** ID MATCH:\n Should match any role and plug name, but only messages with ID \"groupMessages\"");
info!(
"\n Received a message from plug named \"{}\" on topic {} with length {} bytes",
input_specify_id.name(),
message.topic(),
message.payload().len()
);
assert_eq!(parse_agent_id(message.topic()), Some("groupMessages"));
}
}
thread::sleep(Duration::from_millis(1000))
}
}sourcepub fn matches(&self, topic: &TetherOrCustomTopic) -> bool
pub fn matches(&self, topic: &TetherOrCustomTopic) -> bool
Examples found in repository?
examples/subscribe.rs (line 74)
20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137
fn main() {
println!("Rust Tether Agent subscribe example");
let mut builder = Builder::from_env(Env::default().default_filter_or("debug"));
builder.init();
debug!("Debugging is enabled; could be verbose");
let tether_agent = TetherAgentOptionsBuilder::new("RustDemoAgent")
.id(Some("example"))
.build()
.expect("failed to init Tether agent");
let input_one = PlugOptionsBuilder::create_input("one")
.build(&tether_agent)
.expect("failed to create input");
debug!("input one {} = {}", input_one.name(), input_one.topic());
let input_two = PlugOptionsBuilder::create_input("two")
.role(Some("specific"))
.build(&tether_agent)
.expect("failed to create input");
debug!("input two {} = {}", input_two.name(), input_two.topic());
let input_empty = PlugOptionsBuilder::create_input("nothing")
.build(&tether_agent)
.expect("failed to create input");
let input_everything = PlugOptionsBuilder::create_input("everything")
.topic(Some("#"))
.build(&tether_agent)
.expect("failed to create input");
let input_specify_id = PlugOptionsBuilder::create_input("groupMessages")
.id(Some("someGroup"))
.name(None)
.build(&tether_agent)
.expect("failed to create input");
debug!(
"input everything {} = {}",
input_everything.name(),
input_everything.topic()
);
info!("Checking messages every 1s, 10x...");
for i in 1..10 {
info!("#{i}: Checking for messages...");
while let Some((topic, message)) = tether_agent.check_messages() {
debug!(
"........ Received a message topic {} => topic parts {:?}",
message.topic(),
topic
);
if input_one.matches(&topic) {
info!(
"******** INPUT ONE:\n Received a message for plug named \"{}\" on topic {} with length {} bytes",
input_one.name(),
message.topic(),
message.payload().len()
);
assert_eq!(parse_plug_name(message.topic()), Some("one"));
}
if input_two.matches(&topic) {
info!(
"******** INPUT TWO:\n Received a message for plug named \"{}\" on topic {} with length {} bytes",
input_two.name(),
message.topic(),
message.payload().len()
);
assert_eq!(parse_plug_name(message.topic()), Some("two"));
assert_ne!(parse_plug_name(message.topic()), Some("one"));
// Notice how you must give the from_slice function a type so it knows what to expect
let decoded = from_slice::<CustomMessage>(&message.payload());
match decoded {
Ok(d) => {
info!("Yes, we decoded the MessagePack payload as: {:?}", d);
let CustomMessage { name, id } = d;
debug!("Name is {} and ID is {}", name, id);
}
Err(e) => {
warn!("Failed to decode the payload: {}", e)
}
};
}
if input_empty.matches(&topic) {
info!(
"******** EMPTY MESSAGE:\n Received a message for plug named \"{}\" on topic {} with length {} bytes",
input_empty.name(),
message.topic(),
message.payload().len()
);
assert_eq!(parse_plug_name(message.topic()), Some("nothing"));
}
if input_everything.matches(&topic) {
info!(
"******** EVERYTHING MATCHES HERE:\n Received a message for plug named \"{}\" on topic {} with length {} bytes",
input_everything.name(),
message.topic(),
message.payload().len()
);
}
if input_specify_id.matches(&topic) {
info!("******** ID MATCH:\n Should match any role and plug name, but only messages with ID \"groupMessages\"");
info!(
"\n Received a message from plug named \"{}\" on topic {} with length {} bytes",
input_specify_id.name(),
message.topic(),
message.payload().len()
);
assert_eq!(parse_agent_id(message.topic()), Some("groupMessages"));
}
}
thread::sleep(Duration::from_millis(1000))
}
}Trait Implementations§
source§impl Debug for PlugDefinition
impl Debug for PlugDefinition
source§impl<'de> Deserialize<'de> for PlugDefinition
impl<'de> Deserialize<'de> for PlugDefinition
source§fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>where
__D: Deserializer<'de>,
fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>where
__D: Deserializer<'de>,
Deserialize this value from the given Serde deserializer. Read more
Auto Trait Implementations§
impl RefUnwindSafe for PlugDefinition
impl Send for PlugDefinition
impl Sync for PlugDefinition
impl Unpin for PlugDefinition
impl UnwindSafe for PlugDefinition
Blanket Implementations§
source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more