On Sun, 2009-03-08 at 23:30 -0700, myst3rious wrote:
> Hi,
> Working on a Django app, which requires profile for each subscribing
> user, I created a Profile model:
> class Profile(models.model):
>     user = models.ForeignKey(User, unique=True)
>     middlename = models.CharField(max_length=32, blank=True)
>     gender = models.CharField(max_length=1, blank=True, null=True,
> choices=GENDER_LIST)
>     last_updated = models.DateTimeField(auto_now=True)
> 
> Then, there is another apps installed, which handles the registration.
> On successful activation of account, I need to create the entry in
> django.contrib.auth.models.User as well as this Profile. Right now,
> what I am doing is :
> 
> def create_account(username, password, firstname, lastname, email):
>     new_user = User.objects.create_user(
>                                         username=username,
>                                         email=email,
>                                         password=password
>                                         ) # This will create entry in
> 
>     new_user.is_active = True
>     new_user.first_name = firstname
>     new_user.last_name = lastname

If you're setting all these things in the User object, then reverse the
logic slightly:

        new_user = User.objects.create(username=username,
            email=email,
            is_active=True,
            first_name=firstname,
            last_name=lastname)
        new_user.set_password(password)
        new_user.save() # needed because set_password() doesn't call
        save()
        
>     new_user.save()
> 
> # Create Extended profile
>     up=UserProfile.objects.create(user=new_user)
>     up.firstname = new_user.first_name
>     up.lastname = new_user.last_name
>     up.save()

Again, this could become a one-liner (split over multiple lines for
presentation):

        UserProfile.objects.create(user=new_user,
           firstname=firstname,
           lastname=lastname)
        

>     return True
> 
> 
> # ----
> 
> But I feel somehow, there would be better way to do this. Like, I can
> use signals (though not much familiar with this) or other way. Can
> anyone suggest me some better way, methods, algo, so the code be
> elegant, more understandable, better flow and more pythonic.

I'm not sure what you're seeing the problems are with your current
approach. You need to supply a minimum amount of information to the User
and UserProfile object to create them, so that says that certain
parameters are required. You're supplying those. I've shaved a couple of
lines off, but it's only minor stuff.

Given that minimal information requirement and the fact that you're
creating both objects in the same place -- a good thing so that nothing
is forgotten -- what else are you hoping to trim?

Regards,
Malcolm



--~--~---------~--~----~------------~-------~--~----~
You received this message because you are subscribed to the Google Groups 
"Django users" group.
To post to this group, send email to django-users@googlegroups.com
To unsubscribe from this group, send email to 
django-users+unsubscr...@googlegroups.com
For more options, visit this group at 
http://groups.google.com/group/django-users?hl=en
-~----------~----~----~----~------~----~------~--~---

Reply via email to