Проблемы с баном пользователей и добавлением их в таблицу - PullRequest
0 голосов
/ 16 мая 2018

У меня есть функция, предназначенная для запрета пользователя, а затем добавления его в таблицу Banned_User. Так что я могу затем отправить пользователю электронное письмо с деталями его запрета. Но я не могу получитьфункция для запрета и сохранения

Текущая ошибка трассировки: Тип исключения: Ошибка типа в / admin / api / profile / Значение исключения: Прямое назначение на переднюю сторону множества ко многимнабор запрещен.Вместо этого используйте report_reason.set ().

def banning_users(self, request, queryset):

for obj in queryset:
    if hasattr(obj, 'user'):
        # This object is a Profile, so lookup the user
        profile = obj
        user = obj.user
    user.is_active = False
    user.save()


    # Get the report(s) for this user
    user_reports = Report.objects.filter(user_reported=profile)

    # Go through each report, in case there are multiples,
    # add a record in the ban table

    banned_reasons = []

    for report in user_reports:
        ban_record = Banned_User.objects.create(profile=profile, report_reason=report)
        ban_record.save() 
        banned_reasons.append(report.get_report_reason_display())



    # Send the email
    subject = 'Ban'
    message = 'You have been banned for the following reasons: []' + \
    report.report_reason + banned_reasons[0] + banned_reasons[1]

    email_from = settings.EMAIL_HOST_USER
    recipient_list = [user.email]
    send_mail( subject, message,email_from, recipient_list)

self.message_user(request, "User is banned and Email has been sent")

BANNED_USER MODEL

class Banned_User(models.Model):
def __str__(self):
    return str.join(str(self.profile), str(self.report_reason.report_reason))
    #return self.profile
    #return str.join(str(self.profile), str(self.report_reason))

profile = models.ForeignKey(
    'Profile',
    on_delete=models.PROTECT,
    blank=False,
    null=False,
    related_name='banned_profile'
)

report_reason = models.ManyToManyField(
    'Report',
    #on_delete=models.PROTECT,
    blank=True,
    #null=True,
)

date_banned = models.DateField(null=True, blank=False,)

REPORT MODEL

class Report(models.Model):
def __str__(self):
    return str.join(str(self.user_reported), str(self.datetime_sent))

TOXICITY = 'Toxicity'
SPORTSMANSHIP = 'Poor sportsmanship'

REPORT_REASON_CHOICES = (
    (TOXICITY, 'Toxicity'),
    (SPORTSMANSHIP, 'Unsportsmanlike Behaviour'),
)

session = models.ForeignKey(
    'Session',
    on_delete=models.PROTECT,
    blank=False,
    null=False,
)

user_reported = models.ForeignKey(
    'Profile',
    on_delete=models.PROTECT,
    blank=False,
    null=False,
    related_name='user_reported_report',
)

sent_by = models.ForeignKey(
    'Profile',
    on_delete=models.PROTECT,
    blank=False,
    null=False,
    related_name='sent_by_report',
)

report_reason = models.CharField(
    max_length=255,
    choices=REPORT_REASON_CHOICES,
    default=TOXICITY,
)

datetime_sent = models.DateTimeField(auto_now_add=True,)

1 Ответ

0 голосов
/ 16 мая 2018

Сообщить о причине сбоя заключается в том, что вы пытаетесь присвоить внешний ключ многим ко многим полям, которое установлено для использования команды добавления.

ban_record = Banned_User.objects.create(profile=profile, report_reason=report)

, который не будет работать. Что вам нужно сделать, так это создать модель banned_user для профиля

banned_user = profile.banned_profile.create(profile=profile)

тогда вы бы добавили причины банов забаненному пользователю Под редакцией

reports = banned_user.profile.user_reported_report.all()
for report in reports:
    banned_user.report_reason.add(report)

Вы можете посмотреть на работу со многими и многими областями здесь. https://docs.djangoproject.com/en/2.0/topics/db/examples/many_to_many/

...