Skip to content

Commit

Permalink
Make it possible to get access token and refresh token
Browse files Browse the repository at this point in the history
Fixes: #29

Signed-off-by: Patrick Uiterwijk <patrick@puiterwijk.org>
  • Loading branch information
puiterwijk committed Sep 27, 2017
1 parent dc4392f commit 194c669
Show file tree
Hide file tree
Showing 3 changed files with 65 additions and 0 deletions.
34 changes: 34 additions & 0 deletions flask_oidc/__init__.py
Original file line number Diff line number Diff line change
Expand Up @@ -252,6 +252,40 @@ def user_getinfo(self, fields, access_token=None):
pass
return info

def get_access_token(self):
"""Method to return the current requests' access_token.
:returns: Access token or None
:rtype: str
.. versionadded:: 1.2
"""
try:
credentials = OAuth2Credentials.from_json(
self.credentials_store[g.oidc_id_token['sub']])
return credentials.access_token
except KeyError:
logger.debug("Expired ID token, credentials missing",
exc_info=True)
return None

def get_refresh_token(self):
"""Method to return the current requests' refresh_token.
:returns: Access token or None
:rtype: str
.. versionadded:: 1.2
"""
try:
credentials = OAuth2Credentials.from_json(
self.credentials_store[g.oidc_id_token['sub']])
return credentials.refresh_token
except KeyError:
logger.debug("Expired ID token, credentials missing",
exc_info=True)
return None

def _retrieve_userinfo(self, access_token=None):
"""
Requests extra user information from the Provider's UserInfo and
Expand Down
17 changes: 17 additions & 0 deletions tests/app.py
Original file line number Diff line number Diff line change
Expand Up @@ -8,24 +8,41 @@
from flask.ext.oidc import OpenIDConnect


oidc = None


def index():
return "too many secrets", 200, {
'Content-Type': 'text/plain; charset=utf-8'
}

def get_at():
return oidc.get_access_token(), 200, {
'Content-Type': 'text/plain; charset=utf-8'
}

def get_rt():
return oidc.get_refresh_token(), 200, {
'Content-Type': 'text/plain; charset=utf-8'
}

def raw_api():
return {'token': g.oidc_token_info}

def api():
return json.dumps(raw_api())

def create_app(config, oidc_overrides=None):
global oidc

app = Flask(__name__)
app.config.update(config)
if oidc_overrides is None:
oidc_overrides = {}
oidc = OpenIDConnect(app, **oidc_overrides)
app.route('/')(oidc.check(index))
app.route('/at')(oidc.check(get_at))
app.route('/rt')(oidc.check(get_rt))
# Check standalone usage
rendered = oidc.accept_token(True, ['openid'])(api)
app.route('/api', methods=['GET', 'POST'])(rendered)
Expand Down
14 changes: 14 additions & 0 deletions tests/test_flask_oidc.py
Original file line number Diff line number Diff line change
Expand Up @@ -133,6 +133,20 @@ def test_signin():
"Expected redirect to destination "\
"(unexpected path {location.path})".format(location=r2location)

# Let's get the at and rt
r3 = test_client.get('/at')
assert r3.status_code == 200,\
"Expected access token to succeed"
page_text = ''.join(codecs.iterdecode(r3.response, 'utf-8'))
assert page_text == 'mock_access_token',\
"Access token expected"
r4 = test_client.get('/rt')
assert r4.status_code == 200,\
"Expected refresh token to succeed"
page_text = ''.join(codecs.iterdecode(r4.response, 'utf-8'))
assert page_text == 'mock_refresh_token',\
"Refresh token expected"


@patch('httplib2.Http', MockHttp)
def test_refresh():
Expand Down

0 comments on commit 194c669

Please sign in to comment.