Distributed James Server — extensions.properties

This files enables an operator to define additional bindings used to instantiate others extensions

guice.extension.module: come separated list of fully qualified class name. These classes need to implement Guice modules.

Here is an example of such a class :

public class MyServiceModule extends AbstractModule {
    @Override
    protected void configure() {
        bind(MyServiceImpl.class).in(Scopes.SINGLETON);
        bind(MyService.class).to(MyServiceImpl.class);
    }
}

Recording it in extensions.properties :

guice.extension.module=com.project.MyServiceModule

Enables to inject MyService into your extensions.

guice.extension.tasks: come separated list of fully qualified class name.

The extension can rely on the Task manager to supervise long-running task execution (progress, await, cancellation, scheduling…​). These extensions need to implement Task extension modules.

Here is an example of such a class :

public class RspamdTaskExtensionModule implements TaskExtensionModule {

    @Inject
    public RspamdTaskExtensionModule() {
    }

    @Override
    public Set<TaskDTOModule<? extends Task, ? extends TaskDTO>> taskDTOModules() {
        return Set.of(...);
    }

    @Override
    public Set<AdditionalInformationDTOModule<? extends TaskExecutionDetails.AdditionalInformation, ? extends AdditionalInformationDTO>> taskAdditionalInformationDTOModules() {
        return Set.of(...);
    }
}

Recording it in extensions.properties :

guice.extension.tasks=com.project.RspamdTaskExtensionModule

Read this page for more details.