Compare commits

..

No commits in common. "6caeb0a8d9ba4eee8c40f84ac5d5f02edb9f0477" and "b42056419ab1b411c57cbcb617d886bc124e2bcb" have entirely different histories.

146 changed files with 3234 additions and 1210 deletions

View File

@ -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

File diff suppressed because it is too large Load Diff

View File

@ -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");

View File

@ -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