Skip to main content

Plugins

Plugins are experimental

Plugins are currently in the early stages of development. Things may break, so always make backups before using them.

Introduction

GameVault is built with modularity in mind, featuring a plugin system that allows users to integrate custom functionality directly into the server. Whether you're looking to extend GameVault or customize its behavior, plugins provide the flexibility you need.

Where to Find Plugins

You can browse a list of available GameVault plugins here. Be sure to check that the plugin is compatible with your specific version of the GameVault backend.

How to Install Plugins

To install a plugin, follow these steps:

  1. Place the folder containing your compiled plugin (.js files) into the /plugins directory of your GameVault server. Archives are currently not supported, so extract them first.
  2. When you start the server, GameVault will automatically detect and load the plugin.

How to Develop GameVault Plugins

If you're a developer interested in creating plugins, you're in luck—it's simple to get started. Here’s a step-by-step guide:

Step 1: Clone the Backend Repository

First, set up a local instance of the GameVault backend. Follow the setup instructions available here.

Step 2: Understand the Architecture

GameVault plugins are built as NestJS modules, just like the rest of the system. You’ll be working with NestJS components such as Modules, Services, and Controllers.

To start, it's a good idea to read the official NestJS documentation, but if you prefer to jump in and learn by doing, you can reference the example code below.

Step 3: Set Up a Plugin

Suppose we’re creating a plugin called useless-plugin.

  1. Navigate to the gamevault-backend directory in your cloned repository.
  2. Create a folder for your plugin: gamevault-backend/.local/plugins/useless-plugin/.
  3. Inside the plugin folder, initialize a git repository with git init.
  4. Create a new file for your module: useless.plugin.module.ts. This file will serve as the entry point for your plugin and should implement the GameVaultPluginModule interface (which can be imported from src/globals.ts).

Here’s a basic example of how your module might look:

import { Module } from "@nestjs/common";
import {
GameVaultPluginModule,
GameVaultPluginModuleMetadataV1,
} from "../../../src/globals";

@Module({
imports: [],
controllers: [],
providers: [],
})
export default class UselessPluginModule implements GameVaultPluginModule {
metadata: GameVaultPluginModuleMetadataV1 = {
name: "Useless Plugin",
author: "Phalcode",
version: "1.0.0",
description:
"An example plugin that does nothing useful. It logs the user count every three seconds and provides two REST APIs with sample data.",
keywords: ["example", "api"],
license: "UNLICENSE",
website: "https://gamevau.lt",
};
}
Avoid Redundancy

When naming files, avoid repeating words. For example, if your plugin is called useless-plugin, name the module file useless.plugin.module.ts, not useless-plugin.plugin.module.ts.

Step 4: Document Your Plugin

Once you've implemented the GameVaultPluginModule interface, make sure to provide details about your plugin in the metadata section. Be sure to add a README.md and LICENSE file to the plugin folder to make it clear and accessible when shared on GitHub.

Step 5: Implement Your Plugin's Logic

Now, develop your plugin by adding services, controllers, or any other NestJS components. You can use existing GameVault modules to extend functionality. For instance in our example you can see we used the UsersService to count the users on our GameVault server. The possibilities are limitless.

Adding Configuration Options

If your plugin should support specific configuration for the end user, you can introduce custom environment variables. Make sure they are unique and do not conflict with existing variables. A good pattern is: PLUGIN_AUTHORNAME_PLUGINNAME_SETTING (e.g., PLUGIN_PHALCODE_USELESS_ENABLED).

You can access these variables in your code via process.env.PLUGIN_AUTHORNAME_PLUGINNAME_SETTING.

Step 6: Test Your Plugin

When you’re ready to test, run pnpm start. GameVault will automatically inject your plugin, and you should see relevant logs. You can debug using logs or Visual Studio Code’s "Toggle Auto Attach" feature. For extra quality assurance, you can write unit tests with Jest by adding a .spec.ts file and running pnpm test.

Step 7: Compile Your Plugin

Once your plugin is working and tested, compile it by running pnpm build. This will generate a dist folder with your compiled plugin in the dist/.local/plugins/useless-plugin directory. Look for folder containing a .plugin.module.js file—this is your compiled plugin. Zip that folder—this is the final, compiled version of your plugin, ready for users to install and run on their servers.

Step 8: Release Your Plugin

  1. Bring your local Git repository to GitHub.
  2. Create a release on GitHub and upload the zipped plugin folder containing your plugin’s JavaScript files.
  3. Tag your repository with gamevault-backend-plugin to make it available for users to find.

If your plugin is particularly useful and you want it to be in the standard feature set, contact us! We might integrate it directly into the official GameVault-Backend product.

Metadata Provider Plugin Specifics

If your plugin should integrate with GameVault’s metadata framework, follow these additional steps:

Once complete, you can feature your plugin right here in the documentation.

Example Plugins

You can check out some example plugins provided by Phalcode here to see how plugins are structured and developed.