73ba446a030e9cb8dc7c5b5d854e10290f370e43
[myslice.git] / auth / manifoldbackend.py
1 import time
2
3 from django.contrib.auth.models import User
4
5 from manifold.manifoldapi import ManifoldAPI, ManifoldResult
6
7 # Name my backend 'ManifoldBackend'
8 class ManifoldBackend:
9
10     # Create an authentication method
11     # This is called by the standard Django login procedure
12     def authenticate(self, token=None):
13         if not token:
14             return None
15
16         try:
17             username = token['username']
18             password = token['password']
19             request = token['request']
20
21             auth = {'AuthMethod': 'password', 'Username': username, 'AuthString': password}
22             api = ManifoldAPI(auth)
23             # Authenticate user and get session key
24             # the new API would expect Get('local:session') instead
25             session_result = api.GetSession()
26             session = session_result.ok_value()
27             if not session:
28                 print "GetSession failed",session_result.error()
29                 return
30             
31             print 'DEALING with session',session
32             #self.session = session
33             # Change GetSession() at some point to return expires as well
34             expires = time.time() + (24 * 60 * 60)
35
36             # Change to session authentication
37             api.auth = {'AuthMethod': '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.GetPersons(auth)
43             persons = persons_result.ok_value()
44             if not persons:
45                 print "GetPersons failed",persons_result.error()
46                 return
47             person = persons[0]
48
49             request.session['manifold'] = {'auth': api.auth, 'person': person, 'expires': expires}
50         except:
51             return None
52
53         try:
54             # Check if the user exists in Django's local database
55             user = User.objects.get(username=username)
56         except User.DoesNotExist:
57             # Create a user in Django's local database
58             user = User.objects.create_user(username, username, 'passworddoesntmatter')
59             user.first_name = person['first_name']
60             user.last_name = person['last_name']
61             user.email = person['email']
62         return user
63
64     # Required for your backend to work properly - unchanged in most scenarios
65     def get_user(self, user_id):
66         try:
67             return User.objects.get(pk=user_id)
68         except User.DoesNotExist:
69             return None
70
71