當前位置: 首頁>>代碼示例>>Python>>正文


Python password_validation.validate_password方法代碼示例

本文整理匯總了Python中django.contrib.auth.password_validation.validate_password方法的典型用法代碼示例。如果您正苦於以下問題:Python password_validation.validate_password方法的具體用法?Python password_validation.validate_password怎麽用?Python password_validation.validate_password使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在django.contrib.auth.password_validation的用法示例。


在下文中一共展示了password_validation.validate_password方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。

示例1: create

# 需要導入模塊: from django.contrib.auth import password_validation [as 別名]
# 或者: from django.contrib.auth.password_validation import validate_password [as 別名]
def create(self, request, *args, **kwargs):
        serializer = self.get_serializer(data=request.data)
        serializer.is_valid(raise_exception=True)

        token = serializer.validated_data["token"]
        password = serializer.validated_data["password"]

        password_validation.validate_password(password)
        email = PasswordReset.validate_reset_token(token)

        try:
            user = User.objects.get(email__iexact=email)
        except User.DoesNotExist:
            raise ValidationError({"email": "User with that email does not exist"})

        user.set_password(password)
        user.save()
        return Response(DetailedUserSerializer(user).data, status=status.HTTP_200_OK) 
開發者ID:webkom,項目名稱:lego,代碼行數:20,代碼來源:password_reset.py

示例2: validate_new_password

# 需要導入模塊: from django.contrib.auth import password_validation [as 別名]
# 或者: from django.contrib.auth.password_validation import validate_password [as 別名]
def validate_new_password(self, password):
        user = self.context['request'].user
        validate_password(password, user=user)

        username = user.username
        if len(username) and username.casefold() in password.casefold():
            raise serializers.ValidationError(
                _("The password is too similar to the username."))

        phone = user.phone
        if phone and phone_validator(phone):
            phone = str(parse_phone(phone).national_number)
            if phone in password:
                raise serializers.ValidationError(
                    _("Passwords cannot contain your phone."))

        return password 
開發者ID:Cadasta,項目名稱:cadasta-platform,代碼行數:19,代碼來源:serializers.py

示例3: validate_password

# 需要導入模塊: from django.contrib.auth import password_validation [as 別名]
# 或者: from django.contrib.auth.password_validation import validate_password [as 別名]
def validate_password(self, password):
        user = self.context['request'].user
        validate_password(password, user=user)
        return password 
開發者ID:apragacz,項目名稱:django-rest-registration,代碼行數:6,代碼來源:change_password.py

示例4: post

# 需要導入模塊: from django.contrib.auth import password_validation [as 別名]
# 或者: from django.contrib.auth.password_validation import validate_password [as 別名]
def post(self, request):
        messages = {"invalid_password": None, "password_validations": None, "success": None, "other": None, "mismatched": None}
        try:
            user = request.user
            old_password = request.POST.get("old_password")
            new_password = request.POST.get("new_password")
            new_password2 = request.POST.get("new_password2")
            if user.check_password(old_password) == False:
                messages["invalid_password"] = _("Invalid password")
            if new_password != new_password2:
                messages["mismatched"] = _("New password and confirmation must match")
            try:
                validation.validate_password(new_password, user)
            except ValidationError as val_err:
                messages["password_validations"] = val_err.messages

            if messages["invalid_password"] is None and messages["password_validations"] is None and messages["mismatched"] is None:
                user.set_password(new_password)
                user.save()
                authenticated_user = authenticate(username=user.username, password=new_password)
                login(request, authenticated_user)
                messages["success"] = _("Password successfully updated")

        except Exception as err:
            messages["other"] = err

        return JSONResponse(messages) 
開發者ID:archesproject,項目名稱:arches,代碼行數:29,代碼來源:auth.py

示例5: validate_password

# 需要導入模塊: from django.contrib.auth import password_validation [as 別名]
# 或者: from django.contrib.auth.password_validation import validate_password [as 別名]
def validate_password(self, value):
        if value is not None:
            validate_password(value)
        return value 
開發者ID:desec-io,項目名稱:desec-stack,代碼行數:6,代碼來源:serializers.py

示例6: validate

# 需要導入模塊: from django.contrib.auth import password_validation [as 別名]
# 或者: from django.contrib.auth.password_validation import validate_password [as 別名]
def validate(self, data):
        """Verify passwords match."""
        passwd = data['password']
        passwd_conf = data['password_confirmation']
        if passwd != passwd_conf:
            raise serializers.ValidationError("Passwords don't match.")
        password_validation.validate_password(passwd)
        return data 
開發者ID:pablotrinidad,項目名稱:cride-platzi,代碼行數:10,代碼來源:users.py

示例7: test_change_password

# 需要導入模塊: from django.contrib.auth import password_validation [as 別名]
# 或者: from django.contrib.auth.password_validation import validate_password [as 別名]
def test_change_password(self) -> None:
        now = timezone_now()
        user = self.example_user('hamlet')
        password = 'test1'
        do_change_password(user, password)
        self.assertEqual(RealmAuditLog.objects.filter(event_type=RealmAuditLog.USER_PASSWORD_CHANGED,
                                                      event_time__gte=now).count(), 1)
        self.assertIsNone(validate_password(password, user)) 
