REST API Manual Configuration
This topic discusses how to manually configure REST API for use with Nerdio Manager.
Default REST API Status in Nerdio Manager
By default, when you install Nerdio Manager, the REST API is disabled.
To verify the REST API status:
In Nerdio Manager navigate to Settings > Integrations.
In the REST API tile, view the status.
Update the Nerdio-nmw-app Manifest
You must update the Nerdio-nmw-app Manifest file with required information.
To update the Nerdio-nmw-app Manifest:
In the Azure portal, navigate to App registrations.
Search for and select Nerdio-nmw-app.
In Overview, copy the Application (client) ID.
In the Manage blade, select Manifest.
Add the following line:
"identifierUris": ["api://<app_id>"],
Change "accessTokenAcceptedVersion" from null to 2.
Note: Your Manifest file should look like this:
Save the Manifest file.
Add an Application ID URI
If the Application ID URI is not set, then you need to add it.
Note: An example of an Application ID URI is api://g0cb288e-ff16-1861-9393-50219a19453c.
To add an application ID URI:
In the Azure portal, navigate to App registrations.
Search for and select Nerdio-nmw-app.
Select Overview.
Select Add an Application ID URI.
Select Add and then select Save.
Once these changes are added and saved in the Azure portal, in Nerdio Manager navigate to Settings > Integrations.
In the REST API tile, next to Credentials, select the info icon .
Close this info pop-up and follow the steps below to complete the REST API configuration.
Create a new App Registration
The next step is to create and configure a new application registration in the Azure portal.
To create a new app registration:
In the Azure portal, navigate to App registrations.
Select + New registration.
Enter the following information:
Name: Type the name of the new App Registration.
Leave the defaults for the other parameters.
Once you have entered the desired information, select Register.
The application is registered and you are taken to the configuration of your newly created application.
Update the new App Registration
The next step is to update the new app registration.
To update the new app registration:
In the Azure portal, navigate to App registrations.
Search for and select Nerdio-nmw-app.
In the Manage blade, select App roles.
Copy the RestClient ID, which is the NME_ID we need.
Navigate back to App registrations.
Select the newly created app registration (RESTApi in our example).
In the Manage blade, select Manifest.
Tip: Before you make any changes, download a copy of the Manifest in case you make any mistakes.
Locate the section tags, which should look like this:
Within the brackets add the following "NMW_REST_API_CLIENT:<app_id>"
Note: The modified tags should look like this:
Locate the "requiredResourceAccess", which should look like this before any modifications:
Make the following changes:
resourceAppId: This is the App_id we have used throughout the document.
id: Is the NME_ID you copied in the previous step.
Type: Change this to Role.
Save the Manifest file.
In the Manage blade, select API permissions.
Grant admin consent.
In the Manage blade, select Certificates & secrets.
Select + New client secret.
Enter the following information:
Description: Type the description of the client secret.
Duration: From the drop-down list, select your desired duration.
Once you have entered all the desired information, select Add.
Copy and save the client secret value, which is needed later on.
Check the REST API State in Nerdio Manager
Once you have completed the steps above in the Azure portal, you must wait a few minutes (important) before checking the REST API state in Nerdio Manager.
To check the REST API state:
After waiting a few minutes, in Nerdio Manager, refresh your session.
Navigate to Settings > Integrations.
In the REST API tile, next to Credentials, select show.
Ensure that your credentials look like the sample shown above.
Select OK to close the credentials pop-up window.
Next to Documentation, select swagger.
In the upper right hand corner of the Swagger page, select Authorize.
Paste the Client Secret value that you previously saved.
Select Authorize.
Test PowerShell
We need the following variables to test the REST API:
Client_Secret: This is the Client Secret you previously saved.
Client_ID: This can be copied from the Rest API Credentials.
Tenant_ID: This can be copied from the Rest API Credentials.
NME_Scope: This can be copied from the Rest API Credentials.
NME_URL: This is the link to the Nerdio Manager web app.
Sub_ID: This can be copied from Settings > Azure environment > Azure subscriptions tile.
To test a PowerShell script:
Create and save a PowerShell script with the following commands using the variables you just copied. In this example, we are saving REST-API.ps1.
# Install NerdioManager Powershell module
Install-Module -Name NerdioManagerPowerShell
# Setup few variables
# Client_Secret is the secret you created for the newly App Registration
$NMEClientSecret = "<Client_Secret>"
# Client_ID can be copied from NME Rest API Credentials
$NMEClientId = "Client_ID"
# Tenant_ID can be copied from NME Rest API Credentials
$NMETenantId = "<Tenant_ID>"
# NME_Scope can be copied from NME Rest API Credentials
$NMEScope = "<NME_Scope>"
# NME_URL is the link to the NME web app
$nMEuRI = "<NME_URL>"
# Sub_ID can be copied from NME > Settings > Azure Environment
$NMWSubscriptionId = "<Sub_ID>"
# Connect
Connect-NME -ClientId $NmeClientId -ClientSecret $NmeClientSecret -TenantId $NmeTenantId -ApiScope $NmeScope -NmeUri $NmeUri
# List available Workspaces
Get-nmeworkspace
Open PowerShell with elevated credentials and browse to where you saved the REST-API.ps1 script.
Run the following commands:
Set-ExecutionPolicy -ExecutionPolicy Unrestricted -Scope CurrentUser
.\REST-API.ps1
When prompted, select Yes or Yes to All.
Confirm that you can see the list of available Workspaces.
Postman
See REST API Endpoint Implementation for details.
Comments (0 comments)