We have an app based on the Hardware Dashboard API sample which has been working for a year+ up until a week ago. After investigation we found that the API had expired. After renewing the key the app is now producing tokens. We've also moved to specifying v2.0 in the request Url as described above. The app now hits a 403 response getting an existing product id. Here are the call details.
Token request
{Method: POST, RequestUri: 'https://login.microsoftonline.com/c1c2acae-a7ad-48b7-a7e0-88c9198c3a43/oauth2/token', Version: 1.1, Content: System.Net.Http.StringContent, Headers:
{
Content-Type: application/x-www-form-urlencoded; charset=utf-8
}}
Content: {System.Net.Http.StringContent}
Headers: {}
Method: {POST}
Properties: Count = 0
RequestUri: {https://login.microsoftonline.com/c1c2acae-a7ad-48b7-a7e0-88c9198c3a43/oauth2/token}
Version: {1.1}
token request content
grant_type=client_credentials&client_id=c70d7683-9fa1-404c-ae30-2a98953ce5a9&client_secret=__OUR_API_SECRET__=&resource=https://manage.devcenter.microsoft.com
GET PRODUCT:
GET /v2.0/my/hardware/products/14375692472057896
request:
{Method: GET, RequestUri: '/v2.0/my/hardware/products/14375692472057896', Version: 1.1, Content: <null>, Headers:
{
MS-CorrelationId: a55bedbf-1336-4aac-b3c9-b21b8538e106
MS-RequestId: 5b4c761a-0f32-4f37-8ff9-ce0ef070e298
Authorization: Bearer eyJ0eXAiOiJKV1QiLCJhbGciOiJSUzI1NiIsIng1dCI6Im5PbzNaRHJPRFhFSzFqS1doWHNsSFJfS1hFZyIsImtpZCI6Im5PbzNaRHJPRFhFSzFqS1doWHNsSFJfS1hFZyJ9.eyJhdWQiOiJodHRwczovL21hbmFnZS5kZXZjZW50ZXIubWljcm9zb2Z0LmNvbSIsImlzcyI6Imh0dHBzOi8vc3RzLndpbmRvd3MubmV0L2MxYzJhY2FlLWE3YWQtNDhiNy1hN2UwLTg4YzkxOThjM2E0My8iLCJpYXQiOjE2MjQzMDMwMTYsIm5iZiI6MTYyNDMwMzAxNiwiZXhwIjoxNjI0MzA2OTE2LCJhaW8iOiJFMlpnWUdnTzhnOFJNREk1OXZKd3RrSDhjdmV0QUE9PSIsImFwcGlkIjoiYzcwZDc2ODMtOWZhMS00MDRjLWFlMzAtMmE5ODk1M2NlNWE5IiwiYXBwaWRhY3IiOiIxIiwiaWRwIjoiaHR0cHM6Ly9zdHMud2luZG93cy5uZXQvYzFjMmFjYWUtYTdhZC00OGI3LWE3ZTAtODhjOTE5OGMzYTQzLyIsIm9pZCI6IjQ0ODg5NWVhLTk4MWEtNDM1OC04MzBlLTRlMTVmOTFjY2E5MSIsInJoIjoiMC5BVFlBcnF6Q3dhMm50MGluNElqSkdZdzZRNE4yRGNlaG4weEFyakFxbUpVODVhazJBQUEuIiwic3ViIjoiNDQ4ODk1ZWEtOTgxYS00MzU4LTgzMGUtNGUxNWY5MWNjYTkxIiwidGlkIjoiYzFjMmFjYWUtYTdhZC00OGI3LWE3ZTAtODhjOTE5OGMzYTQzIiwidXRpIjoiYVBQd0RsZmNFVUtFVjNrajAzU2tBQSIsInZlciI6IjEuMCJ9.AA239DJDfVNm4oOIzizOioIqcVF-a8hEi9yC9QBSPdthLRLng5q7Ah35h-3P83h54brcJOKRCSm2Fw-DAu9wkFZs4T_
ZNBab3h51CyBkK1E1pgiDMdn79AE9YC-qgMNPvNVnDK-VD_mOtQ1YXn_i-RmIitgbzuhSM9i99JTQS7r0bgrl7iDVV0R6ThDEacGEqNaV8kv7_i8nSvqk8kFuvIwE--jwej-qk_HikvhtnRAtttr2L1iN4-XS0PcfNwhJKQAkJBD2gaUUJmmY6NM9Ruf77AHbjQeauKpbzPKyUUtP0-jhHjECp8XUr3Dls6DebpvPcMUmUTJFcSyXO9mkhA
}}
Content: null
Headers: {MS-CorrelationId: a55bedbf-1336-4aac-b3c9-b21b8538e106
MS-RequestId: 5b4c761a-0f32-4f37-8ff9-ce0ef070e298
Authorization: Bearer eyJ0eXAiOiJKV1QiLCJhbGciOiJSUzI1NiIsIng1dCI6Im5PbzNaRHJPRFhFSzFqS1doWHNsSFJfS1hFZyIsImtpZCI6Im5PbzNaRHJPRFhFSzFqS1doWHNsSFJfS1hFZyJ9.eyJhdWQiOiJodHRwczovL21hbmFnZS5kZXZjZW50ZXIubWljcm9zb2Z0LmNvbSIsImlzcyI6Imh0dHBzOi8vc3RzLndpbmRvd3MubmV0L2MxYzJhY2FlLWE3YWQtNDhiNy1hN2UwLTg4YzkxOThjM2E0My8iLCJpYXQiOjE2MjQzMDMwMTYsIm5iZiI6MTYyNDMwMzAxNiwiZXhwIjoxNjI0MzA2OTE2LCJhaW8iOiJFMlpnWUdnTzhnOFJNREk1OXZKd3RrSDhjdmV0QUE9PSIsImFwcGlkIjoiYzcwZDc2ODMtOWZhMS00MDRjLWFlMzAtMmE5ODk1M2NlNWE5IiwiYXBwaWRhY3IiOiIxIiwiaWRwIjoiaHR0cHM6Ly9zdHMud2luZG93cy5uZXQvYzFjMmFjYWUtYTdhZC00OGI3LWE3ZTAtODhjOTE5OGMzYTQzLyIsIm9pZCI6IjQ0ODg5NWVhLTk4MWEtNDM1OC04MzBlLTRlMTVmOTFjY2E5MSIsInJoIjoiMC5BVFlBcnF6Q3dhMm50MGluNElqSkdZdzZRNE4yRGNlaG4weEFyakFxbUpVODVhazJBQUEuIiwic3ViIjoiNDQ4ODk1ZWEtOTgxYS00MzU4LTgzMGUtNGUxNWY5MWNjYTkxIiwidGlkIjoiYzFjMmFjYWUtYTdhZC00OGI3LWE3ZTAtODhjOTE5OGMzYTQzIiwidXRpIjoiYVBQd0RsZmNFVUtFVjNrajAzU2tBQSIsInZlciI6IjEuMCJ9.AA239DJDfVNm4oOIzizOioIqcVF-a8hEi9yC9QBSPdthLRLng5q7Ah35h-3P83h54brcJOKRCSm2Fw-DAu9wkFZs4T_ZN
Bab3h51CyBkK1E1pgiDMdn79AE9YC-qgMNPvNVnDK-VD_mOtQ1YXn_i-RmIitgbzuhSM9i99JTQS7r0bgrl7iDVV0R6ThDEacGEqNaV8kv7_i8nSvqk8kFuvIwE--jwej-qk_HikvhtnRAtttr2L1iN4-XS0PcfNwhJKQAkJBD2gaUUJmmY6NM9Ruf77AHbjQeauKpbzPKyUUtP0-jhHjECp8XUr3Dls6DebpvPcMUmUTJFcSyXO9mkhA
}
Method: {GET}
Properties: Count = 0
RequestUri: {/v2.0/my/hardware/products/14375692472057896}
Version: {1.1}
response
{StatusCode: 403, ReasonPhrase: 'Forbidden', Version: 1.1, Content: System.Net.Http.StreamContent, Headers:
{
Transfer-Encoding: chunked
Request-Context: appId=cid-v1:7c23eef7-4ead-46df-8a76-525b2a71dec2
Date: Mon, 21 Jun 2021 19:25:16 GMT
X-Powered-By: ASP.NET
}}
Content: {System.Net.Http.StreamContent}
Headers: {Transfer-Encoding: chunked
Request-Context: appId=cid-v1:7c23eef7-4ead-46df-8a76-525b2a71dec2
Date: Mon, 21 Jun 2021 19:25:16 GMT
X-Powered-By: ASP.NET
}
IsSuccessStatusCode: false
ReasonPhrase: "Forbidden"
RequestMessage: {Method: GET, RequestUri: 'https://manage.devcenter.microsoft.com/v2.0/my/hardware/products/14375692472057896', Version: 1.1, Content: <null>, Headers:
{
MS-CorrelationId: a55bedbf-1336-4aac-b3c9-b21b8538e106
MS-RequestId: 5b4c761a-0f32-4f37-8ff9-ce0ef070e298
Authorization: Bearer eyJ0eXAiOiJKV1QiLCJhbGciOiJSUzI1NiIsIng1dCI6Im5PbzNaRHJPRFhFSzFqS1doWHNsSFJfS1hFZyIsImtpZCI6Im5PbzNaRHJPRFhFSzFqS1doWHNsSFJfS1hFZyJ9.eyJhdWQiOiJodHRwczovL21hbmFnZS5kZXZjZW50ZXIubWljcm9zb2Z0LmNvbSIsImlzcyI6Imh0dHBzOi8vc3RzLndpbmRvd3MubmV0L2MxYzJhY2FlLWE3YWQtNDhiNy1hN2UwLTg4YzkxOThjM2E0My8iLCJpYXQiOjE2MjQzMDMwMTYsIm5iZiI6MTYyNDMwMzAxNiwiZXhwIjoxNjI0MzA2OTE2LCJhaW8iOiJFMlpnWUdnTzhnOFJNREk1OXZKd3RrSDhjdmV0QUE9PSIsImFwcGlkIjoiYzcwZDc2ODMtOWZhMS00MDRjLWFlMzAtMmE5ODk1M2NlNWE5IiwiYXBwaWRhY3IiOiIxIiwiaWRwIjoiaHR0cHM6Ly9zdHMud2luZG93cy5uZXQvYzFjMmFjYWUtYTdhZC00OGI3LWE3ZTAtODhjOTE5OGMzYTQzLyIsIm9pZCI6IjQ0ODg5NWVhLTk4MWEtNDM1OC04MzBlLTRlMTVmOTFjY2E5MSIsInJoIjoiMC5BVFlBcnF6Q3dhMm50MGluNElqSkdZdzZRNE4yRGNlaG4weEFyakFxbUpVODVhazJBQUEuIiwic3ViIjoiNDQ4ODk1ZWEtOTgxYS00MzU4LTgzMGUtNGUxNWY5MWNjYTkxIiwidGlkIjoiYzFjMmFjYWUtYTdhZC00OGI3LWE3ZTAtODhjOTE5OGMzYTQzIiwidXRpIjoiYVBQd0RsZmNFVUtFVjNrajAzU2tBQSIsInZlciI6IjEuMCJ9.AA239DJDfVNm4oOIzizOioIqcVF-a8hEi9yC9QBSPdthLRLng5q7Ah35h-3P83h54brcJOKRCSm2Fw-DAu9wkFZs4T_
ZNBab3h51CyBkK1E1pgiDMdn79AE9YC-qgMNPvNVnDK-VD_mOtQ1YXn_i-RmIitgbzuhSM9i99JTQS7r0bgrl7iDVV0R6ThDEacGEqNaV8kv7_i8nSvqk8kFuvIwE--jwej-qk_HikvhtnRAtttr2L1iN4-XS0PcfNwhJKQAkJBD2gaUUJmmY6NM9Ruf77AHbjQeauKpbzPKyUUtP0-jhHjECp8XUr3Dls6DebpvPcMUmUTJFcSyXO9mkhA
}}
StatusCode: Forbidden
Version: {1.1}