Compare commits
No commits in common. "6caeb0a8d9ba4eee8c40f84ac5d5f02edb9f0477" and "b42056419ab1b411c57cbcb617d886bc124e2bcb" have entirely different histories.
6caeb0a8d9
...
b42056419a
95
Cargo.toml
95
Cargo.toml
@ -6,41 +6,35 @@ edition = "2021"
|
|||||||
|
|
||||||
[workspace]
|
[workspace]
|
||||||
members = [
|
members = [
|
||||||
"src/client",
|
"client",
|
||||||
"src/drops",
|
"drops",
|
||||||
"src/entity",
|
"entity",
|
||||||
"src/items",
|
"items",
|
||||||
"src/location",
|
"location",
|
||||||
"src/maps",
|
"maps",
|
||||||
"src/networking",
|
"networking",
|
||||||
"src/pktbuilder",
|
"pktbuilder",
|
||||||
"src/quests",
|
"quests",
|
||||||
"src/room",
|
"room",
|
||||||
"src/shops",
|
"shops",
|
||||||
"src/stats",
|
"stats",
|
||||||
"src/trade",
|
"trade",
|
||||||
"src/patch_server",
|
|
||||||
"src/login_server",
|
|
||||||
"src/ship_server",
|
|
||||||
]
|
]
|
||||||
|
|
||||||
[workspace.dependencies]
|
[workspace.dependencies]
|
||||||
entity = { path = "./src/entity" }
|
entity = { path = "./entity" }
|
||||||
maps = { path = "./src/maps" }
|
maps = { path = "./maps" }
|
||||||
networking = { path = "./src/networking" }
|
networking = { path = "./networking" }
|
||||||
shops = { path = "./src/shops" }
|
shops = { path = "./shops" }
|
||||||
stats = { path = "./src/stats" }
|
stats = { path = "./stats" }
|
||||||
items = { path = "./src/items" }
|
items = { path = "./items" }
|
||||||
pktbuilder = { path = "./src/pktbuilder" }
|
pktbuilder = { path = "./pktbuilder" }
|
||||||
quests = { path = "./src/quests" }
|
quests = { path = "./quests" }
|
||||||
location = { path = "./src/location" }
|
location = { path = "./location" }
|
||||||
client = { path = "./src/client" }
|
client = { path = "./client" }
|
||||||
drops = { path = "./src/drops" }
|
drops = { path = "./drops" }
|
||||||
trade = { path = "./src/trade" }
|
trade = { path = "./trade" }
|
||||||
room = { path = "./src/room" }
|
room = { path = "./room" }
|
||||||
patch_server = { path = "./src/patch_server" }
|
|
||||||
login_server = { path = "./src/login_server" }
|
|
||||||
ship_server = { path = "./src/ship_server" }
|
|
||||||
|
|
||||||
libpso = { git = "http://git.sharnoth.com/jake/libpso" }
|
libpso = { git = "http://git.sharnoth.com/jake/libpso" }
|
||||||
|
|
||||||
@ -65,6 +59,7 @@ ages-prs = "0.1"
|
|||||||
async-trait = "0.1.51"
|
async-trait = "0.1.51"
|
||||||
async-recursion= "1.0.0"
|
async-recursion= "1.0.0"
|
||||||
lazy_static = "1.4.0"
|
lazy_static = "1.4.0"
|
||||||
|
barrel = { version = "0.6.5", features = ["pg"] }
|
||||||
refinery = { version = "0.5.0", features = ["postgres"] }
|
refinery = { version = "0.5.0", features = ["postgres"] }
|
||||||
sqlx = { version = "0.6.2", features = ["runtime-async-std-native-tls", "postgres", "json", "chrono"] }
|
sqlx = { version = "0.6.2", features = ["runtime-async-std-native-tls", "postgres", "json", "chrono"] }
|
||||||
strum = "0.19.5"
|
strum = "0.19.5"
|
||||||
@ -75,23 +70,37 @@ anyhow = { version = "1.0.68", features = ["backtrace"] }
|
|||||||
entity = { workspace = true }
|
entity = { workspace = true }
|
||||||
maps = { workspace = true }
|
maps = { workspace = true }
|
||||||
networking = { workspace = true }
|
networking = { workspace = true }
|
||||||
patch_server = { workspace = true }
|
shops = { workspace = true }
|
||||||
login_server = { workspace = true }
|
stats = { workspace = true }
|
||||||
ship_server = { workspace = true }
|
items = { workspace = true }
|
||||||
|
pktbuilder = { workspace = true }
|
||||||
|
quests = { workspace = true }
|
||||||
|
location = { workspace = true }
|
||||||
|
client = { workspace = true }
|
||||||
|
drops = { workspace = true }
|
||||||
|
trade = { workspace = true }
|
||||||
|
room = { workspace = true }
|
||||||
|
|
||||||
libpso = { workspace = true }
|
libpso = { workspace = true }
|
||||||
|
|
||||||
|
ages-prs = { workspace = true }
|
||||||
|
anyhow = { workspace = true }
|
||||||
|
async-recursion = { workspace = true }
|
||||||
async-std = { workspace = true }
|
async-std = { workspace = true }
|
||||||
|
async-trait = { workspace = true }
|
||||||
bcrypt = { workspace = true }
|
bcrypt = { workspace = true }
|
||||||
|
byteorder = { workspace = true }
|
||||||
chrono = { workspace = true }
|
chrono = { workspace = true }
|
||||||
|
crc = { workspace = true }
|
||||||
|
derive_more = { workspace = true }
|
||||||
|
enum-utils = { workspace = true }
|
||||||
fern = { workspace = true }
|
fern = { workspace = true }
|
||||||
futures = { workspace = true }
|
futures = { workspace = true }
|
||||||
log = { workspace = true }
|
log = { workspace = true }
|
||||||
|
rand = { workspace = true }
|
||||||
[dev-dependencies]
|
rand_chacha = { workspace = true }
|
||||||
drops = { workspace = true }
|
ron = { workspace = true }
|
||||||
shops = { workspace = true }
|
serde = { workspace = true }
|
||||||
items = { workspace = true }
|
serde_json = { workspace = true }
|
||||||
quests = { workspace = true }
|
toml = { workspace = true }
|
||||||
stats = { workspace = true }
|
thiserror = { workspace = true }
|
||||||
async-trait = { workspace = true }
|
|
1380
items/src/manager.rs
Normal file
1380
items/src/manager.rs
Normal file
File diff suppressed because it is too large
Load Diff
@ -1,7 +1,7 @@
|
|||||||
use log::{info};
|
use log::{info};
|
||||||
use entity::gateway::postgres::PostgresGateway;
|
use entity::gateway::postgres::PostgresGateway;
|
||||||
use login_server::login::LoginServerState;
|
use elseware::login::login::LoginServerState;
|
||||||
use login_server::character::CharacterServerState;
|
use elseware::login::character::CharacterServerState;
|
||||||
use networking::interserver::AuthToken;
|
use networking::interserver::AuthToken;
|
||||||
|
|
||||||
fn main() {
|
fn main() {
|
||||||
@ -38,17 +38,17 @@ fn main() {
|
|||||||
|
|
||||||
let login_state = LoginServerState::new(entity_gateway.clone(), charserv_ip);
|
let login_state = LoginServerState::new(entity_gateway.clone(), charserv_ip);
|
||||||
let login_loop = async_std::task::spawn(async move {
|
let login_loop = async_std::task::spawn(async move {
|
||||||
networking::mainloop::run_server(login_state, login_server::login::LOGIN_PORT).await;
|
networking::mainloop::run_server(login_state, elseware::login::login::LOGIN_PORT).await;
|
||||||
});
|
});
|
||||||
|
|
||||||
let char_state = CharacterServerState::new(entity_gateway, AuthToken(shipgate_token));
|
let char_state = CharacterServerState::new(entity_gateway, AuthToken(shipgate_token));
|
||||||
let sub_char_state = char_state.clone();
|
let sub_char_state = char_state.clone();
|
||||||
let character_loop = async_std::task::spawn(async move {
|
let character_loop = async_std::task::spawn(async move {
|
||||||
networking::mainloop::run_server(sub_char_state, login_server::character::CHARACTER_PORT).await;
|
networking::mainloop::run_server(sub_char_state, elseware::login::character::CHARACTER_PORT).await;
|
||||||
});
|
});
|
||||||
|
|
||||||
let inter_character_loop = async_std::task::spawn(async move {
|
let inter_character_loop = async_std::task::spawn(async move {
|
||||||
networking::mainloop::run_interserver_listen(char_state, login_server::login::COMMUNICATION_PORT).await;
|
networking::mainloop::run_interserver_listen(char_state, elseware::login::login::COMMUNICATION_PORT).await;
|
||||||
});
|
});
|
||||||
|
|
||||||
info!("[auth/character] starting server");
|
info!("[auth/character] starting server");
|
||||||
|
@ -2,10 +2,10 @@ use std::net::Ipv4Addr;
|
|||||||
use log::{info};
|
use log::{info};
|
||||||
|
|
||||||
use networking::interserver::AuthToken;
|
use networking::interserver::AuthToken;
|
||||||
use login_server::login::LoginServerState;
|
use elseware::login::login::LoginServerState;
|
||||||
use login_server::character::CharacterServerState;
|
use elseware::login::character::CharacterServerState;
|
||||||
use patch_server::{PatchServerState, generate_patch_tree, load_config, load_motd};
|
use elseware::patch::{PatchServerState, generate_patch_tree, load_config, load_motd};
|
||||||
use ship_server::ShipServerStateBuilder;
|
use elseware::ship::ship::ShipServerStateBuilder;
|
||||||
|
|
||||||
use maps::Holiday;
|
use maps::Holiday;
|
||||||
use entity::gateway::{EntityGateway, InMemoryGateway};
|
use entity::gateway::{EntityGateway, InMemoryGateway};
|
||||||
@ -344,67 +344,67 @@ fn main() {
|
|||||||
info!("[auth] starting server");
|
info!("[auth] starting server");
|
||||||
let login_state = LoginServerState::new(entity_gateway.clone(), "127.0.0.1".parse().unwrap());
|
let login_state = LoginServerState::new(entity_gateway.clone(), "127.0.0.1".parse().unwrap());
|
||||||
let login_loop = async_std::task::spawn(async move {
|
let login_loop = async_std::task::spawn(async move {
|
||||||
networking::mainloop::run_server(login_state, login_server::login::LOGIN_PORT).await;
|
networking::mainloop::run_server(login_state, elseware::login::login::LOGIN_PORT).await;
|
||||||
});
|
});
|
||||||
|
|
||||||
info!("[character] starting server");
|
info!("[character] starting server");
|
||||||
let char_state = CharacterServerState::new(entity_gateway.clone(), AuthToken("".into()));
|
let char_state = CharacterServerState::new(entity_gateway.clone(), AuthToken("".into()));
|
||||||
let sub_char_state = char_state.clone();
|
let sub_char_state = char_state.clone();
|
||||||
let character_loop = async_std::task::spawn(async move {
|
let character_loop = async_std::task::spawn(async move {
|
||||||
networking::mainloop::run_server(sub_char_state, login_server::character::CHARACTER_PORT).await;
|
networking::mainloop::run_server(sub_char_state, elseware::login::character::CHARACTER_PORT).await;
|
||||||
});
|
});
|
||||||
|
|
||||||
let sub_char_state = char_state.clone();
|
let sub_char_state = char_state.clone();
|
||||||
let inter_character_loop = async_std::task::spawn(async move {
|
let inter_character_loop = async_std::task::spawn(async move {
|
||||||
networking::mainloop::run_interserver_listen(sub_char_state, login_server::login::COMMUNICATION_PORT).await;
|
networking::mainloop::run_interserver_listen(sub_char_state, elseware::login::login::COMMUNICATION_PORT).await;
|
||||||
});
|
});
|
||||||
|
|
||||||
info!("[ship] starting servers");
|
info!("[ship] starting servers");
|
||||||
let ship_state = ShipServerStateBuilder::default()
|
let ship_state = ShipServerStateBuilder::default()
|
||||||
.name("US/Sona-Nyl".into())
|
.name("US/Sona-Nyl".into())
|
||||||
.ip(Ipv4Addr::new(127,0,0,1))
|
.ip(Ipv4Addr::new(127,0,0,1))
|
||||||
.port(ship_server::SHIP_PORT)
|
.port(elseware::ship::ship::SHIP_PORT)
|
||||||
.event(Holiday::Halloween)
|
.event(Holiday::Halloween)
|
||||||
.gateway(entity_gateway.clone())
|
.gateway(entity_gateway.clone())
|
||||||
.build();
|
.build();
|
||||||
let sub_ship_state = ship_state.clone();
|
let sub_ship_state = ship_state.clone();
|
||||||
let ship_loop1 = async_std::task::spawn(async move {
|
let ship_loop1 = async_std::task::spawn(async move {
|
||||||
networking::mainloop::run_server(sub_ship_state, ship_server::SHIP_PORT).await;
|
networking::mainloop::run_server(sub_ship_state, elseware::ship::ship::SHIP_PORT).await;
|
||||||
});
|
});
|
||||||
let sub_ship_state = ship_state.clone();
|
let sub_ship_state = ship_state.clone();
|
||||||
let inter_ship_loop1 = async_std::task::spawn(async move {
|
let inter_ship_loop1 = async_std::task::spawn(async move {
|
||||||
networking::mainloop::run_interserver_connect(sub_ship_state, std::net::Ipv4Addr::new(127, 0, 0, 1), login_server::login::COMMUNICATION_PORT).await;
|
networking::mainloop::run_interserver_connect(sub_ship_state, std::net::Ipv4Addr::new(127, 0, 0, 1), elseware::login::login::COMMUNICATION_PORT).await;
|
||||||
});
|
});
|
||||||
|
|
||||||
let ship_state = ShipServerStateBuilder::default()
|
let ship_state = ShipServerStateBuilder::default()
|
||||||
.name("EU/Dylath-Leen".into())
|
.name("EU/Dylath-Leen".into())
|
||||||
.ip(Ipv4Addr::new(127,0,0,1))
|
.ip(Ipv4Addr::new(127,0,0,1))
|
||||||
.port(ship_server::SHIP_PORT+2000)
|
.port(elseware::ship::ship::SHIP_PORT+2000)
|
||||||
.event(Holiday::Christmas)
|
.event(Holiday::Christmas)
|
||||||
.gateway(entity_gateway.clone())
|
.gateway(entity_gateway.clone())
|
||||||
.build();
|
.build();
|
||||||
let sub_ship_state = ship_state.clone();
|
let sub_ship_state = ship_state.clone();
|
||||||
let ship_loop2 = async_std::task::spawn(async move {
|
let ship_loop2 = async_std::task::spawn(async move {
|
||||||
networking::mainloop::run_server(sub_ship_state, ship_server::SHIP_PORT+2000).await;
|
networking::mainloop::run_server(sub_ship_state, elseware::ship::ship::SHIP_PORT+2000).await;
|
||||||
});
|
});
|
||||||
let sub_ship_state = ship_state.clone();
|
let sub_ship_state = ship_state.clone();
|
||||||
let inter_ship_loop2 = async_std::task::spawn(async move {
|
let inter_ship_loop2 = async_std::task::spawn(async move {
|
||||||
networking::mainloop::run_interserver_connect(sub_ship_state, std::net::Ipv4Addr::new(127, 0, 0, 1), login_server::login::COMMUNICATION_PORT).await;
|
networking::mainloop::run_interserver_connect(sub_ship_state, std::net::Ipv4Addr::new(127, 0, 0, 1), elseware::login::login::COMMUNICATION_PORT).await;
|
||||||
});
|
});
|
||||||
|
|
||||||
let ship_state = ShipServerStateBuilder::default()
|
let ship_state = ShipServerStateBuilder::default()
|
||||||
.name("JP/Thalarion".into())
|
.name("JP/Thalarion".into())
|
||||||
.ip(Ipv4Addr::new(127,0,0,1))
|
.ip(Ipv4Addr::new(127,0,0,1))
|
||||||
.port(ship_server::SHIP_PORT+3000)
|
.port(elseware::ship::ship::SHIP_PORT+3000)
|
||||||
.gateway(entity_gateway.clone())
|
.gateway(entity_gateway.clone())
|
||||||
.build();
|
.build();
|
||||||
let sub_ship_state = ship_state.clone();
|
let sub_ship_state = ship_state.clone();
|
||||||
let ship_loop3 = async_std::task::spawn(async move {
|
let ship_loop3 = async_std::task::spawn(async move {
|
||||||
networking::mainloop::run_server(sub_ship_state, ship_server::SHIP_PORT+3000).await;
|
networking::mainloop::run_server(sub_ship_state, elseware::ship::ship::SHIP_PORT+3000).await;
|
||||||
});
|
});
|
||||||
let sub_ship_state = ship_state.clone();
|
let sub_ship_state = ship_state.clone();
|
||||||
let inter_ship_loop3 = async_std::task::spawn(async move {
|
let inter_ship_loop3 = async_std::task::spawn(async move {
|
||||||
networking::mainloop::run_interserver_connect(sub_ship_state, std::net::Ipv4Addr::new(127, 0, 0, 1), login_server::login::COMMUNICATION_PORT).await;
|
networking::mainloop::run_interserver_connect(sub_ship_state, std::net::Ipv4Addr::new(127, 0, 0, 1), elseware::login::login::COMMUNICATION_PORT).await;
|
||||||
});
|
});
|
||||||
|
|
||||||
futures::future::join_all(vec![patch_loop, login_loop, character_loop, inter_character_loop,
|
futures::future::join_all(vec![patch_loop, login_loop, character_loop, inter_character_loop,
|
||||||
|
Some files were not shown because too many files have changed in this diff Show More
Loading…
x
Reference in New Issue
Block a user