TheShadowRealm-Uriel icon

Uriel

A host of server-side QoL enhancements: collect & place world objects into your castle, hot-swap stairs without demolishing, share specific chests or prison cells publicly. Each feature admin-toggleable. Server-side only.

Last updated a week ago
Total downloads 175
Total rating 3 
Categories Server Mods Oakveil Update
Dependency string TheShadowRealm-Uriel-0.19.0
Dependants 0 other packages depend on this package

This mod requires the following mods to function

BepInEx-BepInExPack_V_Rising-1.733.2 icon
BepInEx-BepInExPack_V_Rising

BepInEx pack for V Rising. Preconfigured and includes Unity Base DLLs.

Preferred version: 1.733.2
deca-VampireCommandFramework-0.10.4 icon
deca-VampireCommandFramework

Command framework for developers to easily create universal commands for their plugins.

Preferred version: 0.10.4

README

Uriel, Lord of Hosts

Uriel, Lord of Hosts

A server-side umbrella mod for V Rising dedicated servers — a host of independent, admin-toggleable quality-of-life enhancements and structural fixes.


⚠ Heads-up before you install

Pre-1.0 — in active development. Test it first; don't roll it out broadly on a busy live server until you've vetted it yourself. Uriel is pre-release and evolving quickly. The features below are implemented and tested in local and dedicated development/test-server environments — not yet on a live production server. This is a server-side mod still under development: by running it you are helping test it, and you take that risk on yourself. Please back up your server save before adding any new mod, and ideally trial Uriel on a test server (or a quiet plot) first. Commands, config keys, and behavior may still change before 1.0.

Every feature is independently toggleable. If any one component feels unstable, you can turn just that part off in the config (each feature has its own Enabled switch) and keep using the rest — you never have to disable Uriel wholesale. See the per-section notes below and the Configuration table.

Found a bug or have an idea? The fastest way to get a fix into the next release is the The Shadow Realm Discord — that's the primary bug-report and feedback channel. Written-up GitHub issues are welcome too.


Repo: https://github.com/KDavidP1987/Uriel-Lord-of-Hosts Status: pre-1.0 public testing · server-side only · several feature groups live today, more sub-mods planned under the Uriel umbrella.

What it does

Uriel is never all-or-nothing: every feature ships behind its own config switch, and all sharing/editing is per-object opt-in — nothing is ever shared or changed server-wide on your behalf.

🏺 Object Spawning (collect & place world objects)

Bring world objects the build menu never offers into your castle — resource nodes, world chests, breakable crates and urns, and decorative props from across the map (GloomRot, Cursed Forest, dungeons, ruins). Spawn one at your aim point — or at your own location with the here flag (handy from a UI button) — inside your own plot; it's indestructible and decay-proof by default, and you move/rotate/remove it with .uriel move / .uriel rotate / .uriel despawn. Everything you place persists across restarts and is cleaned up automatically — during play, within a couple of minutes — if its castle is ever abandoned or destroyed (and you can't keep building on a plot you've given up).

Choose how durable it is with optional spawn flags: breakable (raids and decay can destroy it), smashable (you can destroy it by hand too), or respawn (it automatically comes back after being destroyed — until its castle is gone or you .uriel despawn it). Mix them, e.g. .uriel spawn <object> 0 smashable respawn.

Collect them by playing (Discovery mode). You unlock an object by destroying one in the world — chop a tree, smash a crate, break an ore vein — with an admin-set chance to "learn" it. .uriel unlocks shows your collection and percentage; .uriel catalog browses everything that exists; .uriel notify on|off toggles the unlock messages. Roughly half of all objects can't be destroyed — those unlock when you hit 100% collection, defeat Dracula (finish the game), or per boss via an admin-curated map. Admins choose the model (or turn it off), can set a build cost, block specific objects, and grant objects directly.

How it's managed: spawned world objects are placed and moved with the .uriel commands above, not the vanilla build menu (an engine limitation — the game won't let arbitrary world objects be selected in build mode). The optional Raphael companion mod (formerly BloodCraftHub) can present a point-and-click palette UI.

Admins can put rules on player spawning. Set a per-object or global limit on how many of an object fit on one plot, an item cost to build it, and whether players may make it indestructible or auto-respawning.uriel objcfg <object> max 3, .uriel objcfg <object> cost 100 <itemId>, .uriel objcfgglobal … for the defaults, .uriel objcfglist to review. Admins themselves are never restricted.

