Simple event-based client-server networking library for Bevy.
Easily send bevy events to/from a client/server without worrying about serialization or network transport details.
Builds off of the renet/bevy_renet library and attempts to simplify the configuration and management of types to be sent through a network.
Goals: - Simplified network setup and configuration - Easily send any types to/from a client/server
Todo: - Proper derive trait to enforce Event + Serialize + Deserialize - Support secure authentication
See the examples/ping.rs
file for a simple ping-pong example.
In one terminal session, start the server: cargo run --example ping -- -s
In another terminal session, connect with a client: cargo run --example ping
With the client window in focus, hit ENTER
to send a Ping. The server will respond with a Pong.
In this example, we want to send a Ping
event to the server and receive a Pong
event in return.
```rust,ignore
pub struct Ping;
pub struct Pong; ```
As of version 0.4, the Event
, Serialize
, and Deserialize
derive is required.
When setting up our App
, we need to feed it to a macro and provide all the events to be sent over the network.
rust,ignore
fn main() {
// ...
let mut app = App::new();
client_server_events_plugin!(
app,
Ping => NetworkConfig::default(),
Pong => NetworkConfig::default()
);
// ...
You can provide type-specific network configuration, such as reliability, resend time, max memory usage, etc.
The macro should be run regardless of whether this instance will be a server or a client.
You can choose to start a server instance or connect to a server as a client using events.
```rust,ignore
fn startserver(mut startserver: EventWriter
fn connectasclient(mut connecttoserver: EventWriter
Then you can send/receive events as desired.
```rust,ignore
fn updateclient(
mut sendping: EventWriter
fn updateserver(
mut receiveping: EventReader
You can also broadcast a message to all clients using EventWriter<SendToClients<T>>
.
Networking errors can be handled via EventReader<NetcodeTransportError>
.
rust,ignore
fn handle_errors(mut errors: EventReader<NetcodeTransportError>) {
for error in errors.iter() {
println!("Networking Error: {:?}", error);
}
}
|bevy|bevyclientserver_events| |---|---| |0.11|0.4|