Jump to content
Message added by Mevent,

⚠️ MySQL/MariaDB Version Compatibility Notice

To ensure smooth operation with MySQL, please follow these version requirements:

  • MySQL: Use version 5.7.x or lower (recommended version: 5.7.41)
  • MariaDB: Use version 10.9.x or lower (recommended version: 10.9.8)

Note for MySQL 8+ users: If you must use MySQL 8 or higher, you'll need to enable Legacy Authentication Method in your MySQL settings. This requirement is due to Oxide framework limitations, not the plugin itself.

32 Screenshots

  • 22.1k
  • 2.6k
  • 84.4 kB

About Ultimate Leaderboard (+WEB Editor)

Introducing UltimateLeaderboard, the most advanced and comprehensive leaderboard system designed for Rust servers! Elevate your server competitive spirit by tracking an extensive range of player statistics—everything from kills and deaths to resources gathered, items crafted, structures built, and more. Featuring a sleek, customizable user interface and seamless integration with popular plugins, UltimateLeaderboard is the perfect addition to engage your players and showcase their achievements.

 

US4xphR.png

 

⭐ Features of Ultimate Leaderboard

  • Track a wide variety of player statistics, including kills, deaths, resources gathered, items crafted, structures built, and more.
  • Fully customizable leaderboard—choose which stats to display and tailor it to your server unique style.
  • Intuitive and visually appealing user interface for players to view their stats and compare rankings.
  • Seamless integration with plugins like ServerPanel for enhanced displays, and Notify/UINotify for in-game alerts.
  • Flexible data storage options: choose between JSON, SQLite, or MySQL to suit your server needs.
  • Two reward systems: post-wipe awards that give actual items, kits, and money to top players when they connect, plus an optional companion plugin UltimateLeaderboardTop for real-time privilege management based on current rankings.
  • Custom Titles system that automatically displays achievement-based chat titles for top performers (requires BetterChat plugin).
  • Optimized for high performance, ensuring smooth operation even with large player bases and extensive data.
  • Configurable templates.
  • Optional real-time database updates for integrations (e.g., Discord Bot).

 

🖼️ Showcase

Fullscreen Template
6TfNaxv.gif

ServerPanel V1 (V1.1)
u5RnZkK.gif

ServerPanel V2
8DzVUAH.gif

 

📨  Video Overview

 

🎮 Commands

  • /leaderboard or /stats - Opens the leaderboard interface for players to view stats and rankings.
  • /leaderboard <steamid>  - Opens another player's profile (requires ultimateleaderboard.profile permission).
  • /leaderboard.hide - Allows players to hide themselves from the leaderboard (requires ultimateleaderboard.hide.self permission).
  • leaderboard.manage hide <steamid>  - Console command to hide a player from the leaderboard (server console only).
  • leaderboard.wipe  - Console command to reset all leaderboard data (server console only).
  • leaderboard.migrate <migration_id>  - Console command to perform database migrations (server console only). Available:
    leaderboard.migrate 1  adds HiddenFromLeaderboard column to PlayerStats table (upgrade from v1.1.7 to v1.1.8)
    leaderboard.migrate 2  migrates BodyHits data to the new format (upgrade to v1.5.10)
  • leaderboard.find.short.prefab <search_term>  - Console command to search for prefabs containing the specified search term (server console only). Useful for finding correct prefab names for configuration.
  • leaderboard.manage  - Console command to manage player statistics (server console only). Use leaderboard.manage help for detailed usage information.

 

🛡️ Permissions

  • ultimateleaderboard.use - grants players access to leaderboard commands and interface.
  • ultimateleaderboard.profile  - allows players to view other players' profiles using the leaderboard command.
  • ultimateleaderboard.hide.self  - allows players to hide themselves from the leaderboard using the /leaderboard.hide command.

 

⚙️ Web Config Editor

Easily manage your UltimateLeaderboard settings with our web-based configuration editor. This tool allows you to adjust plugin configurations through a user-friendly interface, eliminating the need to manually edit files on your server.

f8lInY4.gif

P.S. To access the web config editor, you must be part of the "UltimateLeaderboard" group in our Discord server. Join us at https://discord.gg/mevent and request the group to get started.

 

📚 FAQ

Q: How do I install UltimateLeaderboard?
A: Download the UltimateLeaderboard.cs file, place it in your oxide/plugins directory, and restart your server or reload the plugin using the Oxide command oxide.reload UltimateLeaderboard.

