Started login_handle.rs
This commit is contained in:
parent
637f054110
commit
cf377ec1c8
|
@ -0,0 +1,26 @@
|
||||||
|
// Yeahbut December 2023
|
||||||
|
|
||||||
|
use tokio::net::tcp::{OwnedReadHalf, OwnedWriteHalf};
|
||||||
|
use tokio::io;
|
||||||
|
use std::error::Error;
|
||||||
|
|
||||||
|
use purple_cello_mc_protocol::{
|
||||||
|
mc_types::{self, Result, Packet},
|
||||||
|
handshake,
|
||||||
|
login,
|
||||||
|
};
|
||||||
|
|
||||||
|
pub async fn respond_login(
|
||||||
|
client_reader: &mut OwnedReadHalf,
|
||||||
|
client_writer: &mut OwnedWriteHalf,
|
||||||
|
server_reader: &mut OwnedReadHalf,
|
||||||
|
server_writer: &mut OwnedWriteHalf,
|
||||||
|
)-> Result<bool> {
|
||||||
|
handshake::serverbound::Handshake {
|
||||||
|
protocol_version: mc_types::VERSION_PROTOCOL,
|
||||||
|
server_address: "localhost".to_string(),
|
||||||
|
server_port: 25565,
|
||||||
|
next_state: 2,
|
||||||
|
}.write(server_writer).await?;
|
||||||
|
Ok(true)
|
||||||
|
}
|
66
src/main.rs
66
src/main.rs
|
@ -5,12 +5,13 @@ use tokio::io;
|
||||||
use std::error::Error;
|
use std::error::Error;
|
||||||
|
|
||||||
use purple_cello_mc_protocol::{
|
use purple_cello_mc_protocol::{
|
||||||
mc_types::{self, Packet},
|
mc_types::Packet,
|
||||||
handshake,
|
handshake,
|
||||||
login,
|
login,
|
||||||
};
|
};
|
||||||
|
|
||||||
mod status_handle;
|
mod status_handle;
|
||||||
|
mod login_handle;
|
||||||
|
|
||||||
|
|
||||||
#[tokio::main]
|
#[tokio::main]
|
||||||
|
@ -72,29 +73,25 @@ async fn handle_client(client_socket: TcpStream) {
|
||||||
} else if handshake_packet.next_state == 2 {
|
} else if handshake_packet.next_state == 2 {
|
||||||
match server_writer {
|
match server_writer {
|
||||||
Some(mut server_writer) => {
|
Some(mut server_writer) => {
|
||||||
handshake::serverbound::Handshake {
|
|
||||||
protocol_version: mc_types::VERSION_PROTOCOL,
|
|
||||||
server_address: "localhost".to_string(),
|
|
||||||
server_port: 25565,
|
|
||||||
next_state: 2,
|
|
||||||
}
|
|
||||||
.write(&mut server_writer)
|
|
||||||
.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 {
|
match server_reader {
|
||||||
Some(mut server_reader) => tokio::spawn(async move {
|
Some(mut server_reader) => {
|
||||||
io::copy(&mut server_reader, &mut client_writer)
|
|
||||||
|
if login_handle::respond_login(
|
||||||
|
&mut client_reader,
|
||||||
|
&mut client_writer,
|
||||||
|
&mut server_reader,
|
||||||
|
&mut server_writer,
|
||||||
|
)
|
||||||
.await
|
.await
|
||||||
.expect("Error copying from backend to client");
|
.expect("Error logging into backend server") {
|
||||||
}),
|
handle_play(
|
||||||
|
client_reader,
|
||||||
|
client_writer,
|
||||||
|
server_reader,
|
||||||
|
server_writer,
|
||||||
|
).await;
|
||||||
|
}
|
||||||
|
},
|
||||||
None => {
|
None => {
|
||||||
eprintln!(
|
eprintln!(
|
||||||
"Failed to connect to the backend server");
|
"Failed to connect to the backend server");
|
||||||
|
@ -121,3 +118,28 @@ Failed to connect to the backend server");
|
||||||
|
|
||||||
println!("Connection Closed");
|
println!("Connection Closed");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
async fn handle_play(
|
||||||
|
mut client_reader: OwnedReadHalf,
|
||||||
|
mut client_writer: OwnedWriteHalf,
|
||||||
|
mut server_reader: OwnedReadHalf,
|
||||||
|
mut server_writer: OwnedWriteHalf,
|
||||||
|
) {
|
||||||
|
// 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");
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
Loading…
Reference in New Issue