KNF:Single Sign On query: verschil tussen versies

Uit Kennisnet Developers Documentatie
Naar navigatie springen Naar zoeken springen
(13 tussenliggende versies door dezelfde gebruiker niet weergegeven)
Regel 4: Regel 4:
   
 
==Inleiding==
 
==Inleiding==
  +
De Single Sign On-query kan worden gebruikt door Service Provider om te detecteren of een gebruiker reeds een lopende SSO sessie via Entree Federatie heeft.
De SSOquery heeft als voornaamste functie het verklikken van de inlogstatus.
 
Een veelgebruikte naam is dan ook wel de inlogstatusverklikker.
 
   
  +
Om te authentiseren, moet de gebruiker op de website op de knop "Inloggen" klikken, waardoor het authenticatieproces via Entree Federatie start. Als de gebruiker echter al een geldige Single Sign On-sessie met Entree Federatie heeft, zal het inloggen onmiddellijk zonder gebruikersinteractie (bijv. het invoeren van een gebruikersnaam en wachtwoord) gebeuren. Het klikken op de knop "Inloggen" is dus overbodig dat en daarom minder gebruiksvriendelijk.
Deze functie biedt de mogelijkheid om te controleren of een gebruiker direct ingelogd kan worden zonder het inlogscherm te tonen.
 
Ook toegang geven tot, of het zichtbaar maken van bepaalde content behoort tot een van de gebruikte usecases.
 
   
  +
Om dit scenario te voorkomen, kan de Service Provider een detectiemechanisme implementeren dat automatisch gebruikers met een geldige SSO-sessie herkent. Dit kan worden bereikt met de Single Sign On-query.
Met deze functie kan de gebruikerservaring verbeterd worden door bijvoorbeeld:
 
* Een 'Inlogknop' niet te tonen en direct de authenticatie te starten met een ingelogde gebruiker als gevolg
 
* Zichtbaar maken dat de gebruiker nog niet ingelogd is, maar dit wel moet doen om bepaalde content te zien
 
   
 
'''Let op:'''<br/>
 
'''Let op:'''<br/>
Regel 18: Regel 14:
 