Q: Can I choose which statistics to track and display?
A: Yes! The plugin allows you to customize tracked statistics and leaderboard displays via the configuration file. You can enable or disable specific stats like kills, resources, or events to suit your server.

Q: What data storage options are available?
A: UltimateLeaderboard supports JSON, SQLite, and MySQL. You can select your preferred storage method in the config file, offering flexibility for small or large servers.

Q: How do I set up the awards system?
A: In the configuration file, define award categories (e.g., most kills, top gatherer) and their criteria. The plugin will automatically track and assign awards to top players based on your settings.

Q: Where can I configure the UI?
A: UI is now template-driven. Use configurable templates stored at oxide/data/UltimateLeaderboard/Templates.

Q: What happens to the data on a server wipe?
A: By default, data wipes with a new save file, but you can disable this in the config (Wipe data on new save) to persist stats across wipes if desired.

Q: How do I add UltimateLeaderboard to the ServerPanel menu?
A: Follow these simple steps:
1. Open ServerPanel menu in-game and click "+ADD CATEGORY" button
2. Set these exact parameters:

  • Type: Plugin
  • Plugin Name: UltimateLeaderboard
  • Plugin Hook: API_OpenPlugin

3. Click "SAVE" button to create the category

Q: I see black images with Rust logo or get error 429 when loading images. What should I do?
A: These issues occur when there are problems downloading images from the internet. The UltimateLeaderboard plugin sends images to ImageLibrary but is not responsible for the downloading process itself. Error 429 typically occurs due to rate limits imposed by image hosting services like Imgur (see HTTP 429 documentation for more details). To fix this, enable Offline Image Mode which will use local images instead:

  1. Enable the mode in config:
    • Open "oxide/config/UltimateLeaderboard.json" (or "carbon/config/UltimateLeaderboard.json" for Carbon)
    • Set "Enable Offline Image Mode": true
  2. Set up the images:
    • Create folder "TheMevent" in "oxide/data" (or "carbon/data" for Carbon)
    • Download PluginsStorage (click "CODE" → "Download ZIP")
    • Extract the ZIP and copy all contents to the "TheMevent" folder
  3. Reload the plugin:
    • Type o.reload UltimateLeaderboard (Oxide) or c.reload UltimateLeaderboard (Carbon)

Note: If you want to add your own custom images, place them in the "TheMevent" folder and reference them with the "TheMevent/" prefix. For example: "TheMevent/Icon1.png", "TheMevent/MyCustomIcon.jpg", etc.

Q: What's the difference between UltimateLeaderboard awards and UltimateLeaderboardTop?
A: UltimateLeaderboardTop is a companion plugin that automatically manages player privileges based on leaderboard positions.

  • Main Plugin Awards: Gives actual rewards (kits, money, commands) to top players after wipe - rewards are given once when player connects.
  • UltimateLeaderboardTop: Continuously manages privileges (VIP groups, permissions) as players enter/exit top positions in real-time.

To display awards in UI while using UltimateLeaderboardTop:

  1. Configure awards in UltimateLeaderboard config
  2. Configure awards in UltimateLeaderboardTop config
  3. Set "Automatically give rewards after the wipe": false

Q: Can UltimateLeaderboardTop give items/kits to players?
A: No, UltimateLeaderboardTop is designed only for reversible actions (permissions, groups, etc.). Since items can't be taken back from players when they leave top positions, item rewards are not supported. Use the main plugin's awards system for item rewards instead.

Q: How do I configure rewards for top players?
A: There are two reward systems available:

UltimateLeaderboard Awards (Post-Wipe Rewards):
Configure in the main plugin's config file under "Awards Settings":

  1. Set award categories (e.g., "Most Kills", "Top Gatherer")
  2. Define criteria: loot type, prefab, and minimum amount required
  3. Set rewards: commands to execute (give items, kits, money, etc.)
  4. Awards are given once when top players connect after a wipe

UltimateLeaderboardTop (Real-time Privileges):
Configure in UltimateLeaderboardTop.json:

  1. Set leaderboard types to monitor (kills, points, playtime, etc.)
  2. Define top positions (1st, 2nd, 3rd, etc.)
  3. Configure "Enter place commands" (given when player reaches position)
  4. Configure "Exit place commands" (executed when player loses position)
  5. Use for permissions, groups, temporary privileges

Example UltimateLeaderboardTop configuration:

