API
Introduction
apifew core task is to grant/check end-users licenses, and when applicable, register usage.
Standalone applications and SaaS can request apifew to check if a given user has been assigned a license. It is done by requesting apifew's API.
APIs applications can also check user rights to request and register requests usage, with 3 different methods.
To interact with apifew's API as a provider, your calls need to be authenticated.
Apifew-Key
is available on apifew's website, in Provider mode, on Applications General settings
headers:
{
"Content-Type": "application/json",
"Apifew-Key": "12345678-aaaa-bbbb-cccc-1234567890abcdef"
}
Info
Currently /v2/ is currently in production.
/v1/ is still available for backward compatibility.
Users management
apifew's API enable your application back-end to manage your end-users directly.
The basic usage includes checking your users'permissions: license status and features.
More advances usages cover end-users login, password management...
User creation
Creates a new user for provider's application and apifew platform.
POST https://gw.apifew.com/v2/app/user/create
{
"USER_LOGIN": "user.name@example.com"
}
Response (Result object)
Result.data:
{
"uid": "ABCDEF1234567890",
}
Result.success_msg: "INFO_APP_USER_CREATED"
Result.error_msg: "ERROR_USER_NOT_FOUND"
User information
Retrieve information about the user and the license that has been assigned to them.
POST https://gw.apifew.com/v2/app/user
{
"USER_LOGIN": "user.name@example.com"
}
Response (Result object)
Result.data:
{
"login": "user.name@example.com",
"uid": "ABCDEF1234567890",
"app": "app.domain.com",
"license_key": "12345678-aaaa-bbbb-cccc-1234567890abcdef",
"pricing_fullname": "monthly_10 rev.21",
"license_role": "normal_user",
"license_features": ["read_report", "download_report"],
"license_active": true,
"license_status": "subscribed"
"name_first": "John"
"name_last": "Smith"
}
Result.error_msg: "ERROR_USER_NOT_FOUND"
User information - update
Change misc. information (first name, last name).
POST https://gw.apifew.com/v2/app/user/info/save
{
"USER_LOGIN": "user.name@example.com",
"USER_SETTINGS": {
"name_first": "John",
"name_last": "Smith"
}
}
Response (Result object)
Result.data: ["name_first", "name_last"]
Result.success_msg: "INFO::USER_INFO_SAVED"
Result.error_msg: "ERROR::USER_NOT_FOUND"
In case of success, Result.data
contains field names for which the value has been modified.
User deletion
Delete an end-user for your application (only).
apifew's related user will not be deleted (they keep access to their invoices, and eventually other applications)
POST https://gw.apifew.com/v2/app/user/delete
{
"USER_LOGIN": "user.name@example.com"
}
Response (Result object)
Result.success_msg: "INFO_APP_USER_DELETED"
Result.error_msg: "ERROR_MISSIN_PARAMETER"
"ERROR_USER_NOT_FOUND"
Managed user creation
Add a managed user to an owner's team
A managed user is an end-user controled by a licenses owner. It allows any license owner to assign and revoke licenses to its managed users, without the need for them to interact with apifew.
POST https://gw.apifew.com/v2/user/managed/create
{
"OWNER_LOGIN": "user1.name1@example.com"
"MANAGED_LOGIN": "user2.name2@example.com"
}
Response (Result object)
Result.success_msg: "INFO_MANAGED_USER_CREATED_Params || <LOGIN>"
Result.error_msg: "ERROR_MISSIN_PARAMETER"
"ERROR_USER_NOT_FOUND"
Managed user removal
Remove a managed user from an owner's team, if no license assigned to managed user.
POST https://gw.apifew.com/v2/user/managed/remove
{
"OWNER_LOGIN": "user1.name1@example.com"
"MANAGED_LOGIN": "user2.name2@example.com"
}
Response (Result object)
Result.success_msg: "INFO_MANAGED_USER_REMOVED"
Result.error_msg: "ERROR_USER_NOT_FOUND"
User login
{
}
Pricings & Licenses
Pricings
Retrieves basic information for all pricings (if CURRENT_REV_ONLY is missing or set to 0, returns lastest revision + all revisions with at least one license attached, otherwise returns only lastest revision).
POST https://gw.apifew.com/v2/app/pricings
{
"CURRENT_REV_ONLY"? 1
}
Response (Result object)
Result.data:
{
"pricings": [
{
"pricing_name": "Monthly pricing",
"pricing_rev": 10,
"licenses_count": 133,
"features": [<feature>, ...]
}
...
]
}
Pricings and licenses details
Retrieve information for all pricings (lastest revision + all revisions with at least one license attached) and licenses information.
POST https://gw.apifew.com/v2/app/pricings
{
}
Response (Result object)
Result.data:
{
"pricings": [
{
"pricing_name": "Monthly pricing",
"pricing_rev": 10,
"licenses": [
{
"key": "",
"pricing_fullname": "Monthly pricing rev.10",
"period_freq": "monthly",
"end_dt": "2022-02-28",
"active": "true",
"status": "subscribed",
"owner_login": "john.smith@noname.com",
"user_login": "agent_smith@noname.com"
}
...
]
}
...
]
}
License information
License information is available on /v2/app/user (see User information)
But you can directly get information with license key:
POST https://gw.apifew.com/v2/app/license
{
"USER_LICENSE": "12345678-aaaa-bbbb-cccc-1234567890abcdef"
}
Result.data:
{
"login": "user.name@example.com",
"uid": "ABCDEF1234567890",
"app": "app.domain.com",
"license_number": "12345678-aaaa-bbbb-cccc-1234567890abcdef",
"pricing_name": "monthly_10 rev.21",
"pricing_features": [],
"pricing_active": true,
"license_status": "subscribed"
}
Result.error_msg: "ERROR_LICENSE_NOT_FOUND"
"APIFEY_KEY_NOT_FOUND"
All licenses
Get all licenses issued (for caching purpose on your back-end)
POST https://gw.apifew.com/v2/app/licenses
Result.data:
{
"licenses": [
{
"key": "12345678-aaaa-bbbb-cccc-1234567890abcdef",
"active": true,
"status": "subscribed",
"end_dt": "1970-01-01",
},
...]
}
Result.error_msg: "APIFEY_KEY_NOT_FOUND"
Create a license
Creates 1 (or QUANTITY
) license(s) for a given pricing and assign ownership to a user.
By default, will also assign usage to owner, except if optional parameter NO_USAGE
is truthy.
POST https://gw.apifew.com/v2/app/pricing/license/create
{
"PRICING_UID" "ABCDEF1234567890",
"OWNER_LOGIN" "user1.name1@example.com"
"QUANTITY"? 10
"NO_USAGE"? true
}
Response (Result object)
Result.data:
{
"keys": ["12345678-aaaa-bbbb-cccc-1234567890abcdef", ...]
}
Result.success_msg: "INFO_LICENSE_CREATED"
"INFO_LICENSE_CREATED_AND_ASSIGNED"
Result.error_msg: "ERROR_LICENSE_CANCELLED"
"ERROR_MISSING_PARAMETER"
"ERROR_NO_LICENSE_AVAIL"
"ERROR_ALREADY_ASSIGNED_APP_LICENSE"
"ERROR_USER_NOT_FOUND"
Assign a license
Assigns usage to a user, if owner has at least 1 license available (unassigned).
POST https://gw.apifew.com/v2/app/pricing/license/assign
{
"PRICING_UID" "ABCDEF1234567890",
"OWNER_LOGIN": "user1.name1@example.com",
"USER_LOGIN": "user2.name2@example.com"
}
Response (Result object)
Result.data:
{
"key": "12345678-aaaa-bbbb-cccc-1234567890abcdef"
}
Result.success_msg: "INFO_LICENSE_ASSIGNED"
Result.error_msg: "ERROR_LICENSE_CANCELLED"
"ERROR_MISSING_PARAMETER"
"ERROR_NO_LICENSE_AVAIL"
"ERROR_ALREADY_ASSIGNED_APP_LICENSE"
"ERROR_USER_NOT_FOUND"
Release a license
Removes usage from a user and leave it available to owner for re-assignation.
POST https://gw.apifew.com/v2/app/pricing/license/create
{
"PRICING_UID" "ABCDEF1234567890",
"USER_LOGIN": "user1.name1@example.com"
}
Response (Result object)
Result.data:
{
"key": "12345678-aaaa-bbbb-cccc-1234567890abcdef"
}
Result.success_msg: "INFO_LICENSE_RELEASED"
Result.error_msg: "ERROR_MISSING_PARAMETER"
"ERROR_USER_NOT_FOUND"
"ERROR_NO_APP_LICENSE_ASSIGNED_TO_USER"
Licenses migration
Migrates all licenses related to a given pricing to pricing's latest revision
POST https://gw.apifew.com/v2/app/pricing/licenses/migrate
{
"PRICING_UID" "ABCDEF1234567890",
}
Response (Result object)
Result.data:
{
"licenses_migrated": 128
}
Result.success_msg: "INFO_LICENSES_MIGRATED"
Result.error_msg: "ERROR_WRONG_PARAMETER"
Counters
Read counter value
A counter is attached to a user's license, so it is unique for each user.
POST https://gw.apifew.com/v2/app/user/license/counter/value/save
{
"COUNTER_NAME" "counter_one",
"USER_LOGIN" "ABCDEF1234567890",
}
Response (Result object)
Result.data:
{
"value": 100
}
Result.success_msg: ""
Result.error_msg: "ERROR_WRONG_VALUE"
"ERROR_COUNTER_NOT_FOUND_FOR_USER"
"ERROR_NO_LICENSE_ASSIGNED_FOR_USER"
"ERROR_USER_ASSIGNED_TO_MORE_THAN_ONE_LICENSE"
Write counter value
A counter is attached to a user's license, so it is unique for each user.
POST https://gw.apifew.com/v2/app/user/license/counter/value/save
{
"COUNTER_NAME" "counter_one",
"USER_LOGIN" "ABCDEF1234567890",
"VALUE" "3.1415927"
}
Response (Result object)
Result.data:
{
"value": 3.1415927
}
Result.success_msg: "INFO_COUNTER_VALUE_SAVED"
Result.error_msg: "ERROR_WRONG_VALUE"
"ERROR_COUNTER_NOT_FOUND_FOR_USER"
"ERROR_NO_LICENSE_ASSIGNED_FOR_USER"
"ERROR_USER_ASSIGNED_TO_MORE_THAN_ONE_LICENSE"
Gateway to your API
Three different ways are available to serve request from end-user to your API (API provider).
Description | Requested server | Pros | Cons |
---|---|---|---|
apifew's gateway | gw.apifew.com | simple for end-user/provider | not suitable for heavy workloads |
token | API provider | suitable for any workload | more work on integration |
request stamp | API provider | simple for end-user | end-user must trust provider |
apifew's gateway
It is the most straighforward. End-user requests via apifew and gets results back in a Result object. There is only 1 change vs a direct API call: request is packaged as an RPC:
endpoint: [POST] https://gw.apifew.com/v1/request
headers: {
'Content-Type': 'application/json',
'Apifew-User-License': '12345678-aaaa-bbbb-cccc-1234567890abcdef'
}
body: {
"APP_NAME": "api.domain.com",
"ROUTE": "/a/route",
"METHOD": "GET",
?"PARAMS": {
"param1": "value1",
"param2": "value2"
},
?"HEADERS": {
"x-api-key": "a_secret_key"
}
?"RESPONSE_AS_RESULT" true
}
------------
response: Result object (or raw response)
Result.data Response from API (if RESPONSE_AS_RESULT is true)
token
Few cases disfavor apifew's gateway option: requests involve heavy load such as picture/video or PDF files, or highly sensitive/regulated data.
In such case, API consumer needs to directly request your API.
With 'token' mode, API consumer first request a one-usage-only token to apifew, and will pass this token as header 'Apifew-Request-Token' when requesting to your API.
Step 1: consumer requests apifew for token
endpoint: POST https://gw.apifew.com/v1/token/create
headers:
body: {
"USER_LICENSE": "<END USER LICENSE NUMBER FOR API>",
"API_URL": "https://exemple.api.com/route/to/request",
"API_METHOD": "GET"
}
------------
response: Result object
Result.data {
"token": "12345678-aaaa-bbbb-cccc-1234567890abcdef"
}
Step 2: consumer requests API directly, with token
endpoint: <METHOD> https://exemple.api.com/route/to/request
headers: 'Apifew-Request-Token': '12345678-aaaa-bbbb-cccc-1234567890abcdef'
params/body: <PARAMS OR BODY>
Step 3: API provider consumes token and set request status
endpoint: POST https://gw.apifew.com/v1/token/consume
headers: {
'Content-Type: "application/json",
'Apifew-Key': "<API KEY (SECRET KEY DISPLAYED ON API GENERAL SETTINGS)>"
}
body: {
"TOKEN": "12345678-aaaa-bbbb-cccc-1234567890abcdef",
"REQUEST_STATUS_CODE": 200,
optional "SHOW_PRICING": true
}
------------
response: Result object
Result.data {
"app_name": "app.api.com",
"token": "12345678-aaaa-bbbb-cccc-1234567890abcdef",
"consumed": true,
"pricing": "main"
}
Warning
Note that if REQUEST_STATUS_CODE differs from 200, no fee will be charged
(optional) Step 4: consumer confirms request status
To be implemented
request stamp
This last option enables API provider to stamp request once processed
Deprecated
Users
endpoint:
POST https://gw.apifew.com/v1/app/user/create
body:
{
"USER": {
"login": "user.name@domain.com"
}
}
------------
response:
Result object
Result.data:
{
"uid": <USER UID FOR APPLICATION>
}
Result.success_msg: "INFO_APP_USER_CREATED"
Result.error_msg: "ERROR_USER_ALREADY_EXISTS"
endpoint:
POST https://gw.apifew.com/v1/app/user
body:
{
"USER": {
"login": "user.name@example.com"
}
}
------------
response:
Result object
Result.data:
{
"login": "user.name@example.com",
"uid": "ABCDEF1234567890",
"app": "app.domain.com",
"license_number": "12345678-aaaa-bbbb-cccc-1234567890abcdef",
"license_ok": true
}
Result.error_msg: "ERROR_USER_NOT_FOUND"
endpoint:
POST https://gw.apifew.com/v1/app/user/delete
body:
{
"USER": {
"login": "user.name@example.com"
}
}
------------
response:
Result object
Result.success_msg: "INFO_APP_USER_DELETED"
Result.error_msg: "ERROR_USER_NOT_FOUND"