|
|
|
@@ -5,13 +5,6 @@ use crate::dataconsts::*;
|
|
|
|
use crate::enums;
|
|
|
|
use crate::enums;
|
|
|
|
use crate::packet::{send_packet, Packet, PacketPayload};
|
|
|
|
use crate::packet::{send_packet, Packet, PacketPayload};
|
|
|
|
use crate::packet_type::PacketType;
|
|
|
|
use crate::packet_type::PacketType;
|
|
|
|
use crate::packets::cli_char_list_req::CliCharListReq;
|
|
|
|
|
|
|
|
use crate::packets::cli_create_char_req::CliCreateCharReq;
|
|
|
|
|
|
|
|
use crate::packets::cli_delete_char_req::CliDeleteCharReq;
|
|
|
|
|
|
|
|
use crate::packets::cli_select_char_req::CliSelectCharReq;
|
|
|
|
|
|
|
|
use crate::packets::srv_create_char_reply::SrvCreateCharReply;
|
|
|
|
|
|
|
|
use crate::packets::srv_delete_char_reply::SrvDeleteCharReply;
|
|
|
|
|
|
|
|
use crate::packets::srv_switch_server::SrvSwitchServer;
|
|
|
|
|
|
|
|
use crate::packets::*;
|
|
|
|
use crate::packets::*;
|
|
|
|
use std::collections::HashMap;
|
|
|
|
use std::collections::HashMap;
|
|
|
|
use std::env;
|
|
|
|
use std::env;
|
|
|
|
@@ -39,6 +32,7 @@ pub(crate) fn convert_slot(slot: i32) -> srv_char_list_reply::EquippedPosition {
|
|
|
|
|
|
|
|
|
|
|
|
pub(crate) async fn handle_char_list_req(stream: &mut TcpStream, packet: Packet, character_client: Arc<Mutex<CharacterClient>>, connection_service: Arc<ConnectionService>, connection_id: String) -> Result<(), Box<dyn Error + Send + Sync>> {
|
|
|
|
pub(crate) async fn handle_char_list_req(stream: &mut TcpStream, packet: Packet, character_client: Arc<Mutex<CharacterClient>>, connection_service: Arc<ConnectionService>, connection_id: String) -> Result<(), Box<dyn Error + Send + Sync>> {
|
|
|
|
use crate::packets::srv_char_list_reply::*;
|
|
|
|
use crate::packets::srv_char_list_reply::*;
|
|
|
|
|
|
|
|
use crate::packets::cli_char_list_req::*;
|
|
|
|
let request = CliCharListReq::decode(packet.payload.as_slice());
|
|
|
|
let request = CliCharListReq::decode(packet.payload.as_slice());
|
|
|
|
debug!("{:?}", request);
|
|
|
|
debug!("{:?}", request);
|
|
|
|
|
|
|
|
|
|
|
|
@@ -96,6 +90,8 @@ pub(crate) async fn handle_char_list_req(stream: &mut TcpStream, packet: Packet,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
pub(crate) async fn handle_create_char_req(stream: &mut TcpStream, packet: Packet, character_client: Arc<Mutex<CharacterClient>>, connection_service: Arc<ConnectionService>, connection_id: String) -> Result<(), Box<dyn Error + Send + Sync>> {
|
|
|
|
pub(crate) async fn handle_create_char_req(stream: &mut TcpStream, packet: Packet, character_client: Arc<Mutex<CharacterClient>>, connection_service: Arc<ConnectionService>, connection_id: String) -> Result<(), Box<dyn Error + Send + Sync>> {
|
|
|
|
|
|
|
|
use crate::packets::cli_create_char_req::*;
|
|
|
|
|
|
|
|
use crate::packets::srv_create_char_reply::*;
|
|
|
|
let request = CliCreateCharReq::decode(packet.payload.as_slice())?;
|
|
|
|
let request = CliCreateCharReq::decode(packet.payload.as_slice())?;
|
|
|
|
debug!("{:?}", request);
|
|
|
|
debug!("{:?}", request);
|
|
|
|
|
|
|
|
|
|
|
|
@@ -128,6 +124,8 @@ pub(crate) async fn handle_create_char_req(stream: &mut TcpStream, packet: Packe
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
pub(crate) async fn handle_delete_char_req(stream: &mut TcpStream, packet: Packet, character_client: Arc<Mutex<CharacterClient>>, connection_service: Arc<ConnectionService>, connection_id: String) -> Result<(), Box<dyn Error + Send + Sync>> {
|
|
|
|
pub(crate) async fn handle_delete_char_req(stream: &mut TcpStream, packet: Packet, character_client: Arc<Mutex<CharacterClient>>, connection_service: Arc<ConnectionService>, connection_id: String) -> Result<(), Box<dyn Error + Send + Sync>> {
|
|
|
|
|
|
|
|
use crate::packets::cli_delete_char_req::*;
|
|
|
|
|
|
|
|
use crate::packets::srv_delete_char_reply::*;
|
|
|
|
let request = CliDeleteCharReq::decode(packet.payload.as_slice())?;
|
|
|
|
let request = CliDeleteCharReq::decode(packet.payload.as_slice())?;
|
|
|
|
debug!("{:?}", request);
|
|
|
|
debug!("{:?}", request);
|
|
|
|
|
|
|
|
|
|
|
|
@@ -156,6 +154,8 @@ pub(crate) async fn handle_delete_char_req(stream: &mut TcpStream, packet: Packe
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
pub(crate) async fn handle_select_char_req(stream: &mut TcpStream, packet: Packet, character_client: Arc<Mutex<CharacterClient>>, connection_service: Arc<ConnectionService>, connection_id: String) -> Result<(), Box<dyn Error + Send + Sync>> {
|
|
|
|
pub(crate) async fn handle_select_char_req(stream: &mut TcpStream, packet: Packet, character_client: Arc<Mutex<CharacterClient>>, connection_service: Arc<ConnectionService>, connection_id: String) -> Result<(), Box<dyn Error + Send + Sync>> {
|
|
|
|
|
|
|
|
use crate::packets::cli_select_char_req::*;
|
|
|
|
|
|
|
|
use crate::packets::srv_switch_server::*;
|
|
|
|
use crate::packets::srv_select_char_reply::*;
|
|
|
|
use crate::packets::srv_select_char_reply::*;
|
|
|
|
use crate::packets::srv_inventory_data::*;
|
|
|
|
use crate::packets::srv_inventory_data::*;
|
|
|
|
use crate::packets::srv_quest_data::*;
|
|
|
|
use crate::packets::srv_quest_data::*;
|
|
|
|
|