Authentication
There are three ways we authenticate access to self service features:
- Email and password - standard customer facing login
- Masquerade - support user login
- Expiring URLs - access to particular features via a link (usually sent to the customer via and email from Kraken or an customer service user)
The end result of each of these processes is a Kraken token. To learn more about the mechanisms of authentication end to end, please see our Guide to Authentication.
Login
This is the standard login page where a user puts in their email and password. Here is what that looks like in an app:
Masquerade
This is how a support user in Kraken can log into the consumer site for that Kraken instance with a customers user details, to see the site as the customer sees it.
Expiring URLs
This is how a user can access various features without having to log in at all, generally via a link sent in email.
We use this for features that have a very high value to the business. These features therefore require the friction for
the customer performing the given action to be as low as possible.
These URLs might be sent by a support user, or automatically via Kraken. In Blueprint, these URLs are supported by providing a
dynamic route
which takes a preSignedKey
which we exchange for an authorization token with limited scope, and set a cookie with that
token using middleware. preSignedKeys
are generally scoped to allow the user to
perform particular actions. Some examples are to provide feedback on a customer service interaction or a meter reading.
By limiting the scope to particular actions, we reduce the impact of these urls being accidentally shared by the customer,
since the actions that can be performed with them are limited.
Expiring URLs step by step
-
To see this feature in action, we first choose which expiring url we'd like to access. You can see which are supported in a given app in the
src/pages/anon
directory. All apps support the customer service feedback url, so we'll use that for our example. We assume for our example that your Kraken has a customer feedback form set up and you've generated a customer feedback object for your chosen test account. You can read more about that setup on the Global Technical Guide. -
Next we need to generate a
preSignedKey
. You can generate that in your test Kraken environment using the 'Generate an expiring URL' recipie and your chosen test account. Kraken will generate a full example url, but thepreSignedKey
is the bit that followskey=
. We then provide this to our chosen route, so for example, if your local server is running on port 3000 and the KRAKEN_GRAPHQL_ENDPOINT is set to your test Kraken, you can use:localhost:3000/anon/<key_goes_here>/<account_number_goes_here>/<feedback_form_id_goes_here>/<feedback_id_goes_here>`
-
This is where the middleware is invoked. We define the following matcher configuration setting which is then triggered for all routes under
pages/anon
:matcher: ['/anon/:path*'],
The pre-signed key is taken from the dynamic route's parameters and exchanged for an authorization token by passing it as an input value of the
obtainKrakenToken
mutation. Upon a successful response from theobtainKrakenToken
mutation, the Authorization token is stored in a cookie with a key namedscopedToken
. This cookie will then be stored within the client's browser storage when the response is provided from the middleware handler. ThemiddlewareSetScopedTokenCookie
is responsible for handling and creating this cookie and is located withinpackages/core/middlewares
for usage by all apps. The expires option is used to ensure the cookie is removed from the browser storage after a pre-determined period. This value is set to theexp
value taken from thepayload
object within theobtainKrakenToken
mutation response. -
This should then render the customer feedback form for that account and allow the user to submit feedback.
Security of Expiring URLs
There are three configured options being utilised when the cookie is created to ensure the security of the Authorization token. The 3 options in use are as follows:
Note: Secure is only set when the environment is production to avoid issues with local & test environments using http.
By employing all 3 options in conjunction, we provide a solution that ensures the token is not publicly exposed during requests and is not susceptible to XSS attacks by preventing client-side access to the stored token (in accordance with OWASP recommendations).