Statistics
| Branch: | Tag: | Revision:

root / snf-astakos-app / astakos / im / auth_providers.py @ cbc7a32c

History | View | Annotate | Download (22.2 kB)

1 d2633501 Kostas Papadimitriou
# Copyright 2011 GRNET S.A. All rights reserved.
2 d2633501 Kostas Papadimitriou
#
3 d2633501 Kostas Papadimitriou
# Redistribution and use in source and binary forms, with or
4 d2633501 Kostas Papadimitriou
# without modification, are permitted provided that the following
5 d2633501 Kostas Papadimitriou
# conditions are met:
6 d2633501 Kostas Papadimitriou
#
7 d2633501 Kostas Papadimitriou
#   1. Redistributions of source code must retain the above
8 d2633501 Kostas Papadimitriou
#      copyright notice, this list of conditions and the following
9 d2633501 Kostas Papadimitriou
#      disclaimer.
10 d2633501 Kostas Papadimitriou
#
11 d2633501 Kostas Papadimitriou
#   2. Redistributions in binary form must reproduce the above
12 d2633501 Kostas Papadimitriou
#      copyright notice, this list of conditions and the following
13 d2633501 Kostas Papadimitriou
#      disclaimer in the documentation and/or other materials
14 d2633501 Kostas Papadimitriou
#      provided with the distribution.
15 d2633501 Kostas Papadimitriou
#
16 d2633501 Kostas Papadimitriou
# THIS SOFTWARE IS PROVIDED BY GRNET S.A. ``AS IS'' AND ANY EXPRESS
17 d2633501 Kostas Papadimitriou
# OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
18 d2633501 Kostas Papadimitriou
# WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
19 d2633501 Kostas Papadimitriou
# PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL GRNET S.A OR
20 d2633501 Kostas Papadimitriou
# CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
21 d2633501 Kostas Papadimitriou
# SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
22 d2633501 Kostas Papadimitriou
# LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF
23 d2633501 Kostas Papadimitriou
# USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
24 d2633501 Kostas Papadimitriou
# AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
25 d2633501 Kostas Papadimitriou
# LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
26 d2633501 Kostas Papadimitriou
# ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
27 d2633501 Kostas Papadimitriou
# POSSIBILITY OF SUCH DAMAGE.
28 d2633501 Kostas Papadimitriou
#
29 d2633501 Kostas Papadimitriou
# The views and conclusions contained in the software and
30 d2633501 Kostas Papadimitriou
# documentation are those of the authors and should not be
31 d2633501 Kostas Papadimitriou
# interpreted as representing official policies, either expressed
32 d2633501 Kostas Papadimitriou
# or implied, of GRNET S.A.
33 d2633501 Kostas Papadimitriou
34 9d20fe23 Kostas Papadimitriou
import copy
35 9d20fe23 Kostas Papadimitriou
import json
36 9d20fe23 Kostas Papadimitriou
37 9d20fe23 Kostas Papadimitriou
from synnefo.lib.ordereddict import OrderedDict
38 d2633501 Kostas Papadimitriou
39 d2633501 Kostas Papadimitriou
from django.core.urlresolvers import reverse
40 d2633501 Kostas Papadimitriou
from django.utils.translation import ugettext as _
41 9d20fe23 Kostas Papadimitriou
from django.contrib.auth.models import Group
42 9d20fe23 Kostas Papadimitriou
from django import template
43 d2633501 Kostas Papadimitriou
44 081070a5 Kostas Papadimitriou
from django.conf import settings
45 c4b1a172 Kostas Papadimitriou
46 081070a5 Kostas Papadimitriou
from astakos.im import settings as astakos_settings
47 c4b1a172 Kostas Papadimitriou
from astakos.im import messages as astakos_messages
48 d2633501 Kostas Papadimitriou
49 cbc7a32c Kostas Papadimitriou
from synnefo_branding import utils as branding_utils
50 cbc7a32c Kostas Papadimitriou
51 d2633501 Kostas Papadimitriou
import logging
52 d2633501 Kostas Papadimitriou
53 d2633501 Kostas Papadimitriou
logger = logging.getLogger(__name__)
54 d2633501 Kostas Papadimitriou
55 d2633501 Kostas Papadimitriou
# providers registry
56 6012535a Kostas Papadimitriou
PROVIDERS = {}
57 badcb2a9 Kostas Papadimitriou
REQUIRED_PROVIDERS = {}
58 d2633501 Kostas Papadimitriou
59 9d20fe23 Kostas Papadimitriou
60 d2633501 Kostas Papadimitriou
class AuthProviderBase(type):
61 d2633501 Kostas Papadimitriou
62 d2633501 Kostas Papadimitriou
    def __new__(cls, name, bases, dct):
63 d2633501 Kostas Papadimitriou
        include = False
64 d2633501 Kostas Papadimitriou
        if [b for b in bases if isinstance(b, AuthProviderBase)]:
65 d2633501 Kostas Papadimitriou
            type_id = dct.get('module')
66 d2633501 Kostas Papadimitriou
            if type_id:
67 d2633501 Kostas Papadimitriou
                include = True
68 081070a5 Kostas Papadimitriou
            if type_id in astakos_settings.IM_MODULES:
69 591068ae Kostas Papadimitriou
                if astakos_settings.IM_MODULES.index(type_id) == 0:
70 591068ae Kostas Papadimitriou
                    dct['is_primary'] = True
71 d2633501 Kostas Papadimitriou
                dct['module_enabled'] = True
72 d2633501 Kostas Papadimitriou
73 d2633501 Kostas Papadimitriou
        newcls = super(AuthProviderBase, cls).__new__(cls, name, bases, dct)
74 d2633501 Kostas Papadimitriou
        if include:
75 6012535a Kostas Papadimitriou
            PROVIDERS[type_id] = newcls
76 9d20fe23 Kostas Papadimitriou
            if newcls().get_required_policy:
77 badcb2a9 Kostas Papadimitriou
                REQUIRED_PROVIDERS[type_id] = newcls
78 d2633501 Kostas Papadimitriou
        return newcls
79 d2633501 Kostas Papadimitriou
80 d2633501 Kostas Papadimitriou
81 d2633501 Kostas Papadimitriou
class AuthProvider(object):
82 d2633501 Kostas Papadimitriou
83 d2633501 Kostas Papadimitriou
    __metaclass__ = AuthProviderBase
84 d2633501 Kostas Papadimitriou
85 d2633501 Kostas Papadimitriou
    module = None
86 d2633501 Kostas Papadimitriou
    module_enabled = False
