Open dmm opened 4 years ago
These all sound like great ideas! I'd definitely be open to accepting new examples, and if there's anything that you think would be reusable it might make sense to have an actix-web
feature that enables additional functionality within act-zero itself.
My goal with this was to make async/await really easy, but I've only done the bare minimum to get to that point, so there's a ton of opportunities to improve it still.
Testing is something I have thought about a little. My current plan was to implement some kind of "snapshot" functionality that you could use to quickly get the state of all the actors in the system and make assertions about, but it's still very much in the ideas phase... There are also questions like: do we want to be able to make actors completely deterministic? That would certainly help with tests but might be quite difficult to accomplish.
- [ ] dynamic actor launching and cleanup In several places I have an actor that will dynamically create and destroy actors. I have been doing this with a "Supervisor" actor that creates, and routes messages to, worker actors.
This would be really cool. You could implement a supervision tree and have the supervisor restart actors that die:
async fn spawn_child(&mut self) {
self.child = spawn_actor(...);
let termination = self.child.termination();
self.addr.send_fut_with(|addr| async move {
termination.await;
// The child stopped for some reason, re-spawn it again
send!(addr.spawn_child());
});
}
from: https://github.com/Diggsey/act-zero/issues/4#issuecomment-720778840
I wonder if it would be possible to create an DynamicSupervisor like in elixir: https://hexdocs.pm/elixir/DynamicSupervisor.html
I've been playing with implementing a trait to allow an actor to handle stream values. My work so far can be found here: https://github.com/dmm/act-zero-stream/blob/main/src/stream.rs
I added the new StreamHandler
trait to the example from your README.
#[async_trait]
impl StreamHandler<String> for SimpleGreeter {
async fn started2(&mut self) {
println!("Stream has started!");
}
async fn handle(&mut self, item: String) {
println!("Got stream item: {}", item);
if let Ok(Produces::Value(greeting)) = self.greet(item).await {
println!("{}", greeting);
}
}
async fn finished(&mut self) {
println!("Stream has stopped!");
}
}
The idea is that an actor will own (in the general sense) a stream and handle stream output as actor messages.
A couple of questions that came up:
send!
macro? For example here I had to rename my StreamHandler
function to started2
so that it wouldn't conflict with the Actor::started
function. https://github.com/dmm/act-zero-stream/blob/main/src/stream.rs#L72I've added a websocket example: https://github.com/dmm/act-zero-stream/blob/main/websocket/src/websocket_actor.rs
Receiving data from the client works well but now I need to figure out how to share the stream so the actor can send data as well.
Hi Diggsey!
Thanks for sharing this interesting project. I like the async/await support and your emphasis on correctly mutating actor state.
I have a small application currently implemented in Actix that I'd like to explore reimplementing in act-zero. Rather than try to tackle the whole thing I thought I would make a few little programs in act-zero demonstrating how I commonly use actors. I'm not super experienced with async rust(or sync rust) so I thought I could get some feedback or maybe we could turn anything interesting into some act-zero examples?
[X] actix-web integration The first example integrates actix-web and act-zero. In particular I wanted to send a message to an actor and create an http response from the actor's response. For the example I made an actor that tracks the number of times a route is hit. Another route returns the count.;
This was pretty straightforward: https://github.com/dmm/act-zero-examples/blob/main/actix-web-interop/src/main.rs
The only tricky part was using app_data() instead of data() to prevent the Addr<> from being wrapping in an Arc.
Some more things I'd like to attempt:
Feel free to close this if you don't want it cluttering your issues.