開發者ID:zulip,項目名稱:zulip,代碼行數:10,代碼來源:test_audit_log.py

示例8: validate_password

# 需要導入模塊: from django.contrib.auth import password_validation [as 別名]
# 或者: from django.contrib.auth.password_validation import validate_password [as 別名]
def validate_password(self, value):
        user = self.context["request"].user
        if user.has_usable_password() and not user.check_password(value):
            raise serializers.ValidationError(self.error_messages["invalid_password"])
        return value 
開發者ID:webkom,項目名稱:lego,代碼行數:7,代碼來源:password_change.py

示例9: validate_new_password

# 需要導入模塊: from django.contrib.auth import password_validation [as 別名]
# 或者: from django.contrib.auth.password_validation import validate_password [as 別名]
def validate_new_password(self, password):
        if password:
            password_validation.validate_password(password)
        return password 
開發者ID:webkom,項目名稱:lego,代碼行數:6,代碼來源:password_change.py

示例10: validate_password

# 需要導入模塊: from django.contrib.auth import password_validation [as 別名]
# 或者: from django.contrib.auth.password_validation import validate_password [as 別名]
def validate_password(self, password):
        password_validation.validate_password(password)
        return password 
開發者ID:webkom,項目名稱:lego,代碼行數:5,代碼來源:registration.py

示例11: clean_password2

# 需要導入模塊: from django.contrib.auth import password_validation [as 別名]
# 或者: from django.contrib.auth.password_validation import validate_password [as 別名]
def clean_password2(self):
        # Check that the two password entries match
        password1 = self.cleaned_data.get("password1")
        password2 = self.cleaned_data.get("password2")
        if password1 and password2 and password1 != password2:
            raise forms.ValidationError("Passwords don't match")
        #self.instance.username = self.cleaned_data.get('email')
        #password_validation.validate_password(self.cleaned_data.get['password2'],self.instance)
        return password2 
開發者ID:cc0411,項目名稱:devops,代碼行數:11,代碼來源:admin.py

示例12: validate_password

# 需要導入模塊: from django.contrib.auth import password_validation [as 別名]
# 或者: from django.contrib.auth.password_validation import validate_password [as 別名]
def validate_password(self, password):
        validate_password(password)

        errors = []
        email = self.initial_data.get('email')
        if email:
            email = email.split('@')
            if email[0].casefold() in password.casefold():
                errors.append(_("Passwords cannot contain your email."))

        username = self.initial_data.get('username')
        if len(username) and username.casefold() in password.casefold():
            errors.append(
                _("The password is too similar to the username."))

        phone = self.initial_data.get('phone')
        if phone:
            if phone_validator(phone):
                try:
                    phone = str(parse_phone(phone).national_number)
                    if phone in password:
                        errors.append(
                            _("Passwords cannot contain your phone."))
                except NumberParseException:
                    pass
        if errors:
            raise serializers.ValidationError(errors)

        return password 
開發者ID:Cadasta,項目名稱:cadasta-platform,代碼行數:31,代碼來源:serializers.py

示例13: __call__

# 需要導入模塊: from django.contrib.auth import password_validation [as 別名]
# 或者: from django.contrib.auth.password_validation import validate_password [as 別名]
def __call__(self, value):
        """Call method, run django's validate_password method."""
        return validate_password(value) 
開發者ID:pawamoy,項目名稱:django-zxcvbn-password,代碼行數:5,代碼來源:fields.py

示例14: create

# 需要導入模塊: from django.contrib.auth import password_validation [as 別名]
# 或者: from django.contrib.auth.password_validation import validate_password [as 別名]
def create(self, validated_data):
        user_data = validated_data.pop('user')

        errors = {}
        if 'username' not in user_data:
            errors['username'] = ['This field is required.']

        if 'password' not in user_data:
            errors['password'] = ['This field is required.']

        if len(errors) > 0:
            raise serializers.ValidationError(errors)

        if 'timezone' not in validated_data:
            validated_data['timezone'] = 'UTC'

        if validated_data['timezone'] not in pytz.all_timezones:
            raise serializers.ValidationError({'timezone': ['Not a valid choice.']})

        password = user_data.pop('password')
        try:
            password_validation.validate_password(password=password, user=User)
        except exceptions.ValidationError as e:
            raise serializers.ValidationError({'password': [e.message]})

        user = User.objects.create(**user_data)
        user.set_password(password)
        user.save()

        return SciriusUser.objects.create(user=user, **validated_data) 
開發者ID:StamusNetworks,項目名稱:scirius,代碼行數:32,代碼來源:rest_api.py

示例15: validate_new_password

# 需要導入模塊: from django.contrib.auth import password_validation [as 別名]
# 或者: from django.contrib.auth.password_validation import validate_password [as 別名]
def validate_new_password(self, password):
        try:
            password_validation.validate_password(password=password, user=User)
        except exceptions.ValidationError as e:
            raise serializers.ValidationError({'password': [unicode(e)]})
        return password 
開發者ID:StamusNetworks,項目名稱:scirius,代碼行數:8,代碼來源:rest_api.py


注:本文中的django.contrib.auth.password_validation.validate_password方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。