87 591068ae Kostas Papadimitriou
    is_primary = False
88 9d20fe23 Kostas Papadimitriou
89 9d20fe23 Kostas Papadimitriou
    message_tpls = OrderedDict((
90 9d20fe23 Kostas Papadimitriou
        ('title', '{module_title}'),
91 9d20fe23 Kostas Papadimitriou
        ('login_title', '{title} LOGIN'),
92 9d20fe23 Kostas Papadimitriou
        ('method_prompt', '{title} login'),
93 9d20fe23 Kostas Papadimitriou
        ('account_prompt', '{title} account'),
94 9d20fe23 Kostas Papadimitriou
        ('signup_title', '{title}'),
95 9d20fe23 Kostas Papadimitriou
        ('profile_title', '{title}'),
96 9d20fe23 Kostas Papadimitriou
        ('method_details', '{account_prompt}: {identifier}'),
97 9d20fe23 Kostas Papadimitriou
        ('primary_login_prompt', 'Login using '),
98 9d20fe23 Kostas Papadimitriou
        ('required', '{title} is required. You can assign it '
99 9d20fe23 Kostas Papadimitriou
                     'from your profile page'),
100 9d20fe23 Kostas Papadimitriou
        ('login_prompt', ''),
101 9d20fe23 Kostas Papadimitriou
        ('add_prompt', 'Allows you to login using {title}'),
102 9d20fe23 Kostas Papadimitriou
        ('login_extra', ''),
103 9d20fe23 Kostas Papadimitriou
        ('username', '{username}'),
104 cbc7a32c Kostas Papadimitriou
        ('disabled_for_create', 'It seems this is the first time you\'re '
105 cbc7a32c Kostas Papadimitriou
                                'trying to access {service_name}. '
106 cbc7a32c Kostas Papadimitriou
                                'Unfortunately, we are not accepting new '
107 cbc7a32c Kostas Papadimitriou
                                'users at this point.'),
108 9d20fe23 Kostas Papadimitriou
        ('switch_success', 'Account changed successfully.'),
109 9d20fe23 Kostas Papadimitriou
        ('cannot_login', '{title} is not available for login. '
110 9d20fe23 Kostas Papadimitriou
                         'Please use one of your other available methods '
111 9d20fe23 Kostas Papadimitriou
                         'to login ({available_methods_links}'),
112 9d20fe23 Kostas Papadimitriou
113 9d20fe23 Kostas Papadimitriou
        # icons should end with _icon
114 9d20fe23 Kostas Papadimitriou
        ('module_medium_icon', 'im/auth/icons-medium/{module}.png'),
115 9d20fe23 Kostas Papadimitriou
        ('module_icon', 'im/auth/icons/{module}.png'))
116 9d20fe23 Kostas Papadimitriou
    )
117 9d20fe23 Kostas Papadimitriou
118 9d20fe23 Kostas Papadimitriou
    messages = {}
119 9d20fe23 Kostas Papadimitriou
    module_urls = {}
120 9d20fe23 Kostas Papadimitriou
121 564a2292 Kostas Papadimitriou
    remote_authenticate = True
122 564a2292 Kostas Papadimitriou
    remote_logout_url = None
123 d2633501 Kostas Papadimitriou
124 9d20fe23 Kostas Papadimitriou
    # templates
125 9d20fe23 Kostas Papadimitriou
    primary_login_template = 'im/auth/generic_primary_login.html'
126 9d20fe23 Kostas Papadimitriou
    login_template = 'im/auth/generic_login.html'
127 9d20fe23 Kostas Papadimitriou
    signup_template = 'im/signup.html'
128 9d20fe23 Kostas Papadimitriou
    login_prompt_template = 'im/auth/generic_login_prompt.html'
129 9d20fe23 Kostas Papadimitriou
    signup_prompt_template = 'im/auth/signup_prompt.html'
130 9d20fe23 Kostas Papadimitriou
131 9d20fe23 Kostas Papadimitriou
    default_policies = {
132 9d20fe23 Kostas Papadimitriou
        'login': True,
133 9d20fe23 Kostas Papadimitriou
        'create': True,
134 9d20fe23 Kostas Papadimitriou
        'add': True,
135 9d20fe23 Kostas Papadimitriou
        'remove': True,
136 9d20fe23 Kostas Papadimitriou
        'limit': 1,
137 9d20fe23 Kostas Papadimitriou
        'switch': True,
138 9d20fe23 Kostas Papadimitriou
        'add_groups': [],
139 9d20fe23 Kostas Papadimitriou
        'creation_groups': [],
140 9d20fe23 Kostas Papadimitriou
        'required': False,
141 9d20fe23 Kostas Papadimitriou
        'automoderate': not astakos_settings.MODERATION_ENABLED
142 9d20fe23 Kostas Papadimitriou
    }
143 9d20fe23 Kostas Papadimitriou
144 9d20fe23 Kostas Papadimitriou
    policies = {}
145 9d20fe23 Kostas Papadimitriou
146 9d20fe23 Kostas Papadimitriou
    def __init__(self, user=None, identifier=None, **provider_params):
147 9d20fe23 Kostas Papadimitriou
        """
148 9d20fe23 Kostas Papadimitriou
        3 ways to initialize (no args, user, user and identifier).
149 9d20fe23 Kostas Papadimitriou

150 9d20fe23 Kostas Papadimitriou
        no args: Used for anonymous unauthenticated users.
151 9d20fe23 Kostas Papadimitriou
        >>> p = auth_providers.get_provider('local')
152 9d20fe23 Kostas Papadimitriou
        >>> # check that global settings allows us to create a new account
153 9d20fe23 Kostas Papadimitriou
        >>> # using `local` provider.
154 9d20fe23 Kostas Papadimitriou
        >>> print p.is_available_for_create()
155 9d20fe23 Kostas Papadimitriou

156 9d20fe23 Kostas Papadimitriou
        user and identifier: Used to provide details about a user's specific
157 9d20fe23 Kostas Papadimitriou
        login method.
158 97246b51 Kostas Papadimitriou
        >>> p = auth_providers.get_provider('google', user,
159 97246b51 Kostas Papadimitriou
        >>>                                 identifier='1421421')
160 9d20fe23 Kostas Papadimitriou
        >>> # provider (google) details prompt
161 9d20fe23 Kostas Papadimitriou
        >>> print p.get_method_details()
162 9d20fe23 Kostas Papadimitriou
        "Google account: 1421421"
163 9d20fe23 Kostas Papadimitriou
        """
164 9d20fe23 Kostas Papadimitriou
165 9d20fe23 Kostas Papadimitriou
        # handle AnonymousUser instance
