2020-01-31 18:46:06 +00:00
|
|
|
import '@ms/ployfill'
|
|
|
|
let containerStartTime = new Date().getTime()
|
|
|
|
console.log(`Initialization MiaoScript IOC Container @ms/container. Please wait...`)
|
|
|
|
import { plugin, server, task } from '@ms/api'
|
2019-09-07 04:23:15 +00:00
|
|
|
import { PluginManagerImpl } from '@ms/plugin'
|
2020-01-17 03:10:30 +00:00
|
|
|
import { DefaultContainer as container, injectable, inject, ContainerInstance } from '@ms/container'
|
2020-01-31 18:46:06 +00:00
|
|
|
console.log('MiaoScript IOC Container @ms/container loading completed(' + (new Date().getTime() - containerStartTime) / 1000 + 's)!');
|
2019-09-07 04:23:15 +00:00
|
|
|
|
2019-09-21 07:06:17 +00:00
|
|
|
@injectable()
|
|
|
|
class MiaoScriptCore {
|
|
|
|
@inject(server.Console)
|
|
|
|
private Console: Console;
|
|
|
|
@inject(task.TaskManager)
|
|
|
|
private taskManager: task.TaskManager;
|
2020-02-24 08:25:16 +00:00
|
|
|
@inject(plugin.PluginFolder)
|
|
|
|
private pluginFolder: string;
|
2019-09-21 07:06:17 +00:00
|
|
|
@inject(plugin.PluginManager)
|
|
|
|
private pluginManager: plugin.PluginManager;
|
|
|
|
|
|
|
|
enable() {
|
2020-01-15 08:48:18 +00:00
|
|
|
this.loadServerConsole();
|
|
|
|
this.loadTaskFunction();
|
2020-01-31 18:46:06 +00:00
|
|
|
global.level = "TRACE"
|
2020-01-15 08:48:18 +00:00
|
|
|
this.loadPlugins();
|
2019-09-21 07:06:17 +00:00
|
|
|
return () => this.disable();
|
|
|
|
}
|
2020-01-17 03:10:30 +00:00
|
|
|
|
2019-09-21 07:06:17 +00:00
|
|
|
loadServerConsole() {
|
2019-11-04 12:26:22 +00:00
|
|
|
// @ts-ignore
|
|
|
|
console = new this.Console();
|
2019-09-21 07:06:17 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
loadTaskFunction() {
|
|
|
|
//@ts-ignore
|
2019-11-05 09:02:58 +00:00
|
|
|
global.setTimeout = (func: Function, tick: number, async: boolean = false) => this.taskManager.create(func).later(tick).async(async).submit()
|
2019-09-21 07:06:17 +00:00
|
|
|
//@ts-ignore
|
2019-11-05 09:02:58 +00:00
|
|
|
global.setInterval = (func: Function, tick: number, async: boolean = false) => this.taskManager.create(func).timer(tick).async(async).submit()
|
2019-09-21 07:06:17 +00:00
|
|
|
}
|
2019-09-07 04:23:15 +00:00
|
|
|
|
2019-09-21 07:06:17 +00:00
|
|
|
loadPlugins() {
|
2020-01-31 18:46:06 +00:00
|
|
|
let loadPluginStartTime = new Date().getTime()
|
|
|
|
console.log(`Initialization MiaoScript Plugin System. Please wait...`)
|
2020-02-24 08:25:16 +00:00
|
|
|
this.pluginManager.scan(this.pluginFolder);
|
2020-01-17 03:10:30 +00:00
|
|
|
this.pluginManager.build();
|
2019-09-21 07:06:17 +00:00
|
|
|
this.pluginManager.load();
|
|
|
|
this.pluginManager.enable();
|
2020-01-31 18:46:06 +00:00
|
|
|
console.log('MiaoScript Plugin System loading completed(' + (new Date().getTime() - loadPluginStartTime) / 1000 + 's)!');
|
2019-09-21 07:06:17 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
disable() {
|
2020-02-25 15:15:39 +00:00
|
|
|
console.log("Disable MiaoScript Engine...")
|
2019-09-21 07:06:17 +00:00
|
|
|
this.pluginManager.disable();
|
|
|
|
}
|
2019-09-10 09:22:22 +00:00
|
|
|
}
|
|
|
|
|
2020-01-17 03:10:30 +00:00
|
|
|
function detectServer() {
|
2019-09-21 07:06:17 +00:00
|
|
|
try {
|
|
|
|
Java.type("org.bukkit.Bukkit");
|
2020-01-31 19:37:56 +00:00
|
|
|
return 'bukkit'
|
2019-09-21 07:06:17 +00:00
|
|
|
} catch (ex) {
|
|
|
|
}
|
|
|
|
try {
|
|
|
|
Java.type("org.spongepowered.api.Sponge");
|
2020-01-31 19:37:56 +00:00
|
|
|
return 'sponge'
|
2020-01-15 08:48:18 +00:00
|
|
|
} catch (ex) {
|
|
|
|
}
|
2020-02-23 20:02:29 +00:00
|
|
|
try {
|
|
|
|
Java.type("cn.nukkit.Nukkit");
|
|
|
|
return 'nukkit'
|
|
|
|
} catch (ex) {
|
|
|
|
}
|
2020-01-15 08:48:18 +00:00
|
|
|
try {
|
|
|
|
Java.type("net.md_5.bungee.api.ProxyServer");
|
2020-01-31 19:37:56 +00:00
|
|
|
return 'bungee'
|
2019-09-21 07:06:17 +00:00
|
|
|
} catch (ex) {
|
|
|
|
}
|
2020-01-31 19:37:56 +00:00
|
|
|
throw Error('Unknow Server Type...')
|
2020-01-15 08:48:18 +00:00
|
|
|
}
|
2019-09-21 07:06:17 +00:00
|
|
|
|
2020-01-31 19:37:56 +00:00
|
|
|
function initialize() {
|
2020-01-31 18:46:06 +00:00
|
|
|
let corePackageStartTime = new Date().getTime()
|
2020-01-17 03:10:30 +00:00
|
|
|
container.bind(ContainerInstance).toConstantValue(container);
|
2020-01-15 08:48:18 +00:00
|
|
|
container.bind(plugin.PluginInstance).toConstantValue(base.getInstance());
|
2020-02-24 08:25:16 +00:00
|
|
|
container.bind(plugin.PluginFolder).toConstantValue('plugins');
|
2020-01-15 08:48:18 +00:00
|
|
|
let type = detectServer();
|
2020-01-31 19:37:56 +00:00
|
|
|
console.info(`Detect Compatible Server set ServerType to ${type} ...`)
|
2020-01-31 18:46:06 +00:00
|
|
|
container.bind(server.ServerType).toConstantValue(type);
|
|
|
|
console.log(`Initialization MiaoScript Package @ms/core @ms/${type}. Please wait...`)
|
|
|
|
require(`@ms/${type}`).default(container);
|
2019-09-21 07:06:17 +00:00
|
|
|
container.bind(plugin.PluginManager).to(PluginManagerImpl).inSingletonScope();
|
|
|
|
container.bind(MiaoScriptCore).to(MiaoScriptCore).inSingletonScope();
|
2020-01-31 18:46:06 +00:00
|
|
|
console.log(`MiaoScript Package @ms/core @ms/${type} loading completed(` + (new Date().getTime() - corePackageStartTime) / 1000 + 's)!');
|
|
|
|
let disable = container.get<MiaoScriptCore>(MiaoScriptCore).enable()
|
|
|
|
console.log('MiaoScript ScriptEngine loading completed... Done (' + (new Date().getTime() - global.NashornEngineStartTime) / 1000 + 's)!');
|
|
|
|
return disable;
|
2019-09-21 07:06:17 +00:00
|
|
|
}
|
2019-09-07 04:23:15 +00:00
|
|
|
|
2020-01-31 19:37:56 +00:00
|
|
|
export default initialize();
|