- 03 Sep 2024
- 3 Minutes to read
- Print
- DarkLight
Create an API Service Account
- Updated on 03 Sep 2024
- 3 Minutes to read
- Print
- DarkLight
Creating a CMiC Service Account
This article covers:
- Setting up an CMiC API Service Account for Basic Authentication.
- Verifying the API Service Account.
- Authentication using Postman.
- Authentication using a browser.
If you are an existing CMiC Partner and would like API access or you're interested in becoming a CMiC Integration Partner, please reach out to CMIC Partnership.
CMiC Integrations API access
Step 1: Setting up a User Account to use as a API Service Account.
Creating a new User in CMiC.
Step 2: Verify the User Account.
Using the User Account created in Step 1, login to CMiC application to verify accessibility.
Example front end login:
Client ID : SOLUTIONS (Supplied by CMiC Customer)
User ID : JSMITH (Supplied by CMiC Customer)
Password : ****** (Supplied by CMiC Customer)
Note: Tenant ID typically appears in the CMiC login credentials as in "ClientID".
a: Launch the CMiC Login page and enter credentials.
b: On login, select CMiC Enterprise for full Enterprise Menu
c: The CMiC Enterprise Menu contains the following modules:
d: If CMiC Field menu is selected, you’ll be accessing CMiC Project Management Menu:
Additional resources:
If you are unable to see the displayed menus or access data after login, this could be due to security setup. System Security and User Management provides additional videos and knowledge articles on how to setup security for a User Account (API Service Account).
Navigating back-end API access
Using the same User credentials from Step 2, you can authenticate using Postman or a browser.
Step 3: Authenticate with Postman.
To download the Postman application, go to Postman
a: Create a collection in Postman.
b: Add a request.
c: Enter your CMiC domain and server along with the API endpoint you'd like to use.
For a full list of available APIs, go to CMIC Developers Website
For a full list of available CMiC Cloud Domains and Servers, go to CMiC API Server URLs
The example below is using the Project endpoint
There are two approaches to authentication in Postman: directly on the request or by using Environment variables. In this example, we will set up a Postman Environment to embed our authentication variables. This is so we can mask the credentials in our request.
d: Navigate to Environments from the left navigation pane:
e: Enter your domain/server, user, and password variables with value as shown below.
Variable 1 : Create a variable for the domain and server URL,
Example | CMiC_BaseURL |Type: default | Initial Value: https://atlas-api-test-cmiccloud.com/cmictest
Variable 2: Create a variable for User ID.
Example | User_Name | Type: default | Initial Value: SOLUTIONS || JSMITH
Variable 3: Create a variable for password.
Example | Pass | Type: default | Initial Value: *******
f: Return back to your collection. On the collection header, select Authorization tab. Select Basic Auth and embed the User and Pass variables into the Username and Password fields.
Auth type: Basic Auth
Username: {{enter variable for user}}, example {{User}}
Password: {{enter variable for password}}, example {{Pass}}
Switch your environment drop down (top right of screen) is pointing to the environment where variables are defined under Step 3, section d:.
g: Finally, return back to the API request setup earlier, and embed the base URL variable with the endpoint URL as shown below.
Next, test your authentication by sending a request, using the same request created earlier. For this example below we are using the PM Project endpoint
Step 4: Authenticate using a browser.
a: Copy and Paste the API URL with embedded CMiC domain and server into any browser.
Example, we're using,
https://atlas-api-test.cmiccloud.com/cmictest/pm-rest-api/rest/1/pmproject
b: You'll be immediately prompted to authenticate. In this case, use the same User credentials from Step 1 following this format:
CLIENT ID||USER ID | Example: SOLUTIONS|| JSMITH
PASSWORD
c: On Sign-in, you're results should look similar to the below: