@serenityjs/plugins 0.6.4 → 0.7.0-beta-20241221054452
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +13 -0
- package/README.md +2 -4
- package/dist/index.d.mts +31 -0
- package/dist/index.d.ts +31 -0
- package/dist/index.js +1 -1
- package/dist/index.mjs +1 -1
- package/package.json +5 -5
package/CHANGELOG.md
CHANGED
|
@@ -1,5 +1,18 @@
|
|
|
1
1
|
# @serenityjs/plugins
|
|
2
2
|
|
|
3
|
+
## 0.7.0-beta-20241221054452
|
|
4
|
+
|
|
5
|
+
### Minor Changes
|
|
6
|
+
|
|
7
|
+
- [`b857e0a`](https://github.com/SerenityJS/serenity/commit/b857e0a36e4a9be1684ac4f13ce1688611dd363b) Thanks [@PMK744](https://github.com/PMK744)! - init 0.7.0-beta
|
|
8
|
+
|
|
9
|
+
### Patch Changes
|
|
10
|
+
|
|
11
|
+
- Updated dependencies [[`b857e0a`](https://github.com/SerenityJS/serenity/commit/b857e0a36e4a9be1684ac4f13ce1688611dd363b)]:
|
|
12
|
+
- @serenityjs/protocol@0.7.0-beta-20241221054452
|
|
13
|
+
- @serenityjs/logger@0.7.0-beta-20241221054452
|
|
14
|
+
- @serenityjs/core@0.7.0-beta-20241221054452
|
|
15
|
+
|
|
3
16
|
## 0.6.4
|
|
4
17
|
|
|
5
18
|
### Patch Changes
|
package/README.md
CHANGED
|
@@ -1,5 +1,3 @@
|
|
|
1
|
-
# @serenityjs/plugins
|
|
2
|
-
|
|
3
1
|
## Introduction
|
|
4
2
|
Plugins all developers to create server sided modifications to the base server software. SerenityJS provides a powerfull set of apis to allow full control over your server. We provide a TypeScript and JavaSample plugin template, which can be found [here](https://github.com/SerenityJS/sample-plugin).
|
|
5
3
|
|
|
@@ -10,7 +8,7 @@ First, you want access the [sample-plugin](https://github.com/SerenityJS/sample-
|
|
|
10
8
|
<br/>
|
|
11
9
|
<p align="center">
|
|
12
10
|
<a href="https://github.com/SerenityJS/serenity">
|
|
13
|
-
<img src="
|
|
11
|
+
<img src="https://github.com/SerenityJS/serenity/blob/main/packages/plugins/public/template-generation.png?raw=true" alt="Template Generation" />
|
|
14
12
|
</a>
|
|
15
13
|
</p>
|
|
16
14
|
|
|
@@ -18,6 +16,6 @@ Next, you will choose the location and the name of your repository. In this case
|
|
|
18
16
|
<br/>
|
|
19
17
|
<p align="center">
|
|
20
18
|
<a href="https://github.com/SerenityJS/serenity">
|
|
21
|
-
<img src="
|
|
19
|
+
<img src="https://github.com/SerenityJS/serenity/blob/main/packages/plugins/public/creating-plugin.png?raw=true" alt="Creating Plugin" />
|
|
22
20
|
</a>
|
|
23
21
|
</p>
|
package/dist/index.d.mts
CHANGED
|
@@ -137,6 +137,37 @@ interface PluginProperties extends Partial<PluginEvents> {
|
|
|
137
137
|
logger: Logger;
|
|
138
138
|
type: PluginType;
|
|
139
139
|
}
|
|
140
|
+
/**
|
|
141
|
+
* # Introduction
|
|
142
|
+
* Plugins are the fundamental building blocks of SerenityJS.
|
|
143
|
+
* They are used to add additional functionality to the server, which allows total control over the server.
|
|
144
|
+
*
|
|
145
|
+
* There are 2 types of plugins that are defined in the `PluginType` enum: `Addon` & `Api`
|
|
146
|
+
*
|
|
147
|
+
* Addon plugins add additional functionality to the server, without an exposed API. This means external plugins cannot directly interact with the plugins API.
|
|
148
|
+
* Api plugins add additional functionality to the server, with an exposed API for other plugins to use. This means external plugins can directly interact with the plugins API.
|
|
149
|
+
*
|
|
150
|
+
* ## Class Extending Plugin
|
|
151
|
+
* ```ts
|
|
152
|
+
* import { Plugin, PluginType, PluginEvents } from "@serenityjs/plugins";
|
|
153
|
+
*
|
|
154
|
+
* class SamplePlugin extends Plugin {
|
|
155
|
+
* public readonly type = PluginType.Addon;
|
|
156
|
+
*
|
|
157
|
+
* public constructor() {
|
|
158
|
+
* super("sample-plugin", "1.0.0");
|
|
159
|
+
* }
|
|
160
|
+
*
|
|
161
|
+
* public onInitialize(): void {}
|
|
162
|
+
*
|
|
163
|
+
* public onStartUp(): void {}
|
|
164
|
+
*
|
|
165
|
+
* public onShutDown(): void {}
|
|
166
|
+
* }
|
|
167
|
+
*
|
|
168
|
+
* export default new SamplePlugin();
|
|
169
|
+
* ```
|
|
170
|
+
*/
|
|
140
171
|
declare class Plugin implements PluginProperties {
|
|
141
172
|
/**
|
|
142
173
|
* The identifier of the plugin.
|
package/dist/index.d.ts
CHANGED
|
@@ -137,6 +137,37 @@ interface PluginProperties extends Partial<PluginEvents> {
|
|
|
137
137
|
logger: Logger;
|
|
138
138
|
type: PluginType;
|
|
139
139
|
}
|
|
140
|
+
/**
|
|
141
|
+
* # Introduction
|
|
142
|
+
* Plugins are the fundamental building blocks of SerenityJS.
|
|
143
|
+
* They are used to add additional functionality to the server, which allows total control over the server.
|
|
144
|
+
*
|
|
145
|
+
* There are 2 types of plugins that are defined in the `PluginType` enum: `Addon` & `Api`
|
|
146
|
+
*
|
|
147
|
+
* Addon plugins add additional functionality to the server, without an exposed API. This means external plugins cannot directly interact with the plugins API.
|
|
148
|
+
* Api plugins add additional functionality to the server, with an exposed API for other plugins to use. This means external plugins can directly interact with the plugins API.
|
|
149
|
+
*
|
|
150
|
+
* ## Class Extending Plugin
|
|
151
|
+
* ```ts
|
|
152
|
+
* import { Plugin, PluginType, PluginEvents } from "@serenityjs/plugins";
|
|
153
|
+
*
|
|
154
|
+
* class SamplePlugin extends Plugin {
|
|
155
|
+
* public readonly type = PluginType.Addon;
|
|
156
|
+
*
|
|
157
|
+
* public constructor() {
|
|
158
|
+
* super("sample-plugin", "1.0.0");
|
|
159
|
+
* }
|
|
160
|
+
*
|
|
161
|
+
* public onInitialize(): void {}
|
|
162
|
+
*
|
|
163
|
+
* public onStartUp(): void {}
|
|
164
|
+
*
|
|
165
|
+
* public onShutDown(): void {}
|
|
166
|
+
* }
|
|
167
|
+
*
|
|
168
|
+
* export default new SamplePlugin();
|
|
169
|
+
* ```
|
|
170
|
+
*/
|
|
140
171
|
declare class Plugin implements PluginProperties {
|
|
141
172
|
/**
|
|
142
173
|
* The identifier of the plugin.
|
package/dist/index.js
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
"use strict";var w=Object.defineProperty;var D=Object.getOwnPropertyDescriptor;var F=Object.getOwnPropertyNames;var O=Object.prototype.hasOwnProperty;var f=(a,e)=>w(a,"name",{value:e,configurable:!0});var j=(a,e)=>{for(var r in e)w(a,r,{get:e[r],enumerable:!0})},C=(a,e,r,n)=>{if(e&&typeof e=="object"||typeof e=="function")for(let t of F(e))!O.call(a,t)&&t!==r&&w(a,t,{get:()=>e[t],enumerable:!(n=D(e,t))||n.enumerable});return a};var L=a=>C(w({},"__esModule",{value:!0}),a);var W={};j(W,{DefaultPipelineProperties:()=>I,Pipeline:()=>_,Plugin:()=>v,PluginType:()=>h});module.exports=L(W);var s=require("fs"),o=require("path"),y=require("zlib"),x=require("child_process"),P=require("@serenityjs/logger"),m=require("@serenityjs/core"),B=require("@serenityjs/binarystream");var b=require("@serenityjs/logger");var h=function(a){return a[a.Addon=0]="Addon",a[a.Api=1]="Api",a}(h||{});var v=class{static{f(this,"Plugin")}identifier;version;logger;type;path;isBundled;pipeline;serenity;constructor(e,r,n){this.identifier=e,this.version=r,this.logger=n?.logger??new b.Logger(`${e}@${r}`,b.LoggerColors.Blue),this.type=n?.type??h.Addon,n?.onInitialize&&(this.onInitialize=n.onInitialize),n?.onStartUp&&(this.onStartUp=n.onStartUp),n?.onShutDown&&(this.onShutDown=n.onShutDown)}onInitialize(e){}onStartUp(e){}onShutDown(e){}};var A=require("path"),k=require("@serenityjs/protocol");var E=require("@serenityjs/core");var g=class extends E.CustomEnum{static{f(this,"PluginsEnum")}static identifier="plugins";static options=[]},z=class extends E.CustomEnum{static{f(this,"PluginActionsEnum")}static identifier="plugin_actions";static options=["list","reload","bundle"]};var q=f((a,e)=>{a.commands.register("plugins","Interact with the plugins of the server",r=>{r.permissionLevel=k.CommandPermissionLevel.Operator,r.overload({action:z},({action:n})=>{if(n.result!=="list")return;if(e.plugins.size===0)return{message:"\xA7cThere are current no plugins loaded on the server."};let t=[...e.plugins.values()],i=[];for(let d of t)i.push(`\xA7u${d.identifier} v${d.version}\xA7r`);return{message:`\xA77Active Plugins (${t.length}):\xA7r ${i.join("\xA77,\xA7r ")}`}}),r.overload({action:z,plugin:g},({action:n,plugin:t})=>{if(n.result!=="reload"&&n.result!=="bundle")return;let i=e.plugins.get(t.result);if(!i)throw new Error(`Plugin ${t.result} is not found.`);if(n.result==="reload")return e.reload(i),{message:`\xA7aSuccessfully reloaded \xA72${i.identifier}\xA7a.`};if(i.isBundled)throw new Error(`Plugin ${i.identifier} cannot be bundled, as it is already a bundled plugin.`);return e.bundle(i),{message:`\xA7aSuccessfully bundled \xA72${i.identifier}\xA7a, output file was placed at \xA77${(0,A.relative)(process.cwd(),e.path)}\xA7a.`}})},()=>{throw new Error("No overload matched the provided arguments.")})},"register"),U=q;var I={path:"./plugins",commands:!0,initialize:!0},_=class{static{f(this,"Pipeline")}serenity;properties;logger=new P.Logger("Plugins",P.LoggerColors.CyanBright);plugins=new Map;tempPaths=new Set;esm=typeof module<"u"&&module?.exports!==exports;get path(){return this.properties.path}set path(e){throw new Error("The path property is read-only.")}constructor(e,r){this.serenity=e,this.properties={...I,...r},e.on(m.ServerEvent.Start,this.start.bind(this)),e.on(m.ServerEvent.Stop,this.stop.bind(this)),this.properties.commands&&e.on(m.WorldEvent.WorldInitialize,({world:n})=>U(n,this)),this.properties.initialize&&this.initialize()}initialize(){(0,s.existsSync)((0,o.resolve)(this.path))||(0,s.mkdirSync)((0,o.resolve)(this.path),{recursive:!0});let r=(0,s.readdirSync)((0,o.resolve)(this.path),{withFileTypes:!0}).filter(t=>t.isFile()?t.name.endsWith(".plugin"):!1);for(let t of r)try{let i=(0,o.resolve)(this.path,t.name),d=(0,y.inflateSync)((0,s.readFileSync)(i)),l=new B.BinaryStream(d),S=l.readByte();if(S===h.Addon){let p=l.readRemainingBuffer().toString("utf-8"),c=(0,o.resolve)(this.path,t.name.slice(0,-7));(0,s.writeFileSync)(c,p);let u=require(c).default;if(!(u instanceof v)){this.logger.warn(`Unable to load plugin from \xA78${(0,o.relative)(process.cwd(),i)}\xA7r, the plugin is not an instance of the Plugin class.`);continue}if(this.plugins.has(u.identifier)){this.logger.warn(`Unable to load plugin \xA71${u.identifier}\xA7r, the plugin is already loaded in the pipeline.`);continue}u.pipeline=this,u.serenity=this.serenity,u.path=i,u.isBundled=!0,this.plugins.set(u.identifier,u),u.onInitialize(u),this.bindEvents(u),g.options.push(u.identifier),this.tempPaths.add(c)}else if(S===h.Api){let p=l.readRemainingBuffer();(0,s.unlinkSync)(i);let c=(0,o.resolve)(this.path,t.name.slice(0,-7));(0,s.writeFileSync)(c,p),(0,x.execSync)(`tar -xzf ${c} -C ${this.path}`,{stdio:"ignore"}),(0,s.unlinkSync)(c);let $=t.name.slice(0,-7);(0,s.renameSync)((0,o.resolve)(this.path,"package"),(0,o.resolve)(this.path,$)),(0,x.execSync)("npm install",{cwd:(0,o.resolve)(this.path,$),stdio:"ignore"})}}catch(i){this.logger.error(`Failed to load plugin from "${(0,o.relative)(process.cwd(),(0,o.resolve)(this.path,t.name))}", skipping the plugin.`,i)}let n=(0,s.readdirSync)((0,o.resolve)(this.path),{withFileTypes:!0}).filter(t=>t.isDirectory());for(let t of n)try{let i=(0,o.resolve)(this.path,t.name);if(!(0,s.existsSync)((0,o.resolve)(i,"package.json")))continue;let d=JSON.parse((0,s.readFileSync)((0,o.resolve)(i,"package.json"),"utf-8")),l=(0,o.resolve)(i,d.main);if(!(0,s.existsSync)((0,o.resolve)(i,l))){this.logger.warn(`Unable to load plugin \xA71${d.name}\xA78@\xA71${d.version}\xA7r, the main entry path "\xA78${(0,o.relative)(process.cwd(),(0,o.resolve)(i,l))}\xA7r" was not found in the directory.`);continue}let p=require((0,o.resolve)(i,l)).default;if(this.plugins.has(p.identifier)){this.logger.warn(`Unable to load plugin \xA71${p.identifier}\xA7r, the plugin is already loaded in the pipeline.`);continue}p.pipeline=this,p.serenity=this.serenity,p.path=i,p.isBundled=!1,this.plugins.set(p.identifier,p),g.options.push(p.identifier),p.onInitialize(p),this.bindEvents(p)}catch(i){this.logger.error(`Failed to load plugin from "${(0,o.relative)(process.cwd(),(0,o.resolve)(this.path,t.name))}", skipping the plugin.`,i)}}start(){for(let e of this.plugins.values())e.onStartUp(e)}stop(){for(let e of this.plugins.values())e.onShutDown(e);for(let e of this.tempPaths)(0,s.unlinkSync)(e)}reload(e){e.onShutDown(e),this.plugins.delete(e.identifier);let r=e.path;delete require.cache[require.resolve(r)],this.serenity.removePath(r);try{let t=require(r).default;if(!(t instanceof v)){this.logger.warn(`Unable to reload plugin from \xA78${(0,o.relative)(process.cwd(),r)}\xA7r, the plugin is not an instance of the Plugin class.`);return}t.pipeline=this,t.serenity=this.serenity,t.path=r,this.plugins.set(t.identifier,t),t.onInitialize(t),this.bindEvents(t),t.onStartUp(t),this.logger.info(`Successfully reloaded plugin \xA71${t.identifier}\xA7r from \xA78${(0,o.relative)(process.cwd(),r)}\xA7r.`)}catch(n){this.logger.error(`Failed to reload plugin from \xA78${(0,o.relative)(process.cwd(),r)}\xA7r, skipping the plugin.`,n)}}bundle(e){let r=new B.BinaryStream;if(r.writeByte(e.type),e.type===h.Addon){let n=(0,o.resolve)(e.path,"dist"),t=(0,s.readFileSync)((0,o.resolve)(n,"index.js"));r.writeBuffer(t),(0,s.writeFileSync)((0,o.resolve)(this.path,`${e.identifier}.plugin`),(0,y.deflateSync)(r.getBuffer()))}else if(e.type===h.Api){(0,x.execSync)("npm pack",{cwd:e.path,stdio:"ignore"});let n=(0,s.readdirSync)(e.path).find(i=>i.endsWith(".tgz"));if(!n)throw new Error("Packed tarball not found.");let t=(0,s.readFileSync)((0,o.resolve)(e.path,n));(0,s.unlinkSync)((0,o.resolve)(e.path,n)),r.writeBuffer(t),(0,s.writeFileSync)((0,o.resolve)(this.path,`${e.identifier}.plugin`),(0,y.deflateSync)(r.getBuffer()))}}bindEvents(e){let r=Object.getPrototypeOf(e),n=Object.getOwnPropertyNames(r),t=Object.keys(m.WorldEvent);t=t.slice(t.length/2);for(let i of t){let d=t.indexOf(i);if(n.includes("on"+i)){let l=e["on"+i];typeof l=="function"&&this.serenity.on(d,l.bind(e))}if(n.includes("before"+i)){let l=e["before"+i];typeof l=="function"&&this.serenity.before(d,l.bind(e))}if(n.includes("after"+i)){let l=e["after"+i];typeof l=="function"&&this.serenity.after(d,l.bind(e))}}}};0&&(module.exports={DefaultPipelineProperties,Pipeline,Plugin,PluginType});
|
|
2
|
-
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../src/index.ts", "../src/pipeline.ts", "../src/plugin.ts", "../src/enums/type.ts", "../src/commands/command.ts", "../src/commands/enum.ts"],
  "sourcesContent": ["export * from \"./pipeline\";\nexport * from \"./plugin\";\nexport * from \"./enums\";\nexport * from \"./types\";\n", "/* eslint-disable @typescript-eslint/no-require-imports */\nimport {\n  existsSync,\n  mkdirSync,\n  readdirSync,\n  readFileSync,\n  renameSync,\n  unlinkSync,\n  writeFileSync\n} from \"node:fs\";\nimport { relative, resolve } from \"node:path\";\nimport { deflateSync, inflateSync } from \"node:zlib\";\nimport { execSync } from \"node:child_process\";\n\nimport { Logger, LoggerColors } from \"@serenityjs/logger\";\nimport { Serenity, ServerEvent, WorldEvent } from \"@serenityjs/core\";\nimport { BinaryStream } from \"@serenityjs/binarystream\";\n\nimport { PluginPackage } from \"./types\";\nimport { Plugin } from \"./plugin\";\nimport Command from \"./commands/command\";\nimport { PluginsEnum } from \"./commands\";\nimport { PluginType } from \"./enums\";\n\ninterface PipelineProperties {\n  path: string;\n  commands: boolean;\n  initialize: boolean;\n}\n\nconst DefaultPipelineProperties: PipelineProperties = {\n  path: \"./plugins\",\n  commands: true,\n  initialize: true\n};\n\nclass Pipeline {\n  /**\n   * The serenity server instance for the plugins pipeline.\n   */\n  protected readonly serenity: Serenity;\n\n  /**\n   * The properties for the plugins pipeline.\n   */\n  protected readonly properties: PipelineProperties;\n\n  /**\n   * The logger for the plugins pipeline.\n   */\n  public readonly logger = new Logger(\"Plugins\", LoggerColors.CyanBright);\n\n  /**\n   * The plugins loaded in the pipeline.\n   */\n  public readonly plugins = new Map<string, Plugin>();\n\n  /**\n   * The temporary paths used by the pipeline.\n   */\n  protected readonly tempPaths = new Set<string>();\n\n  /**\n   * Whether the pipeline is running in ESM mode.\n   */\n  public readonly esm: boolean =\n    typeof module !== \"undefined\" && module?.exports !== exports;\n\n  /**\n   * The path to the plugins directory.\n   */\n  public get path(): string {\n    return this.properties.path;\n  }\n\n  /**\n   * The path to the plugins directory.\n   */\n  public set path(_) {\n    throw new Error(\"The path property is read-only.\");\n  }\n\n  /**\n   * Creates a new instance of the Pipeline class.\n   * @param serenity The serenity server instance.\n   * @param properties The properties for the pipeline.\n   */\n  public constructor(\n    serenity: Serenity,\n    properties?: Partial<PipelineProperties>\n  ) {\n    // Set the serenity server instance\n    this.serenity = serenity;\n\n    // Merge the properties with the default properties\n    this.properties = { ...DefaultPipelineProperties, ...properties };\n\n    // Hook into the serenity server events\n    serenity.on(ServerEvent.Start, this.start.bind(this));\n    serenity.on(ServerEvent.Stop, this.stop.bind(this));\n\n    // Check if the plugins command should be registered\n    if (this.properties.commands) {\n      // Hook into the world initialize event\n      serenity.on(WorldEvent.WorldInitialize, ({ world }) =>\n        Command(world, this)\n      );\n    }\n\n    // Check if the plugins should be initialized\n    if (this.properties.initialize) this.initialize();\n  }\n\n  /**\n   * Initializes the plugins pipeline.\n   */\n  public initialize(): void {\n    // Check if the plugins directory exists\n    if (!existsSync(resolve(this.path)))\n      // If not, create the plugins directory\n      mkdirSync(resolve(this.path), { recursive: true });\n\n    // Read all the entries in the plugins directory\n    const entries = readdirSync(resolve(this.path), {\n      withFileTypes: true\n    });\n\n    // Filter out all the files that have a .plugin extension\n    const bundles = entries.filter((dirent) =>\n      dirent.isFile() ? dirent.name.endsWith(\".plugin\") : false\n    );\n\n    // Iterate over all the bundled plugins, and import them\n    for (const bundle of bundles) {\n      // Attempt to load the plugin\n      try {\n        // Get the path to the plugin\n        const path = resolve(this.path, bundle.name);\n\n        // Read the .plugin file and inflate it, and create a new binary stream\n        const buffer = inflateSync(readFileSync(path));\n        const stream = new BinaryStream(buffer);\n\n        // Read the plugin type from the stream\n        const type = stream.readByte();\n\n        // Check if the plugin type is valid\n        if (type === PluginType.Addon) {\n          // Read the module entry point from the stream\n          const index = stream.readRemainingBuffer().toString(\"utf-8\");\n\n          // Write the module or main entry points to temporary files\n          const tempPath = resolve(this.path, bundle.name.slice(0, -7));\n          writeFileSync(tempPath, index);\n\n          // Import the plugin module\n          const module = require(tempPath);\n\n          // Get the plugin class from the module\n          const plugin = module.default as Plugin;\n\n          // Check if the plugin is an instance of the Plugin class\n          if (!(plugin instanceof Plugin)) {\n            this.logger.warn(\n              `Unable to load plugin from §8${relative(process.cwd(), path)}§r, the plugin is not an instance of the Plugin class.`\n            );\n\n            // Skip the plugin\n            continue;\n          }\n\n          // Check if the plugin has already been loaded\n          if (this.plugins.has(plugin.identifier)) {\n            this.logger.warn(\n              `Unable to load plugin §1${plugin.identifier}§r, the plugin is already loaded in the pipeline.`\n            );\n\n            // Skip the plugin\n            continue;\n          }\n\n          // Set the pipeline, serenity, and path for the plugin\n          plugin.pipeline = this;\n          plugin.serenity = this.serenity;\n          plugin.path = path;\n          plugin.isBundled = true;\n\n          // Add the plugin to the plugins map\n          this.plugins.set(plugin.identifier, plugin);\n\n          // Initialize the plugin and bind the events\n          plugin.onInitialize(plugin);\n          this.bindEvents(plugin);\n\n          // Add the plugin to the plugins enum\n          PluginsEnum.options.push(plugin.identifier);\n\n          // Add the temporary path to the set\n          this.tempPaths.add(tempPath);\n        } else if (type === PluginType.Api) {\n          // Read the buffer from the stream\n          const buffer = stream.readRemainingBuffer();\n\n          // Delete the .plugin file\n          unlinkSync(path);\n\n          // Write the buffer to a temporary file\n          const tempPath = resolve(this.path, bundle.name.slice(0, -7));\n\n          // Write the buffer to the temporary file\n          writeFileSync(tempPath, buffer);\n\n          // Extract the tarball to the plugins directory\n          execSync(`tar -xzf ${tempPath} -C ${this.path}`, {\n            stdio: \"ignore\"\n          });\n\n          // Delete the temporary file\n          unlinkSync(tempPath);\n\n          // Get the plugin name from the tarball\n          const name = bundle.name.slice(0, -7);\n\n          // Rename the extracted \"package\" directory to the plugin name\n          renameSync(resolve(this.path, \"package\"), resolve(this.path, name));\n\n          // Install the dependencies for the plugin\n          execSync(\"npm install\", {\n            cwd: resolve(this.path, name),\n            stdio: \"ignore\"\n          });\n        }\n      } catch (reason) {\n        // Log the error\n        this.logger.error(\n          `Failed to load plugin from \"${relative(process.cwd(), resolve(this.path, bundle.name))}\", skipping the plugin.`,\n          reason\n        );\n      }\n    }\n\n    // Filter out all the directories from the entries\n    const directories = readdirSync(resolve(this.path), {\n      withFileTypes: true\n    }).filter((dirent) => dirent.isDirectory());\n\n    // Iterate over all the directories, checking if they are valid plugins\n    for (const directory of directories) {\n      // Attempt to load the plugin\n      try {\n        // Get the path to the plugin\n        const path = resolve(this.path, directory.name);\n\n        // Check if the plugin has a package.json file, if not, skip the plugin\n        if (!existsSync(resolve(path, \"package.json\"))) continue;\n\n        // Read the package.json file\n        const manifest = JSON.parse(\n          readFileSync(resolve(path, \"package.json\"), \"utf-8\")\n        ) as PluginPackage;\n\n        // Get the main entry point for the plugin\n        // const main = resolve(path, this.esm ? manifest.module : manifest.main);\n        const main = resolve(path, manifest.main);\n\n        // Check if the provided entry point is valid\n        if (!existsSync(resolve(path, main))) {\n          this.logger.warn(\n            `Unable to load plugin §1${manifest.name}§8@§1${manifest.version}§r, the main entry path \"§8${relative(process.cwd(), resolve(path, main))}§r\" was not found in the directory.`\n          );\n\n          // Skip the plugin\n          continue;\n        }\n\n        // Import the plugin module\n        const module = require(resolve(path, main));\n\n        // Get the plugin class from the module\n        const plugin = module.default as Plugin;\n\n        // Check if the plugin has already been loaded\n        if (this.plugins.has(plugin.identifier)) {\n          this.logger.warn(\n            `Unable to load plugin §1${plugin.identifier}§r, the plugin is already loaded in the pipeline.`\n          );\n\n          // Skip the plugin\n          continue;\n        }\n\n        // Set the pipeline, serenity, and path for the plugin\n        plugin.pipeline = this;\n        plugin.serenity = this.serenity;\n        plugin.path = path;\n        plugin.isBundled = false;\n\n        // Add the plugin to the plugins map\n        this.plugins.set(plugin.identifier, plugin);\n\n        // Add the plugin to the plugins enum\n        PluginsEnum.options.push(plugin.identifier);\n\n        // Initialize the plugin, and bind the events\n        plugin.onInitialize(plugin);\n        this.bindEvents(plugin);\n      } catch (reason) {\n        // Log the error\n        this.logger.error(\n          `Failed to load plugin from \"${relative(process.cwd(), resolve(this.path, directory.name))}\", skipping the plugin.`,\n          reason\n        );\n      }\n    }\n  }\n\n  /**\n   * Starts the plugins pipeline.\n   */\n  public start(): void {\n    // Start up all the plugins\n    for (const plugin of this.plugins.values()) plugin.onStartUp(plugin);\n  }\n\n  /**\n   * Stops the plugins pipeline.\n   */\n  public stop(): void {\n    // Shut down all the plugins\n    for (const plugin of this.plugins.values()) plugin.onShutDown(plugin);\n\n    // Delete all the temporary files\n    for (const tempPath of this.tempPaths) {\n      // Delete the temporary file\n      unlinkSync(tempPath);\n    }\n  }\n\n  public reload(plugin: Plugin): void {\n    // Shut down the plugin\n    plugin.onShutDown(plugin);\n\n    // Remove the plugin from the plugins map\n    this.plugins.delete(plugin.identifier);\n\n    // Get the plugin path\n    const path = plugin.path;\n\n    // Delete the require cache for the plugin\n    // eslint-disable-next-line @typescript-eslint/no-dynamic-delete -- Dynamic delete is required here\n    delete require.cache[require.resolve(path)];\n\n    // Remove the plugin from the serenity instance\n    this.serenity.removePath(path);\n\n    // Attempt to load the plugin\n    try {\n      // Import the plugin module\n\n      const module = require(path);\n\n      // Get the plugin class from the module\n      const rPlugin = module.default as Plugin;\n\n      // Check if the plugin is an instance of the Plugin class\n      if (!(rPlugin instanceof Plugin)) {\n        this.logger.warn(\n          `Unable to reload plugin from §8${relative(process.cwd(), path)}§r, the plugin is not an instance of the Plugin class.`\n        );\n\n        // Skip the plugin\n        return;\n      }\n\n      // Set the pipeline, serenity, and path for the plugin\n      rPlugin.pipeline = this;\n      rPlugin.serenity = this.serenity;\n      rPlugin.path = path;\n\n      // Add the plugin to the plugins map\n      this.plugins.set(rPlugin.identifier, rPlugin);\n\n      // Initialize the plugin\n      rPlugin.onInitialize(rPlugin);\n      this.bindEvents(rPlugin);\n\n      // Start up the plugin\n      rPlugin.onStartUp(rPlugin);\n\n      // Log the successful reload\n      this.logger.info(\n        `Successfully reloaded plugin §1${rPlugin.identifier}§r from §8${relative(process.cwd(), path)}§r.`\n      );\n    } catch (reason) {\n      // Log the error\n      this.logger.error(\n        `Failed to reload plugin from §8${relative(process.cwd(), path)}§r, skipping the plugin.`,\n        reason\n      );\n    }\n  }\n\n  public bundle(plugin: Plugin): void {\n    // Create a new BinaryStream instance\n    const stream = new BinaryStream();\n\n    // Write the plugin type to the stream\n    stream.writeByte(plugin.type);\n\n    if (plugin.type === PluginType.Addon) {\n      // Get the addon path\n      const inputPath = resolve(plugin.path, \"dist\");\n\n      // Read the index file\n      const index = readFileSync(resolve(inputPath, \"index.js\"));\n\n      // Write the module entry point to the stream\n      stream.writeBuffer(index);\n\n      // Write the BinaryStream to the output path\n      writeFileSync(\n        resolve(this.path, `${plugin.identifier}.plugin`),\n        deflateSync(stream.getBuffer())\n      );\n    } else if (plugin.type === PluginType.Api) {\n      // Pack the plugin\n      execSync(\"npm pack\", { cwd: plugin.path, stdio: \"ignore\" });\n\n      // Get the tarball path\n      const tarball = readdirSync(plugin.path).find((file) =>\n        file.endsWith(\".tgz\")\n      );\n\n      // Check if the tarball exists\n      if (!tarball) throw new Error(\"Packed tarball not found.\");\n\n      // Read the tarball file\n      const buffer = readFileSync(resolve(plugin.path, tarball));\n\n      // Delete the tarball file\n      unlinkSync(resolve(plugin.path, tarball));\n\n      // Write the buffer to the output path\n      stream.writeBuffer(buffer);\n\n      // Write the buffer to the output path\n      writeFileSync(\n        resolve(this.path, `${plugin.identifier}.plugin`),\n        deflateSync(stream.getBuffer())\n      );\n    }\n  }\n\n  protected bindEvents(plugin: Plugin): void {\n    // Get the prototype of the plugin\n    const prototype = Object.getPrototypeOf(plugin);\n\n    // Get the object keys from the plugin\n    const pluginKeys = Object.getOwnPropertyNames(prototype);\n\n    // Get the world event keys, and slice them in half\n    let eventKeys = Object.keys(WorldEvent);\n    eventKeys = eventKeys.slice(eventKeys.length / 2);\n\n    // Iterate over all the event keys\n    for (const eventKey of eventKeys) {\n      // Get the index of the event key\n      const index = eventKeys.indexOf(eventKey) as WorldEvent;\n\n      // Check if the plugin has any \"on\" event keys\n      if (pluginKeys.includes(\"on\" + eventKey)) {\n        // Get the value of the event key\n        const value = plugin[(\"on\" + eventKey) as keyof Plugin];\n\n        // Check if the value is a function\n        if (typeof value === \"function\")\n          // Bind the event to the plugin\n          this.serenity.on(index, value.bind(plugin) as () => void);\n      }\n\n      // Check if the plugin has any \"before\" event keys\n      if (pluginKeys.includes(\"before\" + eventKey)) {\n        // Get the value of the event key\n        const value = plugin[(\"before\" + eventKey) as keyof Plugin];\n\n        // Check if the value is a function\n        if (typeof value === \"function\")\n          // Bind the event to the plugin\n          this.serenity.before(index, value.bind(plugin) as () => boolean);\n      }\n\n      // Check if the plugin has any \"after\" event keys\n      if (pluginKeys.includes(\"after\" + eventKey)) {\n        // Get the value of the event key\n        const value = plugin[(\"after\" + eventKey) as keyof Plugin];\n\n        // Check if the value is a function\n        if (typeof value === \"function\")\n          // Bind the event to the plugin\n          this.serenity.after(index, value.bind(plugin) as () => void);\n      }\n    }\n  }\n}\n\nexport { Pipeline, DefaultPipelineProperties };\n", "import { Serenity } from \"@serenityjs/core\";\nimport { Logger, LoggerColors } from \"@serenityjs/logger\";\n\nimport { Pipeline } from \"./pipeline\";\nimport { PluginType } from \"./enums\";\nimport { PluginEvents } from \"./types\";\n\ninterface PluginProperties extends Partial<PluginEvents> {\n  logger: Logger;\n  type: PluginType;\n}\n\nclass Plugin implements PluginProperties {\n  /**\n   * The identifier of the plugin.\n   */\n  public readonly identifier: string;\n\n  /**\n   * The version of the plugin.\n   */\n  public readonly version: string;\n\n  /**\n   * The logger for the plugin.\n   */\n  public readonly logger: Logger;\n\n  /**\n   * The type of the plugin.\n   */\n  public readonly type: PluginType;\n\n  /**\n   * The path to the plugin.\n   * @Note This is only available after the plugin is initialized.\n   */\n  public path!: string;\n\n  /**\n   * Whether or not the plugin is bundled.\n   * @Note This is only available after the plugin is initialized.\n   */\n  public isBundled!: boolean;\n\n  /**\n   * The plugin pipeline the plugin is in.\n   * @Note This is only available after the plugin is initialized.\n   */\n  public pipeline!: Pipeline;\n\n  /**\n   * The serenity instance of the server.\n   * @Note This is only available after the plugin is initialized.\n   */\n  public serenity!: Serenity;\n\n  /**\n   * Create a new plugin instance.\n   * @param identifier The identifier of the plugin.\n   * @param version The version of the plugin.\n   * @param properties The properties of the plugin.\n   */\n  public constructor(\n    identifier: string,\n    version: string,\n    properties?: Partial<PluginProperties>\n  ) {\n    // Set the identifier and version of the plugin\n    this.identifier = identifier;\n    this.version = version;\n\n    // Set the logger for the plugin\n    this.logger =\n      properties?.logger ??\n      new Logger(`${identifier}@${version}`, LoggerColors.Blue);\n\n    // Set the type of the plugin\n    this.type = properties?.type ?? PluginType.Addon;\n\n    // Set the on initialize, start up, and shut down properties\n    if (properties?.onInitialize) this.onInitialize = properties.onInitialize;\n    if (properties?.onStartUp) this.onStartUp = properties.onStartUp;\n    if (properties?.onShutDown) this.onShutDown = properties.onShutDown;\n  }\n\n  /**\n   * Called when the plugin is initialized.\n   * @param plugin The plugin instance that was initialized. (this)\n   */\n  public onInitialize(_plugin: Plugin): void {\n    // Override this method in your plugin\n  }\n\n  /**\n   * Called when the plugin is started up.\n   * @param plugin The plugin instance that was started up. (this)\n   */\n  public onStartUp(_plugin: Plugin): void {\n    // Override this method in your plugin\n  }\n\n  /**\n   * Called when the plugin is shut down.\n   * @param plugin The plugin instance that was shut down. (this)\n   */\n  public onShutDown(_plugin: Plugin): void {\n    // Override this method in your plugin\n  }\n}\n\nexport { Plugin, PluginProperties };\n", "/**\n * The plugin type declares the use case of the plugin.\n */\nenum PluginType {\n  /**\n   * An addon plugin type adds additional functionality to the server, without an exposed API.\n   */\n  Addon,\n\n  /**\n   * An API plugin type adds additional functionality to the server, with an exposed API for other plugins to use.\n   */\n  Api\n}\n\nexport { PluginType };\n", "import { relative } from \"path\";\n\nimport { World } from \"@serenityjs/core\";\nimport { CommandPermissionLevel } from \"@serenityjs/protocol\";\n\nimport { Pipeline } from \"../pipeline\";\n\nimport { PluginActionsEnum, PluginsEnum } from \"./enum\";\n\nconst register = (world: World, pipeline: Pipeline) => {\n  world.commands.register(\n    \"plugins\",\n    \"Interact with the plugins of the server\",\n    (registry) => {\n      // Set the command to be an operator command\n      registry.permissionLevel = CommandPermissionLevel.Operator;\n\n      // Overload for listing the plugins\n      registry.overload(\n        {\n          action: PluginActionsEnum\n        },\n        ({ action }) => {\n          // Check if the action is list\n          if (action.result !== \"list\") return;\n\n          // Check if the pipeline has no plugins\n          if (pipeline.plugins.size === 0)\n            return {\n              message: \"§cThere are current no plugins loaded on the server.\"\n            };\n\n          // Get the plugins from the pipeline\n          const plugins = [...pipeline.plugins.values()];\n\n          // Prepare the message\n          const message = [];\n\n          // Loop through the plugins\n          for (const plugin of plugins) {\n            // Push the plugin name to the message\n            message.push(`§u${plugin.identifier} v${plugin.version}§r`);\n          }\n\n          // Send the message to the origin\n          return {\n            message: `§7Active Plugins (${plugins.length}):§r ${message.join(\"§7,§r \")}`\n          };\n        }\n      );\n\n      registry.overload(\n        {\n          action: PluginActionsEnum,\n          plugin: PluginsEnum\n        },\n        ({ action, plugin }) => {\n          // Check if the action is reload\n          if (action.result !== \"reload\" && action.result !== \"bundle\") return;\n\n          // Get the plugin from the pipeline\n          const pluginInstance = pipeline.plugins.get(plugin.result as string);\n\n          // Check if the plugin is not found\n          if (!pluginInstance)\n            throw new Error(`Plugin ${plugin.result} is not found.`);\n\n          // Check if the action is reload\n          if (action.result === \"reload\") {\n            // Reload the plugin\n            pipeline.reload(pluginInstance);\n\n            // Send the message to the origin\n            return {\n              message: `§aSuccessfully reloaded §2${pluginInstance.identifier}§a.`\n            };\n          } else {\n            if (pluginInstance.isBundled)\n              // Check if the plugin is already bundled\n              throw new Error(\n                `Plugin ${pluginInstance.identifier} cannot be bundled, as it is already a bundled plugin.`\n              );\n\n            // Bundle the plugin\n            pipeline.bundle(pluginInstance);\n\n            // Send the message to the origin\n            return {\n              message: `§aSuccessfully bundled §2${pluginInstance.identifier}§a, output file was placed at §7${relative(process.cwd(), pipeline.path)}§a.`\n            };\n          }\n        }\n      );\n    },\n    () => {\n      throw new Error(\"No overload matched the provided arguments.\");\n    }\n  );\n};\n\nexport default register;\n", "import { CustomEnum } from \"@serenityjs/core\";\n\nclass PluginsEnum extends CustomEnum {\n  public static readonly identifier = \"plugins\";\n  public static readonly options: Array<string> = [];\n}\n\nclass PluginActionsEnum extends CustomEnum {\n  public static readonly identifier = \"plugin_actions\";\n  public static readonly options: Array<string> = [\"list\", \"reload\", \"bundle\"];\n}\n\nexport { PluginsEnum, PluginActionsEnum };\n"],
  "mappings": "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",
  "names": ["src_exports", "__export", "DefaultPipelineProperties", "Pipeline", "Plugin", "PluginType", "__toCommonJS", "import_node_fs", "import_node_path", "import_node_zlib", "import_node_child_process", "import_logger", "import_core", "import_binarystream", "import_logger", "PluginType", "Plugin", "identifier", "version", "logger", "type", "path", "isBundled", "pipeline", "serenity", "properties", "Logger", "LoggerColors", "Blue", "PluginType", "Addon", "onInitialize", "onStartUp", "onShutDown", "_plugin", "import_path", "import_protocol", "import_core", "PluginsEnum", "CustomEnum", "identifier", "options", "PluginActionsEnum", "register", "__name", "world", "pipeline", "commands", "registry", "permissionLevel", "CommandPermissionLevel", "Operator", "overload", "action", "PluginActionsEnum", "result", "plugins", "size", "message", "values", "plugin", "push", "identifier", "version", "length", "join", "PluginsEnum", "pluginInstance", "get", "Error", "reload", "isBundled", "bundle", "relative", "process", "cwd", "path", "command_default", "DefaultPipelineProperties", "path", "commands", "initialize", "Pipeline", "serenity", "properties", "logger", "Logger", "LoggerColors", "CyanBright", "plugins", "Map", "tempPaths", "Set", "esm", "module", "exports", "_", "Error", "on", "ServerEvent", "Start", "start", "bind", "Stop", "stop", "WorldEvent", "WorldInitialize", "world", "Command", "existsSync", "resolve", "mkdirSync", "recursive", "bundles", "readdirSync", "withFileTypes", "filter", "dirent", "isFile", "name", "endsWith", "bundle", "buffer", "inflateSync", "readFileSync", "stream", "BinaryStream", "type", "readByte", "PluginType", "Addon", "index", "readRemainingBuffer", "toString", "tempPath", "slice", "writeFileSync", "plugin", "require", "default", "Plugin", "warn", "relative", "process", "cwd", "has", "identifier", "pipeline", "isBundled", "set", "onInitialize", "bindEvents", "PluginsEnum", "options", "push", "add", "Api", "unlinkSync", "execSync", "stdio", "renameSync", "reason", "error", "directories", "isDirectory", "directory", "manifest", "JSON", "parse", "main", "version", "values", "onStartUp", "onShutDown", "reload", "delete", "cache", "removePath", "rPlugin", "info", "writeByte", "inputPath", "writeBuffer", "deflateSync", "getBuffer", "tarball", "find", "file", "prototype", "Object", "getPrototypeOf", "pluginKeys", "getOwnPropertyNames", "eventKeys", "keys", "length", "eventKey", "indexOf", "includes", "value", "before", "after"]
}

|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../src/index.ts", "../src/pipeline.ts", "../src/plugin.ts", "../src/enums/type.ts", "../src/commands/command.ts", "../src/commands/enum.ts"],
  "sourcesContent": ["export * from \"./pipeline\";\nexport * from \"./plugin\";\nexport * from \"./enums\";\nexport * from \"./types\";\n", "/* eslint-disable @typescript-eslint/no-require-imports */\nimport {\n  existsSync,\n  mkdirSync,\n  readdirSync,\n  readFileSync,\n  renameSync,\n  unlinkSync,\n  writeFileSync\n} from \"node:fs\";\nimport { relative, resolve } from \"node:path\";\nimport { deflateSync, inflateSync } from \"node:zlib\";\nimport { execSync } from \"node:child_process\";\n\nimport { Logger, LoggerColors } from \"@serenityjs/logger\";\nimport { Serenity, ServerEvent, WorldEvent } from \"@serenityjs/core\";\nimport { BinaryStream } from \"@serenityjs/binarystream\";\n\nimport { PluginPackage } from \"./types\";\nimport { Plugin } from \"./plugin\";\nimport Command from \"./commands/command\";\nimport { PluginsEnum } from \"./commands\";\nimport { PluginType } from \"./enums\";\n\ninterface PipelineProperties {\n  path: string;\n  commands: boolean;\n  initialize: boolean;\n}\n\nconst DefaultPipelineProperties: PipelineProperties = {\n  path: \"./plugins\",\n  commands: true,\n  initialize: true\n};\n\nclass Pipeline {\n  /**\n   * The serenity server instance for the plugins pipeline.\n   */\n  protected readonly serenity: Serenity;\n\n  /**\n   * The properties for the plugins pipeline.\n   */\n  protected readonly properties: PipelineProperties;\n\n  /**\n   * The logger for the plugins pipeline.\n   */\n  public readonly logger = new Logger(\"Plugins\", LoggerColors.CyanBright);\n\n  /**\n   * The plugins loaded in the pipeline.\n   */\n  public readonly plugins = new Map<string, Plugin>();\n\n  /**\n   * The temporary paths used by the pipeline.\n   */\n  protected readonly tempPaths = new Set<string>();\n\n  /**\n   * Whether the pipeline is running in ESM mode.\n   */\n  public readonly esm: boolean =\n    typeof module !== \"undefined\" && module?.exports !== exports;\n\n  /**\n   * The path to the plugins directory.\n   */\n  public get path(): string {\n    return this.properties.path;\n  }\n\n  /**\n   * The path to the plugins directory.\n   */\n  public set path(_) {\n    throw new Error(\"The path property is read-only.\");\n  }\n\n  /**\n   * Creates a new instance of the Pipeline class.\n   * @param serenity The serenity server instance.\n   * @param properties The properties for the pipeline.\n   */\n  public constructor(\n    serenity: Serenity,\n    properties?: Partial<PipelineProperties>\n  ) {\n    // Set the serenity server instance\n    this.serenity = serenity;\n\n    // Merge the properties with the default properties\n    this.properties = { ...DefaultPipelineProperties, ...properties };\n\n    // Hook into the serenity server events\n    serenity.on(ServerEvent.Start, this.start.bind(this));\n    serenity.on(ServerEvent.Stop, this.stop.bind(this));\n\n    // Check if the plugins command should be registered\n    if (this.properties.commands) {\n      // Hook into the world initialize event\n      serenity.on(WorldEvent.WorldInitialize, ({ world }) =>\n        Command(world, this)\n      );\n    }\n\n    // Check if the plugins should be initialized\n    if (this.properties.initialize) this.initialize();\n  }\n\n  /**\n   * Initializes the plugins pipeline.\n   */\n  public initialize(): void {\n    // Check if the plugins directory exists\n    if (!existsSync(resolve(this.path)))\n      // If not, create the plugins directory\n      mkdirSync(resolve(this.path), { recursive: true });\n\n    // Read all the entries in the plugins directory\n    const entries = readdirSync(resolve(this.path), {\n      withFileTypes: true\n    });\n\n    // Filter out all the files that have a .plugin extension\n    const bundles = entries.filter((dirent) =>\n      dirent.isFile() ? dirent.name.endsWith(\".plugin\") : false\n    );\n\n    // Iterate over all the bundled plugins, and import them\n    for (const bundle of bundles) {\n      // Attempt to load the plugin\n      try {\n        // Get the path to the plugin\n        const path = resolve(this.path, bundle.name);\n\n        // Read the .plugin file and inflate it, and create a new binary stream\n        const buffer = inflateSync(readFileSync(path));\n        const stream = new BinaryStream(buffer);\n\n        // Read the plugin type from the stream\n        const type = stream.readByte();\n\n        // Check if the plugin type is valid\n        if (type === PluginType.Addon) {\n          // Read the module entry point from the stream\n          const index = stream.readRemainingBuffer().toString(\"utf-8\");\n\n          // Write the module or main entry points to temporary files\n          const tempPath = resolve(this.path, bundle.name.slice(0, -7));\n          writeFileSync(tempPath, index);\n\n          // Import the plugin module\n          const module = require(tempPath);\n\n          // Get the plugin class from the module\n          const plugin = module.default as Plugin;\n\n          // Check if the plugin is an instance of the Plugin class\n          if (!(plugin instanceof Plugin)) {\n            this.logger.warn(\n              `Unable to load plugin from §8${relative(process.cwd(), path)}§r, the plugin is not an instance of the Plugin class.`\n            );\n\n            // Skip the plugin\n            continue;\n          }\n\n          // Check if the plugin has already been loaded\n          if (this.plugins.has(plugin.identifier)) {\n            this.logger.warn(\n              `Unable to load plugin §1${plugin.identifier}§r, the plugin is already loaded in the pipeline.`\n            );\n\n            // Skip the plugin\n            continue;\n          }\n\n          // Set the pipeline, serenity, and path for the plugin\n          plugin.pipeline = this;\n          plugin.serenity = this.serenity;\n          plugin.path = path;\n          plugin.isBundled = true;\n\n          // Add the plugin to the plugins map\n          this.plugins.set(plugin.identifier, plugin);\n\n          // Initialize the plugin and bind the events\n          plugin.onInitialize(plugin);\n          this.bindEvents(plugin);\n\n          // Add the plugin to the plugins enum\n          PluginsEnum.options.push(plugin.identifier);\n\n          // Add the temporary path to the set\n          this.tempPaths.add(tempPath);\n        } else if (type === PluginType.Api) {\n          // Read the buffer from the stream\n          const buffer = stream.readRemainingBuffer();\n\n          // Delete the .plugin file\n          unlinkSync(path);\n\n          // Write the buffer to a temporary file\n          const tempPath = resolve(this.path, bundle.name.slice(0, -7));\n\n          // Write the buffer to the temporary file\n          writeFileSync(tempPath, buffer);\n\n          // Extract the tarball to the plugins directory\n          execSync(`tar -xzf ${tempPath} -C ${this.path}`, {\n            stdio: \"ignore\"\n          });\n\n          // Delete the temporary file\n          unlinkSync(tempPath);\n\n          // Get the plugin name from the tarball\n          const name = bundle.name.slice(0, -7);\n\n          // Rename the extracted \"package\" directory to the plugin name\n          renameSync(resolve(this.path, \"package\"), resolve(this.path, name));\n\n          // Install the dependencies for the plugin\n          execSync(\"npm install\", {\n            cwd: resolve(this.path, name),\n            stdio: \"ignore\"\n          });\n        }\n      } catch (reason) {\n        // Log the error\n        this.logger.error(\n          `Failed to load plugin from \"${relative(process.cwd(), resolve(this.path, bundle.name))}\", skipping the plugin.`,\n          reason\n        );\n      }\n    }\n\n    // Filter out all the directories from the entries\n    const directories = readdirSync(resolve(this.path), {\n      withFileTypes: true\n    }).filter((dirent) => dirent.isDirectory());\n\n    // Iterate over all the directories, checking if they are valid plugins\n    for (const directory of directories) {\n      // Attempt to load the plugin\n      try {\n        // Get the path to the plugin\n        const path = resolve(this.path, directory.name);\n\n        // Check if the plugin has a package.json file, if not, skip the plugin\n        if (!existsSync(resolve(path, \"package.json\"))) continue;\n\n        // Read the package.json file\n        const manifest = JSON.parse(\n          readFileSync(resolve(path, \"package.json\"), \"utf-8\")\n        ) as PluginPackage;\n\n        // Get the main entry point for the plugin\n        // const main = resolve(path, this.esm ? manifest.module : manifest.main);\n        const main = resolve(path, manifest.main);\n\n        // Check if the provided entry point is valid\n        if (!existsSync(resolve(path, main))) {\n          this.logger.warn(\n            `Unable to load plugin §1${manifest.name}§8@§1${manifest.version}§r, the main entry path \"§8${relative(process.cwd(), resolve(path, main))}§r\" was not found in the directory.`\n          );\n\n          // Skip the plugin\n          continue;\n        }\n\n        // Import the plugin module\n        const module = require(resolve(path, main));\n\n        // Get the plugin class from the module\n        const plugin = module.default as Plugin;\n\n        // Check if the plugin has already been loaded\n        if (this.plugins.has(plugin.identifier)) {\n          this.logger.warn(\n            `Unable to load plugin §1${plugin.identifier}§r, the plugin is already loaded in the pipeline.`\n          );\n\n          // Skip the plugin\n          continue;\n        }\n\n        // Set the pipeline, serenity, and path for the plugin\n        plugin.pipeline = this;\n        plugin.serenity = this.serenity;\n        plugin.path = path;\n        plugin.isBundled = false;\n\n        // Add the plugin to the plugins map\n        this.plugins.set(plugin.identifier, plugin);\n\n        // Add the plugin to the plugins enum\n        PluginsEnum.options.push(plugin.identifier);\n\n        // Initialize the plugin, and bind the events\n        plugin.onInitialize(plugin);\n        this.bindEvents(plugin);\n      } catch (reason) {\n        // Log the error\n        this.logger.error(\n          `Failed to load plugin from \"${relative(process.cwd(), resolve(this.path, directory.name))}\", skipping the plugin.`,\n          reason\n        );\n      }\n    }\n  }\n\n  /**\n   * Starts the plugins pipeline.\n   */\n  public start(): void {\n    // Start up all the plugins\n    for (const plugin of this.plugins.values()) plugin.onStartUp(plugin);\n  }\n\n  /**\n   * Stops the plugins pipeline.\n   */\n  public stop(): void {\n    // Shut down all the plugins\n    for (const plugin of this.plugins.values()) plugin.onShutDown(plugin);\n\n    // Delete all the temporary files\n    for (const tempPath of this.tempPaths) {\n      // Delete the temporary file\n      unlinkSync(tempPath);\n    }\n  }\n\n  public reload(plugin: Plugin): void {\n    // Shut down the plugin\n    plugin.onShutDown(plugin);\n\n    // Remove the plugin from the plugins map\n    this.plugins.delete(plugin.identifier);\n\n    // Get the plugin path\n    const path = plugin.path;\n\n    // Delete the require cache for the plugin\n    // eslint-disable-next-line @typescript-eslint/no-dynamic-delete -- Dynamic delete is required here\n    delete require.cache[require.resolve(path)];\n\n    // Remove the plugin from the serenity instance\n    this.serenity.removePath(path);\n\n    // Attempt to load the plugin\n    try {\n      // Import the plugin module\n\n      const module = require(path);\n\n      // Get the plugin class from the module\n      const rPlugin = module.default as Plugin;\n\n      // Check if the plugin is an instance of the Plugin class\n      if (!(rPlugin instanceof Plugin)) {\n        this.logger.warn(\n          `Unable to reload plugin from §8${relative(process.cwd(), path)}§r, the plugin is not an instance of the Plugin class.`\n        );\n\n        // Skip the plugin\n        return;\n      }\n\n      // Set the pipeline, serenity, and path for the plugin\n      rPlugin.pipeline = this;\n      rPlugin.serenity = this.serenity;\n      rPlugin.path = path;\n\n      // Add the plugin to the plugins map\n      this.plugins.set(rPlugin.identifier, rPlugin);\n\n      // Initialize the plugin\n      rPlugin.onInitialize(rPlugin);\n      this.bindEvents(rPlugin);\n\n      // Start up the plugin\n      rPlugin.onStartUp(rPlugin);\n\n      // Log the successful reload\n      this.logger.info(\n        `Successfully reloaded plugin §1${rPlugin.identifier}§r from §8${relative(process.cwd(), path)}§r.`\n      );\n    } catch (reason) {\n      // Log the error\n      this.logger.error(\n        `Failed to reload plugin from §8${relative(process.cwd(), path)}§r, skipping the plugin.`,\n        reason\n      );\n    }\n  }\n\n  public bundle(plugin: Plugin): void {\n    // Create a new BinaryStream instance\n    const stream = new BinaryStream();\n\n    // Write the plugin type to the stream\n    stream.writeByte(plugin.type);\n\n    if (plugin.type === PluginType.Addon) {\n      // Get the addon path\n      const inputPath = resolve(plugin.path, \"dist\");\n\n      // Read the index file\n      const index = readFileSync(resolve(inputPath, \"index.js\"));\n\n      // Write the module entry point to the stream\n      stream.writeBuffer(index);\n\n      // Write the BinaryStream to the output path\n      writeFileSync(\n        resolve(this.path, `${plugin.identifier}.plugin`),\n        deflateSync(stream.getBuffer())\n      );\n    } else if (plugin.type === PluginType.Api) {\n      // Pack the plugin\n      execSync(\"npm pack\", { cwd: plugin.path, stdio: \"ignore\" });\n\n      // Get the tarball path\n      const tarball = readdirSync(plugin.path).find((file) =>\n        file.endsWith(\".tgz\")\n      );\n\n      // Check if the tarball exists\n      if (!tarball) throw new Error(\"Packed tarball not found.\");\n\n      // Read the tarball file\n      const buffer = readFileSync(resolve(plugin.path, tarball));\n\n      // Delete the tarball file\n      unlinkSync(resolve(plugin.path, tarball));\n\n      // Write the buffer to the output path\n      stream.writeBuffer(buffer);\n\n      // Write the buffer to the output path\n      writeFileSync(\n        resolve(this.path, `${plugin.identifier}.plugin`),\n        deflateSync(stream.getBuffer())\n      );\n    }\n  }\n\n  protected bindEvents(plugin: Plugin): void {\n    // Get the prototype of the plugin\n    const prototype = Object.getPrototypeOf(plugin);\n\n    // Get the object keys from the plugin\n    const pluginKeys = Object.getOwnPropertyNames(prototype);\n\n    // Get the world event keys, and slice them in half\n    let eventKeys = Object.keys(WorldEvent);\n    eventKeys = eventKeys.slice(eventKeys.length / 2);\n\n    // Iterate over all the event keys\n    for (const eventKey of eventKeys) {\n      // Get the index of the event key\n      const index = eventKeys.indexOf(eventKey) as WorldEvent;\n\n      // Check if the plugin has any \"on\" event keys\n      if (pluginKeys.includes(\"on\" + eventKey)) {\n        // Get the value of the event key\n        const value = plugin[(\"on\" + eventKey) as keyof Plugin];\n\n        // Check if the value is a function\n        if (typeof value === \"function\")\n          // Bind the event to the plugin\n          this.serenity.on(index, value.bind(plugin) as () => void);\n      }\n\n      // Check if the plugin has any \"before\" event keys\n      if (pluginKeys.includes(\"before\" + eventKey)) {\n        // Get the value of the event key\n        const value = plugin[(\"before\" + eventKey) as keyof Plugin];\n\n        // Check if the value is a function\n        if (typeof value === \"function\")\n          // Bind the event to the plugin\n          this.serenity.before(index, value.bind(plugin) as () => boolean);\n      }\n\n      // Check if the plugin has any \"after\" event keys\n      if (pluginKeys.includes(\"after\" + eventKey)) {\n        // Get the value of the event key\n        const value = plugin[(\"after\" + eventKey) as keyof Plugin];\n\n        // Check if the value is a function\n        if (typeof value === \"function\")\n          // Bind the event to the plugin\n          this.serenity.after(index, value.bind(plugin) as () => void);\n      }\n    }\n  }\n}\n\nexport { Pipeline, DefaultPipelineProperties };\n", "import { Serenity } from \"@serenityjs/core\";\nimport { Logger, LoggerColors } from \"@serenityjs/logger\";\n\nimport { Pipeline } from \"./pipeline\";\nimport { PluginType } from \"./enums\";\nimport { PluginEvents } from \"./types\";\n\ninterface PluginProperties extends Partial<PluginEvents> {\n  logger: Logger;\n  type: PluginType;\n}\n\n/**\n * # Introduction\n * Plugins are the fundamental building blocks of SerenityJS.\n * They are used to add additional functionality to the server, which allows total control over the server.\n *\n * There are 2 types of plugins that are defined in the `PluginType` enum: `Addon` & `Api`\n *\n * Addon plugins add additional functionality to the server, without an exposed API. This means external plugins cannot directly interact with the plugins API.\n * Api plugins add additional functionality to the server, with an exposed API for other plugins to use. This means external plugins can directly interact with the plugins API.\n *\n * ## Class Extending Plugin\n * ```ts\n * import { Plugin, PluginType, PluginEvents } from \"@serenityjs/plugins\";\n *\n * class SamplePlugin extends Plugin {\n *   public readonly type = PluginType.Addon;\n *\n *   public constructor() {\n *     super(\"sample-plugin\", \"1.0.0\");\n *   }\n *\n *   public onInitialize(): void {}\n *\n *   public onStartUp(): void {}\n *\n *   public onShutDown(): void {}\n * }\n *\n * export default new SamplePlugin();\n * ```\n */\nclass Plugin implements PluginProperties {\n  /**\n   * The identifier of the plugin.\n   */\n  public readonly identifier: string;\n\n  /**\n   * The version of the plugin.\n   */\n  public readonly version: string;\n\n  /**\n   * The logger for the plugin.\n   */\n  public readonly logger: Logger;\n\n  /**\n   * The type of the plugin.\n   */\n  public readonly type: PluginType;\n\n  /**\n   * The path to the plugin.\n   * @Note This is only available after the plugin is initialized.\n   */\n  public path!: string;\n\n  /**\n   * Whether or not the plugin is bundled.\n   * @Note This is only available after the plugin is initialized.\n   */\n  public isBundled!: boolean;\n\n  /**\n   * The plugin pipeline the plugin is in.\n   * @Note This is only available after the plugin is initialized.\n   */\n  public pipeline!: Pipeline;\n\n  /**\n   * The serenity instance of the server.\n   * @Note This is only available after the plugin is initialized.\n   */\n  public serenity!: Serenity;\n\n  /**\n   * Create a new plugin instance.\n   * @param identifier The identifier of the plugin.\n   * @param version The version of the plugin.\n   * @param properties The properties of the plugin.\n   */\n  public constructor(\n    identifier: string,\n    version: string,\n    properties?: Partial<PluginProperties>\n  ) {\n    // Set the identifier and version of the plugin\n    this.identifier = identifier;\n    this.version = version;\n\n    // Set the logger for the plugin\n    this.logger =\n      properties?.logger ??\n      new Logger(`${identifier}@${version}`, LoggerColors.Blue);\n\n    // Set the type of the plugin\n    this.type = properties?.type ?? PluginType.Addon;\n\n    // Set the on initialize, start up, and shut down properties\n    if (properties?.onInitialize) this.onInitialize = properties.onInitialize;\n    if (properties?.onStartUp) this.onStartUp = properties.onStartUp;\n    if (properties?.onShutDown) this.onShutDown = properties.onShutDown;\n  }\n\n  /**\n   * Called when the plugin is initialized.\n   * @param plugin The plugin instance that was initialized. (this)\n   */\n  public onInitialize(_plugin: Plugin): void {\n    // Override this method in your plugin\n  }\n\n  /**\n   * Called when the plugin is started up.\n   * @param plugin The plugin instance that was started up. (this)\n   */\n  public onStartUp(_plugin: Plugin): void {\n    // Override this method in your plugin\n  }\n\n  /**\n   * Called when the plugin is shut down.\n   * @param plugin The plugin instance that was shut down. (this)\n   */\n  public onShutDown(_plugin: Plugin): void {\n    // Override this method in your plugin\n  }\n}\n\nexport { Plugin, PluginProperties };\n", "/**\n * The plugin type declares the use case of the plugin.\n */\nenum PluginType {\n  /**\n   * An addon plugin type adds additional functionality to the server, without an exposed API.\n   */\n  Addon,\n\n  /**\n   * An API plugin type adds additional functionality to the server, with an exposed API for other plugins to use.\n   */\n  Api\n}\n\nexport { PluginType };\n", "import { relative } from \"path\";\n\nimport { World } from \"@serenityjs/core\";\nimport { CommandPermissionLevel } from \"@serenityjs/protocol\";\n\nimport { Pipeline } from \"../pipeline\";\n\nimport { PluginActionsEnum, PluginsEnum } from \"./enum\";\n\nconst register = (world: World, pipeline: Pipeline) => {\n  world.commands.register(\n    \"plugins\",\n    \"Interact with the plugins of the server\",\n    (registry) => {\n      // Set the command to be an operator command\n      registry.permissionLevel = CommandPermissionLevel.Operator;\n\n      // Overload for listing the plugins\n      registry.overload(\n        {\n          action: PluginActionsEnum\n        },\n        ({ action }) => {\n          // Check if the action is list\n          if (action.result !== \"list\") return;\n\n          // Check if the pipeline has no plugins\n          if (pipeline.plugins.size === 0)\n            return {\n              message: \"§cThere are current no plugins loaded on the server.\"\n            };\n\n          // Get the plugins from the pipeline\n          const plugins = [...pipeline.plugins.values()];\n\n          // Prepare the message\n          const message = [];\n\n          // Loop through the plugins\n          for (const plugin of plugins) {\n            // Push the plugin name to the message\n            message.push(`§u${plugin.identifier} v${plugin.version}§r`);\n          }\n\n          // Send the message to the origin\n          return {\n            message: `§7Active Plugins (${plugins.length}):§r ${message.join(\"§7,§r \")}`\n          };\n        }\n      );\n\n      registry.overload(\n        {\n          action: PluginActionsEnum,\n          plugin: PluginsEnum\n        },\n        ({ action, plugin }) => {\n          // Check if the action is reload\n          if (action.result !== \"reload\" && action.result !== \"bundle\") return;\n\n          // Get the plugin from the pipeline\n          const pluginInstance = pipeline.plugins.get(plugin.result as string);\n\n          // Check if the plugin is not found\n          if (!pluginInstance)\n            throw new Error(`Plugin ${plugin.result} is not found.`);\n\n          // Check if the action is reload\n          if (action.result === \"reload\") {\n            // Reload the plugin\n            pipeline.reload(pluginInstance);\n\n            // Send the message to the origin\n            return {\n              message: `§aSuccessfully reloaded §2${pluginInstance.identifier}§a.`\n            };\n          } else {\n            if (pluginInstance.isBundled)\n              // Check if the plugin is already bundled\n              throw new Error(\n                `Plugin ${pluginInstance.identifier} cannot be bundled, as it is already a bundled plugin.`\n              );\n\n            // Bundle the plugin\n            pipeline.bundle(pluginInstance);\n\n            // Send the message to the origin\n            return {\n              message: `§aSuccessfully bundled §2${pluginInstance.identifier}§a, output file was placed at §7${relative(process.cwd(), pipeline.path)}§a.`\n            };\n          }\n        }\n      );\n    },\n    () => {\n      throw new Error(\"No overload matched the provided arguments.\");\n    }\n  );\n};\n\nexport default register;\n", "import { CustomEnum } from \"@serenityjs/core\";\n\nclass PluginsEnum extends CustomEnum {\n  public static readonly identifier = \"plugins\";\n  public static readonly options: Array<string> = [];\n}\n\nclass PluginActionsEnum extends CustomEnum {\n  public static readonly identifier = \"plugin_actions\";\n  public static readonly options: Array<string> = [\"list\", \"reload\", \"bundle\"];\n}\n\nexport { PluginsEnum, PluginActionsEnum };\n"],
  "mappings": "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",
  "names": ["src_exports", "__export", "DefaultPipelineProperties", "Pipeline", "Plugin", "PluginType", "__toCommonJS", "import_node_fs", "import_node_path", "import_node_zlib", "import_node_child_process", "import_logger", "import_core", "import_binarystream", "import_logger", "PluginType", "Plugin", "identifier", "version", "logger", "type", "path", "isBundled", "pipeline", "serenity", "properties", "Logger", "LoggerColors", "Blue", "PluginType", "Addon", "onInitialize", "onStartUp", "onShutDown", "_plugin", "import_path", "import_protocol", "import_core", "PluginsEnum", "CustomEnum", "identifier", "options", "PluginActionsEnum", "register", "__name", "world", "pipeline", "commands", "registry", "permissionLevel", "CommandPermissionLevel", "Operator", "overload", "action", "PluginActionsEnum", "result", "plugins", "size", "message", "values", "plugin", "push", "identifier", "version", "length", "join", "PluginsEnum", "pluginInstance", "get", "Error", "reload", "isBundled", "bundle", "relative", "process", "cwd", "path", "command_default", "DefaultPipelineProperties", "path", "commands", "initialize", "Pipeline", "serenity", "properties", "logger", "Logger", "LoggerColors", "CyanBright", "plugins", "Map", "tempPaths", "Set", "esm", "module", "exports", "_", "Error", "on", "ServerEvent", "Start", "start", "bind", "Stop", "stop", "WorldEvent", "WorldInitialize", "world", "Command", "existsSync", "resolve", "mkdirSync", "recursive", "bundles", "readdirSync", "withFileTypes", "filter", "dirent", "isFile", "name", "endsWith", "bundle", "buffer", "inflateSync", "readFileSync", "stream", "BinaryStream", "type", "readByte", "PluginType", "Addon", "index", "readRemainingBuffer", "toString", "tempPath", "slice", "writeFileSync", "plugin", "require", "default", "Plugin", "warn", "relative", "process", "cwd", "has", "identifier", "pipeline", "isBundled", "set", "onInitialize", "bindEvents", "PluginsEnum", "options", "push", "add", "Api", "unlinkSync", "execSync", "stdio", "renameSync", "reason", "error", "directories", "isDirectory", "directory", "manifest", "JSON", "parse", "main", "version", "values", "onStartUp", "onShutDown", "reload", "delete", "cache", "removePath", "rPlugin", "info", "writeByte", "inputPath", "writeBuffer", "deflateSync", "getBuffer", "tarball", "find", "file", "prototype", "Object", "getPrototypeOf", "pluginKeys", "getOwnPropertyNames", "eventKeys", "keys", "length", "eventKey", "indexOf", "includes", "value", "before", "after"]
}

|
package/dist/index.mjs
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
var F=Object.defineProperty;var d=(s,e)=>F(s,"name",{value:e,configurable:!0}),m=(s=>typeof require<"u"?require:typeof Proxy<"u"?new Proxy(s,{get:(e,o)=>(typeof require<"u"?require:e)[o]}):s)(function(s){if(typeof require<"u")return require.apply(this,arguments);throw Error('Dynamic require of "'+s+'" is not supported')});import{existsSync as $,mkdirSync as _,readdirSync as E,readFileSync as y,renameSync as W,unlinkSync as w,writeFileSync as b}from"node:fs";import{relative as c,resolve as r}from"node:path";import{deflateSync as k,inflateSync as K}from"node:zlib";import{execSync as z}from"node:child_process";import{Logger as N,LoggerColors as T}from"@serenityjs/logger";import{ServerEvent as U,WorldEvent as I}from"@serenityjs/core";import{BinaryStream as D}from"@serenityjs/binarystream";import{Logger as O,LoggerColors as j}from"@serenityjs/logger";var f=function(s){return s[s.Addon=0]="Addon",s[s.Api=1]="Api",s}(f||{});var P=class{static{d(this,"Plugin")}identifier;version;logger;type;path;isBundled;pipeline;serenity;constructor(e,o,n){this.identifier=e,this.version=o,this.logger=n?.logger??new O(`${e}@${o}`,j.Blue),this.type=n?.type??f.Addon,n?.onInitialize&&(this.onInitialize=n.onInitialize),n?.onStartUp&&(this.onStartUp=n.onStartUp),n?.onShutDown&&(this.onShutDown=n.onShutDown)}onInitialize(e){}onStartUp(e){}onShutDown(e){}};import{relative as C}from"path";import{CommandPermissionLevel as L}from"@serenityjs/protocol";import{CustomEnum as B}from"@serenityjs/core";var g=class extends B{static{d(this,"PluginsEnum")}static identifier="plugins";static options=[]},S=class extends B{static{d(this,"PluginActionsEnum")}static identifier="plugin_actions";static options=["list","reload","bundle"]};var q=d((s,e)=>{s.commands.register("plugins","Interact with the plugins of the server",o=>{o.permissionLevel=L.Operator,o.overload({action:S},({action:n})=>{if(n.result!=="list")return;if(e.plugins.size===0)return{message:"\xA7cThere are current no plugins loaded on the server."};let t=[...e.plugins.values()],i=[];for(let u of t)i.push(`\xA7u${u.identifier} v${u.version}\xA7r`);return{message:`\xA77Active Plugins (${t.length}):\xA7r ${i.join("\xA77,\xA7r ")}`}}),o.overload({action:S,plugin:g},({action:n,plugin:t})=>{if(n.result!=="reload"&&n.result!=="bundle")return;let i=e.plugins.get(t.result);if(!i)throw new Error(`Plugin ${t.result} is not found.`);if(n.result==="reload")return e.reload(i),{message:`\xA7aSuccessfully reloaded \xA72${i.identifier}\xA7a.`};if(i.isBundled)throw new Error(`Plugin ${i.identifier} cannot be bundled, as it is already a bundled plugin.`);return e.bundle(i),{message:`\xA7aSuccessfully bundled \xA72${i.identifier}\xA7a, output file was placed at \xA77${C(process.cwd(),e.path)}\xA7a.`}})},()=>{throw new Error("No overload matched the provided arguments.")})},"register"),A=q;var R={path:"./plugins",commands:!0,initialize:!0},Se=class{static{d(this,"Pipeline")}serenity;properties;logger=new N("Plugins",T.CyanBright);plugins=new Map;tempPaths=new Set;esm=typeof module<"u"&&module?.exports!==exports;get path(){return this.properties.path}set path(e){throw new Error("The path property is read-only.")}constructor(e,o){this.serenity=e,this.properties={...R,...o},e.on(U.Start,this.start.bind(this)),e.on(U.Stop,this.stop.bind(this)),this.properties.commands&&e.on(I.WorldInitialize,({world:n})=>A(n,this)),this.properties.initialize&&this.initialize()}initialize(){$(r(this.path))||_(r(this.path),{recursive:!0});let o=E(r(this.path),{withFileTypes:!0}).filter(t=>t.isFile()?t.name.endsWith(".plugin"):!1);for(let t of o)try{let i=r(this.path,t.name),u=K(y(i)),a=new D(u),v=a.readByte();if(v===f.Addon){let l=a.readRemainingBuffer().toString("utf-8"),h=r(this.path,t.name.slice(0,-7));b(h,l);let p=m(h).default;if(!(p instanceof P)){this.logger.warn(`Unable to load plugin from \xA78${c(process.cwd(),i)}\xA7r, the plugin is not an instance of the Plugin class.`);continue}if(this.plugins.has(p.identifier)){this.logger.warn(`Unable to load plugin \xA71${p.identifier}\xA7r, the plugin is already loaded in the pipeline.`);continue}p.pipeline=this,p.serenity=this.serenity,p.path=i,p.isBundled=!0,this.plugins.set(p.identifier,p),p.onInitialize(p),this.bindEvents(p),g.options.push(p.identifier),this.tempPaths.add(h)}else if(v===f.Api){let l=a.readRemainingBuffer();w(i);let h=r(this.path,t.name.slice(0,-7));b(h,l),z(`tar -xzf ${h} -C ${this.path}`,{stdio:"ignore"}),w(h);let x=t.name.slice(0,-7);W(r(this.path,"package"),r(this.path,x)),z("npm install",{cwd:r(this.path,x),stdio:"ignore"})}}catch(i){this.logger.error(`Failed to load plugin from "${c(process.cwd(),r(this.path,t.name))}", skipping the plugin.`,i)}let n=E(r(this.path),{withFileTypes:!0}).filter(t=>t.isDirectory());for(let t of n)try{let i=r(this.path,t.name);if(!$(r(i,"package.json")))continue;let u=JSON.parse(y(r(i,"package.json"),"utf-8")),a=r(i,u.main);if(!$(r(i,a))){this.logger.warn(`Unable to load plugin \xA71${u.name}\xA78@\xA71${u.version}\xA7r, the main entry path "\xA78${c(process.cwd(),r(i,a))}\xA7r" was not found in the directory.`);continue}let l=m(r(i,a)).default;if(this.plugins.has(l.identifier)){this.logger.warn(`Unable to load plugin \xA71${l.identifier}\xA7r, the plugin is already loaded in the pipeline.`);continue}l.pipeline=this,l.serenity=this.serenity,l.path=i,l.isBundled=!1,this.plugins.set(l.identifier,l),g.options.push(l.identifier),l.onInitialize(l),this.bindEvents(l)}catch(i){this.logger.error(`Failed to load plugin from "${c(process.cwd(),r(this.path,t.name))}", skipping the plugin.`,i)}}start(){for(let e of this.plugins.values())e.onStartUp(e)}stop(){for(let e of this.plugins.values())e.onShutDown(e);for(let e of this.tempPaths)w(e)}reload(e){e.onShutDown(e),this.plugins.delete(e.identifier);let o=e.path;delete m.cache[m.resolve(o)],this.serenity.removePath(o);try{let t=m(o).default;if(!(t instanceof P)){this.logger.warn(`Unable to reload plugin from \xA78${c(process.cwd(),o)}\xA7r, the plugin is not an instance of the Plugin class.`);return}t.pipeline=this,t.serenity=this.serenity,t.path=o,this.plugins.set(t.identifier,t),t.onInitialize(t),this.bindEvents(t),t.onStartUp(t),this.logger.info(`Successfully reloaded plugin \xA71${t.identifier}\xA7r from \xA78${c(process.cwd(),o)}\xA7r.`)}catch(n){this.logger.error(`Failed to reload plugin from \xA78${c(process.cwd(),o)}\xA7r, skipping the plugin.`,n)}}bundle(e){let o=new D;if(o.writeByte(e.type),e.type===f.Addon){let n=r(e.path,"dist"),t=y(r(n,"index.js"));o.writeBuffer(t),b(r(this.path,`${e.identifier}.plugin`),k(o.getBuffer()))}else if(e.type===f.Api){z("npm pack",{cwd:e.path,stdio:"ignore"});let n=E(e.path).find(i=>i.endsWith(".tgz"));if(!n)throw new Error("Packed tarball not found.");let t=y(r(e.path,n));w(r(e.path,n)),o.writeBuffer(t),b(r(this.path,`${e.identifier}.plugin`),k(o.getBuffer()))}}bindEvents(e){let o=Object.getPrototypeOf(e),n=Object.getOwnPropertyNames(o),t=Object.keys(I);t=t.slice(t.length/2);for(let i of t){let u=t.indexOf(i);if(n.includes("on"+i)){let a=e["on"+i];typeof a=="function"&&this.serenity.on(u,a.bind(e))}if(n.includes("before"+i)){let a=e["before"+i];typeof a=="function"&&this.serenity.before(u,a.bind(e))}if(n.includes("after"+i)){let a=e["after"+i];typeof a=="function"&&this.serenity.after(u,a.bind(e))}}}};export{R as DefaultPipelineProperties,Se as Pipeline,P as Plugin,f as PluginType};
|
|
2
|
-
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../src/pipeline.ts", "../src/plugin.ts", "../src/enums/type.ts", "../src/commands/command.ts", "../src/commands/enum.ts"],
  "sourcesContent": ["/* eslint-disable @typescript-eslint/no-require-imports */\nimport {\n  existsSync,\n  mkdirSync,\n  readdirSync,\n  readFileSync,\n  renameSync,\n  unlinkSync,\n  writeFileSync\n} from \"node:fs\";\nimport { relative, resolve } from \"node:path\";\nimport { deflateSync, inflateSync } from \"node:zlib\";\nimport { execSync } from \"node:child_process\";\n\nimport { Logger, LoggerColors } from \"@serenityjs/logger\";\nimport { Serenity, ServerEvent, WorldEvent } from \"@serenityjs/core\";\nimport { BinaryStream } from \"@serenityjs/binarystream\";\n\nimport { PluginPackage } from \"./types\";\nimport { Plugin } from \"./plugin\";\nimport Command from \"./commands/command\";\nimport { PluginsEnum } from \"./commands\";\nimport { PluginType } from \"./enums\";\n\ninterface PipelineProperties {\n  path: string;\n  commands: boolean;\n  initialize: boolean;\n}\n\nconst DefaultPipelineProperties: PipelineProperties = {\n  path: \"./plugins\",\n  commands: true,\n  initialize: true\n};\n\nclass Pipeline {\n  /**\n   * The serenity server instance for the plugins pipeline.\n   */\n  protected readonly serenity: Serenity;\n\n  /**\n   * The properties for the plugins pipeline.\n   */\n  protected readonly properties: PipelineProperties;\n\n  /**\n   * The logger for the plugins pipeline.\n   */\n  public readonly logger = new Logger(\"Plugins\", LoggerColors.CyanBright);\n\n  /**\n   * The plugins loaded in the pipeline.\n   */\n  public readonly plugins = new Map<string, Plugin>();\n\n  /**\n   * The temporary paths used by the pipeline.\n   */\n  protected readonly tempPaths = new Set<string>();\n\n  /**\n   * Whether the pipeline is running in ESM mode.\n   */\n  public readonly esm: boolean =\n    typeof module !== \"undefined\" && module?.exports !== exports;\n\n  /**\n   * The path to the plugins directory.\n   */\n  public get path(): string {\n    return this.properties.path;\n  }\n\n  /**\n   * The path to the plugins directory.\n   */\n  public set path(_) {\n    throw new Error(\"The path property is read-only.\");\n  }\n\n  /**\n   * Creates a new instance of the Pipeline class.\n   * @param serenity The serenity server instance.\n   * @param properties The properties for the pipeline.\n   */\n  public constructor(\n    serenity: Serenity,\n    properties?: Partial<PipelineProperties>\n  ) {\n    // Set the serenity server instance\n    this.serenity = serenity;\n\n    // Merge the properties with the default properties\n    this.properties = { ...DefaultPipelineProperties, ...properties };\n\n    // Hook into the serenity server events\n    serenity.on(ServerEvent.Start, this.start.bind(this));\n    serenity.on(ServerEvent.Stop, this.stop.bind(this));\n\n    // Check if the plugins command should be registered\n    if (this.properties.commands) {\n      // Hook into the world initialize event\n      serenity.on(WorldEvent.WorldInitialize, ({ world }) =>\n        Command(world, this)\n      );\n    }\n\n    // Check if the plugins should be initialized\n    if (this.properties.initialize) this.initialize();\n  }\n\n  /**\n   * Initializes the plugins pipeline.\n   */\n  public initialize(): void {\n    // Check if the plugins directory exists\n    if (!existsSync(resolve(this.path)))\n      // If not, create the plugins directory\n      mkdirSync(resolve(this.path), { recursive: true });\n\n    // Read all the entries in the plugins directory\n    const entries = readdirSync(resolve(this.path), {\n      withFileTypes: true\n    });\n\n    // Filter out all the files that have a .plugin extension\n    const bundles = entries.filter((dirent) =>\n      dirent.isFile() ? dirent.name.endsWith(\".plugin\") : false\n    );\n\n    // Iterate over all the bundled plugins, and import them\n    for (const bundle of bundles) {\n      // Attempt to load the plugin\n      try {\n        // Get the path to the plugin\n        const path = resolve(this.path, bundle.name);\n\n        // Read the .plugin file and inflate it, and create a new binary stream\n        const buffer = inflateSync(readFileSync(path));\n        const stream = new BinaryStream(buffer);\n\n        // Read the plugin type from the stream\n        const type = stream.readByte();\n\n        // Check if the plugin type is valid\n        if (type === PluginType.Addon) {\n          // Read the module entry point from the stream\n          const index = stream.readRemainingBuffer().toString(\"utf-8\");\n\n          // Write the module or main entry points to temporary files\n          const tempPath = resolve(this.path, bundle.name.slice(0, -7));\n          writeFileSync(tempPath, index);\n\n          // Import the plugin module\n          const module = require(tempPath);\n\n          // Get the plugin class from the module\n          const plugin = module.default as Plugin;\n\n          // Check if the plugin is an instance of the Plugin class\n          if (!(plugin instanceof Plugin)) {\n            this.logger.warn(\n              `Unable to load plugin from §8${relative(process.cwd(), path)}§r, the plugin is not an instance of the Plugin class.`\n            );\n\n            // Skip the plugin\n            continue;\n          }\n\n          // Check if the plugin has already been loaded\n          if (this.plugins.has(plugin.identifier)) {\n            this.logger.warn(\n              `Unable to load plugin §1${plugin.identifier}§r, the plugin is already loaded in the pipeline.`\n            );\n\n            // Skip the plugin\n            continue;\n          }\n\n          // Set the pipeline, serenity, and path for the plugin\n          plugin.pipeline = this;\n          plugin.serenity = this.serenity;\n          plugin.path = path;\n          plugin.isBundled = true;\n\n          // Add the plugin to the plugins map\n          this.plugins.set(plugin.identifier, plugin);\n\n          // Initialize the plugin and bind the events\n          plugin.onInitialize(plugin);\n          this.bindEvents(plugin);\n\n          // Add the plugin to the plugins enum\n          PluginsEnum.options.push(plugin.identifier);\n\n          // Add the temporary path to the set\n          this.tempPaths.add(tempPath);\n        } else if (type === PluginType.Api) {\n          // Read the buffer from the stream\n          const buffer = stream.readRemainingBuffer();\n\n          // Delete the .plugin file\n          unlinkSync(path);\n\n          // Write the buffer to a temporary file\n          const tempPath = resolve(this.path, bundle.name.slice(0, -7));\n\n          // Write the buffer to the temporary file\n          writeFileSync(tempPath, buffer);\n\n          // Extract the tarball to the plugins directory\n          execSync(`tar -xzf ${tempPath} -C ${this.path}`, {\n            stdio: \"ignore\"\n          });\n\n          // Delete the temporary file\n          unlinkSync(tempPath);\n\n          // Get the plugin name from the tarball\n          const name = bundle.name.slice(0, -7);\n\n          // Rename the extracted \"package\" directory to the plugin name\n          renameSync(resolve(this.path, \"package\"), resolve(this.path, name));\n\n          // Install the dependencies for the plugin\n          execSync(\"npm install\", {\n            cwd: resolve(this.path, name),\n            stdio: \"ignore\"\n          });\n        }\n      } catch (reason) {\n        // Log the error\n        this.logger.error(\n          `Failed to load plugin from \"${relative(process.cwd(), resolve(this.path, bundle.name))}\", skipping the plugin.`,\n          reason\n        );\n      }\n    }\n\n    // Filter out all the directories from the entries\n    const directories = readdirSync(resolve(this.path), {\n      withFileTypes: true\n    }).filter((dirent) => dirent.isDirectory());\n\n    // Iterate over all the directories, checking if they are valid plugins\n    for (const directory of directories) {\n      // Attempt to load the plugin\n      try {\n        // Get the path to the plugin\n        const path = resolve(this.path, directory.name);\n\n        // Check if the plugin has a package.json file, if not, skip the plugin\n        if (!existsSync(resolve(path, \"package.json\"))) continue;\n\n        // Read the package.json file\n        const manifest = JSON.parse(\n          readFileSync(resolve(path, \"package.json\"), \"utf-8\")\n        ) as PluginPackage;\n\n        // Get the main entry point for the plugin\n        // const main = resolve(path, this.esm ? manifest.module : manifest.main);\n        const main = resolve(path, manifest.main);\n\n        // Check if the provided entry point is valid\n        if (!existsSync(resolve(path, main))) {\n          this.logger.warn(\n            `Unable to load plugin §1${manifest.name}§8@§1${manifest.version}§r, the main entry path \"§8${relative(process.cwd(), resolve(path, main))}§r\" was not found in the directory.`\n          );\n\n          // Skip the plugin\n          continue;\n        }\n\n        // Import the plugin module\n        const module = require(resolve(path, main));\n\n        // Get the plugin class from the module\n        const plugin = module.default as Plugin;\n\n        // Check if the plugin has already been loaded\n        if (this.plugins.has(plugin.identifier)) {\n          this.logger.warn(\n            `Unable to load plugin §1${plugin.identifier}§r, the plugin is already loaded in the pipeline.`\n          );\n\n          // Skip the plugin\n          continue;\n        }\n\n        // Set the pipeline, serenity, and path for the plugin\n        plugin.pipeline = this;\n        plugin.serenity = this.serenity;\n        plugin.path = path;\n        plugin.isBundled = false;\n\n        // Add the plugin to the plugins map\n        this.plugins.set(plugin.identifier, plugin);\n\n        // Add the plugin to the plugins enum\n        PluginsEnum.options.push(plugin.identifier);\n\n        // Initialize the plugin, and bind the events\n        plugin.onInitialize(plugin);\n        this.bindEvents(plugin);\n      } catch (reason) {\n        // Log the error\n        this.logger.error(\n          `Failed to load plugin from \"${relative(process.cwd(), resolve(this.path, directory.name))}\", skipping the plugin.`,\n          reason\n        );\n      }\n    }\n  }\n\n  /**\n   * Starts the plugins pipeline.\n   */\n  public start(): void {\n    // Start up all the plugins\n    for (const plugin of this.plugins.values()) plugin.onStartUp(plugin);\n  }\n\n  /**\n   * Stops the plugins pipeline.\n   */\n  public stop(): void {\n    // Shut down all the plugins\n    for (const plugin of this.plugins.values()) plugin.onShutDown(plugin);\n\n    // Delete all the temporary files\n    for (const tempPath of this.tempPaths) {\n      // Delete the temporary file\n      unlinkSync(tempPath);\n    }\n  }\n\n  public reload(plugin: Plugin): void {\n    // Shut down the plugin\n    plugin.onShutDown(plugin);\n\n    // Remove the plugin from the plugins map\n    this.plugins.delete(plugin.identifier);\n\n    // Get the plugin path\n    const path = plugin.path;\n\n    // Delete the require cache for the plugin\n    // eslint-disable-next-line @typescript-eslint/no-dynamic-delete -- Dynamic delete is required here\n    delete require.cache[require.resolve(path)];\n\n    // Remove the plugin from the serenity instance\n    this.serenity.removePath(path);\n\n    // Attempt to load the plugin\n    try {\n      // Import the plugin module\n\n      const module = require(path);\n\n      // Get the plugin class from the module\n      const rPlugin = module.default as Plugin;\n\n      // Check if the plugin is an instance of the Plugin class\n      if (!(rPlugin instanceof Plugin)) {\n        this.logger.warn(\n          `Unable to reload plugin from §8${relative(process.cwd(), path)}§r, the plugin is not an instance of the Plugin class.`\n        );\n\n        // Skip the plugin\n        return;\n      }\n\n      // Set the pipeline, serenity, and path for the plugin\n      rPlugin.pipeline = this;\n      rPlugin.serenity = this.serenity;\n      rPlugin.path = path;\n\n      // Add the plugin to the plugins map\n      this.plugins.set(rPlugin.identifier, rPlugin);\n\n      // Initialize the plugin\n      rPlugin.onInitialize(rPlugin);\n      this.bindEvents(rPlugin);\n\n      // Start up the plugin\n      rPlugin.onStartUp(rPlugin);\n\n      // Log the successful reload\n      this.logger.info(\n        `Successfully reloaded plugin §1${rPlugin.identifier}§r from §8${relative(process.cwd(), path)}§r.`\n      );\n    } catch (reason) {\n      // Log the error\n      this.logger.error(\n        `Failed to reload plugin from §8${relative(process.cwd(), path)}§r, skipping the plugin.`,\n        reason\n      );\n    }\n  }\n\n  public bundle(plugin: Plugin): void {\n    // Create a new BinaryStream instance\n    const stream = new BinaryStream();\n\n    // Write the plugin type to the stream\n    stream.writeByte(plugin.type);\n\n    if (plugin.type === PluginType.Addon) {\n      // Get the addon path\n      const inputPath = resolve(plugin.path, \"dist\");\n\n      // Read the index file\n      const index = readFileSync(resolve(inputPath, \"index.js\"));\n\n      // Write the module entry point to the stream\n      stream.writeBuffer(index);\n\n      // Write the BinaryStream to the output path\n      writeFileSync(\n        resolve(this.path, `${plugin.identifier}.plugin`),\n        deflateSync(stream.getBuffer())\n      );\n    } else if (plugin.type === PluginType.Api) {\n      // Pack the plugin\n      execSync(\"npm pack\", { cwd: plugin.path, stdio: \"ignore\" });\n\n      // Get the tarball path\n      const tarball = readdirSync(plugin.path).find((file) =>\n        file.endsWith(\".tgz\")\n      );\n\n      // Check if the tarball exists\n      if (!tarball) throw new Error(\"Packed tarball not found.\");\n\n      // Read the tarball file\n      const buffer = readFileSync(resolve(plugin.path, tarball));\n\n      // Delete the tarball file\n      unlinkSync(resolve(plugin.path, tarball));\n\n      // Write the buffer to the output path\n      stream.writeBuffer(buffer);\n\n      // Write the buffer to the output path\n      writeFileSync(\n        resolve(this.path, `${plugin.identifier}.plugin`),\n        deflateSync(stream.getBuffer())\n      );\n    }\n  }\n\n  protected bindEvents(plugin: Plugin): void {\n    // Get the prototype of the plugin\n    const prototype = Object.getPrototypeOf(plugin);\n\n    // Get the object keys from the plugin\n    const pluginKeys = Object.getOwnPropertyNames(prototype);\n\n    // Get the world event keys, and slice them in half\n    let eventKeys = Object.keys(WorldEvent);\n    eventKeys = eventKeys.slice(eventKeys.length / 2);\n\n    // Iterate over all the event keys\n    for (const eventKey of eventKeys) {\n      // Get the index of the event key\n      const index = eventKeys.indexOf(eventKey) as WorldEvent;\n\n      // Check if the plugin has any \"on\" event keys\n      if (pluginKeys.includes(\"on\" + eventKey)) {\n        // Get the value of the event key\n        const value = plugin[(\"on\" + eventKey) as keyof Plugin];\n\n        // Check if the value is a function\n        if (typeof value === \"function\")\n          // Bind the event to the plugin\n          this.serenity.on(index, value.bind(plugin) as () => void);\n      }\n\n      // Check if the plugin has any \"before\" event keys\n      if (pluginKeys.includes(\"before\" + eventKey)) {\n        // Get the value of the event key\n        const value = plugin[(\"before\" + eventKey) as keyof Plugin];\n\n        // Check if the value is a function\n        if (typeof value === \"function\")\n          // Bind the event to the plugin\n          this.serenity.before(index, value.bind(plugin) as () => boolean);\n      }\n\n      // Check if the plugin has any \"after\" event keys\n      if (pluginKeys.includes(\"after\" + eventKey)) {\n        // Get the value of the event key\n        const value = plugin[(\"after\" + eventKey) as keyof Plugin];\n\n        // Check if the value is a function\n        if (typeof value === \"function\")\n          // Bind the event to the plugin\n          this.serenity.after(index, value.bind(plugin) as () => void);\n      }\n    }\n  }\n}\n\nexport { Pipeline, DefaultPipelineProperties };\n", "import { Serenity } from \"@serenityjs/core\";\nimport { Logger, LoggerColors } from \"@serenityjs/logger\";\n\nimport { Pipeline } from \"./pipeline\";\nimport { PluginType } from \"./enums\";\nimport { PluginEvents } from \"./types\";\n\ninterface PluginProperties extends Partial<PluginEvents> {\n  logger: Logger;\n  type: PluginType;\n}\n\nclass Plugin implements PluginProperties {\n  /**\n   * The identifier of the plugin.\n   */\n  public readonly identifier: string;\n\n  /**\n   * The version of the plugin.\n   */\n  public readonly version: string;\n\n  /**\n   * The logger for the plugin.\n   */\n  public readonly logger: Logger;\n\n  /**\n   * The type of the plugin.\n   */\n  public readonly type: PluginType;\n\n  /**\n   * The path to the plugin.\n   * @Note This is only available after the plugin is initialized.\n   */\n  public path!: string;\n\n  /**\n   * Whether or not the plugin is bundled.\n   * @Note This is only available after the plugin is initialized.\n   */\n  public isBundled!: boolean;\n\n  /**\n   * The plugin pipeline the plugin is in.\n   * @Note This is only available after the plugin is initialized.\n   */\n  public pipeline!: Pipeline;\n\n  /**\n   * The serenity instance of the server.\n   * @Note This is only available after the plugin is initialized.\n   */\n  public serenity!: Serenity;\n\n  /**\n   * Create a new plugin instance.\n   * @param identifier The identifier of the plugin.\n   * @param version The version of the plugin.\n   * @param properties The properties of the plugin.\n   */\n  public constructor(\n    identifier: string,\n    version: string,\n    properties?: Partial<PluginProperties>\n  ) {\n    // Set the identifier and version of the plugin\n    this.identifier = identifier;\n    this.version = version;\n\n    // Set the logger for the plugin\n    this.logger =\n      properties?.logger ??\n      new Logger(`${identifier}@${version}`, LoggerColors.Blue);\n\n    // Set the type of the plugin\n    this.type = properties?.type ?? PluginType.Addon;\n\n    // Set the on initialize, start up, and shut down properties\n    if (properties?.onInitialize) this.onInitialize = properties.onInitialize;\n    if (properties?.onStartUp) this.onStartUp = properties.onStartUp;\n    if (properties?.onShutDown) this.onShutDown = properties.onShutDown;\n  }\n\n  /**\n   * Called when the plugin is initialized.\n   * @param plugin The plugin instance that was initialized. (this)\n   */\n  public onInitialize(_plugin: Plugin): void {\n    // Override this method in your plugin\n  }\n\n  /**\n   * Called when the plugin is started up.\n   * @param plugin The plugin instance that was started up. (this)\n   */\n  public onStartUp(_plugin: Plugin): void {\n    // Override this method in your plugin\n  }\n\n  /**\n   * Called when the plugin is shut down.\n   * @param plugin The plugin instance that was shut down. (this)\n   */\n  public onShutDown(_plugin: Plugin): void {\n    // Override this method in your plugin\n  }\n}\n\nexport { Plugin, PluginProperties };\n", "/**\n * The plugin type declares the use case of the plugin.\n */\nenum PluginType {\n  /**\n   * An addon plugin type adds additional functionality to the server, without an exposed API.\n   */\n  Addon,\n\n  /**\n   * An API plugin type adds additional functionality to the server, with an exposed API for other plugins to use.\n   */\n  Api\n}\n\nexport { PluginType };\n", "import { relative } from \"path\";\n\nimport { World } from \"@serenityjs/core\";\nimport { CommandPermissionLevel } from \"@serenityjs/protocol\";\n\nimport { Pipeline } from \"../pipeline\";\n\nimport { PluginActionsEnum, PluginsEnum } from \"./enum\";\n\nconst register = (world: World, pipeline: Pipeline) => {\n  world.commands.register(\n    \"plugins\",\n    \"Interact with the plugins of the server\",\n    (registry) => {\n      // Set the command to be an operator command\n      registry.permissionLevel = CommandPermissionLevel.Operator;\n\n      // Overload for listing the plugins\n      registry.overload(\n        {\n          action: PluginActionsEnum\n        },\n        ({ action }) => {\n          // Check if the action is list\n          if (action.result !== \"list\") return;\n\n          // Check if the pipeline has no plugins\n          if (pipeline.plugins.size === 0)\n            return {\n              message: \"§cThere are current no plugins loaded on the server.\"\n            };\n\n          // Get the plugins from the pipeline\n          const plugins = [...pipeline.plugins.values()];\n\n          // Prepare the message\n          const message = [];\n\n          // Loop through the plugins\n          for (const plugin of plugins) {\n            // Push the plugin name to the message\n            message.push(`§u${plugin.identifier} v${plugin.version}§r`);\n          }\n\n          // Send the message to the origin\n          return {\n            message: `§7Active Plugins (${plugins.length}):§r ${message.join(\"§7,§r \")}`\n          };\n        }\n      );\n\n      registry.overload(\n        {\n          action: PluginActionsEnum,\n          plugin: PluginsEnum\n        },\n        ({ action, plugin }) => {\n          // Check if the action is reload\n          if (action.result !== \"reload\" && action.result !== \"bundle\") return;\n\n          // Get the plugin from the pipeline\n          const pluginInstance = pipeline.plugins.get(plugin.result as string);\n\n          // Check if the plugin is not found\n          if (!pluginInstance)\n            throw new Error(`Plugin ${plugin.result} is not found.`);\n\n          // Check if the action is reload\n          if (action.result === \"reload\") {\n            // Reload the plugin\n            pipeline.reload(pluginInstance);\n\n            // Send the message to the origin\n            return {\n              message: `§aSuccessfully reloaded §2${pluginInstance.identifier}§a.`\n            };\n          } else {\n            if (pluginInstance.isBundled)\n              // Check if the plugin is already bundled\n              throw new Error(\n                `Plugin ${pluginInstance.identifier} cannot be bundled, as it is already a bundled plugin.`\n              );\n\n            // Bundle the plugin\n            pipeline.bundle(pluginInstance);\n\n            // Send the message to the origin\n            return {\n              message: `§aSuccessfully bundled §2${pluginInstance.identifier}§a, output file was placed at §7${relative(process.cwd(), pipeline.path)}§a.`\n            };\n          }\n        }\n      );\n    },\n    () => {\n      throw new Error(\"No overload matched the provided arguments.\");\n    }\n  );\n};\n\nexport default register;\n", "import { CustomEnum } from \"@serenityjs/core\";\n\nclass PluginsEnum extends CustomEnum {\n  public static readonly identifier = \"plugins\";\n  public static readonly options: Array<string> = [];\n}\n\nclass PluginActionsEnum extends CustomEnum {\n  public static readonly identifier = \"plugin_actions\";\n  public static readonly options: Array<string> = [\"list\", \"reload\", \"bundle\"];\n}\n\nexport { PluginsEnum, PluginActionsEnum };\n"],
  "mappings": "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",
  "names": ["existsSync", "mkdirSync", "readdirSync", "readFileSync", "renameSync", "unlinkSync", "writeFileSync", "relative", "resolve", "deflateSync", "inflateSync", "execSync", "Logger", "LoggerColors", "ServerEvent", "WorldEvent", "BinaryStream", "Logger", "LoggerColors", "PluginType", "Plugin", "identifier", "version", "logger", "type", "path", "isBundled", "pipeline", "serenity", "properties", "Logger", "LoggerColors", "Blue", "PluginType", "Addon", "onInitialize", "onStartUp", "onShutDown", "_plugin", "relative", "CommandPermissionLevel", "CustomEnum", "PluginsEnum", "CustomEnum", "identifier", "options", "PluginActionsEnum", "register", "__name", "world", "pipeline", "commands", "registry", "permissionLevel", "CommandPermissionLevel", "Operator", "overload", "action", "PluginActionsEnum", "result", "plugins", "size", "message", "values", "plugin", "push", "identifier", "version", "length", "join", "PluginsEnum", "pluginInstance", "get", "Error", "reload", "isBundled", "bundle", "relative", "process", "cwd", "path", "command_default", "DefaultPipelineProperties", "path", "commands", "initialize", "Pipeline", "serenity", "properties", "logger", "Logger", "LoggerColors", "CyanBright", "plugins", "Map", "tempPaths", "Set", "esm", "module", "exports", "_", "Error", "on", "ServerEvent", "Start", "start", "bind", "Stop", "stop", "WorldEvent", "WorldInitialize", "world", "Command", "existsSync", "resolve", "mkdirSync", "recursive", "bundles", "readdirSync", "withFileTypes", "filter", "dirent", "isFile", "name", "endsWith", "bundle", "buffer", "inflateSync", "readFileSync", "stream", "BinaryStream", "type", "readByte", "PluginType", "Addon", "index", "readRemainingBuffer", "toString", "tempPath", "slice", "writeFileSync", "plugin", "require", "default", "Plugin", "warn", "relative", "process", "cwd", "has", "identifier", "pipeline", "isBundled", "set", "onInitialize", "bindEvents", "PluginsEnum", "options", "push", "add", "Api", "unlinkSync", "execSync", "stdio", "renameSync", "reason", "error", "directories", "isDirectory", "directory", "manifest", "JSON", "parse", "main", "version", "values", "onStartUp", "onShutDown", "reload", "delete", "cache", "removePath", "rPlugin", "info", "writeByte", "inputPath", "writeBuffer", "deflateSync", "getBuffer", "tarball", "find", "file", "prototype", "Object", "getPrototypeOf", "pluginKeys", "getOwnPropertyNames", "eventKeys", "keys", "length", "eventKey", "indexOf", "includes", "value", "before", "after"]
}

|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../src/pipeline.ts", "../src/plugin.ts", "../src/enums/type.ts", "../src/commands/command.ts", "../src/commands/enum.ts"],
  "sourcesContent": ["/* eslint-disable @typescript-eslint/no-require-imports */\nimport {\n  existsSync,\n  mkdirSync,\n  readdirSync,\n  readFileSync,\n  renameSync,\n  unlinkSync,\n  writeFileSync\n} from \"node:fs\";\nimport { relative, resolve } from \"node:path\";\nimport { deflateSync, inflateSync } from \"node:zlib\";\nimport { execSync } from \"node:child_process\";\n\nimport { Logger, LoggerColors } from \"@serenityjs/logger\";\nimport { Serenity, ServerEvent, WorldEvent } from \"@serenityjs/core\";\nimport { BinaryStream } from \"@serenityjs/binarystream\";\n\nimport { PluginPackage } from \"./types\";\nimport { Plugin } from \"./plugin\";\nimport Command from \"./commands/command\";\nimport { PluginsEnum } from \"./commands\";\nimport { PluginType } from \"./enums\";\n\ninterface PipelineProperties {\n  path: string;\n  commands: boolean;\n  initialize: boolean;\n}\n\nconst DefaultPipelineProperties: PipelineProperties = {\n  path: \"./plugins\",\n  commands: true,\n  initialize: true\n};\n\nclass Pipeline {\n  /**\n   * The serenity server instance for the plugins pipeline.\n   */\n  protected readonly serenity: Serenity;\n\n  /**\n   * The properties for the plugins pipeline.\n   */\n  protected readonly properties: PipelineProperties;\n\n  /**\n   * The logger for the plugins pipeline.\n   */\n  public readonly logger = new Logger(\"Plugins\", LoggerColors.CyanBright);\n\n  /**\n   * The plugins loaded in the pipeline.\n   */\n  public readonly plugins = new Map<string, Plugin>();\n\n  /**\n   * The temporary paths used by the pipeline.\n   */\n  protected readonly tempPaths = new Set<string>();\n\n  /**\n   * Whether the pipeline is running in ESM mode.\n   */\n  public readonly esm: boolean =\n    typeof module !== \"undefined\" && module?.exports !== exports;\n\n  /**\n   * The path to the plugins directory.\n   */\n  public get path(): string {\n    return this.properties.path;\n  }\n\n  /**\n   * The path to the plugins directory.\n   */\n  public set path(_) {\n    throw new Error(\"The path property is read-only.\");\n  }\n\n  /**\n   * Creates a new instance of the Pipeline class.\n   * @param serenity The serenity server instance.\n   * @param properties The properties for the pipeline.\n   */\n  public constructor(\n    serenity: Serenity,\n    properties?: Partial<PipelineProperties>\n  ) {\n    // Set the serenity server instance\n    this.serenity = serenity;\n\n    // Merge the properties with the default properties\n    this.properties = { ...DefaultPipelineProperties, ...properties };\n\n    // Hook into the serenity server events\n    serenity.on(ServerEvent.Start, this.start.bind(this));\n    serenity.on(ServerEvent.Stop, this.stop.bind(this));\n\n    // Check if the plugins command should be registered\n    if (this.properties.commands) {\n      // Hook into the world initialize event\n      serenity.on(WorldEvent.WorldInitialize, ({ world }) =>\n        Command(world, this)\n      );\n    }\n\n    // Check if the plugins should be initialized\n    if (this.properties.initialize) this.initialize();\n  }\n\n  /**\n   * Initializes the plugins pipeline.\n   */\n  public initialize(): void {\n    // Check if the plugins directory exists\n    if (!existsSync(resolve(this.path)))\n      // If not, create the plugins directory\n      mkdirSync(resolve(this.path), { recursive: true });\n\n    // Read all the entries in the plugins directory\n    const entries = readdirSync(resolve(this.path), {\n      withFileTypes: true\n    });\n\n    // Filter out all the files that have a .plugin extension\n    const bundles = entries.filter((dirent) =>\n      dirent.isFile() ? dirent.name.endsWith(\".plugin\") : false\n    );\n\n    // Iterate over all the bundled plugins, and import them\n    for (const bundle of bundles) {\n      // Attempt to load the plugin\n      try {\n        // Get the path to the plugin\n        const path = resolve(this.path, bundle.name);\n\n        // Read the .plugin file and inflate it, and create a new binary stream\n        const buffer = inflateSync(readFileSync(path));\n        const stream = new BinaryStream(buffer);\n\n        // Read the plugin type from the stream\n        const type = stream.readByte();\n\n        // Check if the plugin type is valid\n        if (type === PluginType.Addon) {\n          // Read the module entry point from the stream\n          const index = stream.readRemainingBuffer().toString(\"utf-8\");\n\n          // Write the module or main entry points to temporary files\n          const tempPath = resolve(this.path, bundle.name.slice(0, -7));\n          writeFileSync(tempPath, index);\n\n          // Import the plugin module\n          const module = require(tempPath);\n\n          // Get the plugin class from the module\n          const plugin = module.default as Plugin;\n\n          // Check if the plugin is an instance of the Plugin class\n          if (!(plugin instanceof Plugin)) {\n            this.logger.warn(\n              `Unable to load plugin from §8${relative(process.cwd(), path)}§r, the plugin is not an instance of the Plugin class.`\n            );\n\n            // Skip the plugin\n            continue;\n          }\n\n          // Check if the plugin has already been loaded\n          if (this.plugins.has(plugin.identifier)) {\n            this.logger.warn(\n              `Unable to load plugin §1${plugin.identifier}§r, the plugin is already loaded in the pipeline.`\n            );\n\n            // Skip the plugin\n            continue;\n          }\n\n          // Set the pipeline, serenity, and path for the plugin\n          plugin.pipeline = this;\n          plugin.serenity = this.serenity;\n          plugin.path = path;\n          plugin.isBundled = true;\n\n          // Add the plugin to the plugins map\n          this.plugins.set(plugin.identifier, plugin);\n\n          // Initialize the plugin and bind the events\n          plugin.onInitialize(plugin);\n          this.bindEvents(plugin);\n\n          // Add the plugin to the plugins enum\n          PluginsEnum.options.push(plugin.identifier);\n\n          // Add the temporary path to the set\n          this.tempPaths.add(tempPath);\n        } else if (type === PluginType.Api) {\n          // Read the buffer from the stream\n          const buffer = stream.readRemainingBuffer();\n\n          // Delete the .plugin file\n          unlinkSync(path);\n\n          // Write the buffer to a temporary file\n          const tempPath = resolve(this.path, bundle.name.slice(0, -7));\n\n          // Write the buffer to the temporary file\n          writeFileSync(tempPath, buffer);\n\n          // Extract the tarball to the plugins directory\n          execSync(`tar -xzf ${tempPath} -C ${this.path}`, {\n            stdio: \"ignore\"\n          });\n\n          // Delete the temporary file\n          unlinkSync(tempPath);\n\n          // Get the plugin name from the tarball\n          const name = bundle.name.slice(0, -7);\n\n          // Rename the extracted \"package\" directory to the plugin name\n          renameSync(resolve(this.path, \"package\"), resolve(this.path, name));\n\n          // Install the dependencies for the plugin\n          execSync(\"npm install\", {\n            cwd: resolve(this.path, name),\n            stdio: \"ignore\"\n          });\n        }\n      } catch (reason) {\n        // Log the error\n        this.logger.error(\n          `Failed to load plugin from \"${relative(process.cwd(), resolve(this.path, bundle.name))}\", skipping the plugin.`,\n          reason\n        );\n      }\n    }\n\n    // Filter out all the directories from the entries\n    const directories = readdirSync(resolve(this.path), {\n      withFileTypes: true\n    }).filter((dirent) => dirent.isDirectory());\n\n    // Iterate over all the directories, checking if they are valid plugins\n    for (const directory of directories) {\n      // Attempt to load the plugin\n      try {\n        // Get the path to the plugin\n        const path = resolve(this.path, directory.name);\n\n        // Check if the plugin has a package.json file, if not, skip the plugin\n        if (!existsSync(resolve(path, \"package.json\"))) continue;\n\n        // Read the package.json file\n        const manifest = JSON.parse(\n          readFileSync(resolve(path, \"package.json\"), \"utf-8\")\n        ) as PluginPackage;\n\n        // Get the main entry point for the plugin\n        // const main = resolve(path, this.esm ? manifest.module : manifest.main);\n        const main = resolve(path, manifest.main);\n\n        // Check if the provided entry point is valid\n        if (!existsSync(resolve(path, main))) {\n          this.logger.warn(\n            `Unable to load plugin §1${manifest.name}§8@§1${manifest.version}§r, the main entry path \"§8${relative(process.cwd(), resolve(path, main))}§r\" was not found in the directory.`\n          );\n\n          // Skip the plugin\n          continue;\n        }\n\n        // Import the plugin module\n        const module = require(resolve(path, main));\n\n        // Get the plugin class from the module\n        const plugin = module.default as Plugin;\n\n        // Check if the plugin has already been loaded\n        if (this.plugins.has(plugin.identifier)) {\n          this.logger.warn(\n            `Unable to load plugin §1${plugin.identifier}§r, the plugin is already loaded in the pipeline.`\n          );\n\n          // Skip the plugin\n          continue;\n        }\n\n        // Set the pipeline, serenity, and path for the plugin\n        plugin.pipeline = this;\n        plugin.serenity = this.serenity;\n        plugin.path = path;\n        plugin.isBundled = false;\n\n        // Add the plugin to the plugins map\n        this.plugins.set(plugin.identifier, plugin);\n\n        // Add the plugin to the plugins enum\n        PluginsEnum.options.push(plugin.identifier);\n\n        // Initialize the plugin, and bind the events\n        plugin.onInitialize(plugin);\n        this.bindEvents(plugin);\n      } catch (reason) {\n        // Log the error\n        this.logger.error(\n          `Failed to load plugin from \"${relative(process.cwd(), resolve(this.path, directory.name))}\", skipping the plugin.`,\n          reason\n        );\n      }\n    }\n  }\n\n  /**\n   * Starts the plugins pipeline.\n   */\n  public start(): void {\n    // Start up all the plugins\n    for (const plugin of this.plugins.values()) plugin.onStartUp(plugin);\n  }\n\n  /**\n   * Stops the plugins pipeline.\n   */\n  public stop(): void {\n    // Shut down all the plugins\n    for (const plugin of this.plugins.values()) plugin.onShutDown(plugin);\n\n    // Delete all the temporary files\n    for (const tempPath of this.tempPaths) {\n      // Delete the temporary file\n      unlinkSync(tempPath);\n    }\n  }\n\n  public reload(plugin: Plugin): void {\n    // Shut down the plugin\n    plugin.onShutDown(plugin);\n\n    // Remove the plugin from the plugins map\n    this.plugins.delete(plugin.identifier);\n\n    // Get the plugin path\n    const path = plugin.path;\n\n    // Delete the require cache for the plugin\n    // eslint-disable-next-line @typescript-eslint/no-dynamic-delete -- Dynamic delete is required here\n    delete require.cache[require.resolve(path)];\n\n    // Remove the plugin from the serenity instance\n    this.serenity.removePath(path);\n\n    // Attempt to load the plugin\n    try {\n      // Import the plugin module\n\n      const module = require(path);\n\n      // Get the plugin class from the module\n      const rPlugin = module.default as Plugin;\n\n      // Check if the plugin is an instance of the Plugin class\n      if (!(rPlugin instanceof Plugin)) {\n        this.logger.warn(\n          `Unable to reload plugin from §8${relative(process.cwd(), path)}§r, the plugin is not an instance of the Plugin class.`\n        );\n\n        // Skip the plugin\n        return;\n      }\n\n      // Set the pipeline, serenity, and path for the plugin\n      rPlugin.pipeline = this;\n      rPlugin.serenity = this.serenity;\n      rPlugin.path = path;\n\n      // Add the plugin to the plugins map\n      this.plugins.set(rPlugin.identifier, rPlugin);\n\n      // Initialize the plugin\n      rPlugin.onInitialize(rPlugin);\n      this.bindEvents(rPlugin);\n\n      // Start up the plugin\n      rPlugin.onStartUp(rPlugin);\n\n      // Log the successful reload\n      this.logger.info(\n        `Successfully reloaded plugin §1${rPlugin.identifier}§r from §8${relative(process.cwd(), path)}§r.`\n      );\n    } catch (reason) {\n      // Log the error\n      this.logger.error(\n        `Failed to reload plugin from §8${relative(process.cwd(), path)}§r, skipping the plugin.`,\n        reason\n      );\n    }\n  }\n\n  public bundle(plugin: Plugin): void {\n    // Create a new BinaryStream instance\n    const stream = new BinaryStream();\n\n    // Write the plugin type to the stream\n    stream.writeByte(plugin.type);\n\n    if (plugin.type === PluginType.Addon) {\n      // Get the addon path\n      const inputPath = resolve(plugin.path, \"dist\");\n\n      // Read the index file\n      const index = readFileSync(resolve(inputPath, \"index.js\"));\n\n      // Write the module entry point to the stream\n      stream.writeBuffer(index);\n\n      // Write the BinaryStream to the output path\n      writeFileSync(\n        resolve(this.path, `${plugin.identifier}.plugin`),\n        deflateSync(stream.getBuffer())\n      );\n    } else if (plugin.type === PluginType.Api) {\n      // Pack the plugin\n      execSync(\"npm pack\", { cwd: plugin.path, stdio: \"ignore\" });\n\n      // Get the tarball path\n      const tarball = readdirSync(plugin.path).find((file) =>\n        file.endsWith(\".tgz\")\n      );\n\n      // Check if the tarball exists\n      if (!tarball) throw new Error(\"Packed tarball not found.\");\n\n      // Read the tarball file\n      const buffer = readFileSync(resolve(plugin.path, tarball));\n\n      // Delete the tarball file\n      unlinkSync(resolve(plugin.path, tarball));\n\n      // Write the buffer to the output path\n      stream.writeBuffer(buffer);\n\n      // Write the buffer to the output path\n      writeFileSync(\n        resolve(this.path, `${plugin.identifier}.plugin`),\n        deflateSync(stream.getBuffer())\n      );\n    }\n  }\n\n  protected bindEvents(plugin: Plugin): void {\n    // Get the prototype of the plugin\n    const prototype = Object.getPrototypeOf(plugin);\n\n    // Get the object keys from the plugin\n    const pluginKeys = Object.getOwnPropertyNames(prototype);\n\n    // Get the world event keys, and slice them in half\n    let eventKeys = Object.keys(WorldEvent);\n    eventKeys = eventKeys.slice(eventKeys.length / 2);\n\n    // Iterate over all the event keys\n    for (const eventKey of eventKeys) {\n      // Get the index of the event key\n      const index = eventKeys.indexOf(eventKey) as WorldEvent;\n\n      // Check if the plugin has any \"on\" event keys\n      if (pluginKeys.includes(\"on\" + eventKey)) {\n        // Get the value of the event key\n        const value = plugin[(\"on\" + eventKey) as keyof Plugin];\n\n        // Check if the value is a function\n        if (typeof value === \"function\")\n          // Bind the event to the plugin\n          this.serenity.on(index, value.bind(plugin) as () => void);\n      }\n\n      // Check if the plugin has any \"before\" event keys\n      if (pluginKeys.includes(\"before\" + eventKey)) {\n        // Get the value of the event key\n        const value = plugin[(\"before\" + eventKey) as keyof Plugin];\n\n        // Check if the value is a function\n        if (typeof value === \"function\")\n          // Bind the event to the plugin\n          this.serenity.before(index, value.bind(plugin) as () => boolean);\n      }\n\n      // Check if the plugin has any \"after\" event keys\n      if (pluginKeys.includes(\"after\" + eventKey)) {\n        // Get the value of the event key\n        const value = plugin[(\"after\" + eventKey) as keyof Plugin];\n\n        // Check if the value is a function\n        if (typeof value === \"function\")\n          // Bind the event to the plugin\n          this.serenity.after(index, value.bind(plugin) as () => void);\n      }\n    }\n  }\n}\n\nexport { Pipeline, DefaultPipelineProperties };\n", "import { Serenity } from \"@serenityjs/core\";\nimport { Logger, LoggerColors } from \"@serenityjs/logger\";\n\nimport { Pipeline } from \"./pipeline\";\nimport { PluginType } from \"./enums\";\nimport { PluginEvents } from \"./types\";\n\ninterface PluginProperties extends Partial<PluginEvents> {\n  logger: Logger;\n  type: PluginType;\n}\n\n/**\n * # Introduction\n * Plugins are the fundamental building blocks of SerenityJS.\n * They are used to add additional functionality to the server, which allows total control over the server.\n *\n * There are 2 types of plugins that are defined in the `PluginType` enum: `Addon` & `Api`\n *\n * Addon plugins add additional functionality to the server, without an exposed API. This means external plugins cannot directly interact with the plugins API.\n * Api plugins add additional functionality to the server, with an exposed API for other plugins to use. This means external plugins can directly interact with the plugins API.\n *\n * ## Class Extending Plugin\n * ```ts\n * import { Plugin, PluginType, PluginEvents } from \"@serenityjs/plugins\";\n *\n * class SamplePlugin extends Plugin {\n *   public readonly type = PluginType.Addon;\n *\n *   public constructor() {\n *     super(\"sample-plugin\", \"1.0.0\");\n *   }\n *\n *   public onInitialize(): void {}\n *\n *   public onStartUp(): void {}\n *\n *   public onShutDown(): void {}\n * }\n *\n * export default new SamplePlugin();\n * ```\n */\nclass Plugin implements PluginProperties {\n  /**\n   * The identifier of the plugin.\n   */\n  public readonly identifier: string;\n\n  /**\n   * The version of the plugin.\n   */\n  public readonly version: string;\n\n  /**\n   * The logger for the plugin.\n   */\n  public readonly logger: Logger;\n\n  /**\n   * The type of the plugin.\n   */\n  public readonly type: PluginType;\n\n  /**\n   * The path to the plugin.\n   * @Note This is only available after the plugin is initialized.\n   */\n  public path!: string;\n\n  /**\n   * Whether or not the plugin is bundled.\n   * @Note This is only available after the plugin is initialized.\n   */\n  public isBundled!: boolean;\n\n  /**\n   * The plugin pipeline the plugin is in.\n   * @Note This is only available after the plugin is initialized.\n   */\n  public pipeline!: Pipeline;\n\n  /**\n   * The serenity instance of the server.\n   * @Note This is only available after the plugin is initialized.\n   */\n  public serenity!: Serenity;\n\n  /**\n   * Create a new plugin instance.\n   * @param identifier The identifier of the plugin.\n   * @param version The version of the plugin.\n   * @param properties The properties of the plugin.\n   */\n  public constructor(\n    identifier: string,\n    version: string,\n    properties?: Partial<PluginProperties>\n  ) {\n    // Set the identifier and version of the plugin\n    this.identifier = identifier;\n    this.version = version;\n\n    // Set the logger for the plugin\n    this.logger =\n      properties?.logger ??\n      new Logger(`${identifier}@${version}`, LoggerColors.Blue);\n\n    // Set the type of the plugin\n    this.type = properties?.type ?? PluginType.Addon;\n\n    // Set the on initialize, start up, and shut down properties\n    if (properties?.onInitialize) this.onInitialize = properties.onInitialize;\n    if (properties?.onStartUp) this.onStartUp = properties.onStartUp;\n    if (properties?.onShutDown) this.onShutDown = properties.onShutDown;\n  }\n\n  /**\n   * Called when the plugin is initialized.\n   * @param plugin The plugin instance that was initialized. (this)\n   */\n  public onInitialize(_plugin: Plugin): void {\n    // Override this method in your plugin\n  }\n\n  /**\n   * Called when the plugin is started up.\n   * @param plugin The plugin instance that was started up. (this)\n   */\n  public onStartUp(_plugin: Plugin): void {\n    // Override this method in your plugin\n  }\n\n  /**\n   * Called when the plugin is shut down.\n   * @param plugin The plugin instance that was shut down. (this)\n   */\n  public onShutDown(_plugin: Plugin): void {\n    // Override this method in your plugin\n  }\n}\n\nexport { Plugin, PluginProperties };\n", "/**\n * The plugin type declares the use case of the plugin.\n */\nenum PluginType {\n  /**\n   * An addon plugin type adds additional functionality to the server, without an exposed API.\n   */\n  Addon,\n\n  /**\n   * An API plugin type adds additional functionality to the server, with an exposed API for other plugins to use.\n   */\n  Api\n}\n\nexport { PluginType };\n", "import { relative } from \"path\";\n\nimport { World } from \"@serenityjs/core\";\nimport { CommandPermissionLevel } from \"@serenityjs/protocol\";\n\nimport { Pipeline } from \"../pipeline\";\n\nimport { PluginActionsEnum, PluginsEnum } from \"./enum\";\n\nconst register = (world: World, pipeline: Pipeline) => {\n  world.commands.register(\n    \"plugins\",\n    \"Interact with the plugins of the server\",\n    (registry) => {\n      // Set the command to be an operator command\n      registry.permissionLevel = CommandPermissionLevel.Operator;\n\n      // Overload for listing the plugins\n      registry.overload(\n        {\n          action: PluginActionsEnum\n        },\n        ({ action }) => {\n          // Check if the action is list\n          if (action.result !== \"list\") return;\n\n          // Check if the pipeline has no plugins\n          if (pipeline.plugins.size === 0)\n            return {\n              message: \"§cThere are current no plugins loaded on the server.\"\n            };\n\n          // Get the plugins from the pipeline\n          const plugins = [...pipeline.plugins.values()];\n\n          // Prepare the message\n          const message = [];\n\n          // Loop through the plugins\n          for (const plugin of plugins) {\n            // Push the plugin name to the message\n            message.push(`§u${plugin.identifier} v${plugin.version}§r`);\n          }\n\n          // Send the message to the origin\n          return {\n            message: `§7Active Plugins (${plugins.length}):§r ${message.join(\"§7,§r \")}`\n          };\n        }\n      );\n\n      registry.overload(\n        {\n          action: PluginActionsEnum,\n          plugin: PluginsEnum\n        },\n        ({ action, plugin }) => {\n          // Check if the action is reload\n          if (action.result !== \"reload\" && action.result !== \"bundle\") return;\n\n          // Get the plugin from the pipeline\n          const pluginInstance = pipeline.plugins.get(plugin.result as string);\n\n          // Check if the plugin is not found\n          if (!pluginInstance)\n            throw new Error(`Plugin ${plugin.result} is not found.`);\n\n          // Check if the action is reload\n          if (action.result === \"reload\") {\n            // Reload the plugin\n            pipeline.reload(pluginInstance);\n\n            // Send the message to the origin\n            return {\n              message: `§aSuccessfully reloaded §2${pluginInstance.identifier}§a.`\n            };\n          } else {\n            if (pluginInstance.isBundled)\n              // Check if the plugin is already bundled\n              throw new Error(\n                `Plugin ${pluginInstance.identifier} cannot be bundled, as it is already a bundled plugin.`\n              );\n\n            // Bundle the plugin\n            pipeline.bundle(pluginInstance);\n\n            // Send the message to the origin\n            return {\n              message: `§aSuccessfully bundled §2${pluginInstance.identifier}§a, output file was placed at §7${relative(process.cwd(), pipeline.path)}§a.`\n            };\n          }\n        }\n      );\n    },\n    () => {\n      throw new Error(\"No overload matched the provided arguments.\");\n    }\n  );\n};\n\nexport default register;\n", "import { CustomEnum } from \"@serenityjs/core\";\n\nclass PluginsEnum extends CustomEnum {\n  public static readonly identifier = \"plugins\";\n  public static readonly options: Array<string> = [];\n}\n\nclass PluginActionsEnum extends CustomEnum {\n  public static readonly identifier = \"plugin_actions\";\n  public static readonly options: Array<string> = [\"list\", \"reload\", \"bundle\"];\n}\n\nexport { PluginsEnum, PluginActionsEnum };\n"],
  "mappings": "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",
  "names": ["existsSync", "mkdirSync", "readdirSync", "readFileSync", "renameSync", "unlinkSync", "writeFileSync", "relative", "resolve", "deflateSync", "inflateSync", "execSync", "Logger", "LoggerColors", "ServerEvent", "WorldEvent", "BinaryStream", "Logger", "LoggerColors", "PluginType", "Plugin", "identifier", "version", "logger", "type", "path", "isBundled", "pipeline", "serenity", "properties", "Logger", "LoggerColors", "Blue", "PluginType", "Addon", "onInitialize", "onStartUp", "onShutDown", "_plugin", "relative", "CommandPermissionLevel", "CustomEnum", "PluginsEnum", "CustomEnum", "identifier", "options", "PluginActionsEnum", "register", "__name", "world", "pipeline", "commands", "registry", "permissionLevel", "CommandPermissionLevel", "Operator", "overload", "action", "PluginActionsEnum", "result", "plugins", "size", "message", "values", "plugin", "push", "identifier", "version", "length", "join", "PluginsEnum", "pluginInstance", "get", "Error", "reload", "isBundled", "bundle", "relative", "process", "cwd", "path", "command_default", "DefaultPipelineProperties", "path", "commands", "initialize", "Pipeline", "serenity", "properties", "logger", "Logger", "LoggerColors", "CyanBright", "plugins", "Map", "tempPaths", "Set", "esm", "module", "exports", "_", "Error", "on", "ServerEvent", "Start", "start", "bind", "Stop", "stop", "WorldEvent", "WorldInitialize", "world", "Command", "existsSync", "resolve", "mkdirSync", "recursive", "bundles", "readdirSync", "withFileTypes", "filter", "dirent", "isFile", "name", "endsWith", "bundle", "buffer", "inflateSync", "readFileSync", "stream", "BinaryStream", "type", "readByte", "PluginType", "Addon", "index", "readRemainingBuffer", "toString", "tempPath", "slice", "writeFileSync", "plugin", "require", "default", "Plugin", "warn", "relative", "process", "cwd", "has", "identifier", "pipeline", "isBundled", "set", "onInitialize", "bindEvents", "PluginsEnum", "options", "push", "add", "Api", "unlinkSync", "execSync", "stdio", "renameSync", "reason", "error", "directories", "isDirectory", "directory", "manifest", "JSON", "parse", "main", "version", "values", "onStartUp", "onShutDown", "reload", "delete", "cache", "removePath", "rPlugin", "info", "writeByte", "inputPath", "writeBuffer", "deflateSync", "getBuffer", "tarball", "find", "file", "prototype", "Object", "getPrototypeOf", "pluginKeys", "getOwnPropertyNames", "eventKeys", "keys", "length", "eventKey", "indexOf", "includes", "value", "before", "after"]
}

|
package/package.json
CHANGED
|
@@ -2,7 +2,7 @@
|
|
|
2
2
|
"name": "@serenityjs/plugins",
|
|
3
3
|
"author": "Serenity",
|
|
4
4
|
"license": "MIT",
|
|
5
|
-
"version": "0.
|
|
5
|
+
"version": "0.7.0-beta-20241221054452",
|
|
6
6
|
"main": "./dist/index.js",
|
|
7
7
|
"module": "./dist/index.mjs",
|
|
8
8
|
"types": "./dist/index.d.ts",
|
|
@@ -20,7 +20,7 @@
|
|
|
20
20
|
"typecheck": "tsc --noEmit"
|
|
21
21
|
},
|
|
22
22
|
"devDependencies": {
|
|
23
|
-
"@serenityjs/internal-config": "
|
|
23
|
+
"@serenityjs/internal-config": "0.7.0-beta-20241221054452",
|
|
24
24
|
"@swc/core": "1.7.42",
|
|
25
25
|
"@types/node": "22.8.6",
|
|
26
26
|
"eslint": "9.13.0",
|
|
@@ -29,8 +29,8 @@
|
|
|
29
29
|
},
|
|
30
30
|
"dependencies": {
|
|
31
31
|
"@serenityjs/binarystream": "^2.7.0",
|
|
32
|
-
"@serenityjs/core": "
|
|
33
|
-
"@serenityjs/logger": "
|
|
34
|
-
"@serenityjs/protocol": "
|
|
32
|
+
"@serenityjs/core": "0.7.0-beta-20241221054452",
|
|
33
|
+
"@serenityjs/logger": "0.7.0-beta-20241221054452",
|
|
34
|
+
"@serenityjs/protocol": "0.7.0-beta-20241221054452"
|
|
35
35
|
}
|
|
36
36
|
}
|