Vincolo NOT NULL non riuscito: blog_userpost.user_id

Aug 23 2020

Sto cercando di creare un modo in cui le persone possano pubblicare le loro idee ma mi dà questo errore: Vincolo NOT NULL fallito: blog_userpost.user_id. Voglio che l'utente debba essere registrato ed effettuare il login per poter scrivere / leggere i post.

views.py:

    #create view
    @login_required(login_url='login')
def userposts_create_view(request):
    form= UserPostForm(request.POST or None)


if request.method == "POST":
    if form.is_valid():
        form = form.save()
        form.save()
    return HttpResponseRedirect("/Blog/posts/")



context= {'form': form,
          }

return render(request, 'posts/userposts-create-view.html', context)



#list view
   @login_required(login_url='login')
   def userposts_list_view(request):

allposts= UserPost.objects.all()

context= {'allposts': allposts,
          }

return render(request, 'posts/userposts-list-view.html', context)


#detail view
@login_required(login_url='login')
def userposts_detail_view(request, url=None):

post= get_object_or_404(UserPost, url=url)




context= {'post': post,
          }

return render(request, 'posts/userposts-detail-view.html', context)

models.py

Queste sono le categorie che voglio che il post abbia, posso "creare" il post ma ogni volta che lo invio mi dà l'errore.

User= settings.AUTH_USER_MODEL

class UserPost(models.Model):
    user= models.ForeignKey(User, null=False,editable=False, verbose_name='Usuario', on_delete=models.CASCADE)
    title= models.CharField(max_length=500)
    content= models.TextField()
    categories = models.ManyToManyField(Category, verbose_name='Categorias', blank=True,related_name="articles")
    created_at = models.DateTimeField(auto_now_add=True, verbose_name='Creado el ')
    updated_at = models.DateTimeField(auto_now=True, verbose_name='Actualizado el ')
    

    def save(self, *args, **kwargs):
        super(UserPost, self).save(*args, **kwargs)    

forms.py

    from django import forms
from .models import UserPost


class UserPostForm(forms.ModelForm):
    class Meta:
        model= UserPost
        fields= ["title", "content","categories"]

Risposte

1 Roham Aug 23 2020 at 12:34

Un modo semplice è usare il gestore del modello invece di form.save(). Quindi nella tua condizione (cioè if form.is_valid()) puoi usare qualcosa come:

def userposts_create_view(request):
    form= UserPostForm(request.POST or None)

    if form.is_valid():
        data = form.cleaned_data
        categories = data.pop('categories', None)
        user_post = UserPost.objects.create(**data, user=request.user)
        if categories:
            user_post.categories.add(*categories)
        return HttpResponseRedirect("/Blog/posts/")
    
    context= {'form': form}

    return render(request, 'posts/userposts-create-view.html', context)