Class ResolverSvc
- All Implemented Interfaces:
ResolverService
-
Nested Class Summary
Nested classes/interfaces inherited from interface com.djrapitops.plan.delivery.web.ResolverService
ResolverService.Holder
-
Constructor Summary
ConstructorDescriptionResolverSvc
(PlanConfig config, net.playeranalytics.plugin.server.PluginLogger logger, DBSystem dbSystem) -
Method Summary
Modifier and TypeMethodDescriptiongetPluginInChargeOf
(String target) getResolver
(String target) Obtain aResolver
for a target.getResolvers
(String target) Obtain all Resolvers that match the target.void
register()
void
registerPermission
(String webPermission, String whenHasPermission) Register a new permission that you are using in yourResolver.canAccess(Request)
method.registerPermissions
(String... webPermissions) Register a new permission that you are using in yourResolver.canAccess(Request)
method.void
registerResolver
(String pluginName, String start, Resolver resolver) Register a new resolver.void
registerResolverForMatches
(String pluginName, Pattern pattern, Resolver resolver) Register a new resolver with regex that matches start of target.
-
Constructor Details
-
ResolverSvc
@Inject public ResolverSvc(PlanConfig config, net.playeranalytics.plugin.server.PluginLogger logger, DBSystem dbSystem)
-
-
Method Details
-
register
public void register() -
registerResolver
Description copied from interface:ResolverService
Register a new resolver.- Specified by:
registerResolver
in interfaceResolverService
- Parameters:
pluginName
- Name of the plugin that is registering (For error messages)start
- Start of the target to match against, eg "/example" will send "/example/target" etc to the Resolver.resolver
-Resolver
to use for this
-
registerResolverForMatches
Description copied from interface:ResolverService
Register a new resolver with regex that matches start of target.NOTICE: It is recommended to avoid too generic regex like "/.*" to not override existing resolvers.
Parameters (?param=value) are not included in the regex matching.
- Specified by:
registerResolverForMatches
in interfaceResolverService
- Parameters:
pluginName
- Name of the plugin that is registering (For error messages)pattern
- Regex Pattern, "/example.*" will send "/exampletarget" etc to the Resolver.resolver
-Resolver
to use for this.
-
registerPermissions
Description copied from interface:ResolverService
Register a new permission that you are using in yourResolver.canAccess(Request)
method.The permissions are not given to any users by default, and need to be given by admin manually.
- Specified by:
registerPermissions
in interfaceResolverService
- Parameters:
webPermissions
- Permission strings, higher level permissions grant lower level automatically - eg. page.foo also grants page.foo.bar- Returns:
- CompletableFuture that tells when the permissions have been stored.
-
registerPermission
Description copied from interface:ResolverService
Register a new permission that you are using in yourResolver.canAccess(Request)
method.The permission is granted to any groups with
whenHasPermission
parameter.- Specified by:
registerPermission
in interfaceResolverService
- Parameters:
webPermission
- Permission string, higher level permissions grant lower level automatically - eg. page.foo also grants page.foo.barwhenHasPermission
- Permission that a group already has that this permission should be granted to - eg. page.network.overview.numbers
-
getResolver
Description copied from interface:ResolverService
Obtain aResolver
for a target.First matching resolver will be returned.
ResolverService.registerResolver(java.lang.String, java.lang.String, com.djrapitops.plan.delivery.web.resolver.Resolver)
resolvers have higher priority thanResolverService.registerResolverForMatches(java.lang.String, java.util.regex.Pattern, com.djrapitops.plan.delivery.web.resolver.Resolver)
.Can be used when making Resolver middleware.
- Specified by:
getResolver
in interfaceResolverService
- Parameters:
target
- "/example/target"- Returns:
- Resolver if registered or empty.
-
getResolvers
Description copied from interface:ResolverService
Obtain all Resolvers that match the target.If first returns Optional.empty next one should be used.
Requires Capability PAGE_EXTENSION_RESOLVERS_LIST.
- Specified by:
getResolvers
in interfaceResolverService
- Parameters:
target
- "/example/target"- Returns:
- List of Resolvers if registered or empty list.
-
getPluginInChargeOf
-