{"id":6324,"date":"2019-11-22T21:19:03","date_gmt":"2019-11-22T21:19:03","guid":{"rendered":"https:\/\/blogs.aaddevsup.xyz\/?p=6324"},"modified":"2019-11-22T21:19:05","modified_gmt":"2019-11-22T21:19:05","slug":"setup-postman-to-call-microsoft-graph-using-a-client-credentials-grant-access-token-from-the-v2-endpoint","status":"publish","type":"post","link":"https:\/\/blogs.aaddevsup.xyz\/2019\/11\/setup-postman-to-call-microsoft-graph-using-a-client-credentials-grant-access-token-from-the-v2-endpoint\/","title":{"rendered":"Setup Postman to call Microsoft Graph using a Client Credentials Grant Access Token from the v2 endpoint"},"content":{"rendered":"

To use the V1 endpoint, please refer to this post<\/a>.  Our documentation for the client credentials grant type can be found here<\/a>.<\/span><\/span><\/p>\n

You can setup postman to make a client_credentials grant flow to obtain an access token and make a graph call ( or any other call that supports application permissions ). This is very useful for testing code you plan to run as a script or in a Daemon application where you do not want user interaction.<\/p>\n

The first thing you need is an app registration in your Azure Tenant to perform this flow. Create a new application registration:<\/p>\n

\"\"<\/div>\n

Note the application id as you will need it later \u2013 this is the client_id used in the setup for postman:<\/p>\n

\"\"<\/div>\n

Click on the API permissions and assign application permissions. By default, Microsoft Graph is already selected with a delegated permission of User.Read. I will leave that there to demonstrate that permission will not be present in the access token when performing this flow. Lets add an application permission for Microsoft Graph of Group.Read.All :<\/p>\n

\"\"<\/div>\n
\"\"<\/div>\n

Once added, you will now see your permission listed however, all application permissions always require a tenant admin to consent to these permissions:<\/p>\n

\"\"<\/div>\n

Grant admin consent:<\/p>\n

\"\"<\/div>\n

Next, the client_credentials flow requires a client secret. Go to the Certificates and Secrets blade and create a new client secret:<\/p>\n

\"\"<\/div>\n

The value is only shown one time so be sure to copy it to the clipboard with the copy to clipboard button and store that somewhere safe. You don’t want that secret to get out!<\/p>\n

\"\"<\/div>\n

The first method I will demonstrate to you for obtaining an access token with Postman is through the Authorization UI. Start a new request, then click on the Authorization tab and select OAuth 2.0 from the drop-down type list:<\/p>\n

\"\"<\/div>\n

To configure the flow, select Client Credentials<\/a> from the Grant Type drop-down box then plug in your values for the settings it requests. For the scope, I am using https:\/\/graph.microsoft.com\/.default which will pull the default values configured for Microsoft Graph from the app registration \u2013 in this case, we are expecting the groups.read.all permission. Use https:\/\/login.microsoftonline.com\/{your-tenant}\/oauth2\/v2.0\/token\/ for the Access token URL ( obtained from the portal “Endpoints” \u2013 see next image ), the client id from the app registration and of course, the client_secret you configured on the app registration.<\/p>\n

\"\"<\/div>\n

The Access Token URL can be obtained from the portal in the App Registrations blade by clicking on the “Endpoints” button:<\/p>\n

\"\"<\/div>\n

Grab the OAuth 2.0 token endpoint (v2). You can also use your tenant name in place of the tenant id ( guid ):<\/p>\n

\"\"<\/div>\n

Save those values in the postman screen and then click on “Request Token”<\/p>\n

You should get an access token like so:<\/p>\n

\"\"<\/div>\n

To use this token, scroll to the bottom and click on the “Use Token” button:<\/p>\n

\"\"<\/div>\n

You can now make a graph call ( based on the permissions you setup in the app registration \u2013 groups in this example ) \u2013 the rest endpoint in this example is https:\/\/graph.microsoft.com\/v1.0\/groups :<\/p>\n

\"\"<\/div>\n

If you copy the access token and paste it in http:\/\/jwt.ms<\/a> you can decode the token to see the claims it has. If you notice, our token only has permissions for group.read.all \u2013 which shows up as a “role”. Application permissions always show up as roles. Notice, there is not a delegated permission in this token because delegated permissions, even if consented to, will not appear in the token for a client_credentials grant type.<\/p>\n

\"\"<\/div>\n

You can also just do a raw post request to the authority endpoint with the same values like this, again, you need to add the client_id, client_secret, scope but you also need to add grant_type when doing it this way and for that value, be sure to use “client_credentials”:<\/p>\n

\"\"<\/div>\n

The values go in the body of the request in this scenario.<\/p>\n

Summary:<\/h2>\n

You can use postman to obtain an access token for testing your api calls, etc. using the client_credentials flow as demonstrated.<\/p>\n","protected":false},"excerpt":{"rendered":"

To use the V1 endpoint, please refer to this post.  Our documentation for the client credentials grant type can be found here. You can setup postman to make a client_credentials grant flow to obtain an access token and make a graph call ( or any other call that supports application permissions ). This is very useful for testing code you plan to run as a script or in a Daemon…<\/p>\n","protected":false},"author":6,"featured_media":0,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[4,13],"tags":[45,114],"class_list":["post-6324","post","type-post","status-publish","format-standard","hentry","category-authentication-flows","category-tool","tag-client-credential-grant","tag-postman"],"_links":{"self":[{"href":"https:\/\/blogs.aaddevsup.xyz\/wp-json\/wp\/v2\/posts\/6324"}],"collection":[{"href":"https:\/\/blogs.aaddevsup.xyz\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/blogs.aaddevsup.xyz\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/blogs.aaddevsup.xyz\/wp-json\/wp\/v2\/users\/6"}],"replies":[{"embeddable":true,"href":"https:\/\/blogs.aaddevsup.xyz\/wp-json\/wp\/v2\/comments?post=6324"}],"version-history":[{"count":11,"href":"https:\/\/blogs.aaddevsup.xyz\/wp-json\/wp\/v2\/posts\/6324\/revisions"}],"predecessor-version":[{"id":6356,"href":"https:\/\/blogs.aaddevsup.xyz\/wp-json\/wp\/v2\/posts\/6324\/revisions\/6356"}],"wp:attachment":[{"href":"https:\/\/blogs.aaddevsup.xyz\/wp-json\/wp\/v2\/media?parent=6324"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/blogs.aaddevsup.xyz\/wp-json\/wp\/v2\/categories?post=6324"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/blogs.aaddevsup.xyz\/wp-json\/wp\/v2\/tags?post=6324"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}