-
Notifications
You must be signed in to change notification settings - Fork 108
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
pf4j plugin needs to refresh and detect changes automatically with spring #73
Comments
No need to rebuild the main project jars, in any circumstances. Maybe I don't understand well this part with "rebuild the plugins", can you add more details (why is necessary to rebuild the plugins, ...)? |
Hello @decebals , Thank you for the guidance. We have tried to achieve auto refreshment for plugins without rebuilding/restarting the server but facing an issue while refreshing those plugins with registering their endpoints to access their functionalities. here is the code for that along with what we getting after adding new plugin with this code - public Mono<APIResponse> refreshPlugin() throws MalformedURLException {
DefaultUpdateRepository defaultUpdateRepository = new DefaultUpdateRepository("folder", new URL("file:///F:/var/downloads/"));
// We can provide repo by adding list in update manager
// create update manager
UpdateManager updateManager = new UpdateManager(pluginManager, List.of(defaultUpdateRepository));
// >> keep system up-to-date <<
boolean systemUpToDate = true;
// check for updates
if (updateManager.hasUpdates()) {
List<PluginInfo> updates = updateManager.getUpdates();
log.debug("Found {} updates", updates.size());
for (PluginInfo plugin : updates) {
log.debug("Found update for plugin '{}'", plugin.id);
PluginInfo.PluginRelease lastRelease = updateManager.getLastPluginRelease(plugin.id);
String lastVersion = lastRelease.version;
String installedVersion = pluginManager.getPlugin(plugin.id).getDescriptor().getVersion();
log.debug("Update plugin '{}' from version {} to version {}", plugin.id, installedVersion, lastVersion);
boolean updated = updateManager.updatePlugin(plugin.id, lastVersion);
if (updated) {
log.debug("Updated plugin '{}'", plugin.id);
} else {
log.error("Cannot update plugin '{}'", plugin.id);
systemUpToDate = false;
}
}
} else {
log.debug("No updates found");
}
// check for available (new) plugins
if (updateManager.hasAvailablePlugins()) {
List<PluginInfo> availablePlugins = updateManager.getAvailablePlugins();
log.debug("Found {} available plugins", availablePlugins.size());
for (PluginInfo plugin : availablePlugins) {
log.debug("Found available plugin '{}'", plugin.id);
PluginInfo.PluginRelease lastRelease = updateManager.getLastPluginRelease(plugin.id);
String lastVersion = lastRelease.version;
log.debug("Install plugin '{}' with version {}", plugin.id, lastVersion);
boolean installed = updateManager.installPlugin(plugin.id, lastVersion);
if (installed) {
log.debug("Installed plugin '{}'", plugin.id);
pluginManager.startPlugin(plugin.id);
injectExtensions(pluginManager.getPlugin(plugin.id));
} else {
log.error("Cannot install plugin '{}'", plugin.id);
systemUpToDate = false;
}
}
pluginConfig.registerMvcEndpoints(pluginManager);
RouterFunction<ServerResponse> routes = pluginManager.getExtensions(PluginInterface.class).stream()
.flatMap(g -> g.reactiveRoutes().stream())
.map(r -> (RouterFunction<ServerResponse>) r)
.reduce((o, r) -> (RouterFunction<ServerResponse>) o.andOther(r))
.orElse(null);
if (routes != null)
pluginEndpoints.andOther(routes);
} else {
log.debug("No available plugins found");
}
if (systemUpToDate) {
log.debug("System up-to-date");
}
return userHelper.mappedToResponse(null);
}
public void injectExtensions(PluginWrapper plugin) {
Set<String> extensionClassNames;
log.debug("Registering extensions of the plugin '{}' as beans", plugin.getPluginId());
extensionClassNames = pluginManager.getExtensionClassNames(plugin.getPluginId());
Iterator var5 = extensionClassNames.iterator();
while (var5.hasNext()) {
String extensionClassName = (String) var5.next();
try {
log.debug("Register extension '{}' as bean", extensionClassName);
Class<?> extensionClass = plugin.getPluginClassLoader().loadClass(extensionClassName);
this.registerExtension(extensionClass);
} catch (ClassNotFoundException var8) {
log.error(var8.getMessage(), var8);
}
}
}
public void registerExtension(Class<?> extensionClass) {
Map<String, ?> extensionBeanMap = pluginManager.getApplicationContext().getBeansOfType(extensionClass);
if (extensionBeanMap.isEmpty()) {
Object extension = pluginManager.getExtensionFactory().create(extensionClass);
AbstractAutowireCapableBeanFactory beanFactory = (AbstractAutowireCapableBeanFactory) pluginManager.getApplicationContext().getAutowireCapableBeanFactory();
beanFactory.registerSingleton(extensionClass.getName(), extension);
} else {
log.debug("Bean registeration aborted! Extension '{}' already existed as bean!", extensionClass.getName());
}
} Please guide us on, whether it is possible to get plugin features like that. |
You add some business/logical code (RouterFunction, pluginConfig, ..) which makes it difficult for me to read and understand. [1] - https://pf4j.org/dev/quickstart.html |
@decebals,
In the above zip project spring-plugin-container is the application in which I have added code to refresh the plugin. It has the endpoint "/plugins" through which I can check registered plugins. References : |
@decebals, |
I understand your intention but I don't understand what's stopping you. It 's probably the following statement:
I remember seeing a project on Github that uses PF4J to add new routes (a plugin adds routes in application). |
Hello,
I am building a system where it requires someone to be able to add/remove, just adding the plugins in a specific folder. All plugin systems should detect that and work without refreshing or rebuilding the jars.
Currently, we have to rebuild the plugins, need to add updated plugins into our plugin container, and re-run that container to detect the changes.
Could you please suggest some ways to achieve this?
The text was updated successfully, but these errors were encountered: