Class ViewAccessChecker
- All Implemented Interfaces:
BeforeEnterListener,BeforeEnterHandler,Serializable
- Direct Known Subclasses:
SpringViewAccessChecker
AccessAnnotationChecker.
An instance of this class should be added as a BeforeEnterListener to
the UI of interest.
- See Also:
-
Field Summary
Fields -
Constructor Summary
ConstructorsModifierConstructorDescriptionCreates an instance.ViewAccessChecker(boolean enabled) Creates an instance and enables access checker depending on the given flag.protectedViewAccessChecker(AccessAnnotationChecker accessAnnotationChecker) Creates an instance using the given checker. -
Method Summary
Modifier and TypeMethodDescriptionvoidbeforeEnter(BeforeEnterEvent beforeEnterEvent) Callback executed before navigation to attaching Component chain is made.voidenable()Enables the access checker.protected PrincipalgetPrincipal(VaadinRequest request) Gets the principal for the currently logged in user.getRolesChecker(VaadinRequest request) Gets a function for checking roles for the currently logged in user.voidsetLoginView(Class<? extends Component> loginView) Sets the Flow login view to use.voidsetLoginView(String loginUrl) Sets the frontend login view to use.
-
Field Details
-
SESSION_STORED_REDIRECT
-
SESSION_STORED_REDIRECT_ABSOLUTE
-
-
Constructor Details
-
ViewAccessChecker
public ViewAccessChecker()Creates an instance.Note that the access checker is enabled by default. If this isn't desired, one can use
ViewAccessChecker(boolean)withenabled=falseand callenable()later on whenever appropriate. -
ViewAccessChecker
public ViewAccessChecker(boolean enabled) Creates an instance and enables access checker depending on the given flag.- Parameters:
enabled-falsefor disabling the access checker,truefor enabling the access checker.
-
ViewAccessChecker
Creates an instance using the given checker.Note that the access checker is disabled by default and can be enabled using
enable(). You should also set the login view to use usingsetLoginView(Class)orsetLoginView(String)- Parameters:
accessAnnotationChecker- the checker to use
-
-
Method Details
-
enable
public void enable()Enables the access checker.This must be called for the access checker to perform any checks. By default the access checker is disabled.
-
setLoginView
Sets the Flow login view to use.The login view can only be set once and cannot be changed afterwards.
Note that the access checker needs to be separately enabled using
enable()- Parameters:
loginView- the Flow view to use as login view
-
setLoginView
Sets the frontend login view to use.The login view can only be set once and cannot be changed afterwards.
Note that the access checker needs to be separately enabled using
enable()- Parameters:
loginUrl- the frontend view to use as login view
-
beforeEnter
Description copied from interface:BeforeEnterHandlerCallback executed before navigation to attaching Component chain is made.- Specified by:
beforeEnterin interfaceBeforeEnterHandler- Parameters:
beforeEnterEvent- before navigation event with event details
-
getRolesChecker
Gets a function for checking roles for the currently logged in user.- Parameters:
request- the current request ornullif no request is in progress (e.g. in a background thread)- Returns:
- a function which takes a role name and returns
trueif the user is included in that role
-
getPrincipal
Gets the principal for the currently logged in user.- Parameters:
request- the current request ornullif no request is in progress (e.g. in a background thread)- Returns:
- a representation of the currently logged in user or
nullif no user is currently logged in
-