Authorization#
In this section are described the authorization methods specially useful if you plan to work with the Bacularis API directly.
OAuth2#
General information#
Bacularis API
To obtain access tokens, the OAuth2 implementation in the Bacularis API uses the Authorization Code Grant flow.
Authorization URL:
/oauth/authorize
Access Token URL:
/oauth/token
Note
The Bacularis API does not use refresh tokens. After expiration token the client application has to re-authorize again.
Authorization code expire time is 7 seconds, access token expire time is 1 hour. You can change these default values in the file:
bacularis/protected/Common/Modules/OAuth2.php
You can find there the following constants:
AUTHORIZATION_ID_EXPIRES_TIME
,
ACCESS_TOKEN_EXPIRES_TIME
.
To learn the Bacularis API endpoints please visit the Bacularis API documentation.
Bacularis Web
OAuth2 callback URL (the redirect URI parameter) in the Bacularis Web for
bacularis
host is following:
Enabling OAuth2#
Default the Bacularis API uses the basic authentication. Enabling OAuth2 authorization gives additional features like:
access to Bacularis API by secure tokens,
OAuth2 scopes to limit access to API endpoint by endpoint types (
/jobs/
,/clients/
… and so on).
Enable OAuth2 in API
To enable OAuth2 please switch the Bacularis API into the OAuth2 mode. You can do it in a Bacularis API panel as shown on the following image:
data:image/s3,"s3://crabby-images/6a1b9/6a1b922f9bb737d423d6cd9b972bba0e31b52ffd" alt="../_images/bacularis_enable_oauth2.png"
Create admin OAuth2 client params
You need to create the admin OAuth2 client account which will be used by the Bacularis Web to connect to the Bacularis API. You can create it in a Bacularis API admin panel as shown on the following images:
data:image/s3,"s3://crabby-images/a007a/a007a80785afd67ad54c78055072c19d1a406a4c" alt="../_images/bacularis_api_oauth2_1.png"
data:image/s3,"s3://crabby-images/1fd64/1fd64a03d788522301256b047dd35bf3fb8311c4" alt="../_images/bacularis_api_oauth2_2.png"
Connect Bacularis Web using OAuth2 method
Now you can connect the Bacularis Web to the Bacularis API with using an OAuth2 authorization method in the Bacularis Web.
First please go in the Bacularis Web to the Security page on the tab
API hosts
and there please edit existing API host.
data:image/s3,"s3://crabby-images/28ece/28ece2fb22de4afd10a07a60953987c66ed4d004" alt="../_images/bacularis_web_oauth2_1.png"
Please switch the method to OAuth2 and copy OAuth2 client account parameters (Client ID, Client secret…) from API panel to this form.
data:image/s3,"s3://crabby-images/63378/63378b6a495882faab6948db386bf507380ad979" alt="../_images/bacularis_web_oauth2_2.png"