NomadMay 15, 2020, 3:11 a.m.

AbstarctUser непонятка

django, user model, Custom, abstractuser

я изучаю пока джангу и я придумал задачку для себя:

  • регистрация (простая+сочиал).
  • на момент регистрации пользователь выбирает какой тип аккаунта он хочет зарегать - на пример А и Б.
    данные типы пользователей отличаются не тока по статическим данным профиля но и например у них разные функционалы. в зависимости от этого и регистрационная форма соответствуюшая - разные данные.
    после регистрации попадаешь в свой профиль где все данные.

предположим ты пользователь типа А, авторизуешься, заходишь в профиль и если хочешь поменять тип пользователя то ставишь какой то флажок или что то как то и меняешь и уже в профиле появлаются те данные которые у пользователей типа А нету а те которые были у А и не совпадают с Б исчезают.
Я начал с созданием кастомной модели пользователя наследуемой от AbstarctUser:

=====

class SiteUser(AbstractUser):
is_owner = models.BooleanField( ('AE?'), default=False)
is_client = models.BooleanField(
('Client?'), default=False)

=====

class ProfileClient(models.Model):
profileclient_nickname = models.OneToOneField(SiteUser, on_delete=models.CASCADE, primary_key=True)
profileclient_is_active = models.BooleanField(_("Activ?"), default=False)
profileclient_avatar = models.ImageField("Photo", upload_to="client/", null=True, blank=True,
default='no_image_app_content.png')

=====

class ProfileOwner(models.Model):
profileowner_offname = models.OneToOneField(SiteUser, on_delete=models.CASCADE, primary_key=True)
profileowner_is_active = models.BooleanField(_("Activ?"), default=False)
profileowner_avatar = models.ImageField("Photo", upload_to="owner/", null=True, blank=True,
default='no_image_app_content.png')

=====

в моделях ProfileClient и ProfileOwner есть булевые поля profileclient_is_active и profileowner_is_active соответственно.
про создании профиля из админки, форма состоит из выбрать пользователя, чекбокс для is_active.

в модели SiteUser, есть поле булеевые: is_owner и is_client
про создании пользователя, форма состоит из стандартных юзер, пароль, пароль, а нету в форме чекбокса для is_owner и is_client, а в базе данных есть с значением по умолчании.
может кто обьяснить почему так?

плюс к этому может кто подсказать я иду по правильному пути для реализации данной задачи?
и какие есть другие подходы к реализации данной задумки?

We recommend hosting TIMEWEB
We recommend hosting TIMEWEB
Stable hosting, on which the social network EVILEG is located. For projects on Django we recommend VDS hosting.
6

Добрый день.

В общем-то нормальный подход, только я бы повторяющиеся поля перенёс бы в SiteUser, смысла нет в профилях дублировать то, что одинаковое.

Что касается is_owner и is_client , то вам нужно переопределить UserAdmin

admin.py

from django.contrib.auth.admin import UserAdmin

class SiteUserAdmin(UserAdmin):
    fields = UserAdmin.fields + ['is_owner', 'is_client']

admin.site.register(SteUser, SiteUserAdmin)

В целом подход нормальный, если хотите иметь специфические реализации чего-либо.
Я подобное в недавней статье описывал, только для виджетов.

P/S/ и ради всего святого, отредактируйте топик так, чтобы не было этого большого шрифта. Выглядит жутко...

К слову, для типо пользователей лучше бы подошёл выбор, типо как здесь

class Widget(models.Model):
    HTML = 1
    STANDARD = 2
    WIDGET_TYPE_CHOICES = (
        (HTML, _('HTML Widget')),
        (STANDARD, _('Standard Widget')),
    )

    widget_type = models.IntegerField(
        verbose_name=_('Widget type'),
        choices=WIDGET_TYPE_CHOICES,
        default=HTML
    )

А is_owner и is_client можете написать методами.

Это полезнее в том случае, если в будущем захотите расширить количество типов пользователей

  • May 15, 2020, 4:18 a.m.
  • (edited)

