質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

ただいまの
回答率

89.99%

Django modelでUSERNAME_FIELDの指定が分からない

解決済

回答 1

投稿

  • 評価
  • クリップ 0
  • VIEW 350

Malo

score 13

現在、チャットルームのようなアプリを作成しており、その開発途中で管理者画面からモデルを追加しようとすると、models.pyでエラーが起きてしまいます。エラー内容とコードが以下になります。

type object 'RoomModel' has no attribute 'USERNAME_FIELD'
type object 'ChatModel' has no attribute 'USERNAME_FIELD'
from django.db import models
from django.core.mail import send_mail
from django.contrib.auth.models import PermissionsMixin
from django.contrib.auth.base_user import AbstractBaseUser
from django.utils.translation import ugettext_lazy as _
from django.utils import timezone
from django.contrib.auth.base_user import BaseUserManager


### ユーザーモデルのカスタム
# ユーザーマネージャー
class UserManager(BaseUserManager):

    use_in_migrations = True    # クラスをRunPython操作で利用できるように

    def _create_user(self, email, password, first_name, last_name, username, **extra_fields):
        '''メールアドレスでの登録を必須に'''
        if not email:
            raise ValueError('メールアドレスの登録は必須です。')
        email = self.normalize_email(email)

        user = self.model(email=email, first_name=first_name, last_name=last_name, username=username, **extra_fields)
        user.set_password(password)
        user.save(using=self._db)
        return user

    def create_user(self, email, password=None, first_name=None, last_name=None, username=None, **extra_fields):
        '''管理者権限全般をFalseに'''
        extra_fields.setdefault('is_staff', False)
        extra_fields.setdefault('is_superuser', False)
        return self._create_user(email, password, **extra_fields)

    def create_superuser(self, email, password, **extra_fields):
        '''スーパーユーザーは管理者権限全般をTrueに'''
        extra_fields.setdefault('is_staff', True)
        extra_fields.setdefault('is_superuser', True)

        if extra_fields.get('is_staff') is not True:
            raise ValueError('Superuser must have is_staff=True.')
        if extra_fields.get('is_superuser') is not True:
            raise ValueError('Superuser must have is_superuser=True.')

        return self._create_user(email, password, **extra_fields)

# カスタマイズユーザーモデル
class User(AbstractBaseUser, PermissionsMixin):

    email = models.EmailField(_('email_address'), unique=True)    # ユーザーのメールアドレスは一意に
    first_name = models.CharField(_('first name'), max_length=30, blank=True)    # ユーザの実名(姓)
    last_name = models.CharField(_('last name'), max_length=100, blank=True)    # ユーザーの実名(名)
    username = models.CharField(_('user name'), max_length=100, blank=True)        # ユーザーのハンドルネーム
    is_prime = models.BooleanField(
        _('prime'),
        default=False,
        help_text=_(
            '実名登録による制限解除を行うかどうかを指定します。'
        ),
    )

    is_staff = models.BooleanField(
        _('staff_status'),
        default=False,
        help_text=_(
            'ユーザーが管理者画面にログイン出来るかを指定します。'),
    )
    is_active = models.BooleanField(
        _('active'),
        default=True,
        help_text=_(
            'このユーザーをアクティブとして扱うべきかどうかを指定します。'
            'アカウントを削除する代わりにこの選択を解除してください。'
        ),
    )
    date_joined = models.DateTimeField(_('data joined'), default=timezone.now)

    objects = UserManager()

    EMAIL_FIELD = 'email'
    USERNAME_FIELD = 'email'
    REQUIRED_FIELDS = []


class Meta:
    verbose_name = _('user')
    verbose_name_plural = _('users')

def get_full_name(self):
    '''Return the first_name plus the last_name, with a space in
    between.'''
    full_name = '%s %s' % (self.first_name, self.last_name)
    return full_name.strip()

def get_short_name(self):
    '''Return the short name for the user.'''
    return self.first_name

def email_user(self, subject, message, from_email=None, **kwargs):
    '''Send an email to this user.'''
    send_mail(subject, message, from_email, [self.email], **kwargs)

@property
def username(self):
    '''username属性のゲッター

    他アプリケーションが、username属性にアクセスした場合に備えて定義
    メールアドレスを返す
    '''
    return self.email


### 発言のデータモデル
class ChatModel(models.Model):
    content = models.TextField()                # 発言内容
    author = models.CharField(max_length=50)    # 発言者
    images = models.ImageField(upload_to='')    # 画像
    good = models.IntegerField(null=True, blank=True, default=0)    # いいね数
    good_users = models.TextField(null=True, blank=True, default='')# いいねしたユーザー


### ディスカッションルームのデータモデル
class RoomModel(models.Model):
    # id = models.AutoField(primary_ley=True, default=1)        # ルームID
    title = models.CharField(max_length=30)                    # ルーム名
    author = models.CharField(max_length=50)    # 設立者
    images    = models.ImageField(upload_to='')    # 画像
    positions = models.CharField(max_length=100)# 立場

ユーザーはメールアドレスによって一意に識別されるようにしています。
USERNAME_FIELDはどのように指定すればよいのでしょうか?

初学者ゆえ足りない情報もあると思います。ご指摘いただければ随時追記させていただきます。
よろしくおねがいします。

  • 気になる質問をクリップする

    クリップした質問は、後からいつでもマイページで確認できます。

    またクリップした質問に回答があった際、通知やメールを受け取ることができます。

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

回答 1

checkベストアンサー

0

パッと拝見した印象では、どちらかというと ModelAdmin の設定の方に誤りがあるのではないかと思います。

というコメントだけで解決に至りそうであればご解決いただいて、そうでなければ管理画面の設定( admin.py ?)のコードをご提示いただくと何かしら問題解決に繋がるコメントがさせていただけるものと思います。

(本題とは関係無いように思いますが、ご提示のコードの class Meta: あたりのインデントがずれているような気がするので、見直してみてください)

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2019/07/20 18:38

    ご回答ありがとうございます。
    ご指摘にあったように、admin.pyを見直したところ、admin.site.registerの引数に問題があったようで、無事解決しました。

    キャンセル

15分調べてもわからないことは、teratailで質問しよう!

  • ただいまの回答率 89.99%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる