@@ -1,4 +1,4 @@
 | 
			
		||||
import { injectable, decorate } from "@ccms/container";
 | 
			
		||||
import { injectable, decorate } from "@ccms/container"
 | 
			
		||||
import { interfaces } from './interfaces'
 | 
			
		||||
import { METADATA_KEY } from './constants'
 | 
			
		||||
import { getPluginMetadatas, getPluginCommandMetadata, getPluginListenerMetadata, getPluginTabCompleterMetadata, getPluginConfigMetadata, getPluginStageMetadata, getPluginSources } from './utils'
 | 
			
		||||
@@ -9,17 +9,17 @@ import { getPluginMetadatas, getPluginCommandMetadata, getPluginListenerMetadata
 | 
			
		||||
 */
 | 
			
		||||
export function plugin(metadata: interfaces.PluginMetadata) {
 | 
			
		||||
    return function (target: any) {
 | 
			
		||||
        metadata.target = target;
 | 
			
		||||
        metadata.type = "ioc";
 | 
			
		||||
        decorate(injectable(), target);
 | 
			
		||||
        Reflect.defineMetadata(METADATA_KEY.plugin, metadata, target);
 | 
			
		||||
        const previousMetadata: Map<string, interfaces.PluginMetadata> = getPluginMetadatas();
 | 
			
		||||
        previousMetadata.set(metadata.name, metadata);
 | 
			
		||||
        Reflect.defineMetadata(METADATA_KEY.plugin, previousMetadata, Reflect);
 | 
			
		||||
        const previousSources: Map<string, interfaces.PluginMetadata> = getPluginSources();
 | 
			
		||||
        previousSources.set(metadata.source.toString(), metadata);
 | 
			
		||||
        Reflect.defineMetadata(METADATA_KEY.souece, previousSources, Reflect);
 | 
			
		||||
    };
 | 
			
		||||
        metadata.target = target
 | 
			
		||||
        metadata.type = "ioc"
 | 
			
		||||
        decorate(injectable(), target)
 | 
			
		||||
        Reflect.defineMetadata(METADATA_KEY.plugin, metadata, target)
 | 
			
		||||
        const previousMetadata: Map<string, interfaces.PluginMetadata> = getPluginMetadatas()
 | 
			
		||||
        previousMetadata.set(metadata.name, metadata)
 | 
			
		||||
        Reflect.defineMetadata(METADATA_KEY.plugin, previousMetadata, Reflect)
 | 
			
		||||
        const previousSources: Map<string, interfaces.PluginMetadata> = getPluginSources()
 | 
			
		||||
        previousSources.set(metadata.source.toString(), metadata)
 | 
			
		||||
        Reflect.defineMetadata(METADATA_KEY.souece, previousSources, Reflect)
 | 
			
		||||
    }
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
@@ -28,13 +28,13 @@ export function plugin(metadata: interfaces.PluginMetadata) {
 | 
			
		||||
 */
 | 
			
		||||
export function cmd(metadata: interfaces.CommandMetadata = {}) {
 | 
			
		||||
    return function (target: any, key: string, value: any) {
 | 
			
		||||
        metadata.name = metadata.name || key;
 | 
			
		||||
        metadata.executor = key;
 | 
			
		||||
        metadata.name = metadata.name || key
 | 
			
		||||
        metadata.executor = key
 | 
			
		||||
        metadata.paramtypes = Reflect.getMetadata("design:paramtypes", target, key)
 | 
			
		||||
        const previousMetadata: Map<string, interfaces.CommandMetadata> = getPluginCommandMetadata(target)
 | 
			
		||||
        previousMetadata.set(metadata.name, metadata);
 | 
			
		||||
        Reflect.defineMetadata(METADATA_KEY.cmd, previousMetadata, target.constructor);
 | 
			
		||||
    };
 | 
			
		||||
        previousMetadata.set(metadata.name, metadata)
 | 
			
		||||
        Reflect.defineMetadata(METADATA_KEY.cmd, previousMetadata, target.constructor)
 | 
			
		||||
    }
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
@@ -43,14 +43,14 @@ export function cmd(metadata: interfaces.CommandMetadata = {}) {
 | 
			
		||||
 */
 | 
			
		||||
export function tab(metadata: interfaces.CommandMetadata = {}) {
 | 
			
		||||
    return function (target: any, key: string, value: any) {
 | 
			
		||||
        metadata.name = metadata.name || (key.startsWith('tab') ? key.split('tab', 2)[1] : key);
 | 
			
		||||
        if (!metadata.name) { return; }
 | 
			
		||||
        metadata.executor = key;
 | 
			
		||||
        metadata.name = metadata.name || (key.startsWith('tab') ? key.split('tab', 2)[1] : key)
 | 
			
		||||
        if (!metadata.name) { return }
 | 
			
		||||
        metadata.executor = key
 | 
			
		||||
        metadata.paramtypes = Reflect.getMetadata("design:paramtypes", target, key)
 | 
			
		||||
        const previousMetadata: Map<string, interfaces.CommandMetadata> = getPluginTabCompleterMetadata(target)
 | 
			
		||||
        previousMetadata.set(metadata.name, metadata)
 | 
			
		||||
        Reflect.defineMetadata(METADATA_KEY.tab, previousMetadata, target.constructor);
 | 
			
		||||
    };
 | 
			
		||||
        Reflect.defineMetadata(METADATA_KEY.tab, previousMetadata, target.constructor)
 | 
			
		||||
    }
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
@@ -59,30 +59,32 @@ export function tab(metadata: interfaces.CommandMetadata = {}) {
 | 
			
		||||
 */
 | 
			
		||||
export function listener(metadata: interfaces.ListenerMetadata = {}) {
 | 
			
		||||
    return function (target: any, key: string, value: any) {
 | 
			
		||||
        metadata.name = metadata.name || key;
 | 
			
		||||
        metadata.executor = key;
 | 
			
		||||
        metadata.name = metadata.name || key
 | 
			
		||||
        metadata.executor = key
 | 
			
		||||
        const previousMetadata: interfaces.ListenerMetadata[] = getPluginListenerMetadata(target)
 | 
			
		||||
        Reflect.defineMetadata(METADATA_KEY.listener, [metadata, ...previousMetadata], target.constructor);
 | 
			
		||||
    };
 | 
			
		||||
        Reflect.defineMetadata(METADATA_KEY.listener, [metadata, ...previousMetadata], target.constructor)
 | 
			
		||||
    }
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
export function config(metadata: interfaces.ConfigMetadata = { version: 1, format: 'yml' }) {
 | 
			
		||||
export function config(metadata: interfaces.ConfigMetadata = {}) {
 | 
			
		||||
    return function (target: any, key: string) {
 | 
			
		||||
        metadata.name = metadata.name || key;
 | 
			
		||||
        metadata.variable = key;
 | 
			
		||||
        metadata.name = metadata.name || key
 | 
			
		||||
        metadata.variable = key
 | 
			
		||||
        metadata.version = metadata.version ?? 1
 | 
			
		||||
        metadata.format = metadata.format ?? 'yml'
 | 
			
		||||
        const previousMetadata: Map<string, interfaces.ConfigMetadata> = getPluginConfigMetadata(target)
 | 
			
		||||
        previousMetadata.set(metadata.name, metadata);
 | 
			
		||||
        Reflect.defineMetadata(METADATA_KEY.config, previousMetadata, target.constructor);
 | 
			
		||||
        previousMetadata.set(metadata.name, metadata)
 | 
			
		||||
        Reflect.defineMetadata(METADATA_KEY.config, previousMetadata, target.constructor)
 | 
			
		||||
    }
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
function stage(metadata: interfaces.ExecMetadata = {}, stage: string) {
 | 
			
		||||
    return function (target: any, key: string, value: any) {
 | 
			
		||||
        metadata.name = metadata.name || key;
 | 
			
		||||
        metadata.executor = key;
 | 
			
		||||
        metadata.name = metadata.name || key
 | 
			
		||||
        metadata.executor = key
 | 
			
		||||
        const previousMetadata: interfaces.ExecMetadata[] = getPluginStageMetadata(target, stage)
 | 
			
		||||
        Reflect.defineMetadata(METADATA_KEY.stage[stage], [metadata, ...previousMetadata], target.constructor);
 | 
			
		||||
    };
 | 
			
		||||
        Reflect.defineMetadata(METADATA_KEY.stage[stage], [metadata, ...previousMetadata], target.constructor)
 | 
			
		||||
    }
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
export function load(metadata: interfaces.ExecMetadata = {}) {
 | 
			
		||||
 
 | 
			
		||||
@@ -30,8 +30,8 @@ export class PluginManagerImpl implements plugin.PluginManager {
 | 
			
		||||
    private pluginMetadataMap: Map<string, interfaces.PluginMetadata>
 | 
			
		||||
 | 
			
		||||
    initialize() {
 | 
			
		||||
        if (this.pluginInstance !== null && this.initialized !== true) {
 | 
			
		||||
            // 如果plugin不等于null 则代表是正式环境
 | 
			
		||||
        if (this.pluginInstance === undefined) { throw new Error("Can't found Plugin Instance!") }
 | 
			
		||||
        if (this.initialized !== true) {
 | 
			
		||||
            console.i18n('ms.plugin.initialize', { plugin: this.pluginInstance, loader: Thread.currentThread().contextClassLoader })
 | 
			
		||||
            console.i18n('ms.plugin.event.map', { count: this.EventManager.mapEventName().toFixed(0), type: this.serverType })
 | 
			
		||||
            this.pluginRequireMap = new Map()
 | 
			
		||||
@@ -262,7 +262,12 @@ export class PluginManagerImpl implements plugin.PluginManager {
 | 
			
		||||
                    console.i18n("ms.plugin.manager.config.save.default", { plugin: plugin.description.name, name: config.name, format: config.format })
 | 
			
		||||
                } else {
 | 
			
		||||
                    plugin[config.variable] = configFactory.load(base.read(configFile))
 | 
			
		||||
                    plugin[config.variable].save = () => base.save(configFile, configFactory.dump(plugin[config.variable]))
 | 
			
		||||
                    plugin[config.variable].save = () => {
 | 
			
		||||
                        let result = configFactory.dump(plugin[config.variable])
 | 
			
		||||
                        base.save(configFile, result)
 | 
			
		||||
                        console.debug(`[${plugin.description.name}] Save Config ${config.variable} to file ${configFile} result ${result}`)
 | 
			
		||||
                    }
 | 
			
		||||
                    console.debug(`[${plugin.description.name}] Load Config ${config.variable} from file ${configFile} result ${JSON.stringify(plugin[config.variable])}`)
 | 
			
		||||
                }
 | 
			
		||||
            } catch (error) {
 | 
			
		||||
                console.i18n("ms.plugin.manager.config.load.error", { plugin: plugin.description.name, name: config.name, format: config.format, error })
 | 
			
		||||
 
 | 
			
		||||
		Reference in New Issue
	
	Block a user