Goal : Configure OAuth2 Authentication for Magic xpi RESTful API Service using KeyCloak Identity Access Management
Prerequisites :
- Access to a Keycloak server https://www.keycloak.org/
- Apache tomcat
- Magic xpi
- Postman
1/ keyCloak Server Installation
Download and unzip keycloak server
install java version « 17.0.11 » 2024-04-16 LTS
Start Keycloak server (Dev environment) : kc start-dev
data:image/s3,"s3://crabby-images/ea215/ea215a546eb8c44b06071bb3ac8175f93f1d3a75" alt=""
Browse : http://localhost:8080 and create Admin user
data:image/s3,"s3://crabby-images/a87d0/a87d07a6cfea3de7638e218a6330dd1d144bc96c" alt=""
2/ Keycloak settings
Create Realm for Magic xpi
data:image/s3,"s3://crabby-images/c62f7/c62f7fbb8cca41a8d25891b8a894f4e04da7ae1c" alt=""
data:image/s3,"s3://crabby-images/8acee/8acee2e1e3997a679b41553f65965ec321a56bb0" alt=""
Create Magic xpi Client
data:image/s3,"s3://crabby-images/f7a6f/f7a6f0aff61d56851894a466e9cb91dd8ce5cabd" alt=""
data:image/s3,"s3://crabby-images/9fed0/9fed02a8a0c13c345e452015d915db116a674127" alt=""
3/ Enter an URL redirection to Magic xpi RESTFul API
data:image/s3,"s3://crabby-images/33c2f/33c2fd3d9c0aded87d1bc767df7e627cbe0e0f2a" alt=""
Save the Client Secret
data:image/s3,"s3://crabby-images/7bc1d/7bc1d5bf033ba6ac8ee5164b247ec9bf59608110" alt=""
4/ Create a Client Scope (magicxpiscope)
data:image/s3,"s3://crabby-images/ed7d5/ed7d53b7913051b291124bac46ed617ef65626bd" alt=""
Create 2 mapper (UserProperty (boolean) and UserAttribute (custom atrribute)) (Add mapper By Configuration)
data:image/s3,"s3://crabby-images/8ff77/8ff77bc4e9e302367fd22e5be75ff07d3e0795a1" alt=""
data:image/s3,"s3://crabby-images/1194a/1194a5122811869002312cea8d27f0b64bd06c30" alt=""
4/ Add the client scope « magicxpiscope » to the client
data:image/s3,"s3://crabby-images/cb4e5/cb4e51a9de10df81f172453a67d0eef458a437dc" alt=""
4/ Deploy Magic xpi Tomcat requester (Magic xpi – RESTful API Provider Installation Instructions.pdf)
Copy the file xpiREST.war from<Magic xpi installation>\Runtime\addon_connectors\RESTfulAPI\servicefiles to <Magic xpi installation>\Runtime\apache-tomcat\webapps
We will use the Magic xpi Embedded Apache Tomcat (<Magic xpi installation>\Runtime\apache-tomcat).
Change the Apache Tomcat port to 6443 in the server.xml file and start the server
data:image/s3,"s3://crabby-images/834b2/834b233acfec414bd651d12c6128e7fa3d94a07c" alt=""
After starting the Apache server (<xpi installation>\Runtime\apache-tomcat\bin\startup.bat), xpiREST and rest-services will appear.
data:image/s3,"s3://crabby-images/d3625/d36255f0a2d7fbe9b1cbd50f2b8458bac6da9252" alt=""
data:image/s3,"s3://crabby-images/ab2a3/ab2a3da6ffcedd5d88bf0e28c1b4f6a0b55e3eca" alt=""
5/ Create a Magic xpi project including a RESTFul Service
data:image/s3,"s3://crabby-images/3b745/3b7459ae63fdcb7af94fb33d9f26ffdaa01f31e3" alt=""
Define 2 methods
data:image/s3,"s3://crabby-images/46988/4698808079523e204580a779300dfd3db72ff46c" alt=""
Under <xpi project>\RESTful API\<ServiceNameFolder>. (ex: C:\MSE\Magicxpi414\Runtime\projects\OAuth2_Keycloak\OAuth2_Keycloak\RESTful API\MyRESTfulAPI)
you will find the Service Definition File (<Project Name>_<Service Name>_serviceDefinition.xml) (C:\MSE\Magicxpi414\Runtime\projects\OAuth2_Keycloak\OAuth2_Keycloak\RESTful API\MyRESTfulAPI\OAuth2_Keycloak_MyRESTfulAPI_serviceDefinition.xml)
Add the OAuth2 Issuer (http://localhost:8080/realms/Magicxpi) and the security role => client scope for each method
data:image/s3,"s3://crabby-images/28c9d/28c9d0ced20be098d360ac18819bf86971a29e75" alt=""
6/ Copy the Service Definition file from <xpi project>\RESTful API\<ServiceNameFolder> to <Magic xpi installation>\Runtime\apache-tomcat\rest-services
data:image/s3,"s3://crabby-images/c05c7/c05c711f5b62f1576254d1ae894aa07c4c23ff51" alt=""
7/ Test using Postman
Make a POST on http://localhost:8080/realms/Magicxpi/protocol/openid-connect/token with these credentials with scope set to openid email address profile magicxpiscope
Check in the response that you get the clientscope that you want
data:image/s3,"s3://crabby-images/ffa0d/ffa0d84f4b98b38cbd85349bed22c2bddd75c685" alt=""
In the response you will get the « access_token » and the « refresh_token » , if you want to test a call to the Magic xpi RESTFUl service, you can use access_token in the authorization header
data:image/s3,"s3://crabby-images/634da/634dad1bd2bf6751f5654745ea5731727dbdd8bc" alt=""
(*) You got Status 201 because in the Magic xpi Flow, i put 201 in the response status (C.UserCode)
data:image/s3,"s3://crabby-images/4a4f5/4a4f52c18fb71a2b20cd027317171fa016011645" alt=""
(**) if you set a wrong role in the service definition file, you get a 403 Forbidden
data:image/s3,"s3://crabby-images/21d01/21d01a64a1c8e985bec633f72a540389947867fd" alt=""
data:image/s3,"s3://crabby-images/42b35/42b35fac78f24eee6e810604861e6570aba40b72" alt=""
(***) If you pass a wrong Bearer token or if the token is expired then you get 401 Unauthorized
data:image/s3,"s3://crabby-images/43cc4/43cc447fc0de7925d0de8410241961d499fa323a" alt=""
8/ By default, the Access token expired after 5min, you can change this setting in the KeyCloak console
data:image/s3,"s3://crabby-images/96232/96232e5dd9b429b46b34d010c717b53763a5b79c" alt=""