我试图对秘密字符串施加限制。例如,如果可以的话,我想要这样的东西:
from pydantic import constr, SecretStr
class SimpleModel(BaseModel):
password: (SecretStr, constr(min_length=8, max_length=32))
Run Code Online (Sandbox Code Playgroud)
如果可以做一些事情来实现这一点,我的下一个问题将是:我还可以添加一个需要非单词字符的约束吗?我可以自己进行正则表达式检查,但我正在尝试pydantic
更全面地采用。
SecretStr
目前这是不可能的。在提交 PR 之前,您可以使用验证器来实现相同的行为:
import re
from pydantic import AnyStrMinLengthError, AnyStrMaxLengthError, BaseModel, SecretStr, StrRegexError, validator
class SimpleModel(BaseModel):
password: SecretStr
@validator('password')
def has_min_length(cls, v):
min_length = 8
if len(v.get_secret_value()) < min_length:
raise AnyStrMinLengthError(limit_value=min_length)
return v
@validator('password')
def has_max_length(cls, v):
max_length = 32
if len(v.get_secret_value()) > max_length:
raise AnyStrMaxLengthError(limit_value=max_length)
return v
@validator('password')
def matches_regex(cls, v):
regex = r'.*\W'
if not re.match(regex, v.get_secret_value()):
raise StrRegexError(pattern=regex)
return v
Run Code Online (Sandbox Code Playgroud)
归档时间: |
|
查看次数: |
3114 次 |
最近记录: |