UC API Auth Overview

Welcome to SkySwitch UC API!

The UC API uses a separate source of authentication tokens from that of the Skyswith Telco API.


Prepare the Credentials

To begin using the UC API, open a ticket with SkySwitch Control Tower to specifically request for client_id and client_secret for the UC API.

client_id : request this from Skyswitch Control Tower

client_secret : request this from Skyswitch Control Tower

username: the PBX user's login name

password : the PBX user's password


Obtaining an Access Token

To obtain a fresh access token, you will use the credentials prepared above.

Note that the URL is https://api.skyswitch.com/oauth2/token.

The grant_type is always password

Add scope=offline_access if you want to get a refresh token.

REQUEST:

curl --location 'https://api.skyswitch.com/oauth2/token'
--header 'Content-Type: application/x-www-form-urlencoded'
--data-urlencode 'grant_type=password'
--data-urlencode 'client_id=your_client_id_provided_by_control_tower'
--data-urlencode 'client_secret=your_client_secret_provided_by_control_tower'
--data-urlencode 'username=your_pbx_user_login_name'
--data-urlencode 'password=your_pbx_user_password'
--data-urlencode 'scope=offline_access'

RESPONSE:

{
"access_token": "eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCIsImd0eSI6WyJwYXNzd29yZCJdLCJraWQiOiIwNTRkYmUyMTg5In0.eyJhdWQiOiI2YTMyNTBjOC0yMGQ0LTRjMGEtOGYyYS1lMWEzOTcwNjZkNzEiLCJleHAiOjE3MzA5MTg2OTQsImlhdCI6MTczMDgzMjI5NCwiaXNzIjoiYXV0aC51Yy10ZWNobm9sb2dpZXMuY29tIiwic3ViIjoiYTVkNjU0MDMtMjYyYS01MjhmLWFhMzYtZjhjMTA0NGFjNTU5IiwianRpIjoiMGY0Nzc1ZTctNzGEwOS00NzEzLWIzMDItYjVmYjliMzBkMGE1IiwiYXV0aGVudGljYXRpb25UeXBlIjoiUEFTU1dPUkQiLCJwcmVmZXJyZWRfdXNlcm5hbWUiOiI2NjEzQHNreXN3aXRjaCIsImFwcGxpY2F0aW9uSWQiOiI2YTMyNTBjOC0yMGQ0LTRjMGEtOGYyYS1lMWEzOTcwNjZkNzEiLCJyb2xlcyI6WyJwYnhfcmVzZWxsZXIiXSwic2NvcGUiOiJvZmZsaW5lX2FjY2VzcyIsInNpZCI6IjgzNWI2Njc2LTM4YjctNDMzNS04MzY3LTI3OWM5OTkzMTZmNyIsImF1dGhfdGltZSI6MTczMDgzMjI5NCwidGlkIjoiM2Y2MDYzZTQtMzM3NC0xMWVjLWEyNmUtMGExNjZmMTM5NjY5IiwibnNVaWQiOiI2NjEzQHNreXN3aXRjaC4xNTYxMS5zZXJ2aWNlIiwicGJ4Q29ubmVjdG9yVXVpZCI6ImE1ZDY1NDAzLTI2MmEtNTI4Zi1hYTM2LWY4YzEwNDRhYzU1OSIsInVpZCI6IjY2MTNAc2t5c3dpdGNoLjE1NjExLnNlcnZpY2UiLCJjaGltZUFybiI6ImFybjphd3M6Y2hpbWU6dXMtZWFzdC0xOjQ2NDYxNDA0NDY3NTphcHAtaW5zdGFuY2UvNTMwODViZDYtMDM0NC00MGIzLWI5ZTUtOTJlYWRjMWVmNGIzL3VzZXIvYTVkNjU0MDMtMjYyYS01MjhmLWFhMzYtZjhjMTA0NGFjNTU5IiwicmVzZWxsZXJfaWQiOiIxNTYxMSJ9.5RK4gIxrGzscwcb5ZkQEbdzL1lS9p5Y1OQtLG1iGf2o",
"expires_in": 86400,
"refresh_token": "ZdaHTfNaE3kKoMveMj40EFIn1v4t6od82LA1JRy2QPoOpXWZPkF5Ng",
"refresh_token_id": "835b6676-38b7-4335-8367-279c999316f7",
"scope": "offline_access",
"token_type": "Bearer",
"userId": "11115403-262a-528f-aa36-f8c1044a1111"
}

