configured django-cms for testing purposes
[unfold.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 from manifold.core.query        import Query
7
8 # Name my backend 'ManifoldBackend'
9 class ManifoldBackend:
10
11     # Create an authentication method
12     # This is called by the standard Django login procedure
13     def authenticate(self, token=None):
14         if not token:
15             return None
16
17         try:
18             username = token['username']
19             password = token['password']
20             request = token['request']
21
22             auth = {'AuthMethod': 'password', 'Username': username, 'AuthString': password}
23             api = ManifoldAPI(auth)
24 #old            # Authenticate user and get session key
25 #old            # the new API would expect Get('local:session') instead
26 #old            session_result = api.GetSession()
27 #old            session = session_result.ok_value()
28 #old            if not session:
29 #old                print "GetSession failed",session_result.error()
30 #old                return
31 #old            print 'DEALING with session',session
32 #old            #self.session = session
33 #old            # Change GetSession() at some point to return expires as well
34 #old            expires = time.time() + (24 * 60 * 60)
35
36             sessions_result = api.forward(Query.create('local:session').to_dict())
37             sessions = sessions_result.ok_value()
38             if not sessions:
39                 print "GetSession failed", sessions_result.error()
40                 return
41             session = sessions[0]
42
43             # Change to session authentication
44             api.auth = {'AuthMethod': 'session', 'session': session['session']}
45             self.api = api
46
47             # Get account details
48             # the new API would expect Get('local:user') instead
49             persons_result = api.forward(Query.get('local:user').to_dict())
50             persons = persons_result.ok_value()
51             if not persons:
52                 print "GetPersons failed",persons_result.error()
53                 return
54             person = persons[0]
55
56             request.session['manifold'] = {'auth': api.auth, 'person': person, 'expires': session['expires']}
57         except Exception, e:
58             print "E: manifoldbackend", e
59             import traceback
60             traceback.print_exc()
61             return None
62
63         try:
64             # Check if the user exists in Django's local database
65             user = User.objects.get(username=username)
66         except User.DoesNotExist:
67             # Create a user in Django's local database
68             user = User.objects.create_user(username, username, 'passworddoesntmatter')
69             user.first_name = "DUMMY_FIRST_NAME" #person['first_name']
70             user.last_name = "DUMMY LAST NAME" # person['last_name']
71             user.email = person['email']
72         return user
73
74     # Required for your backend to work properly - unchanged in most scenarios
75     def get_user(self, user_id):
76         try:
77             return User.objects.get(pk=user_id)
78         except User.DoesNotExist:
79             return None
80
81