Thanks for the reply. You're right that auth.User is not a replacement for a profile. Maybe I will make the training app require only that a profile model exists and has a particular set of fields like cost-center, manager's e-mail, etc. This way at least it wouldn't be tied to a particular implementation of a profile.
I would just have things like... class Enrollment(models.Model): person = models.ForeignKey(settings.AUTH_PROFILE_MODULE) offering = models.ForeignKey(Offering) If I do this, then do I run into that problem of not being able to import the models file? ~Eric On May 4, 3:35 pm, Malcolm Tredinnick <malc...@pointy-stick.com> wrote: > On Mon, 2009-05-04 at 11:35 -0700, eric.frederich wrote: > > I wrote an app that consist of an authentication backend and a single > > model "Profile" (extension of auth.User). It also has a function > > which queries ldap to get user information like their manager. We'll > > call this app my_custom_backend. The reason the Profile and > > authentication are in the same app is because when a user logs in for > > the first time it creates an auth.User as well as a > > my_custom_backend.Profile and populates fields like cost center, > > manager, phone number etc. > > > Another app that I have is a training application to register for > > training courses offered here for engineering (Ansys, AutoCad, MathCad > > etc.). > > > At first they were pretty separated through the use of the setting > > AUTH_PROFILE_MODULE. > > > At the top of my models.py in the training application I had this... > > > PROFILE = getattr(settings, 'AUTH_PROFILE_MODULE', 'auth.User') > > > And then later on in my models I would have things like... > > > class Enrollment(models.Model): > > person = models.ForeignKey(PROFILE) > > offering = models.ForeignKey(Offering) > > > So depending on setting AUTH_PROFILE_MODULE it would either link to > > my_custom_backend.Profile or auth.User. > > > Now as I start writing views and functionality I find the training app > > directly depending on my_custom_backend. Like when a user enrolls in > > an offering of a course the manager needs to get emailed for approval > > and finding the manager's email is provided by my_custom_backend. > > > Is it worth keeping them separated through the AUTH_PROFILE_MODULE > > abstraction or should I just make the training app completely > > dependent on my_custom_backend and directly reference > > my_custom_backend.Profile from within there? > > I would make the dependency firm. I'm always very nervous about code > that does what you're doing here, for a couple of reasons: > > Firstly, that setting can never be changed once syncdb is run, since > changing the setting would require changing the database schema (the > reference constraint between the tables). Secondly, as a more minor > point, you've removed the ability to be able to import your models file > before the settings are available. That's why a bunch of Django's own > code has "from django.conf import settings" inside functions -- so that > the module itself can be imported even if the user is going to call > settings.configure() later on. The second point is relatively minor for > you at this stage, I suspect, but it's worth keeping in the back of your > mind. > > Realistically, though, the answer to your question comes down to whether > you'll ever be actually using your code without your particular profile > module? It sounds like you won't be. > > Also, there's kind of an awkward design in what you've got now. The > auth.User class is not a substitute for an AUTH_PROFILE_MODULE class, as > the latter has a related field pointing to the former. Lots of your code > would be easier if you were able to guarantee to yourself that you could > always call get_profile() on a user object and just have it return the > right thing. At a minimum, even if not hard-coding in the particular > profile module, make it a requirement that a profile module exists. > > 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 -~----------~----~----~----~------~----~------~--~---