-# import the User object
+import time
+
from django.contrib.auth.models import User
-from engine.manifoldapi import ManifoldAPI
+from manifoldapi.manifoldapi import ManifoldAPI, ManifoldException, ManifoldResult
+from manifold.core.query import Query
-# import time - this is used to create Django's internal username
-import time
+from myslice.settings import config, logger, DEBUG
# Name my backend 'ManifoldBackend'
class ManifoldBackend:
# Create an authentication method
# This is called by the standard Django login procedure
- def authenticate(self, username=None, password=None):
- if not username or not password:
+ def authenticate(self, token=None):
+ if not token:
return None
+
+ person = {}
try:
+ username = token['username']
+ password = token['password']
+ request = token['request']
+
auth = {'AuthMethod': 'password', 'Username': username, 'AuthString': password}
api = ManifoldAPI(auth)
- # Authenticate user and get session key
- session = api.GetSession()
- if not session :
- return None
-
- #self.session = session
- # Change GetSession() at some point to return expires as well
- expires = time.time() + (24 * 60 * 60)
-
+ sessions_result = api.forward(Query.create('local:session').to_dict())
+ sessions = sessions_result.ok_value()
+ if not sessions:
+ logger.error("GetSession failed", sessions_result.error())
+ return
+ session = sessions[0]
+ logger.debug("SESSION : %s" % session)
+
# Change to session authentication
- api.auth = {'AuthMethod': 'session', 'session': session}
- #self.api = api
+ api.auth = {'AuthMethod': 'session', 'session': session['session']}
+ self.api = api
# Get account details
- person = api.GetPersons(auth)
- #self.person = person[0]
- except:
+ # the new API would expect Get('local:user') instead
+ persons_result = api.forward(Query.get('local:user').to_dict())
+ persons = persons_result.ok_value()
+ if not persons:
+ logger.error("GetPersons failed",persons_result.error())
+ return
+ person = persons[0]
+ logger.debug("PERSON : %s" % person)
+ #logger.info("%s %s <%s> logged in" % (person['config']['first_name'], person['config']['last_name'], person['config']['email']))
+
+ request.session['manifold'] = {'auth': api.auth, 'person': person, 'expires': session['expires']}
+ except ManifoldException, e:
+ logger.error("Manifold Auth Backend: %s" % e.manifold_result)
+ except Exception, e:
+ logger.error("Manifold Auth Backend: %s" % e)
+ #import traceback
+ #traceback.print_exc()
return None
try:
# Check if the user exists in Django's local database
- user = User.objects.get(email=username)
+ user = User.objects.get(username=username)
except User.DoesNotExist:
# Create a user in Django's local database
- user = User.objects.create_user(time.time(), username, 'passworddoesntmatter')
+ user = User.objects.create_user(username, username, 'passworddoesntmatter')
+ user.email = person['email']
+
+ if 'firstname' in person:
+ user.first_name = person['firstname']
+ if 'lastname' in person:
+ user.last_name = person['lastname']
return user