Gamemode Core
The heart of every gamemode
Dependencies
Gear Core (Required)
Custom Loot Spawns (Optional)
Used By
Gamemode FFA
Gamemode Aim Train
Gamemode Gun Game
Gamemode Battle Royale
Gamemode Base Wars (WIP)
Gamemode Honey Drop (WIP)
The backbone of every gamemode, managing core functionality and shared mechanics.











Gamemodes

  1. Gamemode FFA - Everyone is your target. Get the most kills to win.
  2. Gamemode Gun Game - Progress through weapons with each kill. The first to complete wins.
  3. Gamemode Battle Royale - Fight to be the last player standing in an ever-shrinking safe zone.
  4. Gamemode Aim Train - Practice shooting and recoil on bots.
  5. Gamemode Base Wars - Work in progress.
  6. Gamemode Honey Drop - Work in progress.

Permissions

  • gamemodecore.admin - Grants access to all commands required for setting up and managing the lobby and arenas.

Commands

  • /join - Teleports the player into the lobby. (Players can also enter the lobby by physically walking into it.)
  • /leave - Removes the player from the arena, returning them to the lobby.
  • gm.lobby create <position> <radius> - Creates a lobby at the specified position and radius.
  • gm.lobby remove - Deletes the lobby.
  • gm.lobby spawn add <position> <radius> - Adds a new spawn point to the lobby at the specified position and radius.
  • gm.lobby spawn remove <spawnPointId> - Deletes the specified spawn point from the lobby.
  • gm.lobby rule add <rule1> [<rule2> ...] - Adds one or more rules to the lobby. (See Rules for details on available rules.)
  • gm.lobby rule remove <rule1> [<rule2> ...] - Removes one or more specified rules from the lobby.
Note: For commands requiring a position, you can either enter coordinates or type here to use your current location.

Quick Start

  1. Start by creating the lobby using gm.lobby create <position> <radius>.
    Example: gm.lobby create here 30 creates a lobby at your current location with a radius of 30.

  2. Use gm.lobby spawn add <position> <radius> to place spawn points where players will spawn. You can either create multiple spawn points or a single one with a large radius.
    Example: gm.lobby spawn add here 5 adds a spawn point at your location with a radius of 5.

  3. This step is optional, but if you'd like to enforce restrictions in the lobby—such as stopping players from harming each other or from dropping items on the ground—use gm.lobby rule add <rule1>. (For a full list of rules, see Rules.)
    Example: gm.lobby rule add NoPlayerDamage NoKillSelf NoSleepers prevents players from damaging each other, committing suicide, or sleeping within the lobby.

Configuration

JSON:
{
  "Version": "1.4.0",
  "Lobby": {
    "Enable Lobby Only Mode": true,
    "Respawn Gear Set": "Lobby",
    "Join Chat Command": "join",
    "Zone Opacity": 1,
    "Locked Inventory Containers": [
      "all"
    ]
  },
  "Arena": {
    "Leave Chat Command": "leave",
    "Send Join Leave Messages": true,
    "Zone Opacity": 1
  }
}
  • Lobby- Settings related to the lobby.
    • Enable Lobby Only Mode - Forces players to spawn in the lobby whenever they connect or respawn, making the entire server lobby-focused. When disabled, players can freely explore normal gameplay areas outside the lobby.
    • Respawn Gear Set - Specifies the gear set players are equipped with upon respawn in the lobby.
    • Join Chat Command - Defines the chat command players can use to join the lobby.
    • Locked Inventory Containers - Determines which parts of the player's inventory will be locked when they are in the lobby. You can choose one or more of the following values: main, belt, wear, or allI. If you leave it empty, none of the inventory sections will be locked.
  • Gamemode- Settings related to the arenas.
    • Leave Chat Command - Defines the command players can use to leave the arena they're in.
    • Send Join Leave Messages - Broadcasts a message to players when someone joins or leaves an arena.

Rules

