Quick Start - Call Authentication
Pre-requisites
- First Orion Branded Communications agreement
- Access to First Orion Customer Portal
- Vetted and Approved Business
- Ability to originate phone calls from configured phone numbers in calling platform
- Understanding of current calling platform and environment to integrate required API
Steps
The following steps detail the process of configuring an Authenticated Calling Program in the First Orion platform.
Step 1 - Login to First Orion Portal
data:image/s3,"s3://crabby-images/c6e57/c6e576c610d5c849c367bb860fed69e3dd48bea1" alt=""
Step 2 - Locate Business
- Scroll down to the list of businesses
- Search based on Business Name or Business ID
- Click on the business
data:image/s3,"s3://crabby-images/b6c7a/b6c7a577364973ec9732285f7a3ce44503f9b432" alt=""
Step 3 - (Optional) Add Logo to Image Gallery (for new images)
If you are not using Call Authentication with Logo, skip to Step 4
- Navigate to Image Gallery
- Upload and SVG that adheres to the file restrictions.
data:image/s3,"s3://crabby-images/5bd75/5bd75ba807a587c43245416563b23bfd0e05611c" alt=""
data:image/s3,"s3://crabby-images/4dbca/4dbca87c71be55ed19a360a1502d6427e3f02090" alt=""
Step 4 - Setup Program
Authenticated Inform
- Navigate to the Business Unit level.
- Click Manage in the top right.
- Click Create Program.
- Select the Authenticated Inform program type.
- Name the program and select the call purpose.
- Click into Display to add the text display and the program duration.
- Note - skip the "Image" step to ensure the Program is not created as Inform with Logo
- Click into Phone Numbers to add numbers for branding.
- Click Launch.
data:image/s3,"s3://crabby-images/9598a/9598a254fc076c5a6af350a19d28ce298b3589ae" alt="Inform Program Set Up Example"
data:image/s3,"s3://crabby-images/0d4ed/0d4ed168295592dbececc8d3c48dfba28a07e3e5" alt="Inform Program Set Up Example"
Inform with Logo
- Navigate to the Business Unit level
- Click Manage in the top right
- Click Create Program
- Select the Authenticated Inform program type.
- Name the program and select the call purpose.
- Click into Display to add the text display and the program duration.
- Click into Image and select the previously uploaded image.
- Click into Phone Numbers to add numbers for branding.
- Click Launch
data:image/s3,"s3://crabby-images/f6aa8/f6aa8881e238f301e04ab7a948bf3acc2ee5756b" alt="Inform Logo Program Setup"
Sentry
- Navigate to the Business Unit level
- Click Manage in the top right
- Click Create Program
- Select the Sentry program type.
- Name the program and select the call purpose.
- Click into Display. Set program duration then either toggle branding off (just shows phone number) or add the text display.
- Click into Phone Numbers to add numbers for Sentry.
data:image/s3,"s3://crabby-images/1038b/1038b5a77f36b2a4dd4aa557610fa28d1f6618c8" alt=""
data:image/s3,"s3://crabby-images/b42a6/b42a6353e98b124d8dfeed5af095cef361a51bbb" alt="Sentry Progtam set up"
Step 5 - Generate API Keys
- Navigate to the API Keys section on the left hand side.
- Click Generate Key to generate the new key.
- Copy and save or download the generated keys.
data:image/s3,"s3://crabby-images/2babc/2babcafc7dfae118db1f8cdbee189610cb9fd2d6" alt="API Generation Example"
Step 6 - Integrate Call Authentication API
- Verify being able to generate an access token.
curl --location --request POST 'https://api.firstorion.com/v1/auth' \
--header 'X-API-KEY: [API KEY FROM PORTAL]' \
--header 'X-SECRET-KEY: [SECRET KEY FROM PORTAL]' \
--header 'X-SERVICE: auth' \
--header 'accept: application/json'
- Verify being able to make an Authenticated Call API push.
curl --location 'https://api.firstorion.com/exchange/v1/calls/push' \
--header 'authorization: Bearer [FROM GET TOKEN ENDPOINT]' \
--header 'content-type: application/json' \
--data '{
"aNumber": "+18668561234",
"bNumber": "+15019515678",
"businessId": "0e79a3bc-18d1-4f5c-a781-458f8bad9b22"
}'
- Identify where in the platforms call flow this can live and integrate it.
Example Javascript below.
// Libraries
const axios = require('axios'); // Install with, npm install axios
// Gets First Orion Auth Token
const getToken = async () => {
try {
const response = await axios.post(
'https://api.firstorion.com/v1/auth',
null,
{
headers: {
'X-SERVICE':'auth',
'X-API-KEY': 'your-api-key',
'X-SECRET-KEY': 'your-secret-key',
'Content-Type': 'application/json'
}
}
);
return response.data.token;
} catch (error) {
console.error('Error:', error);
return {
statusCode: error.response ? error.response.status : 500,
body: JSON.stringify({ error: error.message })
};
}
}
// Create pre-call push to First Orion for Call Authentication
// Find out more at: https://developer.firstorion.com/firstorion-public/reference/callauthentication
const push_callauth = async (token) => {
let data = JSON.stringify({
"aNumber": '+15555555555',
"bNumber": '15554444444',
"businessId": 'your-business-id'
});
let config = {
method: 'post',
url: 'https://api.firstorion.com/exchange/v1/calls/push',
headers: {
'Authorization': token,
'Content-Type': 'application/json'
},
data : data
};
axios.request(config)
.then((response) => {
console.log(JSON.stringify(response.data));
})
.catch((error) => {
console.log(error);
});
}
// Main function to invoke the pre-call push for call authentication.
const main = async () => {
const token = await getToken();
await push_callauth(token);
await createCall();
}
main()
Updated 8 days ago