Authentication
Authentication
Starting with Servoy 2023.12 a the Solution has a property "authenticator" which replaces the "mustAuthenticate" boolean and can also replace the "loginForm" and "loginSolution"
This new property has 4 possible values:
NONE
No authentication is needed, the solution can be accessed by anonymous users.
DEFAULT
This is the same as "mustAuthenticate" to true, then we are going to look if the "loginForm" is set and if that is set, servoy we load the client and show the loginForm. After that the loginForms behavior is responsible for calling security.login() to login a user into the solution with a set of permissions.
If the login form is not set, in this default mode, then we will show the stateless login screen where a user can type in his credentials and also opt to remember those credentials. If it is remembered then if a user really logs out again in the solution this remember me will be cleared.
The credentials that a user gives in this mode will be validated against the default servoy users table and if the permissions will be got from the default permissions table for that user.
SERVOY_CLOUD
In this mode the same stateless login screen will be shown, but the authentication is relayed to ServoyCloud, where the users and permissions are managed for the solution. After successful login ServoyCloud will give for that user the permissions that must be used in the solution.
AUTHENTICATOR
In this mode also the stateless login screen will be shown, but the authentication is done in an Authenticator solution that must be a module of the main solution having this authenticator property set to this value.
This authenticator solution only needs to have a onSolutionOpen method that gets the username/password as an argument. Then the authenticator solution can validate those credentials and call security.login(username, uuid, permisions). These permissions are then set in the actual clients solution.
OAUTH PROVIDER
In this mode, we redirect to the consent screen of the selected OAuth provider. Then in an authenticator module the received token can be used to find the user, by their email for instance.
To setup stateless login with an OAuth provider, select 'OAUTH' as authenticator in the properties view of the solution. Then click the highlighted button to open a configuration wizard.
The first page of the wizard allows for OAuth configuration with Google or other providers, where the application client id and secret must be filled in.
If "Custom" api is selected, then more information is needed: the authorization base url, access token endpoint and jwks uri. The JWKS URI is the location where the set of public keys needed to validate an ID token can be found. So the authenticator always gets the payload of a token which is not expired and has a valid signature.
The next page is for advanced parameters configuration only. You can setup additional parameters as in the documentation of the selected provider.
Note: It is essential to configure the redirect URL to the index page of your solution on the OAuth provider's application settings. This redirect URL is the location the OAuth provider will send the user back to after they successfully authenticate.
Logout when using OAuth
When using OAuth, on logout the user should be redirected to a different page using application.showURL
if logout is not called with a different solution. By default the user is forced the consent screen again.
Login Screen customization
The login screen that is show can be fully customizeable, in the meda folder of the main solution a login.html file can be generated from the context menu of the media folder.
This html/css file can be changed but only some manatory things must be kept, like the input fiels with their names.
Last updated