8 releases (4 breaking)

0.5.0 Jan 23, 2024
0.4.1 Apr 19, 2023
0.4.0 Mar 21, 2023
0.3.1 Oct 27, 2022
0.1.0 Mar 23, 2019

#20 in #minecraft-server

Download history 3/week @ 2024-08-12 1/week @ 2024-08-26 9/week @ 2024-09-02 21/week @ 2024-09-09 7/week @ 2024-09-16 58/week @ 2024-09-23 52/week @ 2024-09-30 2/week @ 2024-10-07 48/week @ 2024-10-14 2/week @ 2024-10-21 8/week @ 2024-10-28 47/week @ 2024-11-04 6/week @ 2024-11-18 24/week @ 2024-11-25

78 downloads per month
Used in mc-server-pinger

MIT license

30KB
529 lines

craftping crates.io docs.rs license Actively Maintained

craftping is a Rust library to ping Minecraft Servers.

Usage

[dependencies]
craftping = "0.5.0"

You can synchronously ping to the server with craftping::sync::ping:

use std::net::TcpStream;
use craftping::sync::ping;

fn main() {
    let hostname = "localhost";
    let port = 25565;
    let mut stream = TcpStream::connect((hostname, port)).unwrap();
    let pong = ping(&mut stream, hostname, port).expect("Cannot ping server");
    println!("Ping result: {:?}", pong);
}

sync module requires sync feature, which is enabled by default.

If you want to send pings asynchronously, you can use craftping::tokio::ping or craftping::futures::ping:

  • craftping::tokio::ping
use tokio::net::TcpStream;
use craftping::tokio::ping;

#[tokio::main]
async fn main() {
    let hostname = "localhost";
    let port = 25565;
    let mut stream = TcpStream::connect((hostname, port)).await.unwrap();
    let pong = ping(&mut stream, hostname, port).await.expect("Cannot ping server");
    println!("Ping result: {:?}", pong);
}
  • craftping::futures::ping
use async_std::net::TcpStream;
use craftping::futures::ping;

#[async_std::main]
async fn main() {
    let hostname = "localhost";
    let port = 25565;
    let mut stream = TcpStream::connect((hostname, port)).await.unwrap();
    let pong = ping(&mut stream, hostname, port).await.expect("Cannot ping server");
    println!("Ping result: {:?}", pong);
}

Note that tokio module requires async-tokio feature and futures async-futures.

Check here for more information about ping result.

Contributing

Pull requests are welcome. For major issues, please open the issue on this repository first.

License

MIT

Dependencies

~1–7.5MB
~60K SLoC