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
The following events are useful for servers:
- EventWriter<StartServer>
- Send this event to start a server
- EventWriter<StopServer>
- Send this event to stop a running server
- EventReader<ClientConnected>
- Received whenever a new client is connected
- EventReader<ClientDisconnected>
- Received whenever a client has disconnected
- EventReader<ReceiveFromClient<T>>
- Received whenever a client has sent type T to the server
- EventWriter<SendToClient<T>>
- Send this event to have a particular client receive type T
- EventWriter<SendToClients<T>>
- Send this event to have all connected clients receive type T
The following events are useful for clients:
- EventWriter<ConnectToServer>
- Send this event to connect to a server
- EventWriter<DisconnectFromServer>
- Send this event to disconnect from the server
- EventWriter<SendToServer<T>>
- Send this event to have the server receive type T
- EventReader<ReceiveFromServer<T>>
- Received whenever the server has sent type T to the client
Both the client and the server can receive the EventReader<NetcodeTransportError>
events to deal with networking errors.
There are a few examples in the examples/
directory.
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.1, the Event
, Encode
, and Decode
derives are 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
See the examples/features.rs
file for examples of more features, such as encryption, broadcasting, networking error handling, and client connect/disconnect events.
In one terminal session, start the server: cargo run --example features -- -s
In another terminal session, connect with a client: cargo run --example features
The server and client will use encryption to communicate.
Every 500 frames the server will broadcast a message of it's frame count.
With focus on the server window: - Hit 'ESC' to stop the server - Hit 'ENTER' to start the server
With focus on the client window: - Hit 'ESC' to disconnect from the server - Hit 'ENTER' to reconnect to the server - Hit 'SPACE' to send a message of type PlayerMovement
The server will respond to the PlayerMovement message with a ServerResponse message.
|bevy|bevyclientserver_events| |---|---| |0.11|0.5|