You could write a wrapper around it if you wanted.

def x_edit(request, x_id):
    x = X.objects.get(id = x_id)
    if x.user != request.user:
        return HttpResponseRedirect('/you cant edit that/')
    return update_object(request, model = X, object_id = x_id,)


On Oct 12, 1:51 pm, "Ed Kawas" <ed.ka...@gmail.com> wrote:
> Ah, so there is no way to use 'create_object' when doing this, right?
>
> Thank you,
>
> Eddie
>
> -----Original Message-----
> From: django-users@googlegroups.com [mailto:django-us...@googlegroups.com]
>
> On Behalf Of Brian McKeever
> Sent: October-12-09 12:50 PM
> To: Django users
> Subject: Re: showing user data in a view
>
> It's the same thing.
>
> Lets say this is your view:
> def x_edit(request, x_id):
>     x = X.objects.get(id = x_id)
>     if x.user != request.user:
>         return HttpResponseRedirect('/you cant edit that/')
>     if request.method == 'POST':
>         form = XForm(request.POST)
>         if form.is_valid():
>             #whatever you need to do to save an x object here
>             return HttpResponseRedirect('/thanks/')
>     else:
>         form = XForm()
>
>     return render_to_response('x_edit.html', {
>         'form': form,
>     })
>
> You can split that into multiple views if you want, but the idea is to
> do the check before saving the object.
>
> On Oct 12, 1:25 pm, "Ed Kawas" <ed.ka...@gmail.com> wrote:
> > That works for retrieving information, but how can I save information too?
>
> > Thanks for your patience,
>
> > Eddie
>
> > -----Original Message-----
> > From: django-users@googlegroups.com [mailto:django-us...@googlegroups.com]
>
> > On Behalf Of Brian McKeever
> > Sent: October-12-09 11:52 AM
> > To: Django users
> > Subject: Re: showing user data in a view
>
> > The easy way is to just check that the owner of X is the user logged
> > in.
> > I don't know that you can pass an argument to the decorator, but you
> > could certainly just use an if statement.
>
> >http://docs.djangoproject.com/en/dev/topics/auth/#limiting-access-to-...
> > in-users-that-pass-a-test
>
> > On Oct 12, 11:40 am, Ed <ed.ka...@gmail.com> wrote:
> > > Hi All,
>
> > > I am completely lost. I *think* that I have read most of the doc that
> > > i can find and I must be pretty dense, because I cannot figure this
> > > one out ...
>
> > > Let me outline what i have and where i want to go!
>
> > > model:
> > > # an X
> > > class X(db.Model):
> > >    user = models.ForeignKey(User, unique=True)
> > >    name = db.StringProperty(required=True)
>
> > > Form:
> > > class XForm(forms.ModelForm):
> > >     name = models.CharField(max_length=100)
> > >     class Meta:
> > >         model = X
> > >         fields = {'name'}
>
> > > views:
> > > def add_x(request):
> > >   return create_object(request,
> > >                                     form_class=XForm,
> > >                                     post_save_redirect=reverse
> > > ('myapp.views.show_x',
> > > kwargs=dict(key='%(key)s')))
>
> > > I am trying to allow authenticated users the ability to add X. I am
> > > trying to associate a user with a specific X so that only that user
> > > can modify it. How can I do this?
> > > Thanks.
--~--~---------~--~----~------------~-------~--~----~
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