3 from django.contrib.auth.models import User
5 from manifold.manifoldapi import ManifoldAPI, ManifoldResult
7 # Name my backend 'ManifoldBackend'
10 # Create an authentication method
11 # This is called by the standard Django login procedure
12 def authenticate(self, token=None):
17 username = token['username']
18 password = token['password']
19 request = token['request']
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()
28 print "GetSession failed",session_result.error()
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)
36 # Change to session authentication
37 api.auth = {'AuthMethod': 'session', 'session': session}
41 # the new API would expect Get('local:user') instead
42 persons_result = api.GetPersons(auth)
43 persons = persons_result.ok_value()
45 print "GetPersons failed",persons_result.error()
49 request.session['manifold'] = {'auth': api.auth, 'person': person, 'expires': expires}
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']
64 # Required for your backend to work properly - unchanged in most scenarios
65 def get_user(self, user_id):
67 return User.objects.get(pk=user_id)
68 except User.DoesNotExist: