I see what you are saying. your template would become somewhat complex
and hard to maintain if you had a lot of permissions. However you can
create whatever permissions you want in the meta class of your model
and use those instead of the ACCESS_CHOICES and number checks

class Meta:
    permissions=(
        ('system_acess','Has System Access'),
        ('staff_acess','Has Staff Access'),
    )

So a user can have both system and staff access or one or the other
and you would only need to check once.

if you are on a django version less than 1.2, there is a smart if tag
on djangosnippets that is the basis of the new if tag in django 1.2.
you can down load that and do {% if user.access <=  100 %}

you have to be careful with booleans. The version I have doesn't treat
zeros as false so you have rewrite some code to check for 1 or 0

{% if user.is_staff = 1 %}

So you have options. You template tag would seem to be the most
concise and DRYest route, at least in the template code

On Feb 1, 12:12 am, Dylan Evans <dy...@contentfree.info> wrote:
> On Sun, Jan 31, 2010 at 11:46 PM, esatterwh...@wi.rr.com <
>
> esatterwh...@wi.rr.com> wrote:
> > if if you want to change the menu based on the user, you could
> > probably just use the user permissions from the auth context processor
>
> > if the user has the permissions ( access ) to the option - show it
>
> > else - don't show it.
>
> > or if you want to use the model you have listed here, you could use
> > the {% ifequal tag %}
>
> > {% ifequal myuser.access 1000 %}
> >     show some stuff...
> > {% else %}
> >     show something else...
> > {% endifequal %}
>
> The problem with that is if the user has permission 1000 for superuser and
> there is a menu item for staff requiring a permission of 100 the if check
> would fail. My programmers brain says, no problem just use a bit vector, but
> django templates don't allow that either. In the development version it's
> possible to do;
> {% if myuser.access >= 100 %}
> But i'm looking at deploying the site so i don't really want to use it.
>
>
>
> > I personally think using putting users in groups and assigning
> > permissions then checking in the template for who has what would be
> > the easiest solution. Django does most of the work for you
>
> That may be a better option, i'm still learning django and may have cheated
> with access permissions. I'll look into it but i want to avoid a mess of if
> checks. Since the menu is dynamically generated i can't assume a menu item
> with any particular permission is going to arrive.
>
> The solution i did use seems to be working quite well. In the template the
> "access" tag works like this.
>
> {% for item in menu.objects.all %}
>     {% access item %}
>         #Do stuff
>     {% endaccess %}
> {% endfor %}
>
> The "access" tag checks for the existence of user in the context and
> calculates the users access level, or failing that assumes an access of 1
> (Anonymous). Then it checks for an access property on item and renders the
> block only if user.access >= item.access . You see why the formerly
> mentioned if check is way simpler?
>
> > On Jan 30, 9:28 pm, Dylan Evans <dy...@contentfree.info> wrote:
> > > No i have processors, i have all the data i need in the template, i just
> > > don't know an elegant way to condition out menu items.
>
> > > This is how my model works
>
> > > ACCESS_CHOICES = (
> > >     (1,  "Public"),
> > >     (10, "Private"),
> > >     (100,   "Staff"),
> > >     (1000,  "System")
> > > )
>
> > > class Menu(models.Model):
> > >     name = models.CharField(max_length=16)
>
> > > class MenuItem(models.Model):
> > >     menu = models.ForeignKey(Menu)
> > >     access = models.IntegerField(choices=ACCESS_CHOICES)
>
> > > class MenuSubItem(models.Model):
> > >     item = models.ForeignKey(MenuItem)
> > >     access = models.ForeignKey(MenuSubItem)
>
> > > On Sun, Jan 31, 2010 at 5:31 AM, Shawn Milochik <sh...@milochik.com>
> > wrote:
> > > > I think you've missed context processors, which is easy to do. I'm
> > assuming
> > > > that your issue is that you want to have something passed in the
> > context on
> > > > every page load to do something like decide which menu items are
> > available
> > > > based upon whether the user is logged in, their privileges, or
> > whatever.
>
> > > > Context processors allow you to define a dictionary that gets appended
> > to
> > > > the context of every response you send, so you can have that common
> > stuff
> > > > there.
>
> > > > 1. Write code to get the values appropriate for the current user or
> > > > whatever. Put these in a Python file in your app.
> > > > 2. Add that file to the TEMPLATE_CONTEXT_PROCESSORS in your
> > settings.py.
> > > > 3. Replace Context() with RequestContext() in your render_to_response
> > > > calls.
>
> > > > If I've missed your actual point, please give more detail. I think this
> > > > simplifies what you're trying to do.
>
> > > > Shawn
>
> > > > --
> > > > You received this message because you are subscribed to the Google
> > Groups
> > > > "Django users" group.
> > > > To post to this group, send email to django-us...@googlegroups.com.
> > > > To unsubscribe from this group, send email to
> > > > django-users+unsubscr...@googlegroups.com<django-users%2bunsubscr...@google
> > > >  groups.com>
> > <django-users%2bunsubscr...@google groups.com>
> > > > .
> > > > For more options, visit this group at
> > > >http://groups.google.com/group/django-users?hl=en.
>
> > > --
> > > "The UNIX system has a command, nice ... in order to be nice to the other
> > > users. Nobody ever uses it." - Andrew S. Tanenbaum
>
> > --
> > You received this message because you are subscribed to the Google Groups
> > "Django users" group.
> > To post to this group, send email to django-us...@googlegroups.com.
> > To unsubscribe from this group, send email to
> > django-users+unsubscr...@googlegroups.com<django-users%2bunsubscr...@google 
> > groups.com>
> > .
> > For more options, visit this group at
> >http://groups.google.com/group/django-users?hl=en.
>
> --
> "The UNIX system has a command, nice ... in order to be nice to the other
> users. Nobody ever uses it." - Andrew S. Tanenbaum

-- 
You received this message because you are subscribed to the Google Groups 
"Django users" group.
To post to this group, send email to django-us...@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