Plugin Engine
PluginLicenseRef-All-Rights-Reserved

Plugin Engine

Plugin Engine is a live scripting IDE for Minecraft that lets you write and execute JavaScript or Java directly on a running server through a browser, without restarts or configuration. It also provides secure session-based access, persistent scripts, and

23
Downloads
1
Followers
2 months ago
Updated
📦
1
Versions

📖About Plugin Engine

Plugin Engine, Live Scripting IDE for Minecraft

Write JavaScript or Java in your browser and execute it on your running server, no reload, no restart, no config.

Just drop the JAR into /plugins, type /plugin-engine in chat, click the link, and start coding. That's it.


✨ Features

🟡 JavaScript, Instant & No Boilerplate

Register Bukkit event handlers with a single line using the built-in scripting API:

on("playerJoin", (player) => {
  player.sendMessage("§aWelcome, §e" + player.name + "§a!");
  server.broadcast("§7[§a+§7] §a" + player.name + " joined.");
});

on("playerChat", (player, msg) => {
  if (msg.startsWith("!heal")) player.heal();
});

Press Ctrl+Enter → runs live on the server. No classes, no imports, no boilerplate.


☕ Java, Real Classes, Live Compiled

Compile actual Java classes at runtime using the server's JDK. Supports implements Listener, extends EngineScript, or any class with a run(ScriptContext) method:

public class JoinScript extends EngineScript {
    @Override
    public void onEnable(ScriptContext ctx) {
        ctx.listen(PlayerJoinEvent.class, e ->
            e.getPlayer().sendMessage("§aWelcome!"));
        ctx.scheduleRepeating(() -> ctx.log("Tick!"), 20L, 20L);
    }
    @Override public void onDisable() {}
}

Requires JDK (not just JRE) on the server.


🌐 Zero Config, Works Out of the Box

Plugin Engine automatically connects to the hosted cloud backend at gianhosting.tech. No API keys, no shared secrets, no reverse proxy setup required.

  • Install JAR → start server → type /plugin-engine → get a link → code.
  • The plugin generates a unique server ID on first start and connects automatically.
  • Want to self-host the backend? The Node.js backend is open source.

🔒 Secure Session Links

  • Sessions are tied to your Minecraft account, identity cannot be spoofed.
  • Each link is a one-time personalized token, valid for 60 minutes (configurable).
  • All session routes are protected by session validation on every request.
  • Security headers (CSP, X-Frame-Options, Referrer-Policy, Permissions-Policy) on all session pages.

🛒 Community Script Marketplace

Share your scripts with the community and discover scripts made by others, directly from within the IDE.

  • Uploader identity is verified through the Minecraft session: the player name is pulled from the authenticated Minecraft session, not user input. It cannot be faked.
  • Every script shows a warning that community code should be reviewed before execution.
  • Filter by JS / Java, search by name, author, or description.
  • Your own scripts show a delete button.

🔄 Scripts Survive Sessions & Restarts

Scripts keep running after your session ends, they are not tied to the browser tab.

  • Use /plugin-engine stop to explicitly stop all scripts (admin-only).
  • Mark any script as Auto-Start in the IDE: it will be saved to disk and re-executed automatically every time the server starts, with no further action required.
  • Auto-Start entries are stored in plugins/PluginEngine/startup.json.

💾 Script Storage

Save and load your scripts from within the IDE. Storage can be:

  • Global (global-storage: true, default), all players on the server share one script library.
  • Per-player (global-storage: false), each player gets their own scripts/{name}/ folder.

🚀 Getting Started

1. Install
Drop PluginEngine-1.0.0.jar into your server's /plugins folder and restart.

2. Open the IDE
In Minecraft chat, type:

/plugin-engine

A clickable link appears in chat. Click it to open the browser IDE.

3. Write & Execute
Select JavaScript or Java, write your code, press Ctrl+Enter.

That's everything. No configuration required.


⚙️ Configuration (config.yml)

Option Default Description
port 5000 Port for the built-in web server (fallback if no backend)
max-sessions 5 Maximum number of simultaneous open sessions
session-duration-minutes 60 How long a session link stays valid
global-storage true true = shared script folder, false = per-player folders
backend-url wss://gianhosting.tech/plugin-wss WebSocket URL of the backend
public-url https://gianhosting.tech Public URL used in session links
server-id (auto-generated) Unique identifier for this server, do not edit manually

You don't have to change anything, everything is already setup.


📋 Permissions

Permission Default Description
pluginengine.use op Open a session and use the IDE
pluginengine.admin op Access to /plugin-engine stop and revoke all

🖥️ Commands

Command Description
/plugin-engine Open a new session and receive a link
/plugin-engine revoke End your own sessions (scripts keep running)
/plugin-engine stop Stop all running scripts [Admin]
/plugin-engine status Show active sessions, script count, backend status
/plugin-engine help Show all available commands

Aliases: /pe, /peng


📦 Requirements

  • Paper 1.21 or higher (Spigot is not officially supported)
  • Java 21 or higher
  • JDK (not just JRE), required for Java compilation. JavaScript works without JDK.

🔧 JavaScript API Reference

// Event handler
const id = on("eventName", callback)  // register
off(id)                                // unregister

// Events
"playerJoin"       // (player)
"playerQuit"       // (player)
"playerDeath"      // (player)
"playerRespawn"    // (player)
"playerMove"       // (player)
"playerInteract"   // (player)
"playerChat"       // (player, msg)
"blockBreak"       // (player, block)
"blockPlace"       // (player, block)

// Player
player.name           player.health      player.gameMode
player.sendMessage("§aText")
player.kick("reason")
player.teleport(x, y, z)
player.giveItem("DIAMOND", 1)
player.heal()
player.setGameMode("creative")

// Server
server.broadcast("§6Text")
server.runCommand("say hello")
server.getOnlinePlayers()
server.getTPS()

// Logging
log("message")

❓ FAQ

Does this work without internet?
Yes. If the cloud backend is unreachable, the plugin falls back to the built-in web server on the configured port. You can also set backend-url to blank in config.yml to always use the local server.

Are scripts persisted across reloads?
Scripts in memory are lost on /reload or restart. Use the Auto-Start feature in the IDE to re-execute scripts automatically on every server start.

Can players grief with this?
The pluginengine.use permission defaults to op. Only grant it to trusted players. Scripts run with full server permissions, treat them like plugins.

Why does Java compilation require JDK?
The javax.tools.JavaCompiler API used for runtime compilation is only available in a JDK, not a plain JRE. Most server hosting providers include a JDK; if yours doesn't, JavaScript still works without it.

Is the cloud backend safe?
The server authenticates to the backend using its auto-generated UUID server-id (stored in config.yml). This ID acts as a 128-bit random secret. Don't share your config.yml.


Built with Mozilla Rhino for JavaScript · Ace Editor · Fastify backend on Raspberry Pi via Cloudflare Tunnel