Skip to content
This repository has been archived by the owner on Nov 5, 2019. It is now read-only.

Commit

Permalink
Populate token expiry for GCE credentials
Browse files Browse the repository at this point in the history
Populates the token_expiry property for GCE App Assertion credentials
(thus enabling access_token_expired). This corrects assumptions like the
one in the access_token_expired property on GCE specifically: it's stated
there "If the token_expiry isn't set, we assume the token doesn't expire"
which seems to be incorrect for tokens retrieved from the GCE Metadata service.
  • Loading branch information
Ben Demaree committed Mar 24, 2016
1 parent 3ca2ca7 commit c96c404
Show file tree
Hide file tree
Showing 2 changed files with 15 additions and 3 deletions.
4 changes: 4 additions & 0 deletions oauth2client/contrib/gce.py
Original file line number Diff line number Diff line change
Expand Up @@ -17,6 +17,7 @@
Utilities for making it easier to use OAuth 2.0 on Google Compute Engine.
"""

import datetime
import json
import logging
import warnings
Expand All @@ -27,6 +28,7 @@

from oauth2client._helpers import _from_bytes
from oauth2client import util
from oauth2client.client import _UTCNOW
from oauth2client.client import HttpAccessTokenRefreshError
from oauth2client.client import AssertionCredentials

Expand Down Expand Up @@ -135,6 +137,8 @@ def _refresh(self, http_request):
raise HttpAccessTokenRefreshError(str(e),
status=response.status)
self.access_token = token_content['access_token']
delta = datetime.timedelta(seconds=int(token_content['expires_in']))
self.token_expiry = delta + _UTCNOW()
else:
if response.status == http_client.NOT_FOUND:
content += (' This can occur if a VM was created'
Expand Down
14 changes: 11 additions & 3 deletions tests/contrib/test_gce.py
Original file line number Diff line number Diff line change
Expand Up @@ -15,6 +15,7 @@
"""Unit tests for oauth2client.contrib.gce."""

import json
from datetime import datetime
from six.moves import http_client
from six.moves import urllib
import unittest2
Expand Down Expand Up @@ -62,7 +63,11 @@ def test_to_json_and_from_json(self):

def _refresh_success_helper(self, bytes_response=False):
access_token = u'this-is-a-token'
return_val = json.dumps({u'access_token': access_token})
expires_in = 600
return_val = json.dumps({
u'access_token': access_token,
u'expires_in': expires_in
})
if bytes_response:
return_val = _to_bytes(return_val)
http = mock.MagicMock()
Expand All @@ -73,6 +78,8 @@ def _refresh_success_helper(self, bytes_response=False):
self.assertEquals(None, credentials.access_token)
credentials.refresh(http)
self.assertEquals(access_token, credentials.access_token)
self.assertFalse(credentials.access_token_expired)
self.assertTrue(credentials.token_expiry > datetime.utcnow())

base_metadata_uri = (
'http://metadata.google.internal/computeMetadata/v1/instance/'
Expand Down Expand Up @@ -200,12 +207,13 @@ def test_get_access_token(self):
http = mock.MagicMock()
http.request = mock.MagicMock(
return_value=(mock.Mock(status=http_client.OK),
'{"access_token": "this-is-a-token"}'))
'{"access_token": "this-is-a-token", '
'"expires_in": 600}'))

credentials = AppAssertionCredentials()
token = credentials.get_access_token(http=http)
self.assertEqual('this-is-a-token', token.access_token)
self.assertEqual(None, token.expires_in)
self.assertGreaterEqual(600, token.expires_in)

http.request.assert_called_once_with(
'http://metadata.google.internal/computeMetadata/v1/instance/'
Expand Down

0 comments on commit c96c404

Please sign in to comment.