This is a forked repository from https://github.com/Mnikoei/laravel-keycloak-admin
Original work credited to Mnikoei.
Keycloak Admin library made by Scito. https://gitlab.com/scito-performance/keycloak-admin
composer require haizad/laravel-keycloak-admin
php artisan vendor:publish --provider="LaravelKeycloakAdmin\KeycloakAdminServiceProvider"
Create a config
folder in the root directory.
Copy keycloakAdmin.php
from vendor/haizad/laravel-keycloak-admin/src/Config/
, and paste into config
folder.
Register the provider in your boostrap app file bootstrap/app.php
Add the following line at that files. Please note that
$app->configure('keycloakAdmin');
should be placed below
$app->register(\LaravelKeycloakAdmin\KeycloakAdminServiceProvider::class);
.
//"Register Service Providers" section
$app->register(\LaravelKeycloakAdmin\KeycloakAdminServiceProvider::class);
$app->configure('keycloakAdmin');
$app->router->group([
'namespace' => 'App\Http\Controllers',
], function ($router) {
require __DIR__.'/../routes/web.php';
});
return $app;
For facades, uncomment $app->withFacades();
in your boostrap app file bootstrap/app.php
Add these environment variables to your .env :
KEYCLOAK_BASE_URL=http://keycloak-domain.example/auth
KEYCLOAK_REALM=
KEYCLOAK_REALM_PUBLIC_KEY= # realm settings -> keys
KEYCLOAK_CLIENT_ID=
KEYCLOAK_CLIENT_SECRET= # clients -> your_client -> credentials
KEYCLOAK_ADMIN_BASE_URL=${KEYCLOAK_BASE_URL}/admin/realms/${KEYCLOAK_REALM}
Go to clients -> your_client -> Service Account
then select realm-managment
from Client Roles list and assign realm-admin to client.
Package has provided services as below:
- user
- role
- client
- clientRole
- addon
Available functions:
- Create User
- Get All User
- Query User
All API's are declared in config\keycloakAdmin.php
Include the KeycloakAdmin inside your Laravel controller/API route
use LaravelKeycloakAdmin\Facades\KeycloakAdmin;
Example:
KeycloakAdmin::serviceName()->apiName($parameters)
//Create User Sample
//Refer https://www.keycloak.org/docs-api/11.0/rest-api/index.html#_userrepresentation
KeycloakAdmin::user()->create([
'body' => [
'username' => 'foo',
'enabled' => true,
'emailVerified' => false,
'email' => '[email protected]',
'credentials' => [[
'type' => 'password',
'value' => 'foobar',
'temporary' => false
]]
]
]);
//Query User Sample
//Refer Query parameter on GET /{realm}/users https://www.keycloak.org/docs-api/11.0/rest-api/index.html
KeycloakAdmin::user()->find([
'query' => [
'email' => '[email protected]'
]
]);
//Get All User Sample
KeycloakAdmin::user()->all();
KeycloakAdmin::addon()->logoutById([
'id' => 'user_id'
])
KeycloakAdmin::addon()->setAccessTokenExpiry([
'body' => [
'accessTokenLifespan' => 60
]
])
- Lumen Support
- Test LDAP Connection
- Import users from LDAP
All other api calls are same as examples just needs to provide required parameters as described in https://www.keycloak.org/docs-api/11.0/rest-api/index.html