OpenID Connect
Getting started
Welcome to the section dedicated to our login system.
Here, you will find documentation about how to implement our authentication process into your application
Our Strategy
We use the OpenId Connect protocol to manage the connections to our authentication system.
Because there are too many existing Content Management Systems (CMS) and languages for us to support them all, we have decided to start with the most popular ones. See the list of Supported Languages and CMSs below.
If you implement your own solution because your language/CMS was not already supported by us, we are happy to post your solution here, so others using the same language/CMS as you can benefit from it. An easy way to start a dialogue with us regarding this is to send us an email at it@bcc.no.
Requirements
Please contact support if you have any questions regarding these requirements
1. HTTPS(SSL)
HTTPS (SSL) must be installed on your application!
- There are multiple free services available that provide free SSL certificates ( e.g. Let’s Encrypt)
2. BCC Topbar
We encourage all applications to use the BCC topbar, this has the following advantages:
- The user can go back to the home page (BCC portal)
- The user can search for all applications related to BCC
- The user can easily logout of all BCC applications.
We would like to improve the functionality of the BCC Topbar, and are interested in feedback/suggestions from you!
Supported Languages and CMS
- PHP, with wordpress as a CMS
- ASP.NET
- ASP.NET Core
We plan to add solutions for the following as well:
- Joomla
Using SignOn with other languages/CMS's
We recommend using certified OpenID connect libraries
We DO NOT recommend using libraries from Auth0 directly, because these libraries will not work with any other OpenID Connect providers.
Authentication Endpoints
Type: | URL: |
---|---|
Authorization URL | https://login.bcc.no/authorize |
Token URL | https://login.bcc.no/oauth/token |
User Info URL | https://login.bcc.no/userinfo |
OpenID Configuration | https://login.bcc.no/.well-known/openid-configuration |
Get information about the user
It is possible to get additional information about the logged-in user, with the use of claims. Claims are statements ( such as name or email address) about the user.
How to request claims
Claims can be requested via the scope parameter in the authentication request to BCC Signon. The claims will be present in the response of the authentication request.
Available claims
Please keep the requested claims down to the minimal required. You can always ask for additional claims later, when the application needs them.
Standard OpenID Connect claims
See https://openid.net/specs/openid-connect-core-1_0.html#ScopeClaims.
- profile scope
- Claims: name, family_name, given_name, middle_name, nickname, preferred_username, picture, gender, birthdate, locale, and updated_at.
- email scope
- Claims: email and email_verified.
- address scope
- Claims: address.
- phone
- Claims: phone_number and phone_number_verified.
Additional claims of BCC Signon
It’s currently possible to request all available claims. Your application may require additional approval of BCC in the future, before you have access to additional claims of the user (the claims of the ‘openid’ scope will always be available).
openid
scope
Claim name: | Content: |
---|---|
https://login.bcc.no/claims/personId | The primary identifier of the user in the BCC membership system (this value will never change). |
https://login.bcc.no/claims/hasMembership | Shows if the user has an active membership in BCC |
church
scope
Claim name: | Content: |
---|---|
https://login.bcc.no/claims/churchId | The identifier of the church |
https://login.bcc.no/claims/churchName | The name of the church |
country
scope
Claim name: | Content: |
---|---|
https://login.bcc.no/claims/CountryIso2Code | The countryCode of the user his church |
id_token example
The id_token contains the following claims when requesting all scopes.
Payload:
{
"https://login.bcc.no/claims/personId": 12345,
"https://login.bcc.no/claims/hasMembership": true,
"https://login.bcc.no/claims/churchId": 69,
"https://login.bcc.no/claims/churchName": "Oslo/Follo",
"https://login.bcc.no/claims/deprecatedSignonUsername": "johndoe",
"https://login.bcc.no/claims/CountryIso2Code": "no",
"given_name": "John",
"family_name": "Doe",
"nickname": "johndoe",
"name": "John Doe",
"picture": "https://s.gravatar.com/avatar/url-to-avatar-picture",
"gender": "male",
"birthdate": "1980-01-01T00:00:00",
"locale": "en-US",
"updated_at": "2019-05-29T12:15:00.383Z",
"email": "johndoe@example.com",
"email_verified": true,
"phone_number": "+47 123 45 678",
}
Single logout
Single logout is the process of logging the user out of all the applications they signed into with single signon (SSO).
Single signout flow consists of 3 steps:
- Local logout
- Central logout
- Backchannel logout through a webhook
Integrate your application with single logout
This tutorial will explain you how to integrate your application with single logout.
Requirements
HTTPS (SSL) must be installed on your application!
- There are multiple free services available that provide free SSL certificates (e.g. Let’s Encrypt)
- Please contact support if you have any questions regarding SSL certificates.
HEADS UP
WordPress applications that have the BCC Login plugin installed should not follow this tutorial (single logout is included in the plugin).
Local logout
SPA
Create a page in your app that will clear the user session. In SPAs the session is usually stored in localStorage, sessionStorage or in-memory.
Regular web app
1. Create the ‘endsession’ endpoint in your application
This is the endpoint that clears the session of the user (e.g. /account/endsession).
The endpoint needs to delete the session cookie of the user, and if the session was stored in a session store remove it from there as well.
If you are using ASP.NET you can check our documentation here:
Topbar setup
If you're using the topbar as the UI for the logout, you need to register your logout-url there. The logout-url is registered using the data-logout-url
attribute when registering the topbar widget Topbar Widget
2. Redirect the user to the endsession endpoint
Central logout
1. Redirect the user to the central logout endpoint
The logout endpoint is: https://LOGIN_DOMAIN/v2/logout In production environment that would be https://login.bcc.no/v2/logout
Backchannel logout
Backchannel logout is triggered for all applications (that have registered it) after a user logs out centrally.
The backchannel logout is only availible for applications that have a backend that is storing the user sessions in a persistent storage (as opoposed to storing the session inside a cookie), so it can be invalidated
Backchannel logout OIDC specification
https://openid.net/specs/openid-connect-backchannel-1_0.html
Backchannel logout architecture
1. Create the logout endpoint in your backend
The endpoint has to do the following thigs:
- Accept a following request from auth0
- Method: POST
- Body contains an url-encoded object:
interface LogoutRequestBody {
logout_token: string;
}
- Verify the logout token
- The logout token is a JWT
- The token signature can be verified against the auth0 JWKS (https://LOGIN_DOMAIN/.well-known/jwks.json)
- The
iss
andaud
values should also be verified (theiss
should contain the login domain, and theaud
should equal to your applicationclient_id
)
- Invalidate the session
- Use the
sid
(session id) from the token payload to invalidate/remove the corresponding session
- Use the
Logout token payload example
{
"iss": "https://login.bcc.no/",
"sub": "auth0|62b30b0908dcafbc2fda40a",
"aud": "hPK4PRnpFkY5MmuoJZa31sNldB0Mprei",
"iat": 1670000000,
"jti": "3adae621-4423-4a22-ba4a-612beca52ede",
"events": {
"http://schemas.openid.net/event/backchannel-logout": {}
},
"trace_id": "7764a3031fe0bbda",
"sid": "EKIRPdag3PtbAQRfG2BptNi5UThMi5AZl"
}
2. Register the logout endpoint for your application in auth0
To register the logout endpoint contact support, providing the url of your logout endpoint
Test your setup
To verify that you correctly configured single logout, please open a new incognito browser, and follow the following steps:
- Sign in to your application
- Click on the “Sign out” button on the BCC topbar.
- You should be redirected to the login screen after the logout process completed.
- Navigate back to your application
- You should be required to sign in again with BCC signon.
Protect news feed and calendar
The shared link for the calendar and news feed should not be protected with the signon system, but it should be protected with the use of a private URL
A private URL is a link that is very hard to guess: for example by using a GUID. (You can create one with this GUID generator.)
The syntax of a private link would be : https://website.com/{path}/{GUID}
Example for the calendar feed https://example.com/feed/?id=4397c38e49c64977b7841f918e3ae9a7
This is the same concept as a ‘private address’ with Google calendars (documentation).
FAQ
What's my Redirect URI?
The Redirect URI contains the link to which Auth0 will redirect the user after the authentication. This URI is different for each CMS :
Wordpress:
The Redirect URI provided by the plugin. It can be found at the bottom of the OIDC settings page.
ASP.net:
The Redirect URI recommended for this language is:https://your-domain.com/signin-auth0
Replace your-domain.com
with your domain name.
Where can I find my Client ID and Client Secret?
The Client ID and Client Secret are used to authenticate the application in our signon system. If you don’t have them, please contact support.
Warning
The Client Secret should remain confidential! Don’t send it to anybody, and store it in a safe place.
I get redirected to a page that says 'Sorry, an error occurred':
Please open developer tools (F12). and look for the ‘Error’ and ‘Error description’ entry in the console (or the query string parameters of the URL).
Please contact support with the logged ‘Error’ and ‘Error description’ entry