{
  "Loot type": "Kill",
  "Prefab": "kills",
  "Places settings": {
    "1": {
      "Enter place commands": ["o.usergroup add %steamid% vip"],
      "Exit place commands": ["o.usergroup remove %steamid% vip"]
    }
  }
}

Q: What are Custom Titles and how do they work?
A: Custom Titles automatically display achievement-based titles in chat for top players. For example, top killers get "[Killer]" title, top builders get "[Builder]" title, etc. Requires BetterChat plugin to work. Titles are updated automatically based on leaderboard positions and can be configured with priority system and limits.

Q: Why don't I see my statistics updated immediately on the leaderboard?
A: The leaderboard is cached and refreshes periodically (configurable interval) to minimize server load and ensure optimal performance. This means statistics may take a few minutes to appear on the leaderboard after the action is performed. The caching system helps maintain smooth server operation even with large player bases and extensive statistics tracking.

Q: How can I track multiple similar items or entities with one statistic?
A: You can combine multiple prefabs using the pipe symbol | in the prefab field. For example, to track all types of scientists as one "NPC Kills" statistic, use: npc_tunneldweller|npc_underwaterdweller|scientistnpc_arena|scientistnpc_bradley. This is useful for grouping similar items, resources, or entities into a single tracked category.

Q: How do I find the correct prefab names for items, entities, or events?
A: There are several ways to find prefab names:

  • In-game console command: Use leaderboard.find.short.prefab <search_term> in the server console to search for prefabs containing your search term. For example: leaderboard.find.short.prefab scientist will show all prefabs containing "scientist".
  • F1 console spawn command: In-game, open F1 console and use the spawn command to see available entity prefabs. Type spawn followed by part of the name to see matching options.
  • Item shortnames: For items, use their shortname (e.g., "stones", "metal.ore", "wood"). You can find these by examining items in your inventory or using item-related commands.
  • Plugin documentation: Check the "Custom Prefabs" and "Available Loot Types" sections in this plugin's description for comprehensive lists of supported prefabs and loot types.

Q: How can I output the sum of all values by type of statistics (for example, all kills, all loot collected)?
A: Use the prefab total_sum for the desired LootType. For example, to show the total number of all player kills, specify the LootType Kill and the prefab total_sum in the column or block settings. It works for any type: Kill, Gather, Craft, Event, and others.

Q: What award types are available and how do I configure them?
A: UltimateLeaderboard supports 8 award types:

  • Command - Execute console commands. Supports %steamid% placeholder. Use | to separate multiple commands.
    Example: "Command (%steamid%)": "inventory.giveto %steamid% rifle.ak 1|oxide.usergroup add %steamid% vip"
  • Kit - Give kits from Kits plugin. Requires Kits plugin to be loaded.
    Example: "Type": "Kit", "Kit Name": "vip_starter"
  • ServerRewards - Add reward points. Requires ServerRewards plugin.
    Example: "Type": "ServerRewards", "Amount": 1000
  • Economics - Deposit money via Economics plugin.
    Example: "Type": "Economics", "Amount": 5000
  • BankSystem - Deposit money to player's bank account.
    Example: "Type": "BankSystem", "Amount": 2500
  • GameStores - Add balance via GameStoresRUST plugin.
    Example: "Type": "GameStores", "Amount": 100
  • MoscowOVH - Add balance via RustStore plugin (Moscow OVH integration).
    Example: "Type": "MoscowOVH", "Amount": 50

 

💻 Custom Prefabs

UltimateLeaderboard supports advanced custom prefabs for granular statistics tracking and display:

  • total_play_time - Total playtime (in seconds)
  • current_playtime - Current session duration
  • kdr - Kill/Death ratio
  • points - Internal points system
  • longest_kill_distance - Longest kill distance record
  • total_hits - Total player hits
  • total_resources - Total resources gathered
  • total_items_crafted - Items crafted
  • events_won - Event victories
  • structures_built - Structures built
  • upgrades_performed - Building upgrades
  • name/nickname - Player display name
  • formatted_total_playtime - Human-readable playtime (Xd Xh Xm)
  • kd - K/D formatted as "Kills/Deaths"
  • favorite_resource - Most gathered resource
  • favorite_crafted_item - Most crafted item
  • favorite_event - Most won event
  • favorite_building_material - Preferred building material
  • favorite_weapon - Most used weapon
  • total_quests_completed - Total completed quests
  • total_sum - Sum of all values for the selected LootType. For example, using total_sum with LootType Kill will show the total number of all kills for the player (across all kill categories). Works for any LootType: Kill, Gather, Craft, Event, etc.

 

