Azure Rest Client Helper for TypeScript extended from @mild-ts/rest-client, support Azure Credential by default.
npm i @mild-ts/azure-rest-client
import { AzureRestClient } from '@mild-ts/azure-rest-client';
async function main() {
const client = new AzureRestClient();
/**
* https://learn.microsoft.com/en-us/rest/api/appservice/web-apps/get
*/
const res = await client.request(
'GET https://management.azure.com/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}?api-version=2022-03-01',
{
params: {
subscriptionId: '29523625-6fa5-4d9a-86bc-da000544be7d',
resourceGroupName: 'rg-thadaw-demo-multi-app',
name: 'thadaw-demo-multi-app-ant',
},
}
);
console.log(res.status);
console.log(res.data);
}
main();
This package use DefaultAzureCredential
from @azure/identity
. The following credential types will be tried, in order:
-
Environment Credential: This method uses environment variables to authenticate. You would need to set the
AZURE_TENANT_ID
,AZURE_CLIENT_ID
, andAZURE_CLIENT_SECRET
environment variables with your Azure tenant ID, client ID, and client secret, respectively. -
Managed Identity Credential: This method uses a managed identity to authenticate. If you're running your code in Azure, you can enable managed identity for your app and use it to authenticate.
-
Azure CLI Credential: This method uses the Azure CLI to authenticate. You would need to install the Azure CLI on your machine and run az login to authenticate.
-
Azure PowerShell Credential: This method uses Azure PowerShell to authenticate. You would need to install Azure PowerShell on your machine and run Connect-AzAccount to authenticate.
You can read more Azure Identity client library for JavaScript.
Every request sent by AzureRestClient
will be added Authentication
header getting from the DefaultAzureCredential
.
-
Open the Azure CLI and log in to your Azure account using the az login command.
-
Run the following command to create a new service principal and assign it a role:
az ad sp create-for-rbac --name <SERVICE_PRINCIPAL_NAME> --role <ROLE_NAME>
Replace
<SERVICE_PRINCIPAL_NAME>
with a name for your service principal and<ROLE_NAME>
with the name of the Azure role you want to assign to the service principal. For example, if you want to assign the "Contributor" ro le, you can use--role Contributor
. -
The command will output the following information:
{ "appId": "<CLIENT_ID>", "displayName": "<SERVICE_PRINCIPAL_NAME>", "name": "<SERVICE_PRINCIPAL_NAME>", "password": "<CLIENT_SECRET>", "tenant": "<TENANT_ID>" }
Note down the values of <CLIENT_ID>, <CLIENT_SECRET>, and <TENANT_ID> - you will need these for authentication later.
You can now use the client ID, client secret, and tenant ID to authenticate with Azure. For example, you can use them to create a DefaultAzureCredential
object in your code.