Verity allows for real-time lead delivery via an Application Programming Interface (API) post. Web forms from your school’s public sites and marketing landing pages, can be integrated to send lead records in real-time using the specified lead post instructions. The API post can also be used to create web appointment requests as well as create applicant records in Verity.
Technical Requirements Verity exposes an API layer for integrating with third-party systems. The API layer is protected and secure to ensure traffic is safely being transferred via the Internet.
Verity exposes an API layer for integrating with third-party systems. The API layer is protected and secure to ensure traffic is safely being transferred via the Internet.
Verity is delivered via secure Internet channel (https). The API layer requires name/value pair authentication to communicate with third-party providers on behalf of a client. This authentication requires a unique tenant identifier to be provided with every lead post, as well as a secure system key.
Tenant Id: to be provided/specific to tenant VeritySysKey: to be provided/specific to lead provider
Tenant Id: to be provided/specific to tenant VeritySysKey: to be provided/specific to lead provider
Tenant Id: to be provided/specific to lead provider VeritySysKey: to be provided/specific to lead provider
Field Name | Tag Name | Data type | Required | Note |
Verity Security Key | veritySysKey | Text | Yes | Will be provided; max 50 characters |
Tenant Id | tenantid | Numeric | Yes | Will be provided |
External Lead Id | leadid | Text | Yes | Native to 3rd party; max 50 characters |
Campaign Code | Campaigncode | Text | Yes | Native to 3rd party; max 100 characters |
Campaign Type | Campaigntype | Text | Yes | Native to 3rd party; max 100 characters |
The following lead information is stored in Verity, as part of the inquiry management module. The external tag name, as it is received from third-party, will map the value to the corresponding field name in the Verity DB.
Field Name | Tag Name | Data type | Required | Note |
First Name | fname | Text | Yes | max 50 characters |
Middle Name | middlename | Text | No | max 50 characters |
Last Name | lname | Text | Yes | max 50 characters |
Former Name | formername | Text | No | max 50 characters |
Nick Name | nickname | Text | No | max 50 characters |
Salutation | salutation | Text | No | max 50 characters |
Professional Title | professionaltitle | Text | No | max 50 characters |
Preferred Language | lang | Text | No | max 100 characters |
Field Name | Tag Name | Data type | Required | Note |
Gender | gender | Text | No | max 50 characters |
Date Of Birth | dob | Date | No | |
Birth Date | birthdate | Date | No | |
Age | age | Numeric | No | |
Citizenship | citizenship | Text | No | max 100 characters |
Nationality | nationality | Text | No | max 100 characters |
Ethnicity | ethnicity | Text | No | max 100 characters |
Veteran Status | veteran | Text | No | max 100 characters |
Education Level | education | Text | No | max 100 characters |
Employment Status | employment | Text | No | max 100 characters |
Marital Status | maritalstatus | Text | No | max 100 characters |
Placement Status | placementstatus | Text | No | max 75 characters |
Placement Status Id | placementstatusid | Numeric | No |
Field Name | Tag Name | Data type | Required | Note |
Phone Number* | phone | Text | ! | max 30 characters |
Phone Type | phonetype | Enum | No. Default value Home |
Equals with: Home; Work; Billing; Emergency; School; Cell or Starts with: HM; WK; BILL; EM; SC; CE |
Work Phone | workphone | Text | No |
max 30 characters; Default type = Work available on create only |
Email Address* | Text | ! | max 80 characters | |
Email Type | emailttype | Enum | No. Default value Home |
Equals with: Home; Work; Billing; Emergency; School; Cell or Starts with: HM; WK; BILL; EM; SC; CE available on create only |
Street Address* | address | Text | No | max 100 characters |
Address Type | addresstype | Enum | No. Default value Home |
Equals with: Home; Work; Billing; Emergency; School; Cell or Starts with: HM; WK; BILL; EM; SC; CE available on create only |
City | city | Text | No | max 50 characters |
State | state | Text | No | max 50 characters; US address only |
Province | Province | Text | No | max 100 characters; Foreign address only. |
Zip | zip | Text | Yes | max 50 characters |
Country | Country | Text | No | max 100 characters |
County | county | Text | No | max 200 characters |
Phones | Phones | Array of objects | ! | PhoneNumber should have max 30 characters; Allows multiple phones to be posted at once; accepted format * |
Emails | Emails | Array of objects | ! | Email should have max 80 characters; Allows multiple emails to be posted at once; accepted format * |
Note: multiple values per contact path are accepted, if available.
! Important: A lead needs to have at least one point of contact (phone or email), meaning the lead record will not be accepted if the record is submitted without a phone number or email address.
If the "Phones" tag is used, the "phone" tag will be ignored
If the "Emails" tag is used, the "email" tag will be ignored
If the IsPreferred is posted, with the value "true", multiple times for the Phones/Emails list, only the first item will be considered preferred.
Phones | Emails |
"Phones": [ { "IsPreferred": bool, "ContactType": "string", "ContactTypeId": numeric, "PhoneNumber": "string",// required "IsBad": bool, "IsOld": bool, "DoNotText": bool, "DoNotCall": bool }, { .... } ] all properties are optional except "PhoneNumber" |
"Emails": [ { "IsPreferred": bool, "ContactType": "string", "ContactTypeId": numeric, "EmailAddress": "string",// required "IsBad": bool, "IsOld": bool, "DoNotEmail": bool }, { .... } ] all properties are optional except "EmailAddress" |
Field Name | Tag Name | Data type | Required | Note |
High School Grad Year | hsgradyr | Numeric | No | |
High School Grad Date | hsgraddate | Date | No | Saves the value for the Inquiry Hs Grad Yr and Highschool (Grad Date and Grad Year) |
High School City | hscity | Text | No | max 50 characters |
High School State | hsstate | Text | No | max 50 characters; US address only |
High School Province | hsprovince | Text | No | max 200 characters |
Visa Type | visa | Text | No | max 50 characters |
Lead Status | leadstatus | Text | No | max 50 characters |
Lead Type | leadtype | Text | No | max 150 characters |
Note | note | Text | No | max 1000 characters |
Field Name | Tag Name | Data type | Required | Note |
Reference First Name | referencefirstname | Text | No | max 50 characters |
Reference Last Name | referencelastname | Text | No | max 50 characters |
Reference Middle Name | referencemiddlename | Text | No | max 50 characters |
Reference Phone | referencephone | Text | No | max 30 characters |
Reference Email | referenceemail | Text | No | max 80 characters |
Reference Address | referenceaddress | Text | No | max 100 characters |
Reference City | referencecity | Text | No | max 50 characters |
Reference State | referencestate | Text | No | max 50 characters; US address only; |
Reference Country | referencecountry | Text | No | max 100 characters |
Reference Province | referenceprovince | Text | No | max 100 characters; Foreign address only. |
Reference ZipCode | referencezipcode | Text | No | max 50 characters |
Field Name | Tag Name | Data type | Required | Note |
External Applicant Id | externalapplicationid | Text | No | max 50 characters; Native to 3rd party |
Program of Enrollment | programofenrollment | Text | No | max 250 characters |
Lead Status | leadstatus | Text | No | max 50 characters; Applicant |
Parent Signature Required | parentsignaturerequired | Text | No | Sent as Yes or No, or 0 or 1 |
Is Form | isForm | Text | No | Sent as True or False; Allow updates for the inquiry Adm. advisor, Lead Status, Prog. of Interest and Prog. of Enrollment available on re-inquiry only |
Shift | shiftName | Text | No | max 50 characters, if nothing is provided a default value of "Unknown" will be used when creating the application |
Field Name | Tag Name | Data type | Required | Note |
IP Address | ipaddr | Text | Yes | max 50 characters |
Consent For Contact | consent | Text | Yes | Deprecated though still required. Sent as Yes or No, or 0 or 1 |
SMS Opt-in | sms | Text | Yes | Deprecated though still required. Sent as Yes or No or 0 or 1 |
Field Name | Tag Name | Data type | Required | Note |
Is Appointment | isappt | Text | No | Sent as True or true |
Appointment Type | appttype | Text | No | max 5 characters; Appointment Type name as configured in the Appointment Types List Inventory |
Appointment Date and Time | apptdatetime | DateTime | No | Example of format 03/30/2020 10:00 AM |
The following inventory items are being cataloged and maintained in Verity: Lists: Schools, Campuses, Programs, Lead sources, Terms
Field Name | Tag Name | Data type | Required | Note |
School Code | schoolcode | Text | No | max 5 characters |
School Name | schoolname | Text | Yes | max 200 characters |
Campus Code | campuscode | Text | No | max 10 characters |
Campus Name | campus | Text | Yes | max 50 characters |
Program Code | programcode | Text | No | max 10 characters |
Program Name | program | Text | Yes | max 250 characters |
Lead Source Category | channel | Text | No | max 250 characters |
Lead Source | leadsource | Text | Yes | max 250 characters |
Term Start | termstart | Date | No | |
Term Start Id | termstartid | Numeric | No | |
Highschool Name | hsname | Text | No | max 500 characters |
Highschool code | hscode | Text | No | max 50 characters |
Note: more fields could be added, if needed.
Field Name | Tag Name | Data type | Required | Note |
Convicted Felon | convictedfelon | Text | No | Sent as True or False |
Felony Details | felonydetails | Text | No | max 150 characters |
Field Name | Tag Name | Data type | Required | Note |
Provided by client | Provided by client | Text,date,number or url | No | max 100 characters |
Client will provide the tag name and data type expected (text, date, number, or url)
Field Name | Tag Name | Data type | Required | Note | Sample Value |
Ad Code | adcode | Text | No | max 150 characters | Campus Tour Video |
UTM Code Id | utmcodeid | Text | No | max 200 characters | 3a55agb9g649ghbkfyhy85kygj444 |
UTM Source | utm_source | Text | No | max 200 characters | bing.com |
UTM Medium | utm_medium | Text | No | max 200 characters | cpc |
UTM Campaign | utm_campaign | Text | No | max 200 characters | Barber Program |
UTM Term | utm_term | Text | No | max 200 characters | best Barber programs in Florida |
UTM Content | utm_content | Text | No | max 200 characters | accelerated program |
URL: https://apiqa.verityiq.com/api/leadpost Content Type : application/x-www-form-urlencoded Request Body: veritySysKey=123abc&tenantid=1&schoolname=School+Name&campus=Campus+Name&campaignnam e=Campaign+Name &campaigntype=PPL&campaigncode=YYY&leadid=05aipouy9&fname=Martha&lna me=Jones&email=f15aeiou%40aol.com&phone=1234567890&zip=32765&pub_id=DMS&program=Medi cal+Assisting&education=BD&hsgradyr=2004&ipaddr=11.22.33.44&tcpa_timestamp=2017-02-23+21%3A40%3A51+-0600&consent=yes&leadsource=Revenue+Enhancement+Group&CPL=DMS
Leads from source campaigns need to be mapped to the corresponding phone and email campaigns in Verity for task workflow.
Source Campaign Id | Verity Phone Campaign Id | Verity Email Campaign Id |
campaigncode campaigntype |
Field | Status | Message |
veritySysKey | HTTP 401 unauthorized | Invalid system key |
tenantid | HTTP 400 Bad Request | Lead delivery set to invalid recipient. – {sent parameter value or empty} |
schoolname | HTTP 400 Bad Request | Lead delivery set to invalid recipient. – {sent parameter value or empty} |
campus | HTTP 400 Bad Request | Lead delivery set to invalid recipient. – {sent parameter value or empty} |
campaigncode | HTTP 400 Bad Request | Lead Min Required fields not met. – campaigncode is empty |
campaigntype | HTTP 400 Bad Request | Lead Min Required fields not met. – campaigntype is empty |
leadid | HTTP 400 Bad Request | Lead Min Required fields not met. – leadid is empty |
fname | HTTP 400 Bad Request | Lead Min Required fields not met. – fname is empty |
lname | HTTP 400 Bad Request | Lead Min Required fields not met. – lname is empty |
phone OR email not provided/invalid | HTTP 400 Bad Request | Lead info invalid. – no method of contact |
request body is missing | HTTP 400 Bad Request | Lead Min Required fields not met. – empty request |
Unknown exception | HTTP 500 Bad Request | Note: this will require further investigation |
Prior to beginning the configuration required in Verity for real-time lead delivery, it is important to establish the responsible parties for setting up and maintaining the various areas of the system needed to facilitate this process for best outcomes.
It is recommended that Verity Administrators within the organization are chosen to lead the configuration effort, having their Verity Champions complete the following:
In order to configure lead distribution workflows, it is expected that Verity Champions and the power users delegated to complete the needed configuration are granted the permissions to:
As the System Administrator, to configure or review user roles and permissions in Verity:
Go to Settings --> System --> Permissions --> Select the role --> Pull dropdown to view the permissions assigned under the role. (See Illustration 1)
Then, for the power users who need access to the configuration:
Go to Settings --> List Inventory --> System Users --> Users - Find the Verity user on the list, and then click on the pencil icon to edit the account. Ensure the user has assigned the proper role with the needed permissions to reach the necessary screens for completing the configuration. (See Illustration 2)
! The user with the System Administrator role should have access to all the areas in Verity needed for the successful configuration to support new lead distrinution
Create New Team
If the process dictates for a dedicated team to place outbound contact attempts to new leads, a new team needs to be created for the designated staff, such as Campus A Admissions or Campus A Speed to contact team
! You may need to create separate teams based on your new lead distribution workflow. For example, if the new lead distribution is campus based and then a new team will need to be created for each location
To create a new team:
Go to Team Manager --> Click on the Create Team button (See Illustration 3)
At the new team screen, you may provide a name and description for the new team, as well as click on the plus sign to add one or more staff members to the team. Designate the team lead(s) and escalation manager(s), as needed. (See Illustration 4)
To broadcast tasks to a specialized team, create a new team task router and designate the take team task sequence to display the quick call tasks
! When creating a team task router both an inbound and outbound team router needs to be configured
To create a new task router:
Go to Settings --> Task Routers --> User Task Routers (See Illustration 6)
Click on the plus sign to create a new task router. Give the task router a name and description which would suggest the team selected as the recipient for the new tasks. For example: “Campus A Speed to Contact Team” (See Illustration 7)
! For the outbound queue: The team type task router needs to
! For the inbound queue:The team type task router needs to
Illustration 6: Create task router screen
When clicking the plus sign – a window will appear to add a new task router. The following information is available to be populated/edited:
Drip team campaigns need to be created to present the specialized team with tasks for contacting new leads
Go to Campaign Manager --> Ongoing Campaigns --> Team Campaign (See Illustration 8)
Follow the steps to create a new team campaign. (See Illustration 9)
! Option 1: Advisors will call from phone number assigned to the campaign: This option is recommended for campaigns that will broadcast the new lead notification to the team to allow the first available advisor to place the outbound contact attempt. The same phone number will be used regardless of the user placing the outbound contact to allow the inbound calls or text messages to be displayed to all team members
! Option 2: Advisors will call and text from their own Verity phone number: This option is recommended for campaigns in which you would like for all outbound and inbound call attempts to use the advisor’s Verity phone number
! Option 3: Advisors will text from a phone number assigned to the campaign: The same phone number will be used regardless of the user sending the text message and will display the response to the text message to all team members
! Option 4: Advisors will text from their own Verity phone number: The user’s Verity Phone number will be used to send text messages for the campaign and will route the replies to the user who sends the text message
You may configure how the system processes re-inquiry requests based on your duplicate rule and accepted lead statuses. You may also configure what fields at the master inquiry record may be changed upon accepting the re-inquiry.
To configure your re-inquiry management:
Go to Settings --> Workflows --> Lead Flow --> Re-Inquiry Management (See Illustration)
! Not allowing any changes to master inquiry record will keep all original values assigned to lead. The system will display a re-inquiry notification to the team assigned to the new lead campaign for the campus for which the lead has re-inquired.
A lead vendor will need to be added for any vendor for whom you wish to receive real-time leads. This includes web forms that are integrated from your public site or marketing landing pages, lead forms from social media ads and lead vendor partners.
To create a lead vendor:
Go to Settings --> Workflows --> Lead Flow --> Create Lead Vendor (See Illustration)
Enter the lead vendor’s name and select the school to complete the lead vendor assignment to the school. Assign a default advisor and enter the Enter number of days from the contact’s original inquiry date to notify users that he or she has re-inquired. A support ticket will need to be submitted to receive the secret key and tenant id to provide your lead vendor once the vendor has been added to Verity.
The system will then enter a default lead distribution with a campaign code and campaign type which reflects the value of defaultsetup (See Illustration).
This will be used as the default setting for routing a lead to a default campaign for review when the campaign code and campaign type
When adding a new lead distribution to the vendor, the following items will need to be configured
Scenario 1: Broadcast Notifications
New Lead notifications are the first item displayed in the notification menu. The system displays the notification when a new lead is received via the API post. The notification is displayed via the broadcast algorithm which allows all representatives assigned to that New lead campaign an opportunity to contact the lead. Clicking on the notification reserves the attempt to contact the lead.
Scenario 2: Round Robin Notifications
New Lead notifications are the first item displayed in the notification menu. The system displays the notification when a new lead is received via the API post. The notification is displayed to the advisor assigned to the lead via the round robin lead distribution which allows the admissions advisor assigned to the lead, the opportunity to contact the lead. Clicking on the notification reserves the attempt to contact the lead.
In order to make use of the Facebook Lead Generation in Verity, you need to have a Facebook Page already setup for your institution. See more information here: https://www.facebook.com/pages/creation/
Lead generation forms could then be created from within that page.
As an example, we will take the Verity IQ Facebook page (used for example purpose only). In order to create a lead generation form, you need to access the Publishing Tools page, as illustrated in the following screenshot.
From the Publishing Tools page, access the Lead Ads Forms section, as illustrated below:
Click the Create button to create a new lead form.
When creating a form, some of the fields will be mandatory, in order to properly create and route a new lead in Verity. Please refer to the lead post specifications, from above, for information on tags and form field values that could be accepted in Verity.
Setup the form to collect the desired information from the prospective student.
! Ensure the form collects the mandatory information for the Verity API lead delivery.
The tracking parameters will send to Verity API the necessary information for authentication and lead routing. For example, these fields are used to facilitate the authorization, such as the veritySysKey and tenantId, as well as indicate the key elements for lead distribution, such as campaign code and campaign type (or campaign code/type tag! ).
Extra additional parameters could also be provided by specifying additional data (custom fields).
! If the campaign code and type fields depend on a selection from a drop-down menu, use the campaigncodetag and campaigntypetag parameters instead to indicate the tag name of the field which contains the lead routing information, per your lead flow configuration in Verity. For example, if your institution routes FB leads based on campus location only, then both the campaign code tag and campaign type tag fields will contain the value of campus to indicate the API that it would need to read the values from the campus field collected with the form.
Example of form:
Example using static campaign code and type parameters:
Example using dynamic campaign code and type tags:
After successfully setting up the form in the proper form, you need to connect the forms with the Verity API Facebook Webhook.
In order to set up a CRM connection and connect to the Verity API Webhook, we need to go to Leads Setup and connect the CRM, as illustrated next.
! The Verity API Facebook Webhook could be accessed via Zapier.
Selecting Webhooks by Zapier allows the creation of a free account and connection to our API. You may also provide the credentials for connecting to a paid Zapier account already owned by the institution.
Follow the connection steps and select the POST event that will send the form data to Verity.
Select the Facebook Lead Ads App and New Lead trigger event, as illustrated:
Then, choose or create the account to use in Zapier.
Select the Facebook page that contains the desired form to link to the Verity API Facebook Webhook.
After finishing selecting the form and clicking Continue, it is possible to then Test and Preview the form selections. This way, you can ensure the form is properly setup to send the new lead fields.
Select the App Webhooks by Zapier and the Action Event POST, as illustrated below:
Insert the following URL:
https://apiqa.verityiq.com/webhook/facebook/zapier
This is the webhook URL that will create the leads in your production instance of Verity. This webhook URL will receive the form field data, as inputted by the prospective students, as well as the hidden fields that are needed for authorization and campus/school/campaign selection.
In the Payload Type field, select the FORM type.
After setting up the POST URL, use the TEST & REVIEW button to test the form data.
! For help with testing or troubleshooting your Facebook/Instagram connector with Verity, open a ticket with our support team by emailing to support@verityiq.com