Scheduler: adding/removing resources enforce warnings and recount number of unconfigu...
[myslice.git] / auth / manifoldbackend.py
1 import time
2
3 from django.contrib.auth.models import User
4
5 from manifoldapi.manifoldapi    import ManifoldAPI, ManifoldException, ManifoldResult
6 from manifold.core.query        import Query
7
8 from myslice.settings import config, logger, DEBUG
9
10 # Name my backend 'ManifoldBackend'
11 class ManifoldBackend:
12
13     # Create an authentication method
14     # This is called by the standard Django login procedure
15     def authenticate(self, token=None):
16         if not token:
17             return None
18         
19         person = {}
20
21         try:
22             username = token['username']
23             password = token['password']
24             request = token['request']
25
26             auth = {'AuthMethod': 'password', 'Username': username, 'AuthString': password}
27             api = ManifoldAPI(auth)
28             sessions_result = api.forward(Query.create('local:session').to_dict())
29             sessions = sessions_result.ok_value()
30             if not sessions:
31                 logger.error("GetSession failed", sessions_result.error())
32                 return
33             session = sessions[0]
34             logger.debug("SESSION : %s" % session)
35             
36             # Change to session authentication
37             api.auth = {'AuthMethod': 'session', 'session': session['session']}
38             self.api = api
39
40             # Get account details
41             # the new API would expect Get('local:user') instead
42             persons_result = api.forward(Query.get('local:user').to_dict())
43             persons = persons_result.ok_value()
44             if not persons:
45                 logger.error("GetPersons failed",persons_result.error())
46                 return
47             person = persons[0]
48             logger.debug("PERSON : %s" % person)
49             #logger.info("%s %s <%s> logged in" % (person['config']['first_name'], person['config']['last_name'], person['config']['email']))
50
51             request.session['manifold'] = {'auth': api.auth, 'person': person, 'expires': session['expires']}
52         except ManifoldException, e:
53             logger.error("Manifold Auth Backend: %s" % e.manifold_result)
54         except Exception, e:
55             logger.error("Manifold Auth Backend: %s" % e)
56             #import traceback
57             #traceback.print_exc()
58             return None
59
60         try:
61             # Check if the user exists in Django's local database
62             user = User.objects.get(username=username)
63         except User.DoesNotExist:
64             # Create a user in Django's local database
65             user = User.objects.create_user(username, username, 'passworddoesntmatter')
66             user.email = person['email']
67
68         if 'firstname' in person:
69             user.first_name = person['firstname']
70         if 'lastname' in person:
71             user.last_name = person['lastname']
72
73         return user
74
75     # Required for your backend to work properly - unchanged in most scenarios
76     def get_user(self, user_id):
77         try:
78             return User.objects.get(pk=user_id)
79         except User.DoesNotExist:
80             return None
81
82