ServiceNow offers a developer sandbox to interact and develop against their APIs. If you want to try out the ServiceNow Notifer in Iguana X, you’ll first need to login or signup for a ServiceNow developer account and create an App:
Sign in or create a developer account and open your ServiceNow instance
Login or signup for a ServiceNow developer account: https://developer.servicenow.com/dev.do.
Once logged in:
Make sure your user role is set to Admin, which is required to access instance configurations. If not, you can select Change User Role to change it to Admin.
Click Start Building to access your instance and begin configuring your application.
data:image/s3,"s3://crabby-images/477b8/477b8bb243ffa9650db4df563a424a5d04f47d90" alt="Screen Shot 2024-04-05 at 10.16.46 AM.png"
Note the Instance ID in the URL of your ServiceNow instance:
For example - https://dev252204.service-now.com/
Ensure your application has the necessary plugins enabled - OAuth2.0 and REST API Auth Scope
Go to Admin > Application Manager
data:image/s3,"s3://crabby-images/bc55b/bc55b7c42a3cb337d33fab6f1d07bbe31c8747d7" alt="Screen Shot 2024-04-02 at 4.36.12 PM.png"
Search for the following plugins to verify they are installed and enabled:
OAuth 2.0
REST API Auth Scope
data:image/s3,"s3://crabby-images/18da0/18da03e7ecc16040d84c9e035df72b8cf8cc6766" alt="Screen Shot 2024-04-02 at 4.40.48 PM.png"
data:image/s3,"s3://crabby-images/80f97/80f975b4dd36fa4e0ffd83850da71b54da5a00cd" alt="Screen Shot 2024-04-02 at 4.40.29 PM.png"
Create an ssh key pair and upload the public key certificate file to your ServiceNow instance
ServiceNow uses OAuth2.0 JWT API endpoint to authenticate external requests. Therefore we need to upload a public key to ServiceNow so it can verify the integrity of JWT tokens signed by clients (ie. Iguana X), ensuring secure authentication of external requests.
Use OpenSSL command line to generate a key pair. You can use the following sample terminal commands:
openssl genrsa -out private.pem 1024
openssl req -new -x509 -key private.pem -out public.cer -days 365
Upload the public key to the X.509 Certificates table. You’ll use the private key in Iguana later.
Use the explorer in the All tab to navigate to System Definition > Certifications.
Click New, fill out the required information and paste your public key.
data:image/s3,"s3://crabby-images/3a653/3a653edc73f12d872028c5b0dee9a19eb6c6707d" alt="Screen Shot 2024-04-04 at 12.59.33 PM.png"
data:image/s3,"s3://crabby-images/f53ee/f53eeb7298a92814ddcdf2c18e99404645204493" alt="Screen Shot 2024-04-04 at 1.16.22 PM.png"
Create a REST API Auth Scope to provide access to the create scope for the ServiceNow Table API
Navigate to System Web Services > API Auth Scopes > REST API Auth Scope
Create a new auth scope with the appropriate permissions as shown in the screenshot:
REST API: Table API
Auth Scope: create new scope (ex. ticket_create)
data:image/s3,"s3://crabby-images/17181/17181edf9cc4c92126ed7a11f9064068556aa09b" alt="Screen Shot 2024-04-04 at 1.29.15 PM.png"
Create an application endpoint (OAuth JWT API endpoint)
Navigate to System OAuth > Application Registry, click New.
Choose Create an OAuth JWT API endpoint for external clients and fill out the required details:
Name: the name of the application endpoint (ex. IguanaX)
OAuth Application User: a non-admin user account used to authenticate the connection. A new user can be created if necessary. (If this field is missing you can add it by right clicking the top grey bar > Configure > Form Design)
Auth Scope: the scope of access that external clients connecting to this endpoint will have. Click Insert a new row, add ticket_create, the scope we previously created.
data:image/s3,"s3://crabby-images/e6071/e6071d7d35030df26314126366f5e571edeb9d9d" alt="Screen Shot 2024-04-05 at 10.11.47 AM.png"
Click Submit and then click on the newly created application. At the bottom of the page, click New to create a Jwt Verifier Map. For sys certificate, select the public key file you previously uploaded.
data:image/s3,"s3://crabby-images/59a4c/59a4caa19db0662211e726af829c5ba58e6596f8" alt="Screen Shot 2024-04-04 at 1.49.57 PM.png"
Note down all the authentication details required for Iguana to authenticate
From the current application endpoint page, note down the following fields for your Iguana X component:
Instance ID (ex. dev252204)
Client ID
Client Secret (automatically generated)
Jwt Verifier Map Kid (automatically generated)
User field (Email) associated with the selected OAuth Application User (ex. iguanax@demo.com)
data:image/s3,"s3://crabby-images/ae586/ae586eef51c0a2afdab9587fb65e47f5d05ea3e6" alt="Screen Shot 2024-04-04 at 2.02.48 PM.png"
Head into Iguana X to start setting up the ServiceNow Notifier!