166 9d20fe23 Kostas Papadimitriou
        self.user = None
167 9d20fe23 Kostas Papadimitriou
        if user and hasattr(user, 'pk') and user.pk:
168 9d20fe23 Kostas Papadimitriou
            self.user = user
169 c4b1a172 Kostas Papadimitriou
170 9d20fe23 Kostas Papadimitriou
        self.identifier = identifier
171 9d20fe23 Kostas Papadimitriou
        self._instance = None
172 9d20fe23 Kostas Papadimitriou
        if 'instance' in provider_params:
173 9d20fe23 Kostas Papadimitriou
            self._instance = provider_params['instance']
174 9d20fe23 Kostas Papadimitriou
            del provider_params['instance']
175 9d20fe23 Kostas Papadimitriou
176 9d20fe23 Kostas Papadimitriou
        # initialize policies
177 9d20fe23 Kostas Papadimitriou
        self.module_policies = copy.copy(self.default_policies)
178 9d20fe23 Kostas Papadimitriou
        self.module_policies['automoderate'] = not \
179 9d20fe23 Kostas Papadimitriou
            astakos_settings.MODERATION_ENABLED
180 bc8bede2 Kostas Papadimitriou
        for policy, value in self.policies.iteritems():
181 9d20fe23 Kostas Papadimitriou
            setting_key = "%s_POLICY" % policy.upper()
182 9d20fe23 Kostas Papadimitriou
            if self.has_setting(setting_key):
183 9d20fe23 Kostas Papadimitriou
                self.module_policies[policy] = self.get_setting(setting_key)
184 7bb081f5 Kostas Papadimitriou
            else:
185 7bb081f5 Kostas Papadimitriou
                self.module_policies[policy] = value
186 9d20fe23 Kostas Papadimitriou
187 9d20fe23 Kostas Papadimitriou
        # messages cache
188 9d20fe23 Kostas Papadimitriou
        self.message_tpls_compiled = OrderedDict()
189 9d20fe23 Kostas Papadimitriou
190 9d20fe23 Kostas Papadimitriou
        # module specific messages
191 9d20fe23 Kostas Papadimitriou
        self.message_tpls = OrderedDict(self.message_tpls)
192 9d20fe23 Kostas Papadimitriou
        for key, value in self.messages.iteritems():
193 9d20fe23 Kostas Papadimitriou
            self.message_tpls[key] = value
194 9d20fe23 Kostas Papadimitriou
195 9d20fe23 Kostas Papadimitriou
        self._provider_details = provider_params
196 9d20fe23 Kostas Papadimitriou
197 9d20fe23 Kostas Papadimitriou
        self.resolve_available_methods = True
198 9d20fe23 Kostas Papadimitriou
199 9d20fe23 Kostas Papadimitriou
    def get_provider_model(self):
200 9d20fe23 Kostas Papadimitriou
        from astakos.im.models import AstakosUserAuthProvider as AuthProvider
201 9d20fe23 Kostas Papadimitriou
        return AuthProvider
202 9d20fe23 Kostas Papadimitriou
203 9d20fe23 Kostas Papadimitriou
    def remove_from_user(self):
204 9d20fe23 Kostas Papadimitriou
        if not self.get_remove_policy:
205 9d20fe23 Kostas Papadimitriou
            raise Exception("Provider cannot be removed")
206 9d20fe23 Kostas Papadimitriou
207 5d91dccb Kostas Papadimitriou
        for group_name in self.get_add_groups_policy:
208 5d91dccb Kostas Papadimitriou
            group = Group.objects.get(name=group_name)
209 5d91dccb Kostas Papadimitriou
            self.user.groups.remove(group)
210 5d91dccb Kostas Papadimitriou
            self.log('removed from group due to add_groups_policy %s',
211 5d91dccb Kostas Papadimitriou
                     group.name)
212 5d91dccb Kostas Papadimitriou
213 9d20fe23 Kostas Papadimitriou
        self._instance.delete()
214 5d91dccb Kostas Papadimitriou
        self.log('removed')
215 9d20fe23 Kostas Papadimitriou
216 9d20fe23 Kostas Papadimitriou
    def add_to_user(self, **params):
217 9d20fe23 Kostas Papadimitriou
        if self._instance:
218 9d20fe23 Kostas Papadimitriou
            raise Exception("Cannot add an existing provider")
219 9d20fe23 Kostas Papadimitriou
220 9d20fe23 Kostas Papadimitriou
        create = False
221 9d20fe23 Kostas Papadimitriou
        if self.get_user_providers().count() == 0:
222 9d20fe23 Kostas Papadimitriou
            create = True
223 9d20fe23 Kostas Papadimitriou
224 9d20fe23 Kostas Papadimitriou
        if create and not self.get_create_policy:
225 9d20fe23 Kostas Papadimitriou
            raise Exception("Provider not available for create")
226 9d20fe23 Kostas Papadimitriou
227 9d20fe23 Kostas Papadimitriou
        if not self.get_add_policy:
228 9d20fe23 Kostas Papadimitriou
            raise Exception("Provider cannot be added")
229 9d20fe23 Kostas Papadimitriou
230 9d20fe23 Kostas Papadimitriou
        if create:
231 9d20fe23 Kostas Papadimitriou
            for group_name in self.get_creation_groups_policy:
232 9d20fe23 Kostas Papadimitriou
                group, created = Group.objects.get_or_create(name=group_name)
233 9d20fe23 Kostas Papadimitriou
                self.user.groups.add(group)
234 97246b51 Kostas Papadimitriou
                self.log("added to %s group due to creation_groups_policy",
235 97246b51 Kostas Papadimitriou
                         group_name)
236 9d20fe23 Kostas Papadimitriou
237 9d20fe23 Kostas Papadimitriou
        for group_name in self.get_add_groups_policy:
238 9d20fe23 Kostas Papadimitriou
            group, created = Group.objects.get_or_create(name=group_name)
239 9d20fe23 Kostas Papadimitriou
            self.user.groups.add(group)
240 97246b51 Kostas Papadimitriou
            self.log("added to %s group due to add_groups_policy",
241 97246b51 Kostas Papadimitriou
                     group_name)
242 9d20fe23 Kostas Papadimitriou
243 9d20fe23 Kostas Papadimitriou
        if self.identifier:
244 9d20fe23 Kostas Papadimitriou
            pending = self.get_provider_model().objects.unverified(
245 9d20fe23 Kostas Papadimitriou
                self.module, identifier=self.identifier)