🧪 Pre-1.0 guidance & quick tips (Object Spawning)

  • Not every spawnable object has been individually tested. The game ships thousands of prefabs; some may misbehave when placed as décor (spawn invisible, or not function). This is a big reason Uriel is pre-1.0, and exactly why we're asking for feedback — every broken object you report goes onto the block list for the next release.
  • Hazardous/problematic prefabs are blocked from spawning. The game's object list contains many entries that aren't real placeable décor (world-gen controllers, NPC-spawner "points of interest", invisible markers, baked "source" copies). Known-bad ones are filtered out of the catalog so players can't pick them. This filter is still being refined — there may be problematic objects not yet found.
  • If something spawns but you can't see it, it's INVISIBLE, not absent. The object is almost certainly there on the server but not rendering correctly (it's one of the not-yet-caught bad ones). .uriel despawn it to be safe — don't leave it sitting there — and please report it so it can be blocked.
  • Don't overlap objects on purpose. Stacking objects in the same spot can cause problems; Uriel blocks overlapping placements by default (ObjectSpawn.PreventOverlap). Offset things slightly instead.
  • Admins can block any object they don't want available — even one that isn't hard-coded blocked — with .uriel block <guid> (or by configuring their server). Blocked prefabs vanish from the catalog and can't be spawned.
  • Prefer admin-only while you vet it: the default ObjectSpawn.AdminOnly=true keeps spawning to admins; open it to players once you're comfortable. You can also disable this whole feature (ObjectSpawn.Enabled=false) and keep the rest of Uriel.

🗄 Public Storage (per-container opt-in)

Mark a specific chest as publicly accessible so anyone on the server can use it — community chests, donation boxes, free-stuff stashes, even paid vending boxes. Always owner-controlled; nothing is shared unless its owner shares it. Shares survive server restarts.

Sharing rules (set by aiming at your shared container):

  • Permission — take-only, give-only (donation box), or both.
  • Withdrawal limit — e.g. 1 stack per player per 24 hours.
  • Access cost — charge an item per stack withdrawn; the payment is delivered to a private "pay chest" you designate. A vending machine, basically.

Public prison cells (separate switch) — share a prison cell to let anyone tend your prisoner: feed and extract blood through the normal cell UI, and take the prisoner home with .uriel takeprisoner (they're subdued and released to the taker — bring Dominating Presence to escort them). The game's own subdue button only ever appears for the cell's own clan (an engine limitation), so the command covers everyone else.

Heads-up for players accessing a share: when a chest or cell is first made public, a player trying to use it may need to log out and back in once before their client recognizes it as accessible. After that initial relog, it behaves like any other container you can open.

🧪 Pre-1.0 guidance (Public Storage): sharing is always per-container, owner opt-in — nothing is shared unless someone shares it, so the blast radius is small. Trial it on a few containers first. Chest sharing and prison-cell sharing have separate switches (PublicStorage.Enabled / PublicStorage.PrisonEnabled), so you can enable one and not the other. Found an issue? Report it on Discord and, if needed, flip the switch off — your containers simply go back to private.

🪜 Stair Editing

  • Live restyle — aim at a placed staircase and swap it to another style; the change applies instantly for everyone, no server restart or relog (the stair is rebuilt in the new style on the spot). Only styles of the same stair shape (straight, left-curve, right-curve, wide) are offered, and DLC styles require owning that DLC — exactly the same rule as your build menu. Free, preserves position, rotation, and ownership.
  • Clean removal.uriel removestairs deletes a staircase you own without tearing apart the floors and walls it's attached to (something a normal dismantle can't cleanly do).

🧪 Pre-1.0 guidance (Stair Editing): restyling rebuilds the staircase on the spot (destroy + respawn in the new style); position, rotation, and ownership are preserved. As with any pre-1.0 feature, try it on a spare staircase first. If a stray "ghost" stair is ever left behind, an admin can clean it with .uriel stairpurge. You can disable the whole feature with StairSwap.Enabled=false.

Installation

Uriel is a server-side mod — install it on your V Rising dedicated server, not on player clients. Players need nothing installed.

Via Thunderstore Mod Manager / r2modman (recommended)

  1. Open the mod manager and select V Rising → your dedicated-server profile.
  2. Search for Uriel under the Mods tab → Install.
  3. Ensure its dependencies are installed in the same profile (they install automatically): BepInExPack_V_Rising and VampireCommandFramework.
  4. Launch the server through the mod manager's profile.

Manual install

  1. Install BepInExPack V Rising (1.733.2 or compatible) into your dedicated server.
  2. Install VampireCommandFramework into BepInEx/plugins/.
  3. Drop Uriel.dll into BepInEx/plugins/.
  4. Start the server once to generate the config at BepInEx/config/kdpen.Uriel.cfg, then edit and restart as needed.

Stop the server before replacing Uriel.dll — a running server file-locks the DLL.

Dependencies & compatibility

Mod Version Role
BepInExPack V Rising 1.733.2 Loader (hard dependency)
VampireCommandFramework 0.10.x Chat-command framework (hard dependency)

Optional companion (not a dependency): the client-side mod Raphael (formerly BloodCraftHub) is designed to work alongside Uriel — players who install it on their own client can drive Uriel's features from in-game UI panels and buttons instead of typing. It is not required: like any server-side mod, every Uriel feature works fully through the .uriel chat commands, with or without Raphael.

Commands

All commands are chat commands prefixed with .uriel. Type .uriel for a quick overview, or .uriel help for a clean, topic-by-topic menu (objects / storage / stairs / admin). Most targeted commands also accept a trailing nearest token to act on the closest object to you instead of where you're aiming — handy when a menu or UI panel has your aim ray pointing elsewhere (e.g. .uriel share nearest, .uriel stairswap stone2 nearest).

🏺 Object Spawning commands

Players (active when ObjectSpawn.AdminOnly=false; you must be inside your own castle plot):

Command What it does
.uriel spawn <name|guid> [rot 0-3] [flags…] Place an object you've unlocked at your aim point. Flags (any order, after the rotation): breakable (raid/decay), smashable (you can break it too), respawn (auto-returns until castle gone / despawned), here (place at YOUR location), indestructible (default)
.uriel move [here] / .uriel rotate [0-3] / .uriel despawn Move (to your aim, or here = your location) / turn / remove the nearest object you spawned
.uriel unlocks Your collected objects + collection %
.uriel catalog [page] Browse the full world-object catalog
.uriel findprefab <text> Search objects by name
.uriel notify <on|off> Toggle your object-unlock chat messages

In Discovery mode you unlock objects by destroying them in the world; the non-destructible ones unlock on full collection, boss defeats, or admin grant.

Admin sub-commands
Command What it does
.uriel grant|revoke <player> <name|guid> Unlock / remove an object for a player
.uriel grantall <player> [all|destructible|indestructible] Bulk-grant the catalog (or a subset)
.uriel block|unblock <guid> · .uriel blocklist Forbid / allow a prefab
.uriel spawnlist · .uriel purgeplot List / clear spawned objects on the plot (live spawns + records; native objects never touched)
.uriel forcedespawn [confirm] Force-remove the aimed object, ignoring records/ownership (recovers untracked objects); names it, then confirm within 30s
.uriel forcepurgeplot Synonym for purgeplot (live spawns + records; native objects never touched). The old chain sweep was removed — it could delete native resources
.uriel purgeorphans Server-wide cleanup — scan the whole map and remove orphaned Uriel objects (castle gone, or no living heart governing them). Only Uriel's objects are touched; a backup for the automatic boot-time cleanup
.uriel bossmap add|remove|list <vblood> <obj> Curate which objects a V-blood defeat unlocks
.uriel objcfg <name|guid> <field> [v1] [v2] Per-object player limits: max <n> (per plot), cost <amount> <itemGuid>, indestructible <true|false>, respawn <true|false>, clear, show
.uriel objcfgglobal <field> [v1] [v2] · .uriel objcfglist Global default condition (per-object overrides it) · list all conditions
.uriel api version|catalog|unlocked Machine API for Raphael
🗄 Public Storage & Prison commands

Players (aim at a container you own):

Command What it does
.uriel share [modifiers…] Make the aimed container public. Modifiers stack in any order: permission take|give|givetake, limithours <h>, limitwithdrawal <stacks>, cost <itemId> <amount>. Example: .uriel share permission take limithours 24 limitwithdrawal 1
.uriel unshare Make the aimed container private again
.uriel info Show a container's sharing rules (works for anyone)
.uriel shared List every container you have made public
.uriel unsharemine Revert all of your shares in one command
.uriel paychest Designate the aimed private chest to receive access-cost payments
.uriel finditem <name> Search item ids by name (for the cost modifier)
.uriel takeprisoner Take the prisoner from a shared cell — subdued and released to you
Admin sub-commands
Command What it does
.uriel sharedall [name|steamId] List all public containers, or just one player's
.uriel unshareplayer <name|steamId> Revert all of one player's shares
.uriel unshareall Revert every public container to private and clear the registry
.uriel sharedebug Dump the aimed container's live sharing state (diagnostics)

Admins may also aim at any container and use .uriel share […] / .uriel unshare to override its settings directly.

🪜 Stair Editing commands

Players (aim at a staircase you own):

Command What it does
.uriel stairswap <style|next> Restyle the aimed staircase live. Styles: stone1, stone2, stone3, gloomrot, projectk, strongblade* (* = requires that DLC). next cycles to the next style you own.
.uriel removestairs Cleanly delete the aimed staircase, leaving connected floors/walls intact
.uriel stairstyles Show the aimed stair's shape, current style, and which styles you can use
Admin sub-commands
Command What it does
.uriel stairpurge Destroy stray "ghost" stair entities within 5m (cleanup for older builds)

Configuration

BepInEx/config/kdpen.Uriel.cfg — every feature has its own Enabled switch. Config changes take effect on server restart.

Section Key Default Effect
ObjectSpawn Enabled true Master switch for object spawning
ObjectSpawn AdminOnly true When true, only admins may spawn — set false to open the player collection path
ObjectSpawn PlayerAccessMode Discovery Discovery (unlock by destroying) or Full (whole catalog)
ObjectSpawn DiscoveryChancePercent 25 Chance (0–100) that destroying a world object unlocks it
ObjectSpawn NonDestructibleUnlock Off How non-destructible objects unlock: Off/Collection/FinalBoss/AllBosses
ObjectSpawn IncludeCastleBuildables false Include the normal build-menu pieces in the catalog (off = world objects only)
ObjectSpawn PrefabCostItem / PrefabCostStack 0 / 0 Item + amount a player pays to build one object (0 = free)
ObjectSpawn Indestructible true Spawned objects are immortal + decay-proof by default (per-spawn breakable/smashable flags override; turn off globally for PvP)
ObjectSpawn PreventOverlap true Refuse to spawn/move an object onto a wall, station, or another spawned object (only floors may sit under décor) — prevents destabilizing pile-ups. Set false to allow free stacking at your own risk
ObjectSpawn OverlapMinDistance 0.5 Minimum spacing (m) between objects when PreventOverlap is on. Lower it to place décor closer together; 0 = only block the exact same tile. Doesn't affect placing flush against walls
ObjectSpawn RespawnEnabled true Master switch for the respawn flag (auto-return destroyed objects until the castle is gone)
ObjectSpawn RespawnPollSeconds 30 How often (seconds, min 5) the respawn check runs
ObjectSpawn AutoPurgeOrphans true Clean up objects on an abandoned/destroyed castle during play (within ~2 min), not just at the next restart. Only Uriel's own objects are touched
ObjectSpawn OrphanPollSeconds 120 How often (seconds, min 30) the mid-session orphan sweep runs
ObjectSpawn (more) CollectionEnabled, BossUnlocksEnabled, DiscoveryNotify, RefundOnRemove, PurgeOrphansOnBoot — see the generated .cfg. Per-object/global player limits live in object_conditions.json (.uriel objcfg)
PublicStorage Enabled true Master switch for chest sharing
PublicStorage PrisonEnabled true Independently allow prison-cell sharing
PublicStorage MaxTargetDistance 5 Aim distance for .uriel share / unshare targeting
StairSwap Enabled true Allow live stair restyling + .uriel removestairs
StairSwap MaxTargetDistance 6 Aim distance for the stair commands
StairSwap RespawnGapFrames 5 Frames between destroy & respawn when restyling a stair
Diagnostics VerboseLogging false Extra per-action log lines (useful when testing)

Roadmap

Uriel is an umbrella mod — the plan is to keep adding small, independently toggleable server-side sub-mods. Tentative and subject to change; full list (incl. large-scope ideas) in the roadmap.

Planned next:

  • Coffin sharing — share coffin use, with an optional cost-to-use modifier.
  • Conditional door access — share a door behind payment and/or allowed time windows (select hours).
  • Bulk storage sharing — open all heart-linked storage at a location in one action, auto-excluding the pay chest and any chests you've marked private.
  • Raphael integration (formerly BloodCraftHub) — a client-side companion UI (share panels, prisoner-take button, stair-style picker).

Bigger ideas being explored: plot expansion (separate-instance phase gates or map copy/paste), a PvP-arena V Blood boss mode with prize tables, paid area-gating for mazes, scheduled/paid door & teleport controls, more castle decor assets, triggered NPC spawns, and basement levels.

Have a feature you'd like to see in the host? Bring it to the Discord.

Feedback & community

Developed and tested locally and on dedicated development/test servers — it has not yet been run on a live production server, which is exactly why it's pre-1.0 (see the heads-up at the top). It comes out of the V Rising community The Shadow Realm (Brutal PvE), maintained by Chaos, whose Discord is the home for Uriel testing and feedback. As a pre-1.0 mod, bug reports and feedback are hugely valued — and the people who help test now shape what 1.0 becomes.

Acknowledgements

Uriel stands on the shoulders of the V Rising modding community. Big thanks to:

  • VampireCommandFramework — by deca, the chat-command framework Uriel's commands are built on (a hard dependency).
  • BepInEx, the loader that makes V Rising modding possible.
  • KindredCommands & KindredSchematics — by odjit, whose open-source castle-building/tile techniques were a key reference for Uriel's live stair rebuild.
  • Bloodcraft — by zfolmt, a reference for server-side ECS/Harmony patterns.

License

Licensed under the GNU Affero General Public License v3.0 (AGPL-3.0) — copyright © 2026 Kristopher Penland. Uriel adapts techniques from odjit's AGPL-licensed KindredCommands & KindredSchematics and is released under the same copyleft license; full corresponding source is on GitHub.