спасибо за ответ.

что касаемо переопределения UserAdmin для is_owner и is_client, то ваш синтаксис

fields = UserAdmin.fields + ['is_owner', 'is_client']

дает ошибку, решил проблему переопределением свойства add_fieldsets из UserAdmin

class SiteCustomUserAdmin(UserAdmin):
    add_form = SiteUserCreationForm
    form = SiteUserChangeForm

    UserAdmin.add_fieldsets = (
        (None, {
            'classes': ('wide',),
            'fields': ('username', 'password1', 'password2' ),
        }),
        (_('Account type'), {'fields': ('is_owner', 'is_client')}),
    )

    model = SiteUser
    # fields = UserAdmin.fields + ['is_owner', 'is_client']
    list_display = ['id', 'username', 'email', 'date_joined', 'is_owner', 'is_client', ]
    list_display_links = ('username',)

А точно, там же fieldsets, одновременно нельзя определять fieldsets и fields. Ну ок ))

а зачем в вашем коде вот эти строки????

class EmailBlackListEntryAdmin(admin.ModelAdmin):
    search_fields = ['email']

??????

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

Comments

Only authorized users can post comments.
Please, Log in or Sign up
Timeweb

Let me recommend you the excellent hosting on which EVILEG is located.

For many years, Timeweb has been proving his stability.

For projects on Django I recommend VDS hosting

View Hosting
T

C++ - Тест 003. Условия и циклы

  • Result:57points,
  • Rating points-2
TG

C++ - Test 001. The first program and data types

  • Result:53points,
  • Rating points-4
TG

C++ - Test 001. The first program and data types

  • Result:60points,
  • Rating points-1
Last comments
t
  • t1m4
  • Jan. 23, 2021, 8:28 a.m.

Django - Tutorial 052. Redefining a User Model

Добрый день, Я вот написал в admin.py admin.site.register(User, UserAdmin) Но у меня не появилось новые поля в админке?

Django - Tutorial 001. Deploying a site on Django + PostgreSQL + Gunicorn + Nginx

Ошибка в конфиге инжинкса про статику в root последний слеш лишний путь в таком виде получается /home/user/myprojectenv/myproject/myproject//static
  • Jurij
  • Jan. 20, 2021, 1:34 p.m.

Qt/C++ - Lesson 061. Adding images to the application using the Drag And Drop method from the file manager

// Вместо отрисовки иконки и текста будем отрисовывать только одно изображение // с небольшими отступами в 5 пикселей QPixmap pix(m_model->data(index).toString()); …
m
  • magrif
  • Jan. 19, 2021, 12:37 p.m.

Qt Сертификация

Здравствуйте. Подскажите, оплачивать ваучер прямо в выбранном тестовом центре? Можно ли загранник предъявить? Или свой паспорт, а заполнить транслитом? А то там пишут: Your name must exactl…
r
  • retmas
  • Jan. 17, 2021, 4:09 a.m.

Qt/C++ - Tutorial 074. Generating pseudo-random numbers, using STD library random

Дмитрий, решает. Просто автор, видимо, не сильно озаботился изучением документации QRandomGenerator. Да и в листинге с использованием qrand вызов функции qsrand на каждой итерации цикла нав…
Now discuss on the forum
p

Как поменять шаг оси с числового формата на текстовый

онлайн казино Пин Ап официальный сайт играть на деньги или бесплатно без регистрации
S

Добавление данных в модель из textEdit

Котов писать жалко, да что поделать - приходится) Вот мне пока не шибко понятно как именно при внесении новых данных обновлять модель, как мне заставить TableView отображать обновленные дан…
F

QScrollArea dynamically add QCheckBoxes

http://dostavshik.ml/
IP
T

AbstractListModel использование в нескольких элементах

Разобрался. Извиняюсь за беспокойство. Я просто не поставил "model." перед переменными. Делаю рефакторинг под abstractModel, раньше модель была в QML и как то прокатывала без этого. На железе уж…
About
Services
© EVILEG 2015-2020
Recommend hosting TIMEWEB