19 releases
0.1.3 | Aug 1, 2024 |
---|---|
0.1.2 | Jul 27, 2024 |
0.0.13 | Jul 22, 2024 |
0.0.10 | Feb 12, 2023 |
0.0.6 | Jun 26, 2022 |
#175 in Concurrency
958 downloads per month
67KB
1.5K
SLoC
myriam-rs
Local and remote actor model implementation with an API heavily inspired in (but not necessarily equivalent to) Goblins.
// LocalHandle allows for local, type-safe communication
// UntypedHandle tries to do the same, but requests and responses are
// bag of bytes and have to be {de}serialized
let (local_handle, untyped_handle)
= remote::spawn_untyped::<_, _, _, BincodeDencoder>(Mult { a: 3 }).await?;
// create router with a TOR netlayer
let layer =
TorNetLayer::new_for_service("127.0.0.1.9050", "127.0.0.1:8080", "/tmp/myriam/foo")
.await?;
let router_handle = Router::with_netlayer(layer, Some(RouterOpts::default())).await?;
// routers handle external access to several attached actors
// we can think of this exposed actor as a capability
// "tor:0139aa9b4d523e1da515ce21a818e579acd005fbd0aea62ef094ac1b845f99e7@someaddress.onion"
let address = router_handle.attach(untyped_handle).await?;
let new_layer =
TorNetLayer::new_for_service("127.0.0.1.9050", "127.0.0.1:8081", "/tmp/myriam/bar")
.await?;
let remote_handle
= RemoteHandle::<u32, u32, SomeError, BincodeDencoder, TorNetLayer>::new(&address, new_layer);
// type handle once ^
// use RemoteHandle just like a LocalHandle
let res = remote_handle.send(Message::Task(42)).await?;
// capabilities can be revoked anytime
router_handle.revoke(&address).await?;
tokio::time::sleep(Duration::from_millis(100));
// ...and thus we can't invoke this one anymore
remote_handle.send(Message::Ping).await.unwrap_err();
Check out the repo examples for a more comprehensive demo.
features
remote (default)
: support for remote messagingtcp (default)
: TCP test-only net layertor (default)
: Tor net layer - requires a running and properly configured Tor router
license
Copyright 2024 Ariela Wenner
Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License.
Dependencies
~3–9MB
~79K SLoC