mirror of https://github.com/tiangolo/fastapi.git
🚸 Set format to password for fields `password` and `client_secret` in `OAuth2PasswordRequestForm`, make docs show password fields for passwords (#11032)
Co-authored-by: pre-commit-ci[bot] <66853113+pre-commit-ci[bot]@users.noreply.github.com>
This commit is contained in:
parent
6b5b26fa61
commit
30b9dfb11c
|
|
@ -85,7 +85,7 @@ class OAuth2PasswordRequestForm:
|
||||||
],
|
],
|
||||||
password: Annotated[
|
password: Annotated[
|
||||||
str,
|
str,
|
||||||
Form(),
|
Form(json_schema_extra={"format": "password"}),
|
||||||
Doc(
|
Doc(
|
||||||
"""
|
"""
|
||||||
`password` string. The OAuth2 spec requires the exact field name
|
`password` string. The OAuth2 spec requires the exact field name
|
||||||
|
|
@ -130,7 +130,7 @@ class OAuth2PasswordRequestForm:
|
||||||
] = None,
|
] = None,
|
||||||
client_secret: Annotated[
|
client_secret: Annotated[
|
||||||
Union[str, None],
|
Union[str, None],
|
||||||
Form(),
|
Form(json_schema_extra={"format": "password"}),
|
||||||
Doc(
|
Doc(
|
||||||
"""
|
"""
|
||||||
If there's a `client_password` (and a `client_id`), they can be sent
|
If there's a `client_password` (and a `client_id`), they can be sent
|
||||||
|
|
|
||||||
|
|
@ -163,7 +163,11 @@ def test_openapi_schema(client: TestClient):
|
||||||
}
|
}
|
||||||
),
|
),
|
||||||
"username": {"title": "Username", "type": "string"},
|
"username": {"title": "Username", "type": "string"},
|
||||||
"password": {"title": "Password", "type": "string"},
|
"password": {
|
||||||
|
"title": "Password",
|
||||||
|
"type": "string",
|
||||||
|
"format": "password",
|
||||||
|
},
|
||||||
"scope": {"title": "Scope", "type": "string", "default": ""},
|
"scope": {"title": "Scope", "type": "string", "default": ""},
|
||||||
"client_id": IsDict(
|
"client_id": IsDict(
|
||||||
{
|
{
|
||||||
|
|
@ -179,11 +183,16 @@ def test_openapi_schema(client: TestClient):
|
||||||
{
|
{
|
||||||
"title": "Client Secret",
|
"title": "Client Secret",
|
||||||
"anyOf": [{"type": "string"}, {"type": "null"}],
|
"anyOf": [{"type": "string"}, {"type": "null"}],
|
||||||
|
"format": "password",
|
||||||
}
|
}
|
||||||
)
|
)
|
||||||
| IsDict(
|
| IsDict(
|
||||||
# TODO: remove when deprecating Pydantic v1
|
# TODO: remove when deprecating Pydantic v1
|
||||||
{"title": "Client Secret", "type": "string"}
|
{
|
||||||
|
"title": "Client Secret",
|
||||||
|
"type": "string",
|
||||||
|
"format": "password",
|
||||||
|
}
|
||||||
),
|
),
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
|
|
|
||||||
|
|
@ -377,7 +377,11 @@ def test_openapi_schema(mod: ModuleType):
|
||||||
}
|
}
|
||||||
),
|
),
|
||||||
"username": {"title": "Username", "type": "string"},
|
"username": {"title": "Username", "type": "string"},
|
||||||
"password": {"title": "Password", "type": "string"},
|
"password": {
|
||||||
|
"title": "Password",
|
||||||
|
"type": "string",
|
||||||
|
"format": "password",
|
||||||
|
},
|
||||||
"scope": {"title": "Scope", "type": "string", "default": ""},
|
"scope": {"title": "Scope", "type": "string", "default": ""},
|
||||||
"client_id": IsDict(
|
"client_id": IsDict(
|
||||||
{
|
{
|
||||||
|
|
@ -393,11 +397,16 @@ def test_openapi_schema(mod: ModuleType):
|
||||||
{
|
{
|
||||||
"title": "Client Secret",
|
"title": "Client Secret",
|
||||||
"anyOf": [{"type": "string"}, {"type": "null"}],
|
"anyOf": [{"type": "string"}, {"type": "null"}],
|
||||||
|
"format": "password",
|
||||||
}
|
}
|
||||||
)
|
)
|
||||||
| IsDict(
|
| IsDict(
|
||||||
# TODO: remove when deprecating Pydantic v1
|
# TODO: remove when deprecating Pydantic v1
|
||||||
{"title": "Client Secret", "type": "string"}
|
{
|
||||||
|
"title": "Client Secret",
|
||||||
|
"type": "string",
|
||||||
|
"format": "password",
|
||||||
|
}
|
||||||
),
|
),
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue