2020-05-02 16:14:47 +00:00
|
|
|
import { plugin as pluginApi, task, server } from '@ccms/api'
|
2019-09-22 15:31:52 +00:00
|
|
|
|
2020-05-02 16:14:47 +00:00
|
|
|
import { Translate } from '@ccms/i18n'
|
2020-06-20 08:40:34 +00:00
|
|
|
import { inject, DefaultContainer as container } from '@ccms/container'
|
2020-05-02 16:14:47 +00:00
|
|
|
import { interfaces, plugin, cmd, tab } from '@ccms/plugin'
|
2019-09-22 15:31:52 +00:00
|
|
|
|
2020-05-02 16:14:47 +00:00
|
|
|
import * as fs from '@ccms/common/dist/fs'
|
2020-06-20 08:40:34 +00:00
|
|
|
import * as reflect from '@ccms/common/dist/reflect'
|
2020-05-02 16:14:47 +00:00
|
|
|
import http from '@ccms/common/dist/http'
|
2020-03-30 10:49:19 +00:00
|
|
|
|
2019-09-22 15:31:52 +00:00
|
|
|
let help = [
|
2020-05-07 09:13:48 +00:00
|
|
|
'§6========= §6[§aMiaoScriptPackageManager§6] 帮助 §aBy §bMiaoWoo §6=========',
|
2020-05-11 16:07:05 +00:00
|
|
|
'§6/mpm §ainstall §e<插件名称> §6- §3安装仓库插件',
|
|
|
|
'§6/mpm §aload §e<插件名称> §6- §3安装本地插件',
|
|
|
|
'§6/mpm §aunload §e<插件名称> §6- §3卸载已安装插件',
|
|
|
|
'§6/mpm §areload §e<插件名称> §6- §3重载已安装插件(无名称则重载自身)',
|
|
|
|
'§6/mpm §alist [i] §6- §3列出仓库插件[已安装的插件]',
|
|
|
|
'§6/mpm §aupdate §e[插件名称] §6- §3更新插件(无名称则更新源)',
|
|
|
|
'§6/mpm §aupgrade §e[插件名称] §6- §3升级插件/框架(§4无名称则升级框架§3)',
|
|
|
|
'§6/mpm §arun §e<JS代码> §6- §3运行JS代码',
|
|
|
|
'§6/mpm §adeploy §e<插件名称> §6- §3发布插件',
|
|
|
|
'§6/mpm §crestart §6- §4重启MiaoScript脚本引擎'
|
2020-06-20 08:40:34 +00:00
|
|
|
]
|
2019-09-22 15:31:52 +00:00
|
|
|
|
2020-03-30 10:49:19 +00:00
|
|
|
let langMap = {
|
2020-05-11 16:07:05 +00:00
|
|
|
'main.command.not.exists': '§4未知的子命令: §c{command}',
|
|
|
|
'main.command.help.tip': '§6请执行 §b/{command} §ahelp §6查看帮助!',
|
2020-05-07 16:50:30 +00:00
|
|
|
'list.install.header': '§6当前 §bMiaoScript §6已安装下列插件:',
|
2020-07-25 07:24:02 +00:00
|
|
|
'list.install.body': '§6插件名称: §b{name} §6版本: §a{version} §6作者: §3{author} §6来源: §c{from}',
|
2020-03-30 10:49:19 +00:00
|
|
|
'list.header': '§6当前 §bMiaoScriptPackageCenter §6中存在下列插件:',
|
2020-05-07 16:50:30 +00:00
|
|
|
'list.body': '§6插件名称: §b{name} §6版本: §a{version} §6作者: §3{author} §6更新时间: §9{updated_at}',
|
2020-03-30 10:49:19 +00:00
|
|
|
'plugin.not.exists': '§6插件 §b{name} §c不存在!',
|
|
|
|
'plugin.unload.finish': '§6插件 §b{name} §a已卸载!',
|
|
|
|
'plugin.reload.finish': '§6插件 §b{name} §a重载完成!',
|
|
|
|
'plugin.name.empty': '§c请输入插件名称!',
|
|
|
|
'cloud.update.finish': '§6成功从 §aMiaoScriptPackageCenter §6获取到 §a{length} §6个插件!',
|
2020-05-07 09:13:48 +00:00
|
|
|
'cloud.not.exists': '§6当前 §aMiaoScriptPackageCenter §c不存在 §a{name} §c插件!',
|
|
|
|
'download.start': '§6开始下载插件: §b{name}',
|
|
|
|
'download.url': '§6插件下载地址: §b{url}',
|
|
|
|
'download.finish': '§6插件 §b{name} §a下载完毕 开始加载 ...',
|
|
|
|
'install.finish': '§6插件 §b{name} §a安装成功!',
|
2020-05-07 10:33:10 +00:00
|
|
|
'update.finish': '§6插件 §b{name} §a更新成功!',
|
2020-05-13 10:42:05 +00:00
|
|
|
'upgrade.confirm': '§6您正在尝试升级 §bMiaoScript §c核心 §6请执行 §b/mpm §aupgrade §cconfirm §6确认执行!',
|
2020-05-11 16:07:05 +00:00
|
|
|
'deploy.token.not.exists': '§4请先配置发布Token!',
|
2020-05-07 16:50:30 +00:00
|
|
|
'deploy.success': '§6插件 §b{name} §a发布成功! §6服务器返回: §a{msg}',
|
|
|
|
'deploy.fail': '§6插件 §b{name} §c发布失败! §6服务器返回: §c{msg}',
|
2020-05-11 16:07:05 +00:00
|
|
|
'run.script': '§b运行脚本:§r {script}',
|
|
|
|
'run.result': '§a返回结果:§r {result}',
|
|
|
|
'run.noresult': '§4没有返回结果!',
|
2020-03-30 10:49:19 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
let fallbackMap = langMap
|
|
|
|
|
2020-07-25 07:24:02 +00:00
|
|
|
@plugin({ name: 'MiaoScriptPackageManager', prefix: 'PM', version: '1.0.2', author: 'MiaoWoo', source: __filename })
|
2020-01-16 09:27:24 +00:00
|
|
|
export class MiaoScriptPackageManager extends interfaces.Plugin {
|
2019-09-22 15:31:52 +00:00
|
|
|
@inject(pluginApi.PluginManager)
|
2020-06-20 08:40:34 +00:00
|
|
|
private pluginManager: pluginApi.PluginManager
|
2019-09-22 15:31:52 +00:00
|
|
|
@inject(task.TaskManager)
|
2020-06-20 08:40:34 +00:00
|
|
|
private taskManager: task.TaskManager
|
2020-01-16 09:27:24 +00:00
|
|
|
@inject(server.ServerType)
|
2020-06-20 08:40:34 +00:00
|
|
|
private serverType: string
|
2020-01-16 09:27:24 +00:00
|
|
|
@inject(server.Server)
|
|
|
|
private server: server.Server
|
2020-05-07 09:13:48 +00:00
|
|
|
@inject(pluginApi.PluginFolder)
|
2020-06-20 08:40:34 +00:00
|
|
|
private pluginFolder: string
|
2019-09-22 15:31:52 +00:00
|
|
|
|
2020-01-16 09:27:24 +00:00
|
|
|
private packageCache: any[] = [];
|
2020-03-30 10:49:19 +00:00
|
|
|
private packageNameCache: string[] = [];
|
|
|
|
|
2020-06-20 08:40:34 +00:00
|
|
|
private translate: Translate
|
2019-09-22 15:31:52 +00:00
|
|
|
|
|
|
|
load() {
|
2020-03-30 10:49:19 +00:00
|
|
|
this.translate = new Translate({
|
|
|
|
langMap,
|
|
|
|
fallbackMap
|
|
|
|
})
|
|
|
|
this.updateRepo(this.server.getConsoleSender())
|
2019-09-22 15:31:52 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
@cmd()
|
|
|
|
mpm(sender: any, command: string, args: string[]) {
|
2020-06-20 08:40:34 +00:00
|
|
|
this.taskManager.create(() => this.main(sender, command, args)).async().submit()
|
2019-09-22 15:31:52 +00:00
|
|
|
}
|
|
|
|
|
2020-03-30 10:49:19 +00:00
|
|
|
i18n(sender: any, name: string, params?: any) {
|
|
|
|
this.logger.sender(sender, this.translate.translate(name, params))
|
|
|
|
}
|
|
|
|
|
2019-09-22 15:31:52 +00:00
|
|
|
main(sender: any, command: string, args: string[]) {
|
2020-05-13 10:42:05 +00:00
|
|
|
let cmdKey = 'cmd' + (args[0] || 'help')
|
2020-05-11 09:22:45 +00:00
|
|
|
if (!this[cmdKey]) {
|
2020-05-11 16:07:05 +00:00
|
|
|
this.i18n(sender, 'main.command.not.exists', { command: args[0] })
|
|
|
|
this.i18n(sender, 'main.command.help.tip', { command })
|
2020-06-20 08:40:34 +00:00
|
|
|
return
|
2019-09-22 15:31:52 +00:00
|
|
|
}
|
2020-03-30 10:49:19 +00:00
|
|
|
args.shift()
|
2020-06-20 08:40:34 +00:00
|
|
|
this[cmdKey](sender, ...args)
|
2020-03-30 10:49:19 +00:00
|
|
|
}
|
|
|
|
|
2020-05-11 16:07:05 +00:00
|
|
|
cmdhelp(sender: any) {
|
2020-06-20 08:40:34 +00:00
|
|
|
this.logger.sender(sender, help)
|
2020-05-11 16:07:05 +00:00
|
|
|
}
|
|
|
|
|
2020-05-11 09:22:45 +00:00
|
|
|
cmdload(sender: any, name: string) {
|
2020-06-20 08:40:34 +00:00
|
|
|
let pluginFile = fs.concat(__dirname + '', name)
|
2020-05-11 09:22:45 +00:00
|
|
|
if (!fs.exists(pluginFile)) {
|
2020-05-11 16:07:05 +00:00
|
|
|
this.i18n(sender, 'plugin.not.exists', { name: `${name}(${pluginFile})` })
|
2020-06-20 08:40:34 +00:00
|
|
|
return
|
2020-05-11 09:22:45 +00:00
|
|
|
}
|
2020-06-20 08:40:34 +00:00
|
|
|
this.pluginManager.loadFromFile(fs.file(pluginFile))
|
2020-05-11 09:22:45 +00:00
|
|
|
}
|
|
|
|
|
2020-05-07 09:13:48 +00:00
|
|
|
cmdlist(sender: any, type: string = 'cloud') {
|
2020-05-13 10:42:05 +00:00
|
|
|
if (type == "i" || type == "install") {
|
2020-05-07 16:50:30 +00:00
|
|
|
this.i18n(sender, 'list.install.header')
|
2020-03-30 10:49:19 +00:00
|
|
|
this.pluginManager.getPlugins().forEach((plugin) => {
|
2020-07-25 07:24:02 +00:00
|
|
|
this.i18n(sender, 'list.install.body', { ...plugin.description, from: plugin.description.loadMetadata.type })
|
2020-03-30 10:49:19 +00:00
|
|
|
})
|
|
|
|
} else {
|
|
|
|
this.i18n(sender, 'list.header')
|
|
|
|
for (var pkgName in this.packageCache) {
|
2020-06-20 08:40:34 +00:00
|
|
|
this.i18n(sender, 'list.body', this.packageCache[pkgName])
|
2020-03-30 10:49:19 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
cmdinstall(sender: any, name: string) {
|
|
|
|
if (!name) { return this.i18n(sender, 'plugin.name.empty') }
|
2020-06-20 08:40:34 +00:00
|
|
|
this.download(sender, name)
|
2020-03-30 10:49:19 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
cmdupdate(sender: any, name: string) {
|
|
|
|
if (name) {
|
2020-06-20 08:40:34 +00:00
|
|
|
this.update(sender, name)
|
2020-03-30 10:49:19 +00:00
|
|
|
} else {
|
|
|
|
this.updateRepo(sender)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-07-06 08:13:18 +00:00
|
|
|
cmdupgrade(sender: any, name: string, confirm: boolean) {
|
|
|
|
if (name == "system") {
|
|
|
|
if (!confirm) { return this.i18n(sender, 'upgrade.confirm') }
|
|
|
|
let enginePath = fs.path(fs.file(root, 'node_modules'))
|
2020-05-07 16:50:30 +00:00
|
|
|
if (enginePath.startsWith(root)) {
|
2020-06-20 08:40:34 +00:00
|
|
|
base.delete(enginePath)
|
|
|
|
this.cmdrestart(sender)
|
2020-05-07 16:50:30 +00:00
|
|
|
}
|
2020-07-06 08:13:18 +00:00
|
|
|
return
|
2020-05-07 16:50:30 +00:00
|
|
|
}
|
|
|
|
if (this.checkPlugin(sender, name)) {
|
2020-06-20 08:40:34 +00:00
|
|
|
this.update(sender, name)
|
|
|
|
this.pluginManager.reload(name)
|
2020-05-07 16:50:30 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-03-30 10:49:19 +00:00
|
|
|
cmdunload(sender: any, name: string) {
|
|
|
|
if (this.checkPlugin(sender, name)) {
|
|
|
|
this.pluginManager.disable(name)
|
|
|
|
this.i18n(sender, 'plugin.unload.finish', { name })
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
cmdreload(sender: any, name: string) {
|
2020-05-07 10:33:10 +00:00
|
|
|
name = name || this.description.name
|
2020-03-30 10:49:19 +00:00
|
|
|
if (this.checkPlugin(sender, name)) {
|
2020-06-20 08:40:34 +00:00
|
|
|
this.pluginManager.reload(name)
|
2020-03-30 10:49:19 +00:00
|
|
|
this.i18n(sender, 'plugin.reload.finish', { name })
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
checkPlugin(sender: any, name: string) {
|
|
|
|
if (name && this.pluginManager.getPlugins().has(name)) { return true }
|
|
|
|
this.i18n(sender, 'plugin.not.exists', { name })
|
|
|
|
return false
|
|
|
|
}
|
|
|
|
|
2020-05-07 09:13:48 +00:00
|
|
|
checkCloudPlugin(sender: any, name: string) {
|
|
|
|
if (name && this.packageNameCache.includes(name)) { return true }
|
|
|
|
this.i18n(sender, 'cloud.not.exists', { name })
|
|
|
|
return false
|
|
|
|
}
|
|
|
|
|
2020-03-30 10:49:19 +00:00
|
|
|
cmdrestart(sender: any) {
|
|
|
|
if (this.serverType === "sponge") {
|
|
|
|
setTimeout(() => this.server.dispatchConsoleCommand('sponge plugins reload'), 0)
|
|
|
|
return
|
|
|
|
}
|
|
|
|
try {
|
2020-06-20 08:40:34 +00:00
|
|
|
this.logger.sender(sender, '§6Reloading §3MiaoScript Engine...')
|
|
|
|
ScriptEngineContextHolder.disableEngine()
|
|
|
|
Packages.java.lang.System.gc()
|
|
|
|
ScriptEngineContextHolder.enableEngine()
|
|
|
|
this.logger.sender(sender, '§3MiaoScript Engine §6Reload §aSuccessful...')
|
2020-03-30 10:49:19 +00:00
|
|
|
} catch (ex) {
|
2020-06-20 08:40:34 +00:00
|
|
|
this.logger.sender(sender, "§3MiaoScript Engine §6Reload §cError! ERR: " + ex)
|
|
|
|
this.logger.sender(sender, this.logger.stack(ex))
|
2020-03-30 10:49:19 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-05-07 09:13:48 +00:00
|
|
|
cmdrun(sender: any, ...args: any[]) {
|
2020-03-30 10:49:19 +00:00
|
|
|
try {
|
2020-06-20 08:40:34 +00:00
|
|
|
let script = args.join(' ')
|
2020-05-11 16:07:05 +00:00
|
|
|
this.i18n(sender, 'run.script', { script })
|
2020-06-20 08:40:34 +00:00
|
|
|
let result = this.runCode(script, sender)
|
2020-05-13 10:42:05 +00:00
|
|
|
this.i18n(sender, 'run.result', { result: result == undefined ? this.translate.translate('run.noresult') : result + '' })
|
2020-03-30 10:49:19 +00:00
|
|
|
} catch (ex) {
|
2020-06-20 08:40:34 +00:00
|
|
|
this.logger.sender(sender, this.logger.stack(ex))
|
2020-03-30 10:49:19 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-06-20 08:40:34 +00:00
|
|
|
private runCode(code: string, sender: any) {
|
|
|
|
let paramNames = [
|
|
|
|
'sender',
|
|
|
|
'reflect',
|
|
|
|
'container',
|
|
|
|
'pluginManager'
|
|
|
|
]
|
|
|
|
let params = [
|
|
|
|
sender,
|
|
|
|
reflect,
|
|
|
|
container,
|
|
|
|
this.pluginManager
|
|
|
|
]
|
|
|
|
let tfunc = new Function(
|
|
|
|
...paramNames,
|
|
|
|
`var api = require('@ccms/api');
|
|
|
|
if (this.serverType == "spring") {
|
|
|
|
var dbm = container.get(api.database.DataBaseManager)
|
|
|
|
var db = dbm.getMainDatabase()
|
|
|
|
var df = base.getInstance().getAutowireCapableBeanFactory()
|
|
|
|
}
|
|
|
|
return '§a返回结果: §r'+ eval(${JSON.stringify(code)});`)
|
|
|
|
return tfunc.apply(this, params) + ''
|
|
|
|
}
|
|
|
|
|
2020-05-07 09:13:48 +00:00
|
|
|
cmddeploy(sender: any, name: any) {
|
2020-05-11 16:07:05 +00:00
|
|
|
if (!process.env.AccessToken) { return this.i18n(sender, 'deploy.token.not.exists') }
|
2020-05-07 09:13:48 +00:00
|
|
|
this.taskManager.create(() => {
|
|
|
|
if (this.checkPlugin(sender, name)) {
|
2020-06-20 08:40:34 +00:00
|
|
|
let plugin: pluginApi.Plugin = this.pluginManager.getPlugins().get(name)
|
2020-05-11 16:07:05 +00:00
|
|
|
let result = http.post("http://ms.yumc.pw/api/plugin/deploy?access_token=" + process.env.AccessToken, {
|
2020-05-07 09:13:48 +00:00
|
|
|
name,
|
|
|
|
author: plugin.description.author,
|
|
|
|
version: plugin.description.version,
|
2020-07-06 08:13:18 +00:00
|
|
|
source: base.read((plugin.description.source || plugin.description.loadMetadata.file).toString())
|
2020-05-07 09:13:48 +00:00
|
|
|
})
|
2020-05-07 16:50:30 +00:00
|
|
|
this.i18n(sender, result.code == 200 ? 'deploy.success' : 'deploy.fail', { name, msg: result.msg })
|
2020-05-07 09:13:48 +00:00
|
|
|
}
|
|
|
|
}).async().submit()
|
|
|
|
}
|
|
|
|
|
2020-03-30 10:49:19 +00:00
|
|
|
update(sender: any, name: string) {
|
2020-05-07 09:13:48 +00:00
|
|
|
if (this.checkCloudPlugin(sender, name)) {
|
2020-06-20 08:40:34 +00:00
|
|
|
this.download(sender, name, true)
|
2019-09-22 15:31:52 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
@tab()
|
2020-05-07 09:13:48 +00:00
|
|
|
tabmpm(sender: any, command: any, args: string | any[]) {
|
2020-05-07 10:33:10 +00:00
|
|
|
if (args.length === 1) { return ['list', 'install', 'update', 'upgrade', 'reload', 'restart', 'run', 'help', 'create', 'deploy'] }
|
2019-09-22 15:31:52 +00:00
|
|
|
if (args.length > 1) {
|
|
|
|
switch (args[0]) {
|
2020-03-30 10:49:19 +00:00
|
|
|
case "list":
|
|
|
|
return ["install", "cloud"]
|
2019-09-22 15:31:52 +00:00
|
|
|
case "install":
|
2020-06-20 08:40:34 +00:00
|
|
|
return this.packageNameCache
|
2019-09-22 15:31:52 +00:00
|
|
|
case "upgrade":
|
2020-07-06 08:13:18 +00:00
|
|
|
if (args.length == 2) return ["system", ...this.pluginManager.getPlugins().keys()]
|
|
|
|
if (args.length == 3 && args[1] == "system") return ["confirm"]
|
|
|
|
return []
|
|
|
|
case "update":
|
2020-02-23 16:13:19 +00:00
|
|
|
case "load":
|
|
|
|
case "unload":
|
2019-09-22 15:31:52 +00:00
|
|
|
case "reload":
|
2020-05-07 10:33:10 +00:00
|
|
|
case "deploy":
|
2020-06-20 08:40:34 +00:00
|
|
|
return [...this.pluginManager.getPlugins().keys()]
|
2019-09-22 15:31:52 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2020-03-30 10:49:19 +00:00
|
|
|
|
|
|
|
updateRepo(sender: any) {
|
|
|
|
this.taskManager.create(() => {
|
2020-06-20 08:40:34 +00:00
|
|
|
let result = http.get('http://ms.yumc.pw/api/plugin/list')
|
|
|
|
for (const pl of result.data) { this.packageCache[pl.name] = pl }
|
|
|
|
this.packageNameCache = Object.keys(this.packageCache)
|
2020-03-30 10:49:19 +00:00
|
|
|
this.i18n(sender, 'cloud.update.finish', { length: this.packageNameCache.length })
|
2020-06-20 08:40:34 +00:00
|
|
|
}).async().submit()
|
2020-03-30 10:49:19 +00:00
|
|
|
}
|
|
|
|
|
2020-05-07 10:33:10 +00:00
|
|
|
download(sender: any, name: string, update: boolean = false) {
|
2020-05-07 09:13:48 +00:00
|
|
|
this.taskManager.create(() => {
|
|
|
|
this.i18n(sender, 'download.start', { name })
|
|
|
|
this.i18n(sender, 'download.url', { url: this.packageCache[name].url })
|
2020-05-13 10:42:05 +00:00
|
|
|
let pluginFile = update ? fs.concat(root, this.pluginFolder, 'update', name + '.js') : fs.concat(root, this.pluginFolder, name + '.js')
|
2020-05-07 09:13:48 +00:00
|
|
|
http.download(this.packageCache[name].url, pluginFile)
|
|
|
|
this.i18n(sender, 'download.finish', { name })
|
2020-05-13 10:42:05 +00:00
|
|
|
if (!update) {
|
2020-07-25 07:24:02 +00:00
|
|
|
this.pluginManager.loadFromFile(fs.concat(root, this.pluginFolder, name + '.js'))
|
2020-05-13 10:42:05 +00:00
|
|
|
this.i18n(sender, 'install.finish', { name })
|
|
|
|
} else {
|
|
|
|
this.i18n(sender, 'update.finish', { name })
|
|
|
|
}
|
2020-05-07 09:13:48 +00:00
|
|
|
}).async().submit()
|
2020-03-30 10:49:19 +00:00
|
|
|
}
|
2020-01-16 09:27:24 +00:00
|
|
|
}
|