call user.set_password() in PLUser.save() instead of PLUserAdmin.save()
authorTony Mack <tmack@paris.CS.Princeton.EDU>
Thu, 2 May 2013 01:02:12 +0000 (21:02 -0400)
committerTony Mack <tmack@paris.CS.Princeton.EDU>
Thu, 2 May 2013 01:02:12 +0000 (21:02 -0400)
plstackapi/core/admin.py
plstackapi/core/models/pluser.py

index 230dbfc..39838fa 100644 (file)
@@ -280,7 +280,8 @@ class UserCreationForm(forms.ModelForm):
     def save(self, commit=True):
         # Save the provided password in hashed format
         user = super(UserCreationForm, self).save(commit=False)
-        user.set_password(self.cleaned_data["password1"])
+        user.password = self.cleaned_data["password1"]
+        #user.set_password(self.cleaned_data["password1"])
         if commit:
             user.save()
         return user
index 1c01a42..f914662 100644 (file)
@@ -102,15 +102,16 @@ class PLUser(AbstractBaseUser):
 
     def save(self, *args, **kwds):
         if not self.user_id:
-            if not hasattr(self, 'driver'):
+            if not self.driver:
                 setattr(self, 'driver', OpenStackDriver())
             name = self.email[:self.email.find('@')]
             user_fields = {'name': name,
                            'email': self.email,
                            'password': self.password,
-                           'enabled': self.is_active}
-            user = self.driver.create_user(**user_fields)
-            self.user_id = user.id
+                           'enabled': True}
+            keystone_user = self.driver.create_user(**user_fields)
+            self.user_id = keystone_user.id
+        self.set_password(self.password)    
         super(PLUser, self).save(*args, **kwds)   
 
     def delete(self, *args, **kwds):