246 9d20fe23 Kostas Papadimitriou
247 9d20fe23 Kostas Papadimitriou
            if pending:
248 9d20fe23 Kostas Papadimitriou
                pending._instance.delete()
249 9d20fe23 Kostas Papadimitriou
250 9d20fe23 Kostas Papadimitriou
        create_params = {
251 9d20fe23 Kostas Papadimitriou
            'module': self.module,
252 9d20fe23 Kostas Papadimitriou
            'info_data': json.dumps(self.provider_details.get('info', {})),
253 9d20fe23 Kostas Papadimitriou
            'active': True,
254 9d20fe23 Kostas Papadimitriou
            'identifier': self.identifier
255 9d20fe23 Kostas Papadimitriou
        }
256 9d20fe23 Kostas Papadimitriou
        if 'info' in self.provider_details:
257 9d20fe23 Kostas Papadimitriou
            del self.provider_details['info']
258 9d20fe23 Kostas Papadimitriou
259 9d20fe23 Kostas Papadimitriou
        create_params.update(self.provider_details)
260 9d20fe23 Kostas Papadimitriou
        create_params.update(params)
261 97246b51 Kostas Papadimitriou
        create = self.user.auth_providers.create(**create_params)
262 97246b51 Kostas Papadimitriou
        self.log("created %r" % create_params)
263 97246b51 Kostas Papadimitriou
        return create
264 9d20fe23 Kostas Papadimitriou
265 9d20fe23 Kostas Papadimitriou
    def __repr__(self):
266 9d20fe23 Kostas Papadimitriou
        r = "'%s' module" % self.__class__.__name__
267 9d20fe23 Kostas Papadimitriou
        if self.user:
268 9d20fe23 Kostas Papadimitriou
            r += ' (user: %s)' % self.user
269 9d20fe23 Kostas Papadimitriou
        if self.identifier:
270 97246b51 Kostas Papadimitriou
            r += '(identifier: %s)' % self.identifier
271 9d20fe23 Kostas Papadimitriou
        return r
272 9d20fe23 Kostas Papadimitriou
273 9d20fe23 Kostas Papadimitriou
    def _message_params(self, **extra_params):
274 9d20fe23 Kostas Papadimitriou
        """
275 9d20fe23 Kostas Papadimitriou
        Retrieve message formating parameters.
276 9d20fe23 Kostas Papadimitriou
        """
277 9d20fe23 Kostas Papadimitriou
        params = {'module': self.module, 'module_title': self.module.title()}
278 9d20fe23 Kostas Papadimitriou
        if self.identifier:
279 9d20fe23 Kostas Papadimitriou
            params['identifier'] = self.identifier
280 c4b1a172 Kostas Papadimitriou
281 9d20fe23 Kostas Papadimitriou
        if self.user:
282 9d20fe23 Kostas Papadimitriou
            for key, val in self.user.__dict__.iteritems():
283 9d20fe23 Kostas Papadimitriou
                params["user_%s" % key.lower()] = val
284 9d20fe23 Kostas Papadimitriou
285 9d20fe23 Kostas Papadimitriou
        if self.provider_details:
286 9d20fe23 Kostas Papadimitriou
            for key, val in self.provider_details.iteritems():
287 9d20fe23 Kostas Papadimitriou
                params["provider_%s" % key.lower()] = val
288 9d20fe23 Kostas Papadimitriou
289 9d20fe23 Kostas Papadimitriou
            if 'info' in self.provider_details:
290 9d20fe23 Kostas Papadimitriou
                if isinstance(self.provider_details['info'], basestring):
291 9d20fe23 Kostas Papadimitriou
                    self.provider_details['info'] = \
292 9d20fe23 Kostas Papadimitriou
                        json.loads(self.provider_details['info'])
293 9d20fe23 Kostas Papadimitriou
                for key, val in self.provider_details['info'].iteritems():
294 cbc7a32c Kostas Papadimitriou
                    params['provider_info_%s' % key.lower()] = val
295 9d20fe23 Kostas Papadimitriou
296 9d20fe23 Kostas Papadimitriou
        # resolve username, handle unexisting defined username key
297 9d20fe23 Kostas Papadimitriou
        if self.user and self.username_key in params:
298 9d20fe23 Kostas Papadimitriou
            params['username'] = params[self.username_key]
299 9d20fe23 Kostas Papadimitriou
        else:
300 9d20fe23 Kostas Papadimitriou
            params['username'] = self.identifier
301 9d20fe23 Kostas Papadimitriou
302 cbc7a32c Kostas Papadimitriou
        branding_params = dict(map(lambda k: (k[0].lower(), k[1]),
303 cbc7a32c Kostas Papadimitriou
            branding_utils.get_branding_dict().iteritems()))
304 cbc7a32c Kostas Papadimitriou
        params.update(branding_params)
305 cbc7a32c Kostas Papadimitriou
306 9d20fe23 Kostas Papadimitriou
        if not self.message_tpls_compiled:
307 9d20fe23 Kostas Papadimitriou
            for key, message_tpl in self.message_tpls.iteritems():
308 9d20fe23 Kostas Papadimitriou
                msg = self.messages.get(key, self.message_tpls.get(key))
309 9d20fe23 Kostas Papadimitriou
                override_in_settings = self.get_setting(key)
310 9d20fe23 Kostas Papadimitriou
                if override_in_settings is not None:
311 9d20fe23 Kostas Papadimitriou
                    msg = override_in_settings
312 9d20fe23 Kostas Papadimitriou
                try:
313 9d20fe23 Kostas Papadimitriou
                    self.message_tpls_compiled[key] = msg.format(**params)
314 9d20fe23 Kostas Papadimitriou
                    params.update(self.message_tpls_compiled)
315 9d20fe23 Kostas Papadimitriou
                except KeyError, e:
316 9d20fe23 Kostas Papadimitriou
                    continue
317 9d20fe23 Kostas Papadimitriou
        else:
318 9d20fe23 Kostas Papadimitriou
            params.update(self.message_tpls_compiled)
319 9d20fe23 Kostas Papadimitriou
320 9d20fe23 Kostas Papadimitriou
        for key, value in self.urls.iteritems():
321 9d20fe23 Kostas Papadimitriou
            params['%s_url' % key] = value
322 9d20fe23 Kostas Papadimitriou
323 9d20fe23 Kostas Papadimitriou
        if self.user and self.resolve_available_methods:
324 9d20fe23 Kostas Papadimitriou
            available_providers = self.user.get_enabled_auth_providers()
325 9d20fe23 Kostas Papadimitriou
            for p in available_providers:
