Please disclose if any significant portion of your mod was created using AI tools by adding the 'AI Generated' category. Failing to do so may result in the mod being removed from Thunderstore.
PraetorisClient
Client-side tools for the Praetoris Server
| Last updated | 5 hours ago |
| Total downloads | 429 |
| Total rating | 0 |
| Categories | Mods Server-side Client-side AI Generated |
| Dependency string | praetoris-PraetorisClient-0.1.31 |
| Dependants | 1 other package depends on this package |
This mod requires the following mods to function
denikson-BepInExPack_Valheim
BepInEx pack for Valheim. Preconfigured with the correct entry point for mods and preferred defaults for the community.
Preferred version: 5.4.2333ValheimModding-Jotunn
Jötunn (/ˈjɔːtʊn/, 'giant'), the Valheim Library was created with the goal of making the lives of mod developers easier. It enables you to create mods for Valheim using an abstracted API so you can focus on the actual content creation.
Preferred version: 2.29.0README
Praetoris Client
A BepInEx client companion mod for Praetoris gameplay and account-linking features that should not live in DiscordTools.
Features
- In-game Discord link command:
!link CODE - Creative inventory bridge RPC for server-side mods that need a trusted client inventory count.
- Creative biome, terrain, vegetation, drop suppression, and skill suppression bridges for server-side creative zones.
- Siege portal client bridge RPC for server-side siege portal handling.
- Client-side RPC trace capture with HTTP upload to the ValheimTracer relay using short-lived server-issued tokens.
- Client-side ZDO data trace capture for all ZDOData send, receive, apply, and skip events by default.
The moved RPC names intentionally keep their existing DiscordTools_* wire names so current server-side integrations can keep using the same requests.
Build
dotnet build PraetorisClient.csproj
The built DLL is written to bin/Debug/PraetorisClient.dll.
Configuration
The plugin GUID is warpalicious.PraetorisClient. Configure the generated file:
BepInEx/config/warpalicious.PraetorisClient.cfg
Clients do not need the bot URL or API key for local-only features. The Discord link server endpoint and key belong on the dedicated server if PraetorisClient handles link requests there.
Preferred dedicated-server setup:
export PRAETORISCLIENT_LINK_API_URL="https://your-bot-host.example.com/api/valheim-link"
export PRAETORISCLIENT_BOT_API_KEY="shared-secret"
Keep real endpoint and API key values in a local .env file or server environment. .env files are ignored by git; .env.example documents the required variable names without secrets.
Creative Inventory RPC
PraetorisClient registers a client-side request RPC:
DiscordTools_CreativeInventoryRequest
Request package:
int protocolVersion = 1
string requestId
ZDOID characterId
bool includeItems
The client answers the sender with:
DiscordTools_CreativeInventoryResponse
Response package:
int protocolVersion = 1
string requestId
ZDOID characterId
bool available
string error
long playerId
string playerName
int playerInventoryCount
bool extraSlotsLoaded
bool extraSlotsAvailable
int extraSlotsCount
int totalUniqueCount
int itemEntryCount
Each item entry then writes:
string source
string prefabName
string sharedName
int stack
int quality
bool equipped
int gridX
int gridY
totalUniqueCount is the value to enforce for empty-inventory checks. Item entries can include both player and extraSlots views of the same item for debugging. Shudnal ExtraSlots is read through its public ExtraSlots.API.GetAllExtraSlotsItems() method when the mod is loaded.
Creative Biome Override RPC
PraetorisClient registers a client-side biome override RPC:
DiscordTools_CreativeBiomeOverride
Request package:
int protocolVersion = 1
int zoneCount
string zoneId
bool enabled
Vector3 center
float radius
int biome
bool suppressSpawns
The client applies enabled zones by overriding WorldGenerator.GetBiome, Heightmap.GetBiome, and biome color lookups inside the radius. Disabled zones are removed, and affected heightmaps plus clutter are refreshed. Client-side natural and event spawn points are blocked inside enabled creative biome override zones.
Link API
When a player enters !link CODE, the dedicated server posts JSON to LinkApiUrl:
{
"requestId": "6b7b8d9c0f2a4d7ca5f8c37e87b6fd13",
"code": "PRAE-482913",
"playerId": "76561198000000000",
"playerName": "Player",
"endpoint": "76561198000000000",
"platformDisplayName": "SteamName",
"receivedAtUtc": "2026-05-28T18:42:00.0000000Z"
}
The endpoint should return 2xx when the code is accepted. A plain-text response body is shown to the player in chat.
RPC Trace Upload
PraetorisClient can capture routed RPC trace rows locally and upload compressed JSONL batches to the ValheimTracer HTTP relay. The server issues short-lived upload tokens over small Valheim RPC messages. Bulk trace data is not sent through Valheim routed RPC. If HTTP upload fails, the client logs the failure and keeps the local trace file for a later retry.
Trace rows and upload token requests include Steam ID, platform user ID, trace player ID, and player name when available so server-side storage can group traces by player.
Server-synced config controls whether tracing is enabled and whether HTTP upload is preferred.