📊 Available Loot Types

  • None
  • Construction
  • Medical
  • Event
    Available prefabs:
    • Convoy
    • Sputnik
    • Caravan
    • GasStationEvent
    • AirEvent
    • SatDishEvent
    • Triangulation
    • WaterEvent
    • HarborEvent
    • FerryTerminalEvent
    • ArcticBaseEvent
    • JunkyardEvent
    • SupermarketEvent
    • PowerPlantEvent
    • ArmoredTrainEvent
    • SurvivalArena
    • KillBoss
    • PaintballTeam
    • PaintballFFA
    • GunGame
    • ZombieInfection
    • TugboatPirates
    • SpaceEvent
    • AbandonedBase
    • DungeonEvent
    • FlyingCargoEvent
  • Gather
  • Kill
    Available custom prefabs:
    • helisignals_{skin} - Tracks helicopter kills from HeliSignals (e.g., "helisignals_2920175997")
    • bradleydrops_{skin} - Tracks bradley kills from BradleyDrops (e.g., "bradleydrops_2905355269")
    • roadbradley_{profile} - Tracks bradley kills from RoadBradley (e.g., "roadbradley_easy")
    • helicopter - Tracks helicopter kills
    • Custom NPC support:
      • horde_npc - For NPCs from ZombieHorde plugin
      • raidbase_npc - For NPCs from Raidable Bases plugin
      • For NPCs from NpcSpawn use NPC name as key (BossMonster, BetterNpc, NPCs from events, etc.)
    • Other entity prefabs can be found in-game by using the "spawn" command in the F1 console
  • Consume
  • Raid
  • Death
    Available custom prefabs:
    • Custom NPC support:
      • horde_npc - For NPCs from ZombieHorde plugin
      • raidbase_npc - For NPCs from Raidable Bases plugin
      • For NPCs from NpcSpawn use NPC name as key (BossMonster, BetterNpc, NPCs from events, etc.)
  • Craft
  • Crate
  • LootItems
  • Fishing
  • Puzzle
    Available prefabs:
    • keycard_1
    • keycard_2
    • keycard_3
  • Custom
  • Upgrade
  • ShotFired
  • ExplosiveUsed
  • RecycleItem
  • BodyHits
  • WeaponUsed
  • RaidableBases
    Available prefabs:
    • easy
    • medium
    • hard
    • expert
    • nightmare
  • Economy
    Available prefabs:
    • ShoppyStock
    • Economics
    • IQEconomic
  • Quest
  • EconomyBalance
    Available prefabs:
    • Economics
    • ServerRewards
    • BankSystem
    • IQEconomic
  • Gambling
    Available prefabs:
    • BlackjackDeposit
    • BlackjackWon
    • SlotDeposit
    • SlotWon
    • PockerDeposit
    • PockerWon
    • WheelDeposit
    • WheelWon
  • SkillTree
    Available prefabs:
    • xp - Experience points earned
    • level - Skill tree level reached
  • Trivia

 

📡 API for Developers

UltimateLeaderboard provides a comprehensive API for developers to integrate with other plugins and extend functionality:

📊 Methods

  • JArray API_GetUltimateLeaderboardUsers(int offset, int limit, int? columnIndex = null) - Get leaderboard users with pagination
  • float API_GetPlayerStat(ulong playerId, string lootType, string shortname) - Get specific player statistic
  • bool API_IsHiddenFromLeaderboard(ulong playerId) - Check if player is hidden from leaderboard
  • void API_OnItemGather(ulong player, string shortname, int amount) - Add gather statistics for a player
  • void API_OnEventWin(ulong userID, string eventName, int amount = 1) - Record event wins for a player

🎣 Hooks

  • void OnUltimateLeaderboardContent(BasePlayer player, string categoryType, CuiElementContainer container) - Called when displaying custom category content
  • void OnUltimateLeaderboardCached() - Called when leaderboard data is cached and ready
  • Like 4
  • Love 4

Mevent's Collection

User Feedback

2m

Downloads

Total number of downloads.

9.5k

Customers

Total customers served.

138.3k

Files Sold

Total number of files sold.

2.9m

Payments Processed

Total payments processed.

×
×
  • Create New...

Important Information

We have placed cookies on your device to help make this website better. You can adjust your cookie settings, otherwise we'll assume you're okay to continue.