326 9d20fe23 Kostas Papadimitriou
                p.resolve_available_methods = False
327 9d20fe23 Kostas Papadimitriou
                if p.module == self.module and p.identifier == self.identifier:
328 9d20fe23 Kostas Papadimitriou
                    available_providers.remove(p)
329 9d20fe23 Kostas Papadimitriou
330 9d20fe23 Kostas Papadimitriou
            get_msg = lambda p: p.get_method_prompt_msg
331 9d20fe23 Kostas Papadimitriou
            params['available_methods'] = \
332 9d20fe23 Kostas Papadimitriou
                ','.join(map(get_msg, available_providers))
333 9d20fe23 Kostas Papadimitriou
334 9d20fe23 Kostas Papadimitriou
            get_msg = lambda p: "<a href='%s'>%s</a>" % \
335 97246b51 Kostas Papadimitriou
                (p.get_login_url, p.get_method_prompt_msg)
336 9d20fe23 Kostas Papadimitriou
337 9d20fe23 Kostas Papadimitriou
            params['available_methods_links'] = \
338 9d20fe23 Kostas Papadimitriou
                ','.join(map(get_msg, available_providers))
339 9d20fe23 Kostas Papadimitriou
340 9d20fe23 Kostas Papadimitriou
        params.update(extra_params)
341 9d20fe23 Kostas Papadimitriou
        return params
342 9d20fe23 Kostas Papadimitriou
343 9d20fe23 Kostas Papadimitriou
    def get_template(self, tpl):
344 9d20fe23 Kostas Papadimitriou
        tpls = ['im/auth/%s_%s.html' % (self.module, tpl),
345 9d20fe23 Kostas Papadimitriou
                getattr(self, '%s_template' % tpl)]
346 9d20fe23 Kostas Papadimitriou
        found = None
347 9d20fe23 Kostas Papadimitriou
        for tpl in tpls:
348 9d20fe23 Kostas Papadimitriou
            try:
349 9d20fe23 Kostas Papadimitriou
                found = template.loader.get_template(tpl)
350 9d20fe23 Kostas Papadimitriou
                return tpl
351 9d20fe23 Kostas Papadimitriou
            except template.TemplateDoesNotExist:
352 9d20fe23 Kostas Papadimitriou
                continue
353 9d20fe23 Kostas Papadimitriou
        if not found:
354 9d20fe23 Kostas Papadimitriou
            raise template.TemplateDoesNotExist
355 9d20fe23 Kostas Papadimitriou
        return tpl
356 9d20fe23 Kostas Papadimitriou
357 9d20fe23 Kostas Papadimitriou
    def get_username(self):
358 9d20fe23 Kostas Papadimitriou
        return self.get_username_msg
359 9d20fe23 Kostas Papadimitriou
360 9d20fe23 Kostas Papadimitriou
    def get_user_providers(self):
361 680c383d Kostas Papadimitriou
        return self.user.auth_providers.active().filter(
362 680c383d Kostas Papadimitriou
            module__in=astakos_settings.IM_MODULES)
363 9d20fe23 Kostas Papadimitriou
364 9d20fe23 Kostas Papadimitriou
    def get_user_module_providers(self):
365 9d20fe23 Kostas Papadimitriou
        return self.user.auth_providers.active().filter(module=self.module)
366 9d20fe23 Kostas Papadimitriou
367 9d20fe23 Kostas Papadimitriou
    def get_existing_providers(self):
368 9d20fe23 Kostas Papadimitriou
        return ""
369 9d20fe23 Kostas Papadimitriou
370 9d20fe23 Kostas Papadimitriou
    def verified_exists(self):
371 9d20fe23 Kostas Papadimitriou
        return self.get_provider_model().objects.verified(
372 9d20fe23 Kostas Papadimitriou
            self.module, identifier=self.identifier)
373 9d20fe23 Kostas Papadimitriou
374 97246b51 Kostas Papadimitriou
    def resolve_policy(self, policy, default=None):
375 9d20fe23 Kostas Papadimitriou
376 9d20fe23 Kostas Papadimitriou
        if policy == 'switch' and default and not self.get_add_policy:
377 9d20fe23 Kostas Papadimitriou
            return not self.get_policy('remove')
378 9d20fe23 Kostas Papadimitriou
379 9d20fe23 Kostas Papadimitriou
        if not self.user:
380 9d20fe23 Kostas Papadimitriou
            return default
381 9d20fe23 Kostas Papadimitriou
382 9d20fe23 Kostas Papadimitriou
        if policy == 'remove' and default is True:
383 9d20fe23 Kostas Papadimitriou
            return self.get_user_providers().count() > 1
384 9d20fe23 Kostas Papadimitriou
385 9d20fe23 Kostas Papadimitriou
        if policy == 'add' and default is True:
386 9d20fe23 Kostas Papadimitriou
            limit = self.get_policy('limit')
387 9d20fe23 Kostas Papadimitriou
            if limit <= self.get_user_module_providers().count():
388 9d20fe23 Kostas Papadimitriou
                return False
389 9d20fe23 Kostas Papadimitriou
390 9d20fe23 Kostas Papadimitriou
            if self.identifier:
391 9d20fe23 Kostas Papadimitriou
                if self.verified_exists():
392 9d20fe23 Kostas Papadimitriou
                    return False
393 9d20fe23 Kostas Papadimitriou
394 9d20fe23 Kostas Papadimitriou
        return default
395 9d20fe23 Kostas Papadimitriou
396 9d20fe23 Kostas Papadimitriou
    def get_user_policies(self):
397 9d20fe23 Kostas Papadimitriou
        from astakos.im.models import AuthProviderPolicyProfile
398 9d20fe23 Kostas Papadimitriou
        return AuthProviderPolicyProfile.objects.for_user(self.user,
399 9d20fe23 Kostas Papadimitriou
                                                          self.module)
400 9d20fe23 Kostas Papadimitriou
401 9d20fe23 Kostas Papadimitriou
    def get_policy(self, policy):
402 9d20fe23 Kostas Papadimitriou
        module_default = self.module_policies.get(policy)
403 9d20fe23 Kostas Papadimitriou
        settings_key = '%s_POLICY' % policy.upper()
404 9d20fe23 Kostas Papadimitriou
        settings_default = self.get_setting(settings_key, module_default)
405 9d20fe23 Kostas Papadimitriou
406 9d20fe23 Kostas Papadimitriou
        if self.user:
407 9d20fe23 Kostas Papadimitriou
            user_policies = self.get_user_policies()
408 9d20fe23 Kostas Papadimitriou
            settings_default = user_policies.get(policy, settings_default)