Use the providedaccess_token for subsequent UC API method calls. For more information, see Obtain access token method doc.

Use the provided userID whenever a uuid is required by the rest of the UC API method call. The userID is a system-generated unique identifier assigned to the PBX user having the username passed in the request.

If you have a long running app, before the expires_in expiry is reached, use the refresh_token to get a new access token. See next section below for more info.


Authorization Header

For UC API calls method other calls, the access_token must be passed as a bearer token in an Authorization header.

Here is an example UC API method call using the access_token returned in the preceding section.

curl --location 'https://api.skyswitch.com/users/11115403-262a-528f-aa36-f8c1044a1111/faxes/numberlist'
--header 'Authorization: Bearer eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCIsImd0eSI6WyJwYXNzd29yZCJdLCJraWQiOiIwNTRkYmUyMTg5In0.eyJhdWQiOiI2YTMyNTBjOC0yMGQ0LTRjMGEtOGYyYS1lMWEzOTcwNjZkNzEiLCJleHAiOjE3MzA5MTg2OTQsImlhdCI6MTczMDgzMjI5NCwiaXNzIjoiYXV0aC51Yy10ZWNobm9sb2dpZXMuY29tIiwic3ViIjoiYTVkNjU0MDMtMjYyYS01MjhmLWFhMzYtZjhjMTA0NGFjNTU5IiwianRpIjoiMGY0Nzc1ZTctNzGEwOS00NzEzLWIzMDItYjVmYjliMzBkMGE1IiwiYXV0aGVudGljYXRpb25UeXBlIjoiUEFTU1dPUkQiLCJwcmVmZXJyZWRfdXNlcm5hbWUiOiI2NjEzQHNreXN3aXRjaCIsImFwcGxpY2F0aW9uSWQiOiI2YTMyNTBjOC0yMGQ0LTRjMGEtOGYyYS1lMWEzOTcwNjZkNzEiLCJyb2xlcyI6WyJwYnhfcmVzZWxsZXIiXSwic2NvcGUiOiJvZmZsaW5lX2FjY2VzcyIsInNpZCI6IjgzNWI2Njc2LTM4YjctNDMzNS04MzY3LTI3OWM5OTkzMTZmNyIsImF1dGhfdGltZSI6MTczMDgzMjI5NCwidGlkIjoiM2Y2MDYzZTQtMzM3NC0xMWVjLWEyNmUtMGExNjZmMTM5NjY5IiwibnNVaWQiOiI2NjEzQHNreXN3aXRjaC4xNTYxMS5zZXJ2aWNlIiwicGJ4Q29ubmVjdG9yVXVpZCI6ImE1ZDY1NDAzLTI2MmEtNTI4Zi1hYTM2LWY4YzEwNDRhYzU1OSIsInVpZCI6IjY2MTNAc2t5c3dpdGNoLjE1NjExLnNlcnZpY2UiLCJjaGltZUFybiI6ImFybjphd3M6Y2hpbWU6dXMtZWFzdC0xOjQ2NDYxNDA0NDY3NTphcHAtaW5zdGFuY2UvNTMwODViZDYtMDM0NC00MGIzLWI5ZTUtOTJlYWRjMWVmNGIzL3VzZXIvYTVkNjU0MDMtMjYyYS01MjhmLWFhMzYtZjhjMTA0NGFjNTU5IiwicmVzZWxsZXJfaWQiOiIxNTYxMSJ9.5RK4gIxrGzscwcb5ZkQEbdzL1lS9p5Y1OQtLG1iGf2o'


Refreshing a Token

