J'ai besoin de suivre l'invitation des utilisateurs à l'utilisateur. Qui les utilisateurs invitent qui? J'ai donc un modèle User qui a un M2M à "self".django plusieurs à plusieurs problème de relation en double
class User(AbstractBaseUser, PermissionsMixin):
…
# referral part
invited_by = models.ForeignKey("self", blank=True, null=True, db_index=True)
recruits = models.ManyToManyField("self", blank=True, null=True)
direct_matches = models.ManyToManyField("self", blank=True, null=True)
second_matches = models.ManyToManyField("self", blank=True, null=True)
third_matches = models.ManyToManyField("self", blank=True, null=True)
et cette partie du code qui suivent référence:
@login_required
def do_ref_system_stuff(request):
"""
Assign recruits on 'invited_by' user and invited_by to user.
"""
if 'invited_by' in request.session:
# Add user to recruits
invited_by = get_object_or_404(User, pk=request.session['invited_by'])
invited_by.recruits.add(request.user)
invited_by.save()
# Assign invited_by to the new user
request.user.invited_by = invited_by
request.user.save()
del request.session['invited_by']
return HttpResponseRedirect('/dashboard/')
maintenant:
invited_by.recruits.all()
[<User: prova>] # new registered user == 'request.user'
Mais pourquoi si je fais:
request.user.recruits.all()
[<User: dioc>] # invited_by
Pourquoi les relations est double ?
Merci
Question: Pourquoi avez-vous tant invited_by et recrues dans votre modèle? Invité_by est également plusieurs-à-un et recrute est plusieurs-à-plusieurs? semble auto-controversé –