409 9d20fe23 Kostas Papadimitriou
410 97246b51 Kostas Papadimitriou
        return self.resolve_policy(policy, settings_default)
411 9d20fe23 Kostas Papadimitriou
412 9d20fe23 Kostas Papadimitriou
    def get_message(self, msg, **extra_params):
413 9d20fe23 Kostas Papadimitriou
        """
414 9d20fe23 Kostas Papadimitriou
        Retrieve an auth provider message
415 9d20fe23 Kostas Papadimitriou
        """
416 9d20fe23 Kostas Papadimitriou
        if msg.endswith('_msg'):
417 9d20fe23 Kostas Papadimitriou
            msg = msg.replace('_msg', '')
418 9d20fe23 Kostas Papadimitriou
        params = self._message_params(**extra_params)
419 9d20fe23 Kostas Papadimitriou
420 9d20fe23 Kostas Papadimitriou
        # is message ???
421 9d20fe23 Kostas Papadimitriou
        tpl = self.message_tpls_compiled.get(msg.lower(), None)
422 9d20fe23 Kostas Papadimitriou
        if not tpl:
423 9d20fe23 Kostas Papadimitriou
            msg_key = 'AUTH_PROVIDER_%s' % msg.upper()
424 9d20fe23 Kostas Papadimitriou
            try:
425 9d20fe23 Kostas Papadimitriou
                tpl = getattr(astakos_messages, msg_key)
426 9d20fe23 Kostas Papadimitriou
            except AttributeError, e:
427 9d20fe23 Kostas Papadimitriou
                try:
428 9d20fe23 Kostas Papadimitriou
                    msg_key = msg.upper()
429 9d20fe23 Kostas Papadimitriou
                    tpl = getattr(astakos_messages, msg_key)
430 9d20fe23 Kostas Papadimitriou
                except AttributeError, e:
431 9d20fe23 Kostas Papadimitriou
                    tpl = ''
432 9d20fe23 Kostas Papadimitriou
433 9d20fe23 Kostas Papadimitriou
        in_settings = self.get_setting(msg)
434 9d20fe23 Kostas Papadimitriou
        if in_settings:
435 9d20fe23 Kostas Papadimitriou
            tpl = in_settings
436 9d20fe23 Kostas Papadimitriou
437 9d20fe23 Kostas Papadimitriou
        return tpl.format(**params)
438 dd5f8f4d Kostas Papadimitriou
439 0e79735c Kostas Papadimitriou
    @property
440 9d20fe23 Kostas Papadimitriou
    def urls(self):
441 9d20fe23 Kostas Papadimitriou
        urls = {
442 9d20fe23 Kostas Papadimitriou
            'login': reverse(self.login_view),
443 9d20fe23 Kostas Papadimitriou
            'add': reverse(self.login_view),
444 9d20fe23 Kostas Papadimitriou
            'profile': reverse('edit_profile'),
445 9d20fe23 Kostas Papadimitriou
        }
446 0e79735c Kostas Papadimitriou
        if self.user:
447 9d20fe23 Kostas Papadimitriou
            urls.update({
448 9d20fe23 Kostas Papadimitriou
                'resend_activation': self.user.get_resend_activation_url(),
449 9d20fe23 Kostas Papadimitriou
            })
450 9d20fe23 Kostas Papadimitriou
        if self.identifier and self._instance:
451 9d20fe23 Kostas Papadimitriou
            urls.update({
452 cbc7a32c Kostas Papadimitriou
                'switch': reverse(self.login_view) + '?switch_from=%d' %
453 cbc7a32c Kostas Papadimitriou
                self._instance.pk,
454 9d20fe23 Kostas Papadimitriou
                'remove': reverse('remove_auth_provider',
455 9d20fe23 Kostas Papadimitriou
                                  kwargs={'pk': self._instance.pk})
456 9d20fe23 Kostas Papadimitriou
            })
457 9d20fe23 Kostas Papadimitriou
        urls.update(self.module_urls)
458 9d20fe23 Kostas Papadimitriou
        return urls
459 9d20fe23 Kostas Papadimitriou
460 9d20fe23 Kostas Papadimitriou
    def get_setting_key(self, name):
461 9d20fe23 Kostas Papadimitriou
        return 'ASTAKOS_AUTH_PROVIDER_%s_%s' % (self.module.upper(),
462 9d20fe23 Kostas Papadimitriou
                                                name.upper())
463 9d20fe23 Kostas Papadimitriou
464 9d20fe23 Kostas Papadimitriou
    def get_global_setting_key(self, name):
465 9d20fe23 Kostas Papadimitriou
        return 'ASTAKOS_AUTH_PROVIDERS_%s' % name.upper()
466 9d20fe23 Kostas Papadimitriou
467 9d20fe23 Kostas Papadimitriou
    def has_global_setting(self, name):
468 9d20fe23 Kostas Papadimitriou
        return hasattr(settings, self.get_global_setting_key(name))
469 9d20fe23 Kostas Papadimitriou
470 9d20fe23 Kostas Papadimitriou
    def has_setting(self, name):
471 9d20fe23 Kostas Papadimitriou
        return hasattr(settings, self.get_setting_key(name))
472 0e79735c Kostas Papadimitriou
473 9d20fe23 Kostas Papadimitriou
    def get_setting(self, name, default=None):
474 9d20fe23 Kostas Papadimitriou
        attr = self.get_setting_key(name)
475 9d20fe23 Kostas Papadimitriou
        if not self.has_setting(name):
476 9d20fe23 Kostas Papadimitriou
            return self.get_global_setting(name, default)
477 9d20fe23 Kostas Papadimitriou
        return getattr(settings, attr, default)
478 0e79735c Kostas Papadimitriou
479 9d20fe23 Kostas Papadimitriou
    def get_global_setting(self, name, default=None):
480 9d20fe23 Kostas Papadimitriou
        attr = self.get_global_setting_key(name)
481 9d20fe23 Kostas Papadimitriou
        if not self.has_global_setting(name):
482 9d20fe23 Kostas Papadimitriou
            return default
483 9d20fe23 Kostas Papadimitriou
        return getattr(settings, attr, default)
484 9d20fe23 Kostas Papadimitriou
485 9d20fe23 Kostas Papadimitriou
    @property
486 9d20fe23 Kostas Papadimitriou
    def provider_details(self):
487 9d20fe23 Kostas Papadimitriou
        if self._provider_details:
488 9d20fe23 Kostas Papadimitriou
            return self._provider_details
489 564a2292 Kostas Papadimitriou
490 9d20fe23 Kostas Papadimitriou
        self._provider_details = {}
