UNPKG

@clusterio/create

Version:

Installer for clusterio

77 lines (66 loc) 2.03 kB
import * as lib from "@clusterio/lib"; import { BaseInstancePlugin } from "@clusterio/host"; //%if multi_context import { PluginExampleEvent, PluginExampleRequest } from "./messages"; //%endif //%if module type PuginExampleIPC = { tick: number, player_name: string, }; //%endif export class InstancePlugin extends BaseInstancePlugin { //%if multi_context | module async init() { //%endif //%if multi_context this.instance.handle(PluginExampleEvent, this.handlePluginExampleEvent.bind(this)); this.instance.handle(PluginExampleRequest, this.handlePluginExampleRequest.bind(this)); //%endif //%if module this.instance.server.handle("__plugin_name__-plugin_example_ipc", this.handlePluginExampleIPC.bind(this)); //%endif //%if multi_context | module } //%endif async onInstanceConfigFieldChanged(field: string, curr: unknown, prev: unknown) { this.logger.info(`instance::onInstanceConfigFieldChanged ${field}`); } async onStart() { // Called once rcon becomes available this.logger.info("instance::onStart"); } async onStop() { // Called during normal exits before rcon becomes unavailable this.logger.info("instance::onStop"); } onExit() { // Called during all exits, including crashes and init failures, rcon is not available this.logger.info("instance::onExit"); } async onPlayerEvent(event: lib.PlayerEvent) { this.logger.info(`onPlayerEvent::onPlayerEvent ${JSON.stringify(event)}`); //%if module if (this.instance.status === "running") { await this.sendRcon("/sc __plugin_name__.foo()"); } //%endif } //%if multi_context async handlePluginExampleEvent(event: PluginExampleEvent) { this.logger.info(JSON.stringify(event)); } async handlePluginExampleRequest(request: PluginExampleRequest) { this.logger.info(JSON.stringify(request)); return { myResponseString: request.myString, myResponseNumbers: request.myNumberArray, }; } //%endif //%if module async handlePluginExampleIPC(event: PuginExampleIPC) { this.logger.info(JSON.stringify(event)); } //%endif }