diff options
author | Simo Sorce <simo@redhat.com> | 2014-10-08 23:38:18 -0400 |
---|---|---|
committer | Patrick Uiterwijk <puiterwijk@redhat.com> | 2014-10-24 18:03:28 +0200 |
commit | 3d3583f81e78600a37d518a5f8c814c6b4c99b91 (patch) | |
tree | ee7e34b578fe2768e92eda6976b75a292a0984c0 /ipsilon/providers/openid/extensions/cla.py | |
parent | d274763d8dc06b42f70014b14fcb2e852c086751 (diff) | |
download | ipsilon-3d3583f81e78600a37d518a5f8c814c6b4c99b91.tar.gz ipsilon-3d3583f81e78600a37d518a5f8c814c6b4c99b91.tar.xz ipsilon-3d3583f81e78600a37d518a5f8c814c6b4c99b91.zip |
Add OpenId extensions
Implement:
Simple Registration
Attribute Exchange
(Fedora) Teams
CLAs
Signed-off-by: Simo Sorce <simo@redhat.com>
Signed-off-by: Patrick Uiterwijk <puiterwijk@redhat.com>
Reviewed-by: Patrick Uiterwijk <puiterwijk@redhat.com>
Diffstat (limited to 'ipsilon/providers/openid/extensions/cla.py')
-rwxr-xr-x | ipsilon/providers/openid/extensions/cla.py | 34 |
1 files changed, 34 insertions, 0 deletions
diff --git a/ipsilon/providers/openid/extensions/cla.py b/ipsilon/providers/openid/extensions/cla.py new file mode 100755 index 0000000..cc4d11d --- /dev/null +++ b/ipsilon/providers/openid/extensions/cla.py @@ -0,0 +1,34 @@ +#!/usr/bin/python +# +# Copyright (C) 2014 Ipsilon project Contributors, for licensee see COPYING + +from __future__ import absolute_import + +from ipsilon.providers.openid.extensions.common import OpenidExtensionBase +from openid_cla import cla + + +class OpenidExtension(OpenidExtensionBase): + + def __init__(self): + super(OpenidExtension, self).__init__('CLAs') + self.type_uris = [ + cla.cla_uri, + ] + + def _resp(self, request, userdata): + req = cla.CLARequest.fromOpenIDRequest(request) + self.debug(req) + if req is None: + return {} + data = userdata['extras'].get('cla', []) + return cla.CLAResponse.extractResponse(req, data) + + def _display(self, request, userdata): + resp = self._resp(request, userdata) + if resp.clas: + return {'CLA': 'yes'} + return {} + + def _response(self, request, userdata): + return self._resp(request, userdata) |