前提・実現したいこと
JavaScriptでFetch()メゾットを使用してaccess_tokenを取得したいです。
以下のコードを試しましたが、エラーとなりました。ご教示頂ければ幸いです。
Consoleエラーメッセージ
POST https://login.mypurecloud.jp/oauth/token net::ERR_FAILED
該当のソースコード
JavaScript
1 2async function getToken(){ 3 var url = 'https://login.mypurecloud.jp/oauth/token'; 4 var cliendId = 'xxxxxxxx'; 5 var clientSecret = 'yyyyyyyyy'; 6 var auth = 'Basic ' + btoa(cliendId) + ':' + btoa(clientSecret); 7 8 const response = await fetch(url,{ 9 'method':'POST', 10 'payload': { 11 'grant_type': 'client_credentials' 12 }, 13 'headers': { 14 'Authorization': auth, 15 'content-type':'application/x-www-form-urlencoded' 16 } 17 } 18 ); 19 var tokenData = JSON.stringify(response); 20 var token = tokenData.access_token; 21 console.log(token); 22}
試したこと
Google Apps ScriptでUrlFetchApp.fetch()を使用した時は成功しました。
GoogleAppsScript
1function getToken(){ 2 var url = 'https://login.mypurecloud.jp/oauth/token'; 3 var cliendId = 'xxxxxxxxx'; 4 var clientSecret = 'yyyyyyyyy'; 5 var options = { 6 'method':'POST', 7 'payload': { 8 'grant_type': 'client_credentials' 9 }, 10 'headers': { 11 'Authorization':'Basic ' + Utilities.base64Encode(cliendId + ':' + clientSecret), 12 'content-type':'application/x-www-form-urlencoded' 13 } 14 }; 15 var tokenData = JSON.parse(UrlFetchApp.fetch(url,options)); 16 var token = tokenData.access_token; 17 Logger.log(token); 18} 19
取得先(Genesys)が記載したPOSTリクエスト情報
https://developer.genesys.cloud/api/rest/authorization/use-authorization-code#additional-options
POST /oauth/token HTTP/1.1 Host: login.mypurecloud.com Content-Type: application/x-www-form-urlencoded Authorization: Basic BASE64(<client_id>:<client_secret>) grant_type=authorization_code&code=<my-authorization-code>&redirect_uri=<http://example.com/oauth/callback>
あなたの回答
tips
プレビュー