Documentation
Auth Request

Authentication Request

Hello supports both the Code Flow (opens in a new tab) and the Implicit Flow (opens in a new tab)

Create Request URL

The @hellocoop/core (opens in a new tab) npm package has a createAuthRequest() function that simplifies creating an authorization request URL, including the PKCE code_verifier and code_challenge

The request URL is https://wallet.hello.coop/authorize and a query with the following standard OpenID Connect (opens in a new tab) parameters:

ParameterDescription
client_id
required
The client_id for your app from console.hello.coop (opens in a new tab).
redirect_uri
required
One of the redirect_uri values you registered for your app.
scope
required
The openid scope and zero or more space delimited scopes listed at Hellō Claims.
nonce
required
A unique string that will be included in the signed ID Token. This links the ID Token to your request.
response_type
optional
id_token for implicit flow
or
code for code flow - default and recommended, but requires PKCE - RFC7636 (opens in a new tab)).
response_mode
optional
if id_token flow can be fragment or form_post (default)
if code flow can be fragment, form_post, or query (default).
state
optional
A value representing the state of your application that will be returned as a parameter in the response.
code_challengeREQUIRED if code flow and not using a client secret to authenticate to the token endpoint. See PKCE below.
code_challenge_methodMAY be provided if code_challenge is included.
MUST have value of S256 if included. See PKCE below.
login_hint
optinal
A hint for which user account to use. Only email addresses in the form of mailto:name@domain.example are currently supported.
prompt
optional
A space delimited list. Values include:
- login will require the user to re-authenticate at their login provider
- consent will require the user to review, and potentially change, released claims
other values are ignored

The non-standard provider_hint is optionally available. See Wallet API | provider_hint for details.

PKCE Code

RFC 7636 (opens in a new tab) (Proof Key for Code Exchange by OAuth Public Clients) enables your application to prove it made the authorization request that received the authorization code when it calls the token endpoint.

This is done by generating a random code_verifier and then a code_challenge which is a SHA256 cryptographic hash code_verifier.

The code_challenge is part of the authorization request, and the code_verifier is presented with the code to Hellō which verifies the code was requested with the code_challenge. This allows an application to not have to manage a client secret when using a code flow.

Here is a sample id_token (implicit flow) request from the GreenfieldDemo (opens in a new tab) app
(line feeds added for readability)

https://wallet.hello.coop/authorize
?client_id=3574f001-0874-4b20-bffd-8f3e37634274
&redirect_uri=https://greenfielddemo.com/
&scope=name+nickname+email+picture+openid
&nonce=b957cea0-f159-4390-ba48-5c5d7e943ea4
&response_mode=fragment

Here is a sample code flow request from the Hellō Next.js Sample (opens in a new tab) app
(line feeds added for readability)

https://wallet.hello.coop/authorize
?client_id=db4ad0b8-c589-4328-8094-f2d0e2cd3aaa
&redirect_uri=https://hello-nextjs-sample.netlify.app/api/hellocoop
&scope=openid+name+email+picture
&nonce=ecc855c9-41e3-46a0-a99a-d1fa3e3c1d3f
&response_type=code
&response_mode=query
&code_challenge=F_xW4_XNddm_XXZgMQAnHBWZRAtc3ZXxb-kcL_rvDns
&code_challenge_method=S256

Advanced Features

See the API Reference | Wallet for additional functionality including how to change the recommended providers with provider_hint.

Make Request

Cause the user's browser to load the request URL you created in Step 2. Here are some examples:

  • Set window.location.href with JavaScript
window.location.href = "https://wallet.hello.coop/authorize?..."
  • An <a> tag with an href to the requestURL
<a href="https://wallet.hello.coop/authorize?..." /> ... </a>
  • HTTP 302 redirect from the server
HTTP/1.1 302 Found
Location: https://wallet.hello.coop/authorize?...

The user will then interact with Hellō. When finished they will be redirected back to your application with either an ID Token, an authorization code, or an error response.