For applications that would access the UC API for long-running processes and without the original username and password, you may generate a new access_token based off a valid refresh_token.

Here is a sample API call to get a new access token.

REQUEST

curl --location 'https://api.skyswitch.com/oauth2/token'
--header 'Content-Type: application/x-www-form-urlencoded'
--data-urlencode 'grant_type=refresh_token'
--data-urlencode 'client_id=your_client_id_provided_by_control_tower'
--data-urlencode 'client_secret=your_client_secret_provided_by_control_tower'
--data-urlencode 'scope=offline_access'
--data-urlencode 'refresh_token=ZdaHTfNaE3kKoMveMj40EFIn1v4t6od82LA1JRy2QPoOpXWZPkF5Ng'

RESPONSE

{
"access_token": "eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCIsImd0eSI6WyJwYXNzd29yZCIsInJlZnJlc2hfdG9rZW4iXSwia2lkIjoiMDU0ZGJlMjE4OSJ9.eyJhdWQiOiI2YTMyNTBjOC0yMGQ0LTRjMGEtOGYyYS1lMWEzOTcwNjZkNzEiLCJleHAiOjE3MzA5MTg4ODIsImlhdCI6MTczMDgzMjQ4MiwiaXNzIjoiYXV0aC51Yy10ZWNobm9sb2dpZXMuY29tIiwic3ViIjoiYTVkNjU0MDMtMjYyYS01MjhmLWFhMzYtZjhjMTA0NGFjNTU5IiwianRpIjoiYWM3ZDM2NTEtYzYyOS00MDQ3LWJjNjMtOTdkZmVlM2E4NTg5IiwiYXV0aGVudGljYXRpb25UeXBlIjoiUkVGUkVTSF9UT0tFTiIsInByZWZlcnJlZF91c2VybmFtZSI6IjY2MTNAc2t5c3dpdGNoIiwicm9sZXMiOlsicGJ4X3Jlc2VsbGVyIl0sImF1dGhfdGltZSI6MTczMDgzMjI5NCwiYXBwbGljYXRpb25JZCI6IjZhMzI1MGM4LTIwZDQtNGMwYS04ZjJhLWUxYTM5NzA2NmQ3MSIsInRpZCI6IjNmNjA2M2U0LTMzNzQtMTFlYy1hMjZlLTBhMTY2ZjEzOTY2OSIsInNpZCI6IjgzNWI2Njc2LTM4YjctNDMzNS04MzY3LTI3OWM5OTkzMTZmNyIsIm5zVWlkIjoiNjYxM0Bza3lzd2l0Y2guMTU2MTEuc2VydmljZSIsInBieENvbm5lY3RvclV1aWQiOiJhNWQ2NTQwMy0yNjJhLTUyOGYtYWEzNi1mOGMxMDQ0YWM1NTkiLCJ1aWQiOiI2NjEzQHNreXN3aXRjaC4xNTYxMS5zZXJ2aWNlIiwiY2hpbWVBcm4iOiJhcm46YXdzOmNoaW1lOnVzLWVhc3QtMTo0NjQ2MTQwNDQ2NzU6YXBwLWluc3RhbmNlLzUzMDg1YmQ2LTAzNDQtNDBiMy1iOWU1LTkyZWFkYzFlZjRiMy91c2VyL2E1ZDY1NDAzLTI2MmEtNTI4Zi1hYTM2LWY4YzEwNDRhYzU1OSIsInJlc2VsbGVyX2lkIjoiMTU2MTEifQ.LMlPZve80CUj98klsf9IhiCcO1-5ycPzcE2A9_qHAmw",
"expires_in": 86400,
"refresh_token": "ZdaHTfNaE3kKoMveMj40EFIn1v4t6od82LA1JRy2QPoOpXWZPkF5Ng",
"refresh_token_id": "835b6676-38b7-4335-8367-279c999316f7",
"scope": "offline_access",
"token_type": "Bearer",
"userId": "a5d65403-262a-528f-aa36-f8c1044ac559"
}