Neem daarom contact op met [https://support.kennisnet.org/ Kennisnet] als je gebruik wilt maken van SSO query.
 
Neem daarom contact op met [https://support.kennisnet.org/ Kennisnet] als je gebruik wilt maken van SSO query.
   
==Werking==
 
 
Zodra de vraag aan de Entree Federatie gesteld wordt, kunnen er drie antwoorden worden geven op de SSOQuery:
 
Zodra de vraag aan de Entree Federatie gesteld wordt, kunnen er drie antwoorden worden geven op de SSOQuery:
 
;false
 
;false
 
:De gebruiker heeft geen SSO sessie en is voor zover bekend bij de Entree Federatie nergens ingelogd. Het is dus onbekend of de gebruiker wel of niet kan inloggen via Entree Federatie.
 
:De gebruiker heeft geen SSO sessie en is voor zover bekend bij de Entree Federatie nergens ingelogd. Het is dus onbekend of de gebruiker wel of niet kan inloggen via Entree Federatie.
 
;true
 
;true
:De gebruiker heeft een SSO sessie en kan hoogstwaarschijnlijk inloggen zonder gebruikersinteractie
+
:De gebruiker heeft een SSO sessie en kan inloggen zonder gebruikersinteractie
 
;remote
 
;remote
:De gebruiker heeft geen SSO sessie, maar er is wel een SSO notificatie cookie gevonden. De gebruiker is al ingelogd in zijn eigen systeem(ELO) en kan hoogstwaarschijnlijk inloggen zonder gebruikersinteractie
+
:De gebruiker heeft geen SSO sessie, maar er is wel een SSO notificatie cookie gevonden. De gebruiker is al ingelogd bij zijn eigen Identity Provider en kan hoogstwaarschijnlijk inloggen zonder gebruikersinteractie
   
 
==Implementatie==
 
==Implementatie==
De query bestaat uit een simpele HTTP GET met slechts een parameter: response_url (deze parameter moet in de URL worden URL encoded/UTF-8).<br>
+
De query bestaat uit een HTTP GET request met twee parameters:
  +
* response_url: deze parameter moet in de URL worden URL encoded/UTF-8
  +
* format: deze optionele parameter kan gebruikt worden om het antwoord in json format te ontvangen
  +
<br>
 
De volgende urls kunnen worden gebruikt:
 
De volgende urls kunnen worden gebruikt:
   
 
{| class="wikitable"
 
{| class="wikitable"
| Staging environment:
+
| Staging omgeving:
 
|-
 
|-
 
|https://ssoquery.aselect-s.entree.kennisnet.nl/openaselect/sso/ssoquery?response_url=<URL>
 
|https://ssoquery.aselect-s.entree.kennisnet.nl/openaselect/sso/ssoquery?response_url=<URL>
Regel 38: Regel 36:
   
 
{| class="wikitable"
 
{| class="wikitable"
  +
| Productie omgeving:
| Live environment:
 
 
|-
 
|-
 
|https://ssoquery.aselect.entree.kennisnet.nl/openaselect/sso/ssoquery?response_url=<URL>
 
|https://ssoquery.aselect.entree.kennisnet.nl/openaselect/sso/ssoquery?response_url=<URL>
Regel 44: Regel 42:
   
 
===Voorbeeld===
 
===Voorbeeld===
;De dienst stelt de vraag:
+
;De Service Provider stelt de vraag:
 
:https://ssoquery.aselect.entree.kennisnet.nl/openaselect/sso/ssoquery?response_url=https%3A%2F%2Ftestapplicatie.kennisnet.nl
 
:https://ssoquery.aselect.entree.kennisnet.nl/openaselect/sso/ssoquery?response_url=https%3A%2F%2Ftestapplicatie.kennisnet.nl
   
;Entree Federatie redirect naar:
+
;Entree Federatie redirect naar de opgegeven response URL:
 
:https://testapplicatie.kennisnet.nl?result=true
 
:https://testapplicatie.kennisnet.nl?result=true
   
   
===Voorbeeld implementatie op basis van PHP===
+
===Voorbeeld implementatie===
 
<syntaxhighlight lang="HTML">
  +
<html>
  +
<script>
  +
var ssoQuery= 'https://ssoquery.aselect-s.entree.kennisnet.nl/openaselect/sso/ssoquery?response_url=https://domeinnaam&format=json';
   
  +
function isLoggedIn() {
====SSO query====
 
  +
var xhr = new XMLHttpRequest();
<syntaxhighlight lang="php">
 
  +
xhr.open("GET", ssoQuery, true);
  +
xhr.withCredentials = true;
  +
xhr.onreadystatechange = function () {
  +
if (xhr.readyState === 4) {
  +
if (xhr.status === 200 && JSON.parse(xhr.responseText)['result'] === 'true') {
  +
<!-- de gebruiker heeft reeds een lopende SSO sessie via Entree Federatie en kan direct worden ingelogd -->
  +
window.location.href = ''; <!-- redirect naar de pagina waar uw applicatie het authenticatieverzoek naar Entree Federatie verstuurd -->
  +
} else {
  +
<!-- de gebruiker heeft nog geen lopende SSO sessie via Entree Federatie en gebruikersinteractie is vereist -->
  +
window.location.href = ''; <!-- redirect de gebruiker naar de inlogpagina van uw applicatie -->
  +
}
  +
}
  +
};
  +
xhr.ontimeout = function () {
  +
<!-- redirect de gebruiker in geval van een timeout van de SSO query service naar de inlogpagina van uw applicatie
  +
window.location.href = ''; <!-- redirect de gebruiker naar de inlogpagina van uw applicatie -->
  +
};
  +
xhr.send();
  +
}
  +
isLoggedIn();
  +
</script>
  +
</html>
  +
</syntaxhighlight>
  +
  +
<!-- <syntaxhighlight lang="php">
 
<?php
 
<?php
 
$query_url = 'https://ssoquery.aselect-s.entree.kennisnet.nl/openaselect/sso/ssoquery';
 
$query_url = 'https://ssoquery.aselect-s.entree.kennisnet.nl/openaselect/sso/ssoquery';
Regel 63: Regel 90:
 
header('Location: ' . $url, 302);
 
header('Location: ' . $url, 302);
 
?>
 
?>
</syntaxhighlight>
+
</syntaxhighlight> -->
   
  +
<!--
 
====SSO query result====
 
====SSO query result====
 
<syntaxhighlight lang="php">
 
<syntaxhighlight lang="php">
Regel 82: Regel 110:
 
</html>
 
</html>
 
</syntaxhighlight>
 
</syntaxhighlight>
  +
-->
 
   
 
[[Categorie:Entree Federatie]]
 
[[Categorie:Entree Federatie]]

Versie van 20 apr 2020 10:39

Nl.gif Nederlands En.gif English
Warn.gif Met ingang van 1 juli 2019 maakt Entree Federatie gebruik van een nieuw Endpoint voor de SSO query. Per 1 september 2020 zal het oude endpoint uitgezet worden.

Inleiding

De Single Sign On-query kan worden gebruikt door Service Provider om te detecteren of een gebruiker reeds een lopende SSO sessie via Entree Federatie heeft.

Om te authentiseren, moet de gebruiker op de website op de knop "Inloggen" klikken, waardoor het authenticatieproces via Entree Federatie start. Als de gebruiker echter al een geldige Single Sign On-sessie met Entree Federatie heeft, zal het inloggen onmiddellijk zonder gebruikersinteractie (bijv. het invoeren van een gebruikersnaam en wachtwoord) gebeuren. Het klikken op de knop "Inloggen" is dus overbodig dat en daarom minder gebruiksvriendelijk.

Om dit scenario te voorkomen, kan de Service Provider een detectiemechanisme implementeren dat automatisch gebruikers met een geldige SSO-sessie herkent. Dit kan worden bereikt met de Single Sign On-query.

Let op:
Om misbruik van deze functionaliteit te voorkomen dient het domein opgenomen te worden in de whitelist van Entree Federatie. Neem daarom contact op met Kennisnet als je gebruik wilt maken van SSO query.

Zodra de vraag aan de Entree Federatie gesteld wordt, kunnen er drie antwoorden worden geven op de SSOQuery:

false
De gebruiker heeft geen SSO sessie en is voor zover bekend bij de Entree Federatie nergens ingelogd. Het is dus onbekend of de gebruiker wel of niet kan inloggen via Entree Federatie.
true
De gebruiker heeft een SSO sessie en kan inloggen zonder gebruikersinteractie
remote
De gebruiker heeft geen SSO sessie, maar er is wel een SSO notificatie cookie gevonden. De gebruiker is al ingelogd bij zijn eigen Identity Provider en kan hoogstwaarschijnlijk inloggen zonder gebruikersinteractie

Implementatie

De query bestaat uit een HTTP GET request met twee parameters:

  • response_url: deze parameter moet in de URL worden URL encoded/UTF-8
  • format: deze optionele parameter kan gebruikt worden om het antwoord in json format te ontvangen


De volgende urls kunnen worden gebruikt:

Staging omgeving:
https://ssoquery.aselect-s.entree.kennisnet.nl/openaselect/sso/ssoquery?response_url=<URL>
Productie omgeving:
https://ssoquery.aselect.entree.kennisnet.nl/openaselect/sso/ssoquery?response_url=<URL>

Voorbeeld

De Service Provider stelt de vraag
https://ssoquery.aselect.entree.kennisnet.nl/openaselect/sso/ssoquery?response_url=https%3A%2F%2Ftestapplicatie.kennisnet.nl
Entree Federatie redirect naar de opgegeven response URL
https://testapplicatie.kennisnet.nl?result=true


Voorbeeld implementatie

<html>
   <script>
      var ssoQuery= 'https://ssoquery.aselect-s.entree.kennisnet.nl/openaselect/sso/ssoquery?response_url=https://domeinnaam&format=json';

      function isLoggedIn() {
         var xhr = new XMLHttpRequest();
         xhr.open("GET", ssoQuery, true);
         xhr.withCredentials = true;
         xhr.onreadystatechange = function () {
            if (xhr.readyState === 4) {
               if (xhr.status === 200 && JSON.parse(xhr.responseText)['result'] === 'true') {
                  <!-- de gebruiker heeft reeds een lopende SSO sessie via Entree Federatie en kan direct worden ingelogd -->
                  window.location.href = ''; <!-- redirect naar de pagina waar uw applicatie het authenticatieverzoek naar Entree Federatie verstuurd -->
               } else {
                  <!-- de gebruiker heeft nog geen lopende SSO sessie via Entree Federatie en gebruikersinteractie is vereist -->
                  window.location.href = ''; <!-- redirect de gebruiker naar de inlogpagina van uw applicatie -->
               }
            }
         };
         xhr.ontimeout = function () {
            <!-- redirect de gebruiker in geval van een timeout van de SSO query service naar de inlogpagina van uw applicatie
            window.location.href = ''; <!-- redirect de gebruiker naar de inlogpagina van uw applicatie -->
         };
         xhr.send();
      }
      isLoggedIn();
   </script>
</html>