491 64492c49 Kostas Papadimitriou
492 9d20fe23 Kostas Papadimitriou
        if self._instance:
493 9d20fe23 Kostas Papadimitriou
            self._provider_details = self._instance.__dict__
494 bd0f516a Kostas Papadimitriou
495 9d20fe23 Kostas Papadimitriou
        if self.user and self.identifier:
496 9d20fe23 Kostas Papadimitriou
            if self.identifier:
497 9d20fe23 Kostas Papadimitriou
                try:
498 9d20fe23 Kostas Papadimitriou
                    self._provider_details = \
499 9d20fe23 Kostas Papadimitriou
                        self.user.get_auth_providers().get(
500 9d20fe23 Kostas Papadimitriou
                            module=self.module,
501 9d20fe23 Kostas Papadimitriou
                            identifier=self.identifier).__dict__
502 9d20fe23 Kostas Papadimitriou
                except Exception:
503 9d20fe23 Kostas Papadimitriou
                    return {}
504 9d20fe23 Kostas Papadimitriou
        return self._provider_details
505 d0632ab1 Olga Brani
506 081070a5 Kostas Papadimitriou
    def __getattr__(self, key):
507 081070a5 Kostas Papadimitriou
        if not key.startswith('get_'):
508 6974e526 Kostas Papadimitriou
            return super(AuthProvider, self).__getattribute__(key)
509 081070a5 Kostas Papadimitriou
510 9d20fe23 Kostas Papadimitriou
        key = key.replace('get_', '')
511 9d20fe23 Kostas Papadimitriou
        if key.endswith('_msg'):
512 9d20fe23 Kostas Papadimitriou
            return self.get_message(key)
513 91bbc1a4 Kostas Papadimitriou
514 9d20fe23 Kostas Papadimitriou
        if key.endswith('_policy'):
515 9d20fe23 Kostas Papadimitriou
            return self.get_policy(key.replace('_policy', ''))
516 d2633501 Kostas Papadimitriou
517 9d20fe23 Kostas Papadimitriou
        if key.endswith('_url'):
518 9d20fe23 Kostas Papadimitriou
            key = key.replace('_url', '')
519 9d20fe23 Kostas Papadimitriou
            return self.urls.get(key)
520 e9e692be Kostas Papadimitriou
521 9d20fe23 Kostas Papadimitriou
        if key.endswith('_icon'):
522 9d20fe23 Kostas Papadimitriou
            key = key.replace('_msg', '_icon')
523 9d20fe23 Kostas Papadimitriou
            return settings.MEDIA_URL + self.get_message(key)
524 d2633501 Kostas Papadimitriou
525 9d20fe23 Kostas Papadimitriou
        if key.endswith('_setting'):
526 9d20fe23 Kostas Papadimitriou
            key = key.replace('_setting', '')
527 9d20fe23 Kostas Papadimitriou
            return self.get_message(key)
528 d2633501 Kostas Papadimitriou
529 9d20fe23 Kostas Papadimitriou
        if key.endswith('_template'):
530 9d20fe23 Kostas Papadimitriou
            key = key.replace('_template', '')
531 9d20fe23 Kostas Papadimitriou
            return self.get_template(key)
532 d2633501 Kostas Papadimitriou
533 9d20fe23 Kostas Papadimitriou
        return super(AuthProvider, self).__getattribute__(key)
534 badcb2a9 Kostas Papadimitriou
535 d2633501 Kostas Papadimitriou
    def is_active(self):
536 9d20fe23 Kostas Papadimitriou
        return self.module_enabled
537 d2633501 Kostas Papadimitriou
538 97246b51 Kostas Papadimitriou
    @property
539 97246b51 Kostas Papadimitriou
    def log_display(self):
540 97246b51 Kostas Papadimitriou
        dsp = "%sAuth" % self.module.title()
541 97246b51 Kostas Papadimitriou
        if self.user:
542 97246b51 Kostas Papadimitriou
            dsp += "[%s]" % self.user.log_display
543 97246b51 Kostas Papadimitriou
            if self.identifier:
544 97246b51 Kostas Papadimitriou
                dsp += '[%s]' % self.identifier
545 97246b51 Kostas Papadimitriou
                if self._instance and self._instance.pk:
546 97246b51 Kostas Papadimitriou
                    dsp += '[%d]' % self._instance.pk
547 97246b51 Kostas Papadimitriou
        return dsp
548 97246b51 Kostas Papadimitriou
549 97246b51 Kostas Papadimitriou
    def log(self, msg, *args, **kwargs):
550 97246b51 Kostas Papadimitriou
        level = kwargs.pop('level', logging.INFO)
551 97246b51 Kostas Papadimitriou
        message = '%s: %s' % (self.log_display, msg)
552 97246b51 Kostas Papadimitriou
        logger.log(level, message, *args, **kwargs)
553 97246b51 Kostas Papadimitriou
554 d2633501 Kostas Papadimitriou
555 d2633501 Kostas Papadimitriou
class LocalAuthProvider(AuthProvider):
556 d2633501 Kostas Papadimitriou
    module = 'local'
557 9d20fe23 Kostas Papadimitriou
558 dd5f8f4d Kostas Papadimitriou
    login_view = 'password_change'
559 564a2292 Kostas Papadimitriou
    remote_authenticate = False
560 9d20fe23 Kostas Papadimitriou
    username_key = 'user_email'
561 081070a5 Kostas Papadimitriou
562 9d20fe23 Kostas Papadimitriou
    messages = {
563 9d20fe23 Kostas Papadimitriou
        'title': _('Classic'),
564 9d20fe23 Kostas Papadimitriou
        'login_prompt': _('Classic login (username/password)'),
565 9d20fe23 Kostas Papadimitriou
        'login_success': _('Logged in successfully.'),
566 9d20fe23 Kostas Papadimitriou
        'method_details': 'Username: {username}',
567 9d20fe23 Kostas Papadimitriou
        'logout_success_extra': ' '
568 9d20fe23 Kostas Papadimitriou
    }
569 d2633501 Kostas Papadimitriou
570 bc8bede2 Kostas Papadimitriou
    policies = {
571 7bb081f5 Kostas Papadimitriou
        'limit': 1,
572 7bb081f5 Kostas Papadimitriou
        'switch': False
573 bc8bede2 Kostas Papadimitriou
    }
574 bc8bede2 Kostas Papadimitriou
575 d2633501 Kostas Papadimitriou
    @property
576 9d20fe23 Kostas Papadimitriou
    def urls(self):
