mirror of
https://github.com/LamGC/ContentGrabbingJi.git
synced 2025-04-30 06:37:36 +00:00
[Add][Change] Framework-API, Core 添加 FrameworkContext 用于向 Framework 传递与 Bot 有关的相关对象;
[Add] FrameworkContext, DefaultFrameworkContext 添加 FrameworkContext 和一个默认实现; [Change] Framework, FrameworkFactory 调整代码以支持传递 FrameworkContext;
This commit is contained in:
parent
4a2337afd7
commit
2875426f72
@ -0,0 +1,47 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (C) 2020 LamGC
|
||||||
|
*
|
||||||
|
* ContentGrabbingJi is free software: you can redistribute it and/or modify
|
||||||
|
* it under the terms of the GNU Affero General Public License as
|
||||||
|
* published by the Free Software Foundation, either version 3 of the
|
||||||
|
* License, or (at your option) any later version.
|
||||||
|
*
|
||||||
|
* ContentGrabbingJi is distributed in the hope that it will be useful,
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
* GNU Affero General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU Affero General Public License
|
||||||
|
* along with this program. If not, see <https://www.gnu.org/licenses/>.
|
||||||
|
*/
|
||||||
|
|
||||||
|
package net.lamgc.cgj.bot.framework;
|
||||||
|
|
||||||
|
import net.lamgc.cgj.bot.cache.CacheStoreBuilder;
|
||||||
|
import net.lamgc.cgj.bot.event.EventExecutor;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 框架上下文的默认实现.
|
||||||
|
* @author LamGC
|
||||||
|
*/
|
||||||
|
class DefaultFrameworkContext implements FrameworkContext {
|
||||||
|
|
||||||
|
private final EventExecutor eventExecutor;
|
||||||
|
private final CacheStoreBuilder cacheStoreBuilder;
|
||||||
|
|
||||||
|
public DefaultFrameworkContext(EventExecutor eventExecutor, CacheStoreBuilder cacheStoreBuilder) {
|
||||||
|
this.eventExecutor = eventExecutor;
|
||||||
|
|
||||||
|
this.cacheStoreBuilder = cacheStoreBuilder;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public EventExecutor getEventExecutor() {
|
||||||
|
return eventExecutor;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public CacheStoreBuilder getCacheStoreBuilder() {
|
||||||
|
return cacheStoreBuilder;
|
||||||
|
}
|
||||||
|
}
|
@ -17,6 +17,8 @@
|
|||||||
|
|
||||||
package net.lamgc.cgj.bot.framework;
|
package net.lamgc.cgj.bot.framework;
|
||||||
|
|
||||||
|
import net.lamgc.cgj.bot.cache.CacheStoreBuilder;
|
||||||
|
import net.lamgc.cgj.bot.event.EventExecutor;
|
||||||
import org.pf4j.Plugin;
|
import org.pf4j.Plugin;
|
||||||
import org.pf4j.PluginFactory;
|
import org.pf4j.PluginFactory;
|
||||||
import org.pf4j.PluginWrapper;
|
import org.pf4j.PluginWrapper;
|
||||||
@ -36,9 +38,13 @@ final class FrameworkFactory implements PluginFactory {
|
|||||||
private final static Logger log = LoggerFactory.getLogger(FrameworkFactory.class);
|
private final static Logger log = LoggerFactory.getLogger(FrameworkFactory.class);
|
||||||
|
|
||||||
private final File dataRootFolder;
|
private final File dataRootFolder;
|
||||||
|
private final CacheStoreBuilder cacheStoreBuilder;
|
||||||
|
private final EventExecutor eventExecutor;
|
||||||
|
|
||||||
public FrameworkFactory(File dataRootFolder) {
|
public FrameworkFactory(File dataRootFolder, CacheStoreBuilder cacheStoreBuilder, EventExecutor eventExecutor) {
|
||||||
this.dataRootFolder = dataRootFolder;
|
this.dataRootFolder = dataRootFolder;
|
||||||
|
this.cacheStoreBuilder = cacheStoreBuilder;
|
||||||
|
this.eventExecutor = eventExecutor;
|
||||||
if (!this.dataRootFolder.exists() && !this.dataRootFolder.mkdirs()) {
|
if (!this.dataRootFolder.exists() && !this.dataRootFolder.mkdirs()) {
|
||||||
log.warn("框架数据目录创建异常, 可能会导致后续框架存取数据失败!");
|
log.warn("框架数据目录创建异常, 可能会导致后续框架存取数据失败!");
|
||||||
}
|
}
|
||||||
@ -67,9 +73,11 @@ final class FrameworkFactory implements PluginFactory {
|
|||||||
|
|
||||||
try {
|
try {
|
||||||
// <init>(PluginWrapper, DataFolder)
|
// <init>(PluginWrapper, DataFolder)
|
||||||
Constructor<?> constructor = pluginClass.getConstructor(PluginWrapper.class, File.class);
|
Constructor<?> constructor = pluginClass
|
||||||
return (Plugin) constructor.newInstance(pluginWrapper,
|
.getConstructor(PluginWrapper.class, File.class, FrameworkContext.class);
|
||||||
new File(dataRootFolder, pluginWrapper.getPluginId()));
|
return (Framework) constructor.newInstance(pluginWrapper,
|
||||||
|
new File(dataRootFolder, pluginWrapper.getPluginId()),
|
||||||
|
new DefaultFrameworkContext(eventExecutor, cacheStoreBuilder));
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
log.error(e.getMessage(), e);
|
log.error(e.getMessage(), e);
|
||||||
}
|
}
|
||||||
|
@ -31,6 +31,7 @@ import java.io.File;
|
|||||||
public abstract class Framework extends Plugin {
|
public abstract class Framework extends Plugin {
|
||||||
|
|
||||||
private final File dataFolder;
|
private final File dataFolder;
|
||||||
|
private final FrameworkContext context;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 由 FrameworkManager 执行的构造方法.
|
* 由 FrameworkManager 执行的构造方法.
|
||||||
@ -38,8 +39,9 @@ public abstract class Framework extends Plugin {
|
|||||||
*
|
*
|
||||||
* @param wrapper 包含框架运行期间需要使用对象的包装器.
|
* @param wrapper 包含框架运行期间需要使用对象的包装器.
|
||||||
*/
|
*/
|
||||||
public Framework(PluginWrapper wrapper, File dataFolder) {
|
public Framework(PluginWrapper wrapper, File dataFolder, FrameworkContext context) {
|
||||||
super(wrapper);
|
super(wrapper);
|
||||||
|
this.context = context;
|
||||||
if (!(wrapper.getDescriptor() instanceof FrameworkDescriptor)) {
|
if (!(wrapper.getDescriptor() instanceof FrameworkDescriptor)) {
|
||||||
throw new IllegalStateException("Invalid description object");
|
throw new IllegalStateException("Invalid description object");
|
||||||
}
|
}
|
||||||
@ -86,4 +88,11 @@ public abstract class Framework extends Plugin {
|
|||||||
throw new IllegalStateException("无法转换 Descriptor 的类型, 框架管理器可能遭到修改!");
|
throw new IllegalStateException("无法转换 Descriptor 的类型, 框架管理器可能遭到修改!");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 获取当前框架对象与所属 ContentGrabbingJiBot 的上下文.
|
||||||
|
* @return 返回上下文对象.
|
||||||
|
*/
|
||||||
|
protected FrameworkContext getContext() {
|
||||||
|
return context;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -0,0 +1,45 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (C) 2020 LamGC
|
||||||
|
*
|
||||||
|
* ContentGrabbingJi is free software: you can redistribute it and/or modify
|
||||||
|
* it under the terms of the GNU Affero General Public License as
|
||||||
|
* published by the Free Software Foundation, either version 3 of the
|
||||||
|
* License, or (at your option) any later version.
|
||||||
|
*
|
||||||
|
* ContentGrabbingJi is distributed in the hope that it will be useful,
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
* GNU Affero General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU Affero General Public License
|
||||||
|
* along with this program. If not, see <https://www.gnu.org/licenses/>.
|
||||||
|
*/
|
||||||
|
|
||||||
|
package net.lamgc.cgj.bot.framework;
|
||||||
|
|
||||||
|
import net.lamgc.cgj.bot.cache.CacheStoreBuilder;
|
||||||
|
import net.lamgc.cgj.bot.event.EventExecutor;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 框架上下文对象.
|
||||||
|
* <p> 由于 ContentGrabbingJi 按实例分配资源,
|
||||||
|
* 故 Context 可获取专属于框架所属实例的相关可用资源以供框架使用.
|
||||||
|
* @author LamGC
|
||||||
|
*/
|
||||||
|
public interface FrameworkContext {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 获取事件执行器.
|
||||||
|
* <p> 事件执行器用于将事件提交给 CGJ 进行处理.
|
||||||
|
* @return 返回事件执行器.
|
||||||
|
*/
|
||||||
|
EventExecutor getEventExecutor();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 获取缓存存储容器构造器.
|
||||||
|
* <p> 如需使用缓存, 可通过 {@link CacheStoreBuilder} 获取独立的缓存容器.
|
||||||
|
* @return 返回构造器.
|
||||||
|
*/
|
||||||
|
CacheStoreBuilder getCacheStoreBuilder();
|
||||||
|
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user