Rules allow you to control player behavior and enforce restrictions within lobby and arena zones, such as stopping players from dropping items, preventing self-harm, or removing corpses upon death.
  • NoLootSpawn - Prevents the spawning of loot containers within the zone.
  • NoNPCSpawn - Prevents npcs from spawning within the zone.
  • NoSignEditing - Disables the ability for players to edit wooden signs.
  • NoCrafting - Restricts players from crafting items while inside the zone.
  • NoCorpseSpawn - Disables player corpse creation on death.
  • NoSleepers - Removes sleeper bodies when players disconnect.
  • NoItemDrop - Prevents players from dropping items on the ground.
  • NoBuild - Prevents players from building structures within the zone.
  • NoPlayerDamage - Prevents any form of player-to-player damage within the zone.
  • NoItemContainerSpawn - Blocks the spawning of dropped loot bags within the zone.
  • NoKillSelf - Disables the player's ability to use the kill command to end their own character.
  • NoWounding - Stops players from entering a wounded state when their health reaches zero, making them die immediately instead.
  • NoArmoryBoxAccess - Prevents players from opening armory boxes. (Requires Armory plugin.)

Arena Teleporters

This information template holds arena details shown on the teleporter, and the placeholders below can be added to display real-time info, keeping players informed of the arena's current state.
  • {Title} - Displays the title of the arena.
  • {Gamemode} - Displays the game mode type, like 'Free For All' or 'Gun Game.'
  • {Status}- Displays the arena's current phase, such as 'Started,' 'Waiting For Players,' 'Warmup,' or 'Finished.'
  • {TimeLeft} - Displays the remaining time in the current round.
  • {PlayerCount} - Shows the current number of players in the arena.
  • {PlayerCapacity} - Displays the maximum player limit for the arena. If no limit is set, it shows 'Unlimited.'
  • {PlayerList} - Lists the names of all players currently in the arena.
JSON:
      "Information Template": "{Title}\nGamemode: {Gamemode}\nStatus: {Status}\nTime Left: {TimeLeft}\nPlayers: {PlayerCount} / {PlayerCapacity}\n\nParticipants:\n{PlayerList}",

Chat Isolation

Chat is isolated by area, so players can communicate only with others in the same zone. Players within an arena see only messages from others in that arena, while those in the lobby see only messages from other lobby members. Players outside of arenas and the lobby do not see messages from within these areas, keeping conversations focused and relevant to each zone.

Stored Data

JSON:
{
  "Lobby": {
    "Radius": 30.0,
    "Position": {
      "x": -381.155762,
      "y": 0.976623535,
      "z": -388.7592
    },
    "Rules": ["NoBuild", "NoPlayerDamage", "NoSleepers"],
    "Spawn Points": [
      {
        "Id": "001",
        "Position": {
          "x": -380.9209,
          "y": 0.976623535,
          "z": -392.3752
        },
        "Radius": 10.0
      }
    ]
  }
}
Author
VisEntities
License duration
Unlimited
Price
15.00 USD
First release
Last update

Ratings

0.00 star(s) 0 reviews

Child plugins

Also by VisEntities

Latest updates

  1. 1.4.2

    Increased the spawn height for arena spawn points even further to prevent players from getting...
  2. 1.4.1

    Some tweaks to spawn logic upon connecting. Block players from removing the lobby sleeping bag.
  3. 1.4.0

    Added support for Armory plugin, letting you block access to armory boxes in arenas or the lobby...
Back
Top
This plugin uses Oxide's permission system. Grant or revoke permissions using oxide.grant and oxide.revoke. You can assign them to individual players or groups using their Steam id or group name.
Chat commands start with a /, while console commands can be entered directly in the F1 console or server console. Use find <keyword> in console to search for available commands related to the plugin.
Settings are stored in the config file found under the config/ directory. You can edit this file manually, then reload the plugin to apply your changes.
Persistent data is saved in the data/ directory. This includes things like saved settings, usage stats, or player progress depending on the plugin. Deleting a data file will reset stored progress or customizations.
Language files are located in the lang/ folder. To translate messages, copy the en.json file into your target language folder (e.g. fr, de) and edit the values. Reload the plugin after changes to apply new messages.
This section lists public methods exposed by the plugin for use in other plugins. You can call these via the CallHook method. Make sure the plugin is loaded before calling its API to avoid null reference errors.
These are custom hooks that other plugins can listen for. Simply define a method with the same name and expected parameters in your plugin to handle the event. Hooks are triggered at key moments and are useful for extending or reacting to plugin behavior.
These hooks are injected into the game's code using Harmony. They let the plugin run code at key points in the game's internal logic. You can return values to block or modify behavior. Use with caution — these are powerful and can affect core mechanics.
Cart