577 9d20fe23 Kostas Papadimitriou
        urls = super(LocalAuthProvider, self).urls
578 9d20fe23 Kostas Papadimitriou
        urls['change_password'] = reverse('password_change')
579 9d20fe23 Kostas Papadimitriou
        if self.user:
580 9d20fe23 Kostas Papadimitriou
            urls['add'] = reverse('password_change')
581 9d20fe23 Kostas Papadimitriou
        if self._instance:
582 9d20fe23 Kostas Papadimitriou
            urls.update({
583 9d20fe23 Kostas Papadimitriou
                'remove': reverse('remove_auth_provider',
584 9d20fe23 Kostas Papadimitriou
                                  kwargs={'pk': self._instance.pk})
585 9d20fe23 Kostas Papadimitriou
            })
586 9d20fe23 Kostas Papadimitriou
            if 'switch' in urls:
587 9d20fe23 Kostas Papadimitriou
                del urls['switch']
588 9d20fe23 Kostas Papadimitriou
        return urls
589 9d20fe23 Kostas Papadimitriou
590 9d20fe23 Kostas Papadimitriou
    def remove_from_user(self):
591 9d20fe23 Kostas Papadimitriou
        super(LocalAuthProvider, self).remove_from_user()
592 9d20fe23 Kostas Papadimitriou
        self.user.set_unusable_password()
593 9d20fe23 Kostas Papadimitriou
        self.user.save()
594 d2633501 Kostas Papadimitriou
595 74796dd8 Kostas Papadimitriou
596 d2633501 Kostas Papadimitriou
class ShibbolethAuthProvider(AuthProvider):
597 d2633501 Kostas Papadimitriou
    module = 'shibboleth'
598 70e11eaa Sofia Papagiannaki
    login_view = 'astakos.im.views.target.shibboleth.login'
599 830747d2 Kostas Papadimitriou
    username_key = 'provider_info_eppn'
600 d2633501 Kostas Papadimitriou
601 7bb081f5 Kostas Papadimitriou
    policies = {
602 7bb081f5 Kostas Papadimitriou
        'switch': False
603 7bb081f5 Kostas Papadimitriou
    }
604 7bb081f5 Kostas Papadimitriou
605 9d20fe23 Kostas Papadimitriou
    messages = {
606 9d20fe23 Kostas Papadimitriou
        'title': _('Academic'),
607 9d20fe23 Kostas Papadimitriou
        'login_description': _('If you are a student, professor or researcher'
608 9d20fe23 Kostas Papadimitriou
                               ' you can login using your academic account.'),
609 cbc7a32c Kostas Papadimitriou
        'add_prompt': _('Allows you to login using your Academic '
610 cbc7a32c Kostas Papadimitriou
                        'account'),
611 9d20fe23 Kostas Papadimitriou
        'method_details': 'Account: {username}',
612 cbc7a32c Kostas Papadimitriou
        'logout_success_extra': _('You may still be logged in at your Academic'
613 cbc7a32c Kostas Papadimitriou
                                  ' account though. Consider logging out '
614 cbc7a32c Kostas Papadimitriou
                                  'from there too by closing all browser '
615 cbc7a32c Kostas Papadimitriou
                                  'windows')
616 9d20fe23 Kostas Papadimitriou
    }
617 ca5148f2 Kostas Papadimitriou
618 d2633501 Kostas Papadimitriou
619 c101b32b Kostas Papadimitriou
class TwitterAuthProvider(AuthProvider):
620 c101b32b Kostas Papadimitriou
    module = 'twitter'
621 70e11eaa Sofia Papagiannaki
    login_view = 'astakos.im.views.target.twitter.login'
622 9d20fe23 Kostas Papadimitriou
    username_key = 'provider_info_screen_name'
623 c101b32b Kostas Papadimitriou
624 9d20fe23 Kostas Papadimitriou
    messages = {
625 9d20fe23 Kostas Papadimitriou
        'title': _('Twitter'),
626 9d20fe23 Kostas Papadimitriou
        'method_details': 'Screen name: {username}',
627 9d20fe23 Kostas Papadimitriou
    }
628 c101b32b Kostas Papadimitriou
629 74796dd8 Kostas Papadimitriou
630 74796dd8 Kostas Papadimitriou
class GoogleAuthProvider(AuthProvider):
631 74796dd8 Kostas Papadimitriou
    module = 'google'
632 70e11eaa Sofia Papagiannaki
    login_view = 'astakos.im.views.target.google.login'
633 9d20fe23 Kostas Papadimitriou
    username_key = 'provider_info_email'
634 74796dd8 Kostas Papadimitriou
635 9d20fe23 Kostas Papadimitriou
    messages = {
636 9d20fe23 Kostas Papadimitriou
        'title': _('Google'),
637 9d20fe23 Kostas Papadimitriou
        'method_details': 'Email: {username}',
638 9d20fe23 Kostas Papadimitriou
    }
639 74796dd8 Kostas Papadimitriou
640 74796dd8 Kostas Papadimitriou
641 74796dd8 Kostas Papadimitriou
class LinkedInAuthProvider(AuthProvider):
642 74796dd8 Kostas Papadimitriou
    module = 'linkedin'
643 70e11eaa Sofia Papagiannaki
    login_view = 'astakos.im.views.target.linkedin.login'
644 9d20fe23 Kostas Papadimitriou
    username_key = 'provider_info_email'
645 74796dd8 Kostas Papadimitriou
646 9d20fe23 Kostas Papadimitriou
    messages = {
647 9d20fe23 Kostas Papadimitriou
        'title': _('LinkedIn'),
648 9d20fe23 Kostas Papadimitriou
        'method_details': 'Email: {username}',
649 9d20fe23 Kostas Papadimitriou
    }
650 74796dd8 Kostas Papadimitriou
651 74796dd8 Kostas Papadimitriou
652 9d20fe23 Kostas Papadimitriou
# Utility method
653 9d20fe23 Kostas Papadimitriou
def get_provider(module, user_obj=None, identifier=None, **params):
654 d2633501 Kostas Papadimitriou
    """
655 d2633501 Kostas Papadimitriou
    Return a provider instance from the auth providers registry.
656 d2633501 Kostas Papadimitriou
    """
657 9d20fe23 Kostas Papadimitriou
    if not module in PROVIDERS:
658 9d20fe23 Kostas Papadimitriou
        raise Exception('Invalid auth provider "%s"' % id)
659 d2633501 Kostas Papadimitriou
660 9d20fe23 Kostas Papadimitriou
    return PROVIDERS.get(module)(user_obj, identifier, **params)