mirror of
https://github.com/Kelsidavis/WoWee.git
synced 2026-03-23 15:50:20 +00:00
619 lines
14 KiB
Markdown
619 lines
14 KiB
Markdown
# Local Server Setup Guide
|
||
|
||
**Date**: 2026-01-27
|
||
**Purpose**: Testing wowee with a local WoW 3.3.5a server
|
||
**Status**: Ready for testing
|
||
|
||
---
|
||
|
||
## Overview
|
||
|
||
The wowee client is pre-configured to connect to a local WoW 3.3.5a private server. This guide explains how to set up and test with popular server emulators like TrinityCore or AzerothCore.
|
||
|
||
## Default Configuration
|
||
|
||
The authentication screen comes with local server defaults:
|
||
|
||
| Setting | Default Value | Description |
|
||
|---------|---------------|-------------|
|
||
| **Hostname** | 127.0.0.1 | Localhost (your machine) |
|
||
| **Port** | 3724 | Standard auth server port |
|
||
| **Username** | (empty) | Your account username |
|
||
| **Password** | (empty) | Your account password |
|
||
|
||
These values can be changed in the UI before connecting.
|
||
|
||
## Server Requirements
|
||
|
||
You need a WoW 3.3.5a (Wrath of the Lich King) server emulator running on your local machine or network.
|
||
|
||
### Supported Server Emulators
|
||
|
||
**Recommended:**
|
||
- **TrinityCore 3.3.5a** - Most stable and feature-complete
|
||
- GitHub: https://github.com/TrinityCore/TrinityCore (3.3.5 branch)
|
||
- Documentation: https://trinitycore.info/
|
||
|
||
- **AzerothCore** - Active community, good documentation
|
||
- GitHub: https://github.com/azerothcore/azerothcore-wotlk
|
||
- Documentation: https://www.azerothcore.org/wiki/
|
||
|
||
- **MaNGOS WotLK** - Classic emulator, stable
|
||
- GitHub: https://github.com/cmangos/mangos-wotlk
|
||
- Documentation: https://github.com/cmangos/mangos-wotlk/wiki
|
||
|
||
## Quick Setup (TrinityCore)
|
||
|
||
### 1. Install Prerequisites
|
||
|
||
**Ubuntu/Debian:**
|
||
```bash
|
||
sudo apt-get update
|
||
sudo apt-get install git cmake make gcc g++ libssl-dev \
|
||
libmysqlclient-dev libreadline-dev zlib1g-dev libbz2-dev \
|
||
libboost-all-dev mysql-server
|
||
```
|
||
|
||
**macOS:**
|
||
```bash
|
||
brew install cmake boost openssl readline mysql
|
||
```
|
||
|
||
### 2. Download TrinityCore
|
||
|
||
```bash
|
||
cd ~/
|
||
git clone -b 3.3.5 https://github.com/TrinityCore/TrinityCore.git
|
||
cd TrinityCore
|
||
```
|
||
|
||
### 3. Compile Server
|
||
|
||
```bash
|
||
mkdir build && cd build
|
||
cmake ../ -DCMAKE_INSTALL_PREFIX=$HOME/trinitycore-server
|
||
make -j$(nproc)
|
||
make install
|
||
```
|
||
|
||
**Compilation time:** ~30-60 minutes depending on your system.
|
||
|
||
### 4. Setup Database
|
||
|
||
```bash
|
||
# Create MySQL databases
|
||
mysql -u root -p
|
||
|
||
CREATE DATABASE world;
|
||
CREATE DATABASE characters;
|
||
CREATE DATABASE auth;
|
||
CREATE USER 'trinity'@'localhost' IDENTIFIED BY 'trinity';
|
||
GRANT ALL PRIVILEGES ON world.* TO 'trinity'@'localhost';
|
||
GRANT ALL PRIVILEGES ON characters.* TO 'trinity'@'localhost';
|
||
GRANT ALL PRIVILEGES ON auth.* TO 'trinity'@'localhost';
|
||
FLUSH PRIVILEGES;
|
||
EXIT;
|
||
|
||
# Import base database
|
||
cd ~/TrinityCore
|
||
mysql -u trinity -ptrinity auth < sql/base/auth_database.sql
|
||
mysql -u trinity -ptrinity characters < sql/base/characters_database.sql
|
||
mysql -u trinity -ptrinity world < sql/base/world_database.sql
|
||
|
||
# Download world database (TDB)
|
||
wget https://github.com/TrinityCore/TrinityCore/releases/download/TDB335.23041/TDB_full_world_335.23041_2023_04_11.sql
|
||
mysql -u trinity -ptrinity world < TDB_full_world_335.23041_2023_04_11.sql
|
||
```
|
||
|
||
### 5. Configure Server
|
||
|
||
```bash
|
||
cd ~/trinitycore-server/etc/
|
||
|
||
# Copy configuration templates
|
||
cp authserver.conf.dist authserver.conf
|
||
cp worldserver.conf.dist worldserver.conf
|
||
|
||
# Edit authserver.conf
|
||
nano authserver.conf
|
||
```
|
||
|
||
**Key settings in `authserver.conf`:**
|
||
```ini
|
||
LoginDatabaseInfo = "127.0.0.1;3306;trinity;trinity;auth"
|
||
RealmServerPort = 3724
|
||
BindIP = "127.0.0.1"
|
||
```
|
||
|
||
**Key settings in `worldserver.conf`:**
|
||
```ini
|
||
LoginDatabaseInfo = "127.0.0.1;3306;trinity;trinity;auth"
|
||
WorldDatabaseInfo = "127.0.0.1;3306;trinity;trinity;world"
|
||
CharacterDatabaseInfo = "127.0.0.1;3306;trinity;trinity;characters"
|
||
|
||
DataDir = "/path/to/your/WoW-3.3.5a/Data" # Your WoW client data directory
|
||
```
|
||
|
||
### 6. Create Account
|
||
|
||
```bash
|
||
cd ~/trinitycore-server/bin/
|
||
|
||
# Start authserver first
|
||
./authserver
|
||
|
||
# In another terminal, start worldserver
|
||
./worldserver
|
||
|
||
# Wait for worldserver to fully load, then in worldserver console:
|
||
account create testuser testpass
|
||
account set gmlevel testuser 3 -1
|
||
```
|
||
|
||
### 7. Setup Realm
|
||
|
||
In the worldserver console:
|
||
```
|
||
realm add "Local Test Realm" 127.0.0.1:8085 0 1
|
||
```
|
||
|
||
Or directly in database:
|
||
```sql
|
||
mysql -u trinity -ptrinity auth
|
||
|
||
INSERT INTO realmlist (name, address, port, icon, realmflags, timezone, allowedSecurityLevel)
|
||
VALUES ('Local Test Realm', '127.0.0.1', 8085, 1, 0, 1, 0);
|
||
```
|
||
|
||
## Running the Server
|
||
|
||
### Start Services
|
||
|
||
**Terminal 1 - Auth Server:**
|
||
```bash
|
||
cd ~/trinitycore-server/bin/
|
||
./authserver
|
||
```
|
||
|
||
**Terminal 2 - World Server:**
|
||
```bash
|
||
cd ~/trinitycore-server/bin/
|
||
./worldserver
|
||
```
|
||
|
||
### Server Console Commands
|
||
|
||
**Useful commands in worldserver console:**
|
||
|
||
```bash
|
||
# Create account
|
||
account create username password
|
||
|
||
# Set GM level (0=player, 1=moderator, 2=GM, 3=admin)
|
||
account set gmlevel username 3 -1
|
||
|
||
# Teleport character
|
||
.tele ironforge
|
||
.tele stormwind
|
||
|
||
# Get server info
|
||
server info
|
||
server set motd Welcome to Test Server!
|
||
|
||
# List online players
|
||
account onlinelist
|
||
|
||
# Shutdown server
|
||
server shutdown 10 # Shutdown in 10 seconds
|
||
```
|
||
|
||
## Connecting with Wowee-Native
|
||
|
||
### 1. Start the Client
|
||
|
||
```bash
|
||
cd /home/k/Desktop/wowee/wowee
|
||
./build/bin/wowee
|
||
```
|
||
|
||
### 2. Login Screen
|
||
|
||
You'll see the authentication screen with default values:
|
||
- **Hostname:** 127.0.0.1 (already set)
|
||
- **Port:** 3724 (already set)
|
||
- **Username:** (enter your account username)
|
||
- **Password:** (enter your account password)
|
||
|
||
### 3. Connect
|
||
|
||
1. Enter your credentials (e.g., `testuser` / `testpass`)
|
||
2. Click **Connect**
|
||
3. You should see "Authentication successful!"
|
||
4. Select your realm from the realm list
|
||
5. Create or select a character
|
||
6. Enter the world!
|
||
|
||
## Troubleshooting
|
||
|
||
### Connection Refused
|
||
|
||
**Problem:** Cannot connect to auth server
|
||
|
||
**Solutions:**
|
||
```bash
|
||
# Check if authserver is running
|
||
ps aux | grep authserver
|
||
|
||
# Check if port is listening
|
||
netstat -an | grep 3724
|
||
sudo lsof -i :3724
|
||
|
||
# Check firewall
|
||
sudo ufw allow 3724
|
||
sudo ufw status
|
||
|
||
# Verify MySQL is running
|
||
sudo systemctl status mysql
|
||
```
|
||
|
||
### Authentication Failed
|
||
|
||
**Problem:** "Authentication failed" error
|
||
|
||
**Solutions:**
|
||
```bash
|
||
# Verify account exists
|
||
mysql -u trinity -ptrinity auth
|
||
SELECT * FROM account WHERE username='testuser';
|
||
|
||
# Reset password
|
||
# In worldserver console:
|
||
account set password testuser newpass newpass
|
||
|
||
# Check auth server logs
|
||
tail -f ~/trinitycore-server/logs/Auth.log
|
||
```
|
||
|
||
### Realm List Empty
|
||
|
||
**Problem:** No realms showing after login
|
||
|
||
**Solutions:**
|
||
```bash
|
||
# Check realm configuration in database
|
||
mysql -u trinity -ptrinity auth
|
||
SELECT * FROM realmlist;
|
||
|
||
# Verify world server is running
|
||
ps aux | grep worldserver
|
||
|
||
# Check world server port
|
||
netstat -an | grep 8085
|
||
|
||
# Update realmlist address
|
||
UPDATE realmlist SET address='127.0.0.1' WHERE id=1;
|
||
```
|
||
|
||
### Cannot Enter World
|
||
|
||
**Problem:** Stuck at character selection or disconnect when entering world
|
||
|
||
**Solutions:**
|
||
```bash
|
||
# Check worldserver logs
|
||
tail -f ~/trinitycore-server/logs/Server.log
|
||
|
||
# Verify Data directory in worldserver.conf
|
||
DataDir = "/path/to/WoW-3.3.5a/Data"
|
||
|
||
# Ensure maps are extracted
|
||
cd ~/WoW-3.3.5a/
|
||
ls -la maps/ # Should have .map files
|
||
|
||
# Extract maps if needed (from TrinityCore tools)
|
||
cd ~/trinitycore-server/bin/
|
||
./mapextractor
|
||
./vmap4extractor
|
||
./vmap4assembler
|
||
./mmaps_generator
|
||
```
|
||
|
||
## Network Configuration
|
||
|
||
### Local Network Testing
|
||
|
||
To test from another machine on your network:
|
||
|
||
**1. Find your local IP:**
|
||
```bash
|
||
ip addr show | grep inet
|
||
# Or
|
||
ifconfig | grep inet
|
||
```
|
||
|
||
**2. Update server configuration:**
|
||
|
||
Edit `authserver.conf`:
|
||
```ini
|
||
BindIP = "0.0.0.0" # Listen on all interfaces
|
||
```
|
||
|
||
Edit database:
|
||
```sql
|
||
mysql -u trinity -ptrinity auth
|
||
UPDATE realmlist SET address='192.168.1.100' WHERE id=1; # Your local IP
|
||
```
|
||
|
||
**3. Configure firewall:**
|
||
```bash
|
||
sudo ufw allow 3724 # Auth server
|
||
sudo ufw allow 8085 # World server
|
||
```
|
||
|
||
**4. In wowee:**
|
||
- Change hostname to your server's local IP (e.g., 192.168.1.100)
|
||
- Keep port as 3724
|
||
- Connect
|
||
|
||
### Remote Server Testing
|
||
|
||
For testing with a remote server (VPS, dedicated server):
|
||
|
||
**Client configuration:**
|
||
- **Hostname:** server.example.com or remote IP
|
||
- **Port:** 3724 (or custom port)
|
||
|
||
**Server configuration:**
|
||
```ini
|
||
# authserver.conf
|
||
BindIP = "0.0.0.0"
|
||
|
||
# Database
|
||
UPDATE realmlist SET address='your.server.ip' WHERE id=1;
|
||
```
|
||
|
||
## WoW Data Files
|
||
|
||
The client needs access to WoW 3.3.5a data files for terrain, models, and textures.
|
||
|
||
### Setting WOW_DATA_PATH
|
||
|
||
```bash
|
||
# Linux/Mac
|
||
export WOW_DATA_PATH="/path/to/WoW-3.3.5a/Data"
|
||
|
||
# Or add to ~/.bashrc
|
||
echo 'export WOW_DATA_PATH="/path/to/WoW-3.3.5a/Data"' >> ~/.bashrc
|
||
source ~/.bashrc
|
||
|
||
# Run client
|
||
cd /home/k/Desktop/wowee/wowee
|
||
./build/bin/wowee
|
||
```
|
||
|
||
### Data Directory Structure
|
||
|
||
Your WoW Data directory should contain:
|
||
```
|
||
Data/
|
||
├── common.MPQ
|
||
├── common-2.MPQ
|
||
├── expansion.MPQ
|
||
├── lichking.MPQ
|
||
├── patch.MPQ
|
||
├── patch-2.MPQ
|
||
├── patch-3.MPQ
|
||
└── enUS/ (or your locale)
|
||
├── locale-enUS.MPQ
|
||
└── patch-enUS-3.MPQ
|
||
```
|
||
|
||
## Testing Features
|
||
|
||
### In-Game Testing
|
||
|
||
Once connected and in-world, test client features:
|
||
|
||
**Camera Controls:**
|
||
- **WASD** - Move camera
|
||
- **Mouse** - Look around
|
||
- **Shift** - Move faster
|
||
|
||
**Rendering Features:**
|
||
- **F1** - Toggle performance HUD
|
||
- **F2** - Wireframe mode
|
||
- **F8** - Toggle water rendering
|
||
- **F9** - Toggle time progression
|
||
- **F10** - Toggle sun/moon
|
||
- **F11** - Toggle stars
|
||
- **F12** - Toggle fog
|
||
- **+/-** - Change time of day
|
||
|
||
**Effects:**
|
||
- **C** - Toggle clouds
|
||
- **L** - Toggle lens flare
|
||
- **W** - Cycle weather (rain/snow)
|
||
- **M** - Toggle moon phases
|
||
|
||
**Character/Buildings:**
|
||
- **K** - Spawn test character
|
||
- **O** - Spawn test WMO building
|
||
- **Shift+O** - Load real WMO from MPQ (if WOW_DATA_PATH set)
|
||
- **P** - Clear all WMOs
|
||
|
||
### Performance Monitoring
|
||
|
||
Press **F1** to show/hide the performance HUD which displays:
|
||
- **FPS** - Frames per second (color-coded: green=60+, yellow=30-60, red=<30)
|
||
- **Frame time** - Milliseconds per frame
|
||
- **Renderer stats** - Draw calls, triangles
|
||
- **WMO stats** - Building models and instances
|
||
- **Camera position** - X, Y, Z coordinates
|
||
|
||
## Server Administration
|
||
|
||
### GM Commands (in worldserver console or in-game)
|
||
|
||
**Character Management:**
|
||
```
|
||
.character level 80 # Set level to 80
|
||
.character rename # Flag character for rename
|
||
.character customize # Flag for appearance change
|
||
.levelup 80 # Increase level by 80
|
||
```
|
||
|
||
**Item/Gold:**
|
||
```
|
||
.additem 25 10 # Add 10 of item ID 25
|
||
.modify money 1000000 # Add 10 gold (in copper)
|
||
.lookup item sword # Find item IDs
|
||
```
|
||
|
||
**Teleportation:**
|
||
```
|
||
.tele stormwind # Teleport to Stormwind
|
||
.tele ironforge # Teleport to Ironforge
|
||
.gps # Show current position
|
||
```
|
||
|
||
**World Management:**
|
||
```
|
||
.server set motd Welcome! # Set message of the day
|
||
.announce Message # Server-wide announcement
|
||
.server shutdown 60 # Shutdown in 60 seconds
|
||
```
|
||
|
||
## Performance Tips
|
||
|
||
### Server Optimization
|
||
|
||
**worldserver.conf settings for testing:**
|
||
```ini
|
||
# Faster respawn times for testing
|
||
Corpse.Decay.NORMAL = 30
|
||
Corpse.Decay.RARE = 60
|
||
Corpse.Decay.ELITE = 60
|
||
|
||
# Faster leveling for testing
|
||
Rate.XP.Kill = 2
|
||
Rate.XP.Quest = 2
|
||
|
||
# More gold for testing
|
||
Rate.Drop.Money = 2
|
||
|
||
# Instant flight paths (testing)
|
||
Rate.Creature.Normal.Damage = 1
|
||
Rate.Player.Haste = 1
|
||
```
|
||
|
||
### Client Performance
|
||
|
||
- Keep performance HUD (F1) enabled to monitor FPS
|
||
- Disable heavy effects if FPS drops:
|
||
- Weather (W key to None)
|
||
- Clouds (C key to disable)
|
||
- Lens flare (L key to disable)
|
||
|
||
## Security Notes
|
||
|
||
⚠️ **For Local Testing Only**
|
||
|
||
This setup is for **local development and testing** purposes:
|
||
- Default passwords are insecure
|
||
- No SSL/TLS encryption
|
||
- MySQL permissions are permissive
|
||
- Ports are open without authentication
|
||
|
||
**Do not expose these settings to the internet without proper security configuration.**
|
||
|
||
## Additional Resources
|
||
|
||
### Server Emulators
|
||
- **TrinityCore**: https://trinitycore.info/
|
||
- **AzerothCore**: https://www.azerothcore.org/
|
||
- **MaNGOS**: https://getmangos.eu/
|
||
|
||
### Database Tools
|
||
- **Keira3** - Visual database editor: https://github.com/azerothcore/Keira3
|
||
- **HeidiSQL** - MySQL client: https://www.heidisql.com/
|
||
|
||
### WoW Development
|
||
- **WoWDev Wiki**: https://wowdev.wiki/
|
||
- **TrinityCore Forum**: https://community.trinitycore.org/
|
||
- **AzerothCore Discord**: https://discord.gg/azerothcore
|
||
|
||
### Map/DBC Tools
|
||
- **WoW Blender Studio**: https://github.com/Marlamin/WoW-Blender-Studio
|
||
- **WDBXEditor**: https://github.com/WowDevTools/WDBXEditor
|
||
|
||
## Example Testing Session
|
||
|
||
### Complete Workflow
|
||
|
||
1. **Start Server:**
|
||
```bash
|
||
# Terminal 1
|
||
cd ~/trinitycore-server/bin && ./authserver
|
||
|
||
# Terminal 2
|
||
cd ~/trinitycore-server/bin && ./worldserver
|
||
```
|
||
|
||
2. **Create Test Account (in worldserver console):**
|
||
```
|
||
account create demo demopass
|
||
account set gmlevel demo 3 -1
|
||
```
|
||
|
||
3. **Start Client:**
|
||
```bash
|
||
cd /home/k/Desktop/wowee/wowee
|
||
export WOW_DATA_PATH="/path/to/WoW-3.3.5a/Data"
|
||
./build/bin/wowee
|
||
```
|
||
|
||
4. **Connect:**
|
||
- Username: `demo`
|
||
- Password: `demopass`
|
||
- Click Connect
|
||
|
||
5. **Test Features:**
|
||
- Create a character
|
||
- Enter world
|
||
- Test rendering (F1-F12, C, L, W, M keys)
|
||
- Spawn objects (K, O, Shift+O, P keys)
|
||
- Test movement (WASD, mouse)
|
||
|
||
6. **Stop Server (worldserver console):**
|
||
```
|
||
server shutdown 10
|
||
```
|
||
|
||
## Troubleshooting Checklist
|
||
|
||
- [ ] MySQL server running
|
||
- [ ] Databases created and populated
|
||
- [ ] authserver running and listening on port 3724
|
||
- [ ] worldserver running and listening on port 8085
|
||
- [ ] Realmlist configured with correct address
|
||
- [ ] Account created with proper credentials
|
||
- [ ] Firewall allows ports 3724 and 8085
|
||
- [ ] WOW_DATA_PATH set correctly (if using MPQ assets)
|
||
- [ ] Client can resolve hostname (127.0.0.1 for localhost)
|
||
|
||
## Next Steps
|
||
|
||
Once you have a working local server connection:
|
||
1. Test network protocol implementation
|
||
2. Validate packet handling
|
||
3. Test character creation and login
|
||
4. Verify world entry and movement
|
||
5. Test rendering with real terrain data (requires WOW_DATA_PATH)
|
||
6. Profile performance with actual game data
|
||
|
||
---
|
||
|
||
**Status**: Ready for local server testing
|
||
**Last Updated**: 2026-01-27
|
||
**Client Version**: 1.0.3
|
||
**Server Compatibility**: WoW 3.3.5a (12340)
|