0

Google Classroom APIとサービスアカウントを使用してGoogle Classroomコースを作成しようとしています。私は現在、JavaScriptを使って実験しています。すべての設定を行い、コースのリストを取得しています。私はJWTをセットアップし、受け取った認証トークンを要求します。Google Classroom API 401エラー

{"access_token":"----ACCESS TOKEN HERE----------","token_type":"Bearer","expires_in":3600} 

これを使用して(GETを介して)ユーザーのコースリストを取得するときに問題はありません。私はコースのリストで適切な回答を受け取り、テーブルに表示します。

私は(POST経由で)コースを作成しようとする同じプロセスを使用しようとすると、私は401エラーを取得する:

function authenticate(callback) { 
    function b64EncodeUnicode(str) { 
     str = JSON.stringify(str); 
     return btoa(encodeURIComponent(str).replace(/%([0-9A-F]{2})/g, function(match, p1) { 
      return String.fromCharCode('0x' + p1); 
      })); 
     }   


    // constuct the JWT 
    var jwtHeader = { 
     "alg":"RS256", 
     "typ":"JWT" 
    } 
    jwtHeader = JSON.stringify(jwtHeader); 

    //construct the Claim 
    var jwtClaim = { 
     "iss":"[email protected]", 
     "scope":"https://www.googleapis.com/auth/classroom.courses https://www.googleapis.com/auth/classroom.rosters", 
     "sub":"[email protected]", //this is an admin account I shouldn't really need this but tried with and without it 
     "aud":"https://www.googleapis.com/oauth2/v4/token", 
     "exp":(Math.round(new Date().getTime()/1000) + 60 * 10), 
     "iat":Math.round(new Date().getTime()/1000) 
    } 
    jwtClaim = JSON.stringify(jwtClaim); 

    //construct the signature 
    var key="-----BEGIN PRIVATE KEY-----Removed-----END PRIVATE KEY-----\n"; 
    var jwtSign = b64EncodeUnicode(jwtSign); 
    var sJWT = KJUR.jws.JWS.sign("RS256", jwtHeader, jwtClaim, key); 

    var jwt = jwtHeader + "." + jwtClaim + "." + sJWT; 

    //request Token 
    var grantType = "urn:ietf:params:oauth:grant-type:jwt-bearer"; 
    var tokenRequest = "grant_type=" + grantType + "&assertion=" + sJWT; 
    var postURL = "https://www.googleapis.com/oauth2/v4/token" 
    request = $j.ajax({ 
     url: postURL, 
     type: "post", 
     data: tokenRequest, 
     success: callback 
    }); 
} 

{ 
    "error": { 
    "code": 401, 
    "message": "The request does not have valid authentication credentials.", 
    "status": "UNAUTHENTICATED" 
    } 
} 

これは私が認証に使用するコードです

これは私がコースリストを取得するために使用するコードです。

$j("#getClasses").click(function(event){ 
    function getClasses(callback){ 
     authenticate(function(data){ 
      console.log(JSON.stringify(data)); 
      var access_token = data["access_token"]; 
      var apiUrl = 'https://classroom.googleapis.com/v1/courses' 
      var myData = 'teacherId=~(teacheremail)&access_token='+access_token; 

      var files = $j.ajax({ 
       url: apiUrl, 
       type: "get", 
       data: myData, 
       success: function (data) { 
        var retreivedClasses = JSON.stringify(data); 
        for(var i = 0; i < data['courses'].length; i++){ 
         nextObject = data['courses']; 
         $j('#classListTable').append('<tr><td>' + nextObject[i]['name'] + '</td><td>' + nextObject[i]['courseState'] + '</td><td>' + nextObject[i]['enrollmentCode'] + '</td></tr>'); 
        } 
        //$j('#classList').text(retreivedClasses); 
       } 
      }); 
     }); 
    } 
getClasses(); 
}); 

これはPOST経由でコースを作成するためのコードです。私はテストのための変数のいくつかをコーディングしましたが、401エラーを与えます。

$j("#createClass").click(function(event){ 
    function createClass(callback){ 
     authenticate(function(data){ 
      console.log(JSON.stringify(data)); 
      var access_token = data["access_token"]; 
      var tokenInfo = $j.ajax({ 
       url: 'https://www.googleapis.com/oauth2/v3/tokeninfo', 
       type: 'get', 
       data: "access_token="+access_token 
      }); 
      var apiUrl = 'https://classroom.googleapis.com/v1/courses' 
      var myData = 'access_token='+access_token + '&[email protected]&name=myClass' 

      console.log(myData); 
      var newGoogleClassroom = $j.ajax({ 
       url: apiUrl, 
       type: "post", 
       data: myData, 
       success: function (data) { 
        var apiResponse = JSON.stringify(data); 
        $j('#classCreated').text(apiResponse); 
        } 
      }); 
     }); 
    }; 
createClass(); 
}); 

最後に、これがトークン情報を取得したときの結果です。私は任意の助けに感謝するだろう

{ 
"azp": "removed", 
"aud": "removed", 
"scope": "https://www.googleapis.com/auth/classroom.courses https://www.googleapis.com/auth/classroom 
.rosters", 
"exp": "1474512198", 
"expires_in": "3600", 
"access_type": "offline" 
} 

(私はこれで新しいです):それはつまり、適切なスコープ私には正常に見えます。 ダグ

P.S.私はこのコードのセキュリティの意味を知る。それは実験のためだけの安全な環境にある。それは日の光を見ません。

答えて

0

これに基づいて、forumも401エラーを受信して​​います。古いoauthを取り消そうとします。このrelated threadに記載されているように、あなたが経験した401 UnauthorizedエラーはOAuth 2.0 client IDを使用してOAuth 2.0 Authorizationに関連している可能性があります。

Suggested action:長期有効リフレッシュトークンを使用してアクセストークンを更新します。これが失敗する場合は、OAuthフローを経由します。

関連する問題