python - 管理员在管理站点创建员工时随机生成密码
问题描述
我从 User 模型中继承了三个用户,即 Admin、Employee 和 Relative。
模型.py
config = RawConfigParser()
config.read('config.cfg')
class UserManager( BaseUserManager):
def _create_user(self, PAN_ID, password=None, **extra_fields):
"""
Creates and saves a User with the given email, date of
birth and password.
"""
if not PAN_ID:
raise ValueError('Users must have a PAN_ID')
extra_fields['email'] = self.normalize_email(extra_fields["email"])
user = self.model(PAN_ID=PAN_ID, **extra_fields)
user.set_password(password)
user.save(using=self._db)
return user
def create_user(self, PAN_ID, password=None, **extra_fields):
extra_fields.setdefault('is_staff', False)
extra_fields.setdefault('is_superuser', False)
return self._create_user(PAN_ID, password, **extra_fields)
def create_superuser(self, PAN_ID, password=None, **extra_fields):
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(PAN_ID, password, **extra_fields)
class User(AbstractBaseUser, PermissionsMixin):
PAN_ID = models.CharField(max_length=100, unique=True)
password = models.CharField(_('password'), max_length=128, null=False, blank=True)
email = models.EmailField(max_length=100, unique=True, blank=True)
date_joined = models.DateTimeField(auto_now_add=True)
name = models.CharField( max_length=60, blank=True)
address = models.CharField(max_length=70, null=True, blank=True)
holding = models.CharField(max_length=100, null=True, blank=True)
is_staff = models.BooleanField(
_('staff status'),
default=True,
help_text=_(
'Designates whether the user can log into this admin site.'),
)
is_active = models.BooleanField(
_('active'),
default=True,
help_text=_(
'Designates whether this user should be treated as active. '
'Unselect this instead of deleting accounts.'
),
)
objects = UserManager()
USERNAME_FIELD = "PAN_ID"
EMAIL_FIELD = "email"
REQUIRED_FIELDS = ['email', 'name', 'holding']
class Admin(User):
pass
class Employee(User):
designation = models.CharField(max_length=89, null=True)
class Relative(User):
reference = models.OneToOneField(to=User, on_delete=models.CASCADE, related_name="creator")
管理员.py
from django.contrib import admin
from base.models import Admin, Employee, Relative, User
from django import forms
from django.contrib.auth.models import Group
from mass import settings
from django.core.mail import send_mail
from abc import ABC
from django.utils import timezone
from django.dispatch.dispatcher import receiver
from django.db.models.signals import post_save
@receiver(post_save, sender=Employee)
@receiver(post_save, sender=Relative)
def mail(sender,instance, *args, **kwargs ):
subject = "Hi"
message = f"Your password is {instance.password} "
from_email = None
recipient_list = [instance.email]
send_mail(subject, message, from_email, recipient_list, fail_silently=False, auth_user=None, auth_password=None, connection=None, html_message=None)
class RandomPasswordAndEmailMixin:
def save(self, commit=True):
if not self.instance.pk:
instance = super().save(commit=False)
instance.set_password(User.objects.make_random_password())
return instance.save()
else:
self.cleaned_data.pop("password")
return super.save(commit)
class UserModelForm(forms.ModelForm):
class Meta:
exclude = ('is_staff', 'is_active', 'password')
class EmployeeModelForm(RandomPasswordAndEmailMixin, UserModelForm):
class Meta(UserModelForm.Meta):
model = Employee
@admin.register(Employee)
class EmployeeModelAdmin(admin.ModelAdmin, RandomPasswordAndEmailMixin):
form = EmployeeModelForm
管理员将是超级用户。管理员将转到管理站点并对员工和亲属执行 CRUD。在表单中,我只想让管理员输入员工/亲属的用户名(PAN_ID)、密码和电子邮件。单击“保存”后,应发送邮件的相应信号并发送电子邮件,以便在邮件功能中可以访问密码。密码应该由 make_password 自动生成。我收到以下错误。
内部服务器错误:/admin/base/employee/add/ Traceback(最近一次调用最后一次):文件“C:\Users\Dell\OneDrive\Desktop\djangodev\venv\lib\site-packages\django\core\handlers\ exception.py”,第 47 行,内部响应 = get_response(request) 文件“C:\Users\Dell\OneDrive\Desktop\djangodev\venv\lib\site-packages\django\core\handlers\base.py”,第 179 行,在 _get_response response = Wrapped_callback(request, *callback_args, **callback_kwargs) 文件“C:\Users\Dell\OneDrive\Desktop\djangodev\venv\lib\site-packages\django\contrib\admin\options.py ",第 614 行,在包装器中返回 self.admin_site.admin_view(view)(*args, **kwargs) 文件 "C:\Users\Dell\OneDrive\Desktop\djangodev\venv\lib\site-packages\django\utils \decorators.py”,第 130 行,在 _wrapped_view response = view_func(request, *args, **kwargs) 文件“C:\Users\Dell\OneDrive\Desktop\djangodev\venv\lib\site-packages\django\views\decorators\cache.py”,第 44 行,在 _wrapped_view_func 响应 = view_func(request, *args, **kwargs) 文件“ C:\Users\Dell\OneDrive\Desktop\djangodev\venv\lib\site-packages\django\contrib\admin\sites.py",第 233 行,内部返回视图(请求,*args,**kwargs)文件“C:\Users\Dell\OneDrive\Desktop\djangodev\venv\lib\site-packages\django\contrib\admin\options.py”,第 1653 行,在 add_view 返回 self.changeform_view(request, None, form_url, extra_context ) 文件“C:\Users\Dell\OneDrive\Desktop\djangodev\venv\lib\site-packages\django\utils\decorators.py”,第 43 行,在 _wrapper 返回 bound_method(*args, **kwargs) 文件“ C:\Users\Dell\OneDrive\Desktop\djangodev\venv\lib\site-packages\django\utils\decorators.py”,第 130 行,在 _wrapped_view 响应 = view_func(request, *args, **kwargs) 文件“C:\Users\Dell\OneDrive\Desktop\djangodev\venv\lib\site-packages\django\contrib\admin\options.py”,行1534, 在 changeform_view 返回 self._changeform_view(request, object_id, form_url, extra_context) 文件 "C:\Users\Dell\OneDrive\Desktop\djangodev\venv\lib\site-packages\django\contrib\admin\options.py" ,第 1580 行,在 _changeform_view self.save_model(request, new_object, form, not add) 文件“C:\Users\Dell\OneDrive\Desktop\djangodev\venv\lib\site-packages\django\contrib\admin\options. py",第 1093 行,在 save_model obj.save() AttributeError: 'NoneType' 对象没有属性 'save' [22/Jan/2021 15:13:17] "POST /admin/base/employee/add/ HTTP/ 1.1" 500 112227C:\Users\Dell\OneDrive\Desktop\djangodev\venv\lib\site-packages\django\contrib\admin\options.py",第 1534 行,在 changeform_view 返回 self._changeform_view(request, object_id, form_url, extra_context)文件“C:\Users\Dell\OneDrive\Desktop\djangodev\venv\lib\site-packages\django\contrib\admin\options.py”,第 1580 行,在 _changeform_view self.save_model(request, new_object, form, not添加)文件“C:\Users\Dell\OneDrive\Desktop\djangodev\venv\lib\site-packages\django\contrib\admin\options.py”,第 1093 行,在 save_model obj.save() AttributeError: 'NoneType '对象没有属性'保存' [22/Jan/2021 15:13:17] "POST /admin/base/employee/add/HTTP/1.1" 500 112227C:\Users\Dell\OneDrive\Desktop\djangodev\venv\lib\site-packages\django\contrib\admin\options.py",第 1534 行,在 changeform_view 返回 self._changeform_view(request, object_id, form_url, extra_context)文件“C:\Users\Dell\OneDrive\Desktop\djangodev\venv\lib\site-packages\django\contrib\admin\options.py”,第 1580 行,在 _changeform_view self.save_model(request, new_object, form, not添加)文件“C:\Users\Dell\OneDrive\Desktop\djangodev\venv\lib\site-packages\django\contrib\admin\options.py”,第 1093 行,在 save_model obj.save() AttributeError: 'NoneType '对象没有属性'保存' [22/Jan/2021 15:13:17] "POST /admin/base/employee/add/HTTP/1.1" 500 112227在 changeform_view 返回 self._changeform_view(request, object_id, form_url, extra_context) 文件“C:\Users\Dell\OneDrive\Desktop\djangodev\venv\lib\site-packages\django\contrib\admin\options.py”,行1580,在 _changeform_view self.save_model(request, new_object, form, not add) 文件“C:\Users\Dell\OneDrive\Desktop\djangodev\venv\lib\site-packages\django\contrib\admin\options.py” ,第 1093 行,在 save_model obj.save() AttributeError: 'NoneType' object has no attribute 'save' [22/Jan/2021 15:13:17] "POST /admin/base/employee/add/HTTP/1.1" 500 112227在 changeform_view 返回 self._changeform_view(request, object_id, form_url, extra_context) 文件“C:\Users\Dell\OneDrive\Desktop\djangodev\venv\lib\site-packages\django\contrib\admin\options.py”,行1580,在 _changeform_view self.save_model(request, new_object, form, not add) 文件“C:\Users\Dell\OneDrive\Desktop\djangodev\venv\lib\site-packages\django\contrib\admin\options.py” ,第 1093 行,在 save_model obj.save() AttributeError: 'NoneType' object has no attribute 'save' [22/Jan/2021 15:13:17] "POST /admin/base/employee/add/HTTP/1.1" 500 112227不添加)文件“C:\Users\Dell\OneDrive\Desktop\djangodev\venv\lib\site-packages\django\contrib\admin\options.py”,第 1093 行,在 save_model obj.save() AttributeError: ' NoneType' 对象没有属性 'save' [22/Jan/2021 15:13:17] "POST /admin/base/employee/add/HTTP/1.1" 500 112227不添加)文件“C:\Users\Dell\OneDrive\Desktop\djangodev\venv\lib\site-packages\django\contrib\admin\options.py”,第 1093 行,在 save_model obj.save() AttributeError: ' NoneType' 对象没有属性 'save' [22/Jan/2021 15:13:17] "POST /admin/base/employee/add/HTTP/1.1" 500 112227
解决方案
通过覆盖 ModelAdmin 子类的save_model
方法解决。文档: Django ModelAdmin save_model。为了使它可重用,我只是把它作为一个mixin。
class RandomPasswordAndEmailMixin:
def save_model(self, request, obj, form, change):
if not form.instance.pk:
user = form.save(commit=False)
user.set_password(User.objects.make_random_password(20))
user.save()
form.save_m2m()
super().save_model(request, obj, form, change)
@admin.register(Employee)
class EmployeeModelAdmin(RandomPasswordAndEmailMixin,admin.ModelAdmin):
exclude = ('is_staff', 'password')
推荐阅读
- php - 如何编写正则表达式以从文件中选择 php 中的重复模式
- javascript - Onclick 事件无法识别功能
- java - @Cacheput 的真实用例是什么?
- activemq-artemis - Artemis 崩溃,消息/队列丢失
- java - 通过 java 客户端使用呈现的页面链接
- xslt - 如何使用 XSLT 将字符串分成前后数字的两部分?
- php - 是否有一个 PHP 函数可以遍历关联数组并按公共值/键对其进行分组?
- ruby-on-rails - update_all 似乎不适用于儿童
- azure-web-app-service - 无法在 Web 应用服务的部署中心授权一个驱动器
- scikit-learn - SkikitLearn 学习曲线强烈依赖于 MLPClassifier 的批量大小???或者:如何诊断 NN 的偏差/方差?