Change handling server offline
This commit is contained in:
parent
5767ac134a
commit
50a4489499
62
src/main.rs
62
src/main.rs
|
@ -1,6 +1,6 @@
|
||||||
// Yeahbut December 2023
|
// Yeahbut December 2023
|
||||||
|
|
||||||
use tokio::net::{TcpListener, TcpStream};
|
use tokio::net::{TcpListener, TcpStream, tcp::{OwnedReadHalf, OwnedWriteHalf}};
|
||||||
use tokio::io;
|
use tokio::io;
|
||||||
use std::error::Error;
|
use std::error::Error;
|
||||||
|
|
||||||
|
@ -27,10 +27,21 @@ async fn handle_client(client_socket: TcpStream) {
|
||||||
|
|
||||||
let (mut client_reader, mut client_writer) = client_socket.into_split();
|
let (mut client_reader, mut client_writer) = client_socket.into_split();
|
||||||
|
|
||||||
let backend_socket = TcpStream::connect(backend_addr)
|
// "Failed to connect to the backend server"
|
||||||
.await.expect("Failed to connect to the backend server");
|
|
||||||
|
let backend_socket = match TcpStream::connect(backend_addr).await {
|
||||||
|
Ok(backend_socket) => Some(backend_socket.into_split()),
|
||||||
|
Err(_) => None,
|
||||||
|
};
|
||||||
|
|
||||||
|
let (mut server_reader, mut server_writer):
|
||||||
|
(Option<OwnedReadHalf>, Option<OwnedWriteHalf>) =
|
||||||
|
match backend_socket {
|
||||||
|
Some(backend_socket) =>
|
||||||
|
(Some(backend_socket.0), Some(backend_socket.1)),
|
||||||
|
None => (None, None),
|
||||||
|
};
|
||||||
|
|
||||||
let (mut server_reader, mut server_writer) = backend_socket.into_split();
|
|
||||||
let mut buffer: [u8; 1] = [0; 1];
|
let mut buffer: [u8; 1] = [0; 1];
|
||||||
client_reader.peek(&mut buffer)
|
client_reader.peek(&mut buffer)
|
||||||
.await.expect("Failed to peek at first byte from stream");
|
.await.expect("Failed to peek at first byte from stream");
|
||||||
|
@ -54,28 +65,45 @@ async fn handle_client(client_socket: TcpStream) {
|
||||||
).await.expect("Error handling status request");
|
).await.expect("Error handling status request");
|
||||||
return;
|
return;
|
||||||
} else if handshake_packet.next_state == 2 {
|
} else if handshake_packet.next_state == 2 {
|
||||||
handshake::write_handshake(&mut server_writer, handshake::Handshake{
|
match server_writer {
|
||||||
|
Some(mut server_writer) => {
|
||||||
|
handshake::write_handshake(
|
||||||
|
&mut server_writer,
|
||||||
|
handshake::Handshake {
|
||||||
protocol_version: mc_types::VERSION_PROTOCOL,
|
protocol_version: mc_types::VERSION_PROTOCOL,
|
||||||
server_address: "localhost".to_string(),
|
server_address: "localhost".to_string(),
|
||||||
server_port: 25565,
|
server_port: 25565,
|
||||||
next_state: 2,
|
next_state: 2,
|
||||||
}).await.expect("Error logging into backend server");
|
},
|
||||||
|
).await.expect("Error logging into backend server");
|
||||||
|
|
||||||
|
// Forward from client to backend
|
||||||
|
tokio::spawn(async move {
|
||||||
|
io::copy(&mut client_reader, &mut server_writer).await
|
||||||
|
.expect("Error copying from client to backend");
|
||||||
|
});
|
||||||
|
|
||||||
|
// Forward from backend to client
|
||||||
|
match server_reader {
|
||||||
|
Some(mut server_reader) => tokio::spawn(async move {
|
||||||
|
io::copy(&mut server_reader, &mut client_writer)
|
||||||
|
.await
|
||||||
|
.expect("Error copying from backend to client");
|
||||||
|
}),
|
||||||
|
None => {
|
||||||
|
eprintln!(
|
||||||
|
"Failed to connect to the backend server");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
},
|
||||||
|
None => {}
|
||||||
|
};
|
||||||
} else {
|
} else {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Forward from client to backend
|
|
||||||
tokio::spawn(async move {
|
|
||||||
io::copy(&mut client_reader, &mut server_writer)
|
|
||||||
.await.expect("Error copying from client to backend");
|
|
||||||
});
|
|
||||||
|
|
||||||
// Forward from backend to client
|
|
||||||
tokio::spawn(async move {
|
|
||||||
io::copy(&mut server_reader, &mut client_writer)
|
|
||||||
.await.expect("Error copying from backend to client");
|
|
||||||
});
|
|
||||||
|
|
||||||
println!("Connection Closed");
|
println!("Connection Closed");
|
||||||
}
|
}
|
||||||
|
|
|
@ -117,8 +117,8 @@ fn favicon() -> Option<String> {
|
||||||
pub async fn respond_status(
|
pub async fn respond_status(
|
||||||
client_reader: &mut OwnedReadHalf,
|
client_reader: &mut OwnedReadHalf,
|
||||||
client_writer: &mut OwnedWriteHalf,
|
client_writer: &mut OwnedWriteHalf,
|
||||||
server_reader: &mut OwnedReadHalf,
|
server_reader: &mut Option<OwnedReadHalf>,
|
||||||
server_writer: &mut OwnedWriteHalf,
|
server_writer: &mut Option<OwnedWriteHalf>,
|
||||||
)-> Result<()> {
|
)-> Result<()> {
|
||||||
loop {
|
loop {
|
||||||
println!("Status Handling");
|
println!("Status Handling");
|
||||||
|
@ -129,9 +129,25 @@ pub async fn respond_status(
|
||||||
|
|
||||||
if packet_id == 0x00 {
|
if packet_id == 0x00 {
|
||||||
println!("Handling Status");
|
println!("Handling Status");
|
||||||
let online_players =
|
let favicon = favicon();
|
||||||
online_players(server_reader, server_writer).await?;
|
|
||||||
let status_response = StatusResponseData {
|
let online_players = match server_reader {
|
||||||
|
Some(server_reader) => match server_writer {
|
||||||
|
Some(server_writer) => match online_players(
|
||||||
|
server_reader,
|
||||||
|
server_writer,
|
||||||
|
).await {
|
||||||
|
Ok(value) => Some(value),
|
||||||
|
Err(_) => None,
|
||||||
|
},
|
||||||
|
None => None,
|
||||||
|
},
|
||||||
|
None => None,
|
||||||
|
};
|
||||||
|
|
||||||
|
let status_response =
|
||||||
|
match online_players {
|
||||||
|
Some(online_players) => StatusResponseData {
|
||||||
version: StatusVersion {
|
version: StatusVersion {
|
||||||
name: mc_types::VERSION_NAME.to_string(),
|
name: mc_types::VERSION_NAME.to_string(),
|
||||||
protocol: mc_types::VERSION_PROTOCOL,
|
protocol: mc_types::VERSION_PROTOCOL,
|
||||||
|
@ -144,11 +160,28 @@ pub async fn respond_status(
|
||||||
online: online_players.online,
|
online: online_players.online,
|
||||||
sample: online_players.sample,
|
sample: online_players.sample,
|
||||||
},
|
},
|
||||||
favicon: favicon(),
|
favicon: favicon,
|
||||||
enforcesSecureChat: None,
|
enforcesSecureChat: Some(false),
|
||||||
previewsChat: None,
|
previewsChat: Some(false),
|
||||||
// enforcesSecureChat: Some(false),
|
},
|
||||||
// previewsChat: Some(false),
|
None => StatusResponseData {
|
||||||
|
version: StatusVersion {
|
||||||
|
name: "Old".to_string(),
|
||||||
|
protocol: 0,
|
||||||
|
},
|
||||||
|
description: mc_types::Chat {
|
||||||
|
text: "Server Error (Server may be starting)"
|
||||||
|
.to_string() + "\nPurple Cello Server",
|
||||||
|
},
|
||||||
|
players: StatusPlayers {
|
||||||
|
max: 0,
|
||||||
|
online: 0,
|
||||||
|
sample: None,
|
||||||
|
},
|
||||||
|
favicon: favicon,
|
||||||
|
enforcesSecureChat: Some(false),
|
||||||
|
previewsChat: Some(false),
|
||||||
|
},
|
||||||
};
|
};
|
||||||
|
|
||||||
let json = serde_json::to_string(&status_response)?;
|
let json = serde_json::to_string(&status_response)?;
|
||||||
|
|
Loading…
Reference in New Issue