ConfigDict#

class caf.toolkit.translation.ConfigDict#

A TypedDict for configuring Pydantic behaviour.

Attributes

title

The title for the generated JSON schema, defaults to the model's name

model_title_generator

A callable that takes a model class and returns the title for it.

field_title_generator

A callable that takes a field's name and info and returns title for it.

str_to_lower

Whether to convert all characters to lowercase for str types.

str_to_upper

Whether to convert all characters to uppercase for str types.

str_strip_whitespace

Whether to strip leading and trailing whitespace for str types.

str_min_length

The minimum length for str types.

str_max_length

The maximum length for str types.

extra

Whether to ignore, allow, or forbid extra data during model initialization.

frozen

Whether models are faux-immutable, i.e. whether __setattr__ is allowed, and also generates a __hash__() method for the model.

populate_by_name

Whether an aliased field may be populated by its name as given by the model attribute, as well as the alias.

use_enum_values

Whether to populate models with the value property of enums, rather than the raw enum.

validate_assignment

Whether to validate the data when the model is changed.

arbitrary_types_allowed

Whether arbitrary types are allowed for field types.

from_attributes

Whether to build models and look up discriminators of tagged unions using python object attributes.

loc_by_alias

Whether to use the actual key provided in the data (e.g. alias) for error `loc`s rather than the field's name.

alias_generator

A callable that takes a field name and returns an alias for it or an instance of [AliasGenerator][pydantic.aliases.AliasGenerator].

ignored_types

A tuple of types that may occur as values of class attributes without annotations.

allow_inf_nan

Whether to allow infinity (+inf an -inf) and NaN values to float and decimal fields.

json_schema_extra

A dict or callable to provide extra JSON schema properties.

json_encoders

A dict of custom JSON encoders for specific types.

strict

Whether strict validation is applied to all fields on the model.

revalidate_instances

When and how to revalidate models and dataclasses during validation.

ser_json_timedelta

The format of JSON serialized timedeltas.

ser_json_temporal

The format of JSON serialized temporal types from the [datetime][] module.

val_temporal_unit

The unit to assume for validating numeric input for datetime-like types ([datetime.datetime][] and [datetime.date][]).

ser_json_bytes

The encoding of JSON serialized bytes.

val_json_bytes

The encoding of JSON serialized bytes to decode.

ser_json_inf_nan

The encoding of JSON serialized infinity and NaN float values.

validate_default

Whether to validate default values during validation.

validate_return

Whether to validate the return value from call validators.

protected_namespaces

A tuple of strings and/or regex patterns that prevent models from having fields with names that conflict with its existing members/methods.

hide_input_in_errors

Whether to hide inputs when printing errors.

defer_build

Whether to defer model validator and serializer construction until the first model validation.

plugin_settings

A dict of settings for plugins.

schema_generator

The GenerateSchema class to use during core schema generation.

json_schema_serialization_defaults_required

Whether fields with default values should be marked as required in the serialization schema.

json_schema_mode_override

If not None, the specified mode will be used to generate the JSON schema regardless of what mode was passed to the function call.

coerce_numbers_to_str

If True, enables automatic coercion of any Number type to str in "lax" (non-strict) mode.

regex_engine

The regex engine to be used for pattern validation.

validation_error_cause

If True, Python exceptions that were part of a validation failure will be shown as an exception group as a cause.

use_attribute_docstrings

Whether docstrings of attributes (bare string literals immediately following the attribute declaration) should be used for field descriptions.

cache_strings

Whether to cache strings to avoid constructing new Python objects.

validate_by_alias

Whether an aliased field may be populated by its alias.

validate_by_name

Whether an aliased field may be populated by its name as given by the model attribute.

serialize_by_alias

Whether an aliased field should be serialized by its alias.

url_preserve_empty_path

Whether to preserve empty URL paths when validating values for a URL type.

Methods

__init__(*args, **kwargs)

clear()

copy()

fromkeys(iterable[, value])

Create a new dictionary with keys from iterable and values set to value.

get(key[, default])

Return the value for key if key is in the dictionary, else default.

items()

keys()

pop(k[,d])

If the key is not found, return the default if given; otherwise, raise a KeyError.

popitem()

Remove and return a (key, value) pair as a 2-tuple.

setdefault(key[, default])

Insert key with a value of default if key is not in the dictionary.

update([E, ]**F)

If E is present and has a .keys() method, then does: for k in E: D[k] = E[k] If E is present and lacks a .keys() method, then does: for k, v in E: D[k] = v In either case, this is followed by: for k in F: D[k] = F[k]

values()

Attributes Documentation

title: str | None#

The title for the generated JSON schema, defaults to the model’s name

model_title_generator: Callable[[type], str] | None#

A callable that takes a model class and returns the title for it. Defaults to None.

field_title_generator: Callable[[str, FieldInfo | ComputedFieldInfo], str] | None#

A callable that takes a field’s name and info and returns title for it. Defaults to None.

str_to_lower: bool#

Whether to convert all characters to lowercase for str types. Defaults to False.

str_to_upper: bool#

Whether to convert all characters to uppercase for str types. Defaults to False.

str_strip_whitespace: bool#

Whether to strip leading and trailing whitespace for str types.

str_min_length: int#

The minimum length for str types. Defaults to None.

str_max_length: int | None#

The maximum length for str types. Defaults to None.

extra: ExtraValues | None#

Whether to ignore, allow, or forbid extra data during model initialization. Defaults to ‘ignore’.

Three configuration values are available:

  • ‘ignore’: Providing extra data is ignored (the default): ```python from pydantic import BaseModel, ConfigDict

    class User(BaseModel):

    model_config = ConfigDict(extra=’ignore’) # (1)!

    name: str

    user = User(name=’John Doe’, age=20) # (2)! print(user) #> name=’John Doe’ ```

    1. This is the default behaviour.

    2. The age argument is ignored.

  • ‘forbid’: Providing extra data is not permitted, and a [ValidationError][pydantic_core.ValidationError] will be raised if this is the case: ```python from pydantic import BaseModel, ConfigDict, ValidationError

    class Model(BaseModel):

    x: int

    model_config = ConfigDict(extra=’forbid’)

    try:

    Model(x=1, y=’a’)

    except ValidationError as exc:

    print(exc) “”” 1 validation error for Model y

    Extra inputs are not permitted [type=extra_forbidden, input_value=’a’, input_type=str]

    “””

    ```

  • ‘allow’: Providing extra data is allowed and stored in the __pydantic_extra__ dictionary attribute: ```python from pydantic import BaseModel, ConfigDict

    class Model(BaseModel):

    x: int

    model_config = ConfigDict(extra=’allow’)

    m = Model(x=1, y=’a’) assert m.__pydantic_extra__ == {‘y’: ‘a’} ``` By default, no validation will be applied to these extra items, but you can set a type for the values by overriding the type annotation for __pydantic_extra__: ```python from pydantic import BaseModel, ConfigDict, Field, ValidationError

    class Model(BaseModel):

    __pydantic_extra__: dict[str, int] = Field(init=False) # (1)!

    x: int

    model_config = ConfigDict(extra=’allow’)

    try:

    Model(x=1, y=’a’)

    except ValidationError as exc:

    print(exc) “”” 1 validation error for Model y

    Input should be a valid integer, unable to parse string as an integer [type=int_parsing, input_value=’a’, input_type=str]

    “””

    m = Model(x=1, y=’2’) assert m.x == 1 assert m.y == 2 assert m.model_dump() == {‘x’: 1, ‘y’: 2} assert m.__pydantic_extra__ == {‘y’: 2} ```

    1. The = Field(init=False) does not have any effect at runtime, but prevents the __pydantic_extra__ field from being included as a parameter to the model’s __init__ method by type checkers.

As well as specifying an extra configuration value on the model, you can also provide it as an argument to the validation methods. This will override any extra configuration value set on the model: ```python from pydantic import BaseModel, ConfigDict, ValidationError

class Model(BaseModel):

x: int model_config = ConfigDict(extra=”allow”)

try:

# Override model config and forbid extra fields just this time Model.model_validate({“x”: 1, “y”: 2}, extra=”forbid”)

except ValidationError as exc:

print(exc) “”” 1 validation error for Model y

Extra inputs are not permitted [type=extra_forbidden, input_value=2, input_type=int]

“””

```

frozen: bool#

Whether models are faux-immutable, i.e. whether __setattr__ is allowed, and also generates a __hash__() method for the model. This makes instances of the model potentially hashable if all the attributes are hashable. Defaults to False.

Note:

On V1, the inverse of this setting was called allow_mutation, and was True by default.

populate_by_name: bool#

Whether an aliased field may be populated by its name as given by the model attribute, as well as the alias. Defaults to False.

!!! warning

populate_by_name usage is not recommended in v2.11+ and will be deprecated in v3. Instead, you should use the [validate_by_name][pydantic.config.ConfigDict.validate_by_name] configuration setting.

When validate_by_name=True and validate_by_alias=True, this is strictly equivalent to the previous behavior of populate_by_name=True.

In v2.11, we also introduced a [validate_by_alias][pydantic.config.ConfigDict.validate_by_alias] setting that introduces more fine grained control for validation behavior.

Here’s how you might go about using the new settings to achieve the same behavior:

```python from pydantic import BaseModel, ConfigDict, Field

class Model(BaseModel):

model_config = ConfigDict(validate_by_name=True, validate_by_alias=True)

my_field: str = Field(alias=’my_alias’) # (1)!

m = Model(my_alias=’foo’) # (2)! print(m) #> my_field=’foo’

m = Model(my_field=’foo’) # (3)! print(m) #> my_field=’foo’ ```

  1. The field ‘my_field’ has an alias ‘my_alias’.

  2. The model is populated by the alias ‘my_alias’.

  3. The model is populated by the attribute name ‘my_field’.

use_enum_values: bool#

Whether to populate models with the value property of enums, rather than the raw enum. This may be useful if you want to serialize model.model_dump() later. Defaults to False.

!!! note

If you have an Optional[Enum] value that you set a default for, you need to use validate_default=True for said Field to ensure that the use_enum_values flag takes effect on the default, as extracting an enum’s value occurs during validation, not serialization.

```python from enum import Enum from typing import Optional

from pydantic import BaseModel, ConfigDict, Field

class SomeEnum(Enum):

FOO = ‘foo’ BAR = ‘bar’ BAZ = ‘baz’

class SomeModel(BaseModel):

model_config = ConfigDict(use_enum_values=True)

some_enum: SomeEnum another_enum: Optional[SomeEnum] = Field(

default=SomeEnum.FOO, validate_default=True

)

model1 = SomeModel(some_enum=SomeEnum.BAR) print(model1.model_dump()) #> {‘some_enum’: ‘bar’, ‘another_enum’: ‘foo’}

model2 = SomeModel(some_enum=SomeEnum.BAR, another_enum=SomeEnum.BAZ) print(model2.model_dump()) #> {‘some_enum’: ‘bar’, ‘another_enum’: ‘baz’} ```

validate_assignment: bool#

Whether to validate the data when the model is changed. Defaults to False.

The default behavior of Pydantic is to validate the data when the model is created.

In case the user changes the data after the model is created, the model is _not_ revalidated.

```python from pydantic import BaseModel

class User(BaseModel):

name: str

user = User(name=’John Doe’) # (1)! print(user) #> name=’John Doe’ user.name = 123 # (1)! print(user) #> name=123 ```

  1. The validation happens only when the model is created.

  2. The validation does not happen when the data is changed.

In case you want to revalidate the model when the data is changed, you can use validate_assignment=True:

```python from pydantic import BaseModel, ValidationError

class User(BaseModel, validate_assignment=True): # (1)!

name: str

user = User(name=’John Doe’) # (2)! print(user) #> name=’John Doe’ try:

user.name = 123 # (3)!

except ValidationError as e:

print(e) ‘’’ 1 validation error for User name

Input should be a valid string [type=string_type, input_value=123, input_type=int]

‘’’

```

  1. You can either use class keyword arguments, or model_config to set validate_assignment=True.

  2. The validation happens when the model is created.

  3. The validation _also_ happens when the data is changed.

arbitrary_types_allowed: bool#

Whether arbitrary types are allowed for field types. Defaults to False.

```python from pydantic import BaseModel, ConfigDict, ValidationError

# This is not a pydantic model, it’s an arbitrary class class Pet:

def __init__(self, name: str):

self.name = name

class Model(BaseModel):

model_config = ConfigDict(arbitrary_types_allowed=True)

pet: Pet owner: str

pet = Pet(name=’Hedwig’) # A simple check of instance type is used to validate the data model = Model(owner=’Harry’, pet=pet) print(model) #> pet=<__main__.Pet object at 0x0123456789ab> owner=’Harry’ print(model.pet) #> <__main__.Pet object at 0x0123456789ab> print(model.pet.name) #> Hedwig print(type(model.pet)) #> <class ‘__main__.Pet’> try:

# If the value is not an instance of the type, it’s invalid Model(owner=’Harry’, pet=’Hedwig’)

except ValidationError as e:

print(e) ‘’’ 1 validation error for Model pet

Input should be an instance of Pet [type=is_instance_of, input_value=’Hedwig’, input_type=str]

‘’’

# Nothing in the instance of the arbitrary type is checked # Here name probably should have been a str, but it’s not validated pet2 = Pet(name=42) model2 = Model(owner=’Harry’, pet=pet2) print(model2) #> pet=<__main__.Pet object at 0x0123456789ab> owner=’Harry’ print(model2.pet) #> <__main__.Pet object at 0x0123456789ab> print(model2.pet.name) #> 42 print(type(model2.pet)) #> <class ‘__main__.Pet’> ```

from_attributes: bool#

Whether to build models and look up discriminators of tagged unions using python object attributes.

loc_by_alias: bool#

Whether to use the actual key provided in the data (e.g. alias) for error loc`s rather than the field’s name. Defaults to `True.

alias_generator: Callable[[str], str] | AliasGenerator | None#

A callable that takes a field name and returns an alias for it or an instance of [AliasGenerator][pydantic.aliases.AliasGenerator]. Defaults to None.

When using a callable, the alias generator is used for both validation and serialization. If you want to use different alias generators for validation and serialization, you can use [AliasGenerator][pydantic.aliases.AliasGenerator] instead.

If data source field names do not match your code style (e.g. CamelCase fields), you can automatically generate aliases using alias_generator. Here’s an example with a basic callable:

```python from pydantic import BaseModel, ConfigDict from pydantic.alias_generators import to_pascal

class Voice(BaseModel):

model_config = ConfigDict(alias_generator=to_pascal)

name: str language_code: str

voice = Voice(Name=’Filiz’, LanguageCode=’tr-TR’) print(voice.language_code) #> tr-TR print(voice.model_dump(by_alias=True)) #> {‘Name’: ‘Filiz’, ‘LanguageCode’: ‘tr-TR’} ```

If you want to use different alias generators for validation and serialization, you can use [AliasGenerator][pydantic.aliases.AliasGenerator].

```python from pydantic import AliasGenerator, BaseModel, ConfigDict from pydantic.alias_generators import to_camel, to_pascal

class Athlete(BaseModel):

first_name: str last_name: str sport: str

model_config = ConfigDict(
alias_generator=AliasGenerator(

validation_alias=to_camel, serialization_alias=to_pascal,

)

)

athlete = Athlete(firstName=’John’, lastName=’Doe’, sport=’track’) print(athlete.model_dump(by_alias=True)) #> {‘FirstName’: ‘John’, ‘LastName’: ‘Doe’, ‘Sport’: ‘track’} ```

Note:

Pydantic offers three built-in alias generators: [to_pascal][pydantic.alias_generators.to_pascal], [to_camel][pydantic.alias_generators.to_camel], and [to_snake][pydantic.alias_generators.to_snake].

ignored_types: tuple[type, ...]#

A tuple of types that may occur as values of class attributes without annotations. This is typically used for custom descriptors (classes that behave like property). If an attribute is set on a class without an annotation and has a type that is not in this tuple (or otherwise recognized by _pydantic_), an error will be raised. Defaults to ().

allow_inf_nan: bool#

Whether to allow infinity (+inf an -inf) and NaN values to float and decimal fields. Defaults to True.

json_schema_extra: JsonDict | JsonSchemaExtraCallable | None#

A dict or callable to provide extra JSON schema properties. Defaults to None.

json_encoders: dict[type[object], JsonEncoder] | None#

A dict of custom JSON encoders for specific types. Defaults to None.

/// version-deprecated | v2 This configuration option is a carryover from v1. We originally planned to remove it in v2 but didn’t have a 1:1 replacement so we are keeping it for now. It is still deprecated and will likely be removed in the future. ///

strict: bool#

Whether strict validation is applied to all fields on the model.

By default, Pydantic attempts to coerce values to the correct type, when possible.

There are situations in which you may want to disable this behavior, and instead raise an error if a value’s type does not match the field’s type annotation.

To configure strict mode for all fields on a model, you can set strict=True on the model.

```python from pydantic import BaseModel, ConfigDict

class Model(BaseModel):

model_config = ConfigDict(strict=True)

name: str age: int

```

See [Strict Mode](../concepts/strict_mode.md) for more details.

See the [Conversion Table](../concepts/conversion_table.md) for more details on how Pydantic converts data in both strict and lax modes.

/// version-added | v2 ///

revalidate_instances: Literal['always', 'never', 'subclass-instances']#

When and how to revalidate models and dataclasses during validation. Can be one of:

  • ‘never’: will not revalidate models and dataclasses during validation

  • ‘always’: will revalidate models and dataclasses during validation

  • ‘subclass-instances’: will revalidate models and dataclasses during validation if the instance is a

    subclass of the model or dataclass

The default is ‘never’ (no revalidation).

This configuration only affects the current model it is applied on, and does not populate to the models referenced in fields.

```python from pydantic import BaseModel

class User(BaseModel, revalidate_instances=’never’): # (1)!

name: str

class Transaction(BaseModel):

user: User

my_user = User(name=’John’) t = Transaction(user=my_user)

my_user.name = 1 # (2)! t = Transaction(user=my_user) # (3)! print(t) #> user=User(name=1) ```

  1. This is the default behavior.

  2. The assignment is not validated, unless you set [validate_assignment][pydantic.ConfigDict.validate_assignment] in the configuration.

  3. Since revalidate_instances is set to ‘never’, the user instance is not revalidated.

Here is an example demonstrating the behavior of ‘subclass-instances’:

```python from pydantic import BaseModel

class User(BaseModel, revalidate_instances=’subclass-instances’):

name: str

class SubUser(User):

age: int

class Transaction(BaseModel):

user: User

my_user = User(name=’John’) my_user.name = 1 # (1)! t = Transaction(user=my_user) # (2)! print(t) #> user=User(name=1)

my_sub_user = SubUser(name=’John’, age=20) t = Transaction(user=my_sub_user) print(t) # (3)! #> user=User(name=’John’) ```

  1. The assignment is not validated, unless you set [validate_assignment][pydantic.ConfigDict.validate_assignment] in the configuration.

  2. Because my_user is a “direct” instance of User, it is not being revalidated. It would have been the case if

revalidate_instances was set to ‘always’.

  1. Because my_sub_user is an instance of a User subclass, it is being revalidated. In this case, Pydantic coerces my_sub_user to the defined User class defined on Transaction. If one of its fields had an invalid value, a validation error would have been raised.

/// version-added | v2 ///

ser_json_timedelta: Literal['iso8601', 'float']#

The format of JSON serialized timedeltas. Accepts the string values of ‘iso8601’ and ‘float’. Defaults to ‘iso8601’.

/// version-changed | v2.12 It is now recommended to use the [ser_json_temporal][pydantic.config.ConfigDict.ser_json_temporal] setting. ser_json_timedelta will be deprecated in v3. ///

ser_json_temporal: Literal['iso8601', 'seconds', 'milliseconds']#

The format of JSON serialized temporal types from the [datetime][] module. This includes:

  • [datetime.datetime][]

  • [datetime.date][]

  • [datetime.time][]

  • [datetime.timedelta][]

Can be one of:

  • ‘iso8601’ will serialize date-like types to [ISO 8601 text format](https://en.wikipedia.org/wiki/ISO_8601#Durations).

  • ‘milliseconds’ will serialize date-like types to a floating point number of milliseconds since the epoch.

  • ‘seconds’ will serialize date-like types to a floating point number of seconds since the epoch.

Defaults to ‘iso8601’.

/// version-added | v2.12 This setting replaces [ser_json_timedelta][pydantic.config.ConfigDict.ser_json_timedelta], which will be deprecated in v3. ser_json_temporal adds more configurability for the other temporal types. ///

val_temporal_unit: Literal['seconds', 'milliseconds', 'infer']#

The unit to assume for validating numeric input for datetime-like types ([datetime.datetime][] and [datetime.date][]). Can be one of:

  • ‘seconds’ will validate date or time numeric inputs as seconds since the [epoch].

  • ‘milliseconds’ will validate date or time numeric inputs as milliseconds since the [epoch].

  • ‘infer’ will infer the unit from the string numeric input on unix time as:

    • seconds since the [epoch] if $-2^{10} <= v <= 2^{10}$

    • milliseconds since the [epoch] (if $v < -2^{10}$ or $v > 2^{10}$).

Defaults to ‘infer’.

/// version-added | v2.12 ///

[epoch]: https://en.wikipedia.org/wiki/Unix_time

ser_json_bytes: Literal['utf8', 'base64', 'hex']#

The encoding of JSON serialized bytes. Defaults to ‘utf8’. Set equal to val_json_bytes to get back an equal value after serialization round trip.

  • ‘utf8’ will serialize bytes to UTF-8 strings.

  • ‘base64’ will serialize bytes to URL safe base64 strings.

  • ‘hex’ will serialize bytes to hexadecimal strings.

val_json_bytes: Literal['utf8', 'base64', 'hex']#

The encoding of JSON serialized bytes to decode. Defaults to ‘utf8’. Set equal to ser_json_bytes to get back an equal value after serialization round trip.

  • ‘utf8’ will deserialize UTF-8 strings to bytes.

  • ‘base64’ will deserialize URL safe base64 strings to bytes.

  • ‘hex’ will deserialize hexadecimal strings to bytes.

ser_json_inf_nan: Literal['null', 'constants', 'strings']#

The encoding of JSON serialized infinity and NaN float values. Defaults to ‘null’.

  • ‘null’ will serialize infinity and NaN values as null.

  • ‘constants’ will serialize infinity and NaN values as Infinity and NaN.

  • ‘strings’ will serialize infinity as string “Infinity” and NaN as string “NaN”.

validate_default: bool#

Whether to validate default values during validation. Defaults to False.

validate_return: bool#

Whether to validate the return value from call validators. Defaults to False.

protected_namespaces: tuple[str | Pattern[str], ...]#

A tuple of strings and/or regex patterns that prevent models from having fields with names that conflict with its existing members/methods.

Strings are matched on a prefix basis. For instance, with ‘dog’, having a field named ‘dog_name’ will be disallowed.

Regex patterns are matched on the entire field name. For instance, with the pattern ‘^dog$’, having a field named ‘dog’ will be disallowed, but ‘dog_name’ will be accepted.

Defaults to (‘model_validate’, ‘model_dump’). This default is used to prevent collisions with the existing (and possibly future) [validation](../concepts/models.md#validating-data) and [serialization](../concepts/serialization.md#serializing-data) methods.

```python import warnings

from pydantic import BaseModel

warnings.filterwarnings(‘error’) # Raise warnings as errors

try:

class Model(BaseModel):

model_dump_something: str

except UserWarning as e:

print(e) ‘’’ Field ‘model_dump_something’ in ‘Model’ conflicts with protected namespace ‘model_dump’.

You may be able to solve this by setting the ‘protected_namespaces’ configuration to (‘model_validate’,). ‘’’

```

You can customize this behavior using the protected_namespaces setting:

```python {test=”skip”} import re import warnings

from pydantic import BaseModel, ConfigDict

with warnings.catch_warnings(record=True) as caught_warnings:

warnings.simplefilter(‘always’) # Catch all warnings

class Model(BaseModel):

safe_field: str also_protect_field: str protect_this: str

model_config = ConfigDict(
protected_namespaces=(

protect_me_’, ‘also_protect_’, re.compile(‘^protect_this$’),

)

)

for warning in caught_warnings:

print(f’{warning.message}’) ‘’’ Field ‘also_protect_field’ in ‘Model’ conflicts with protected namespace ‘also_protect_’. You may be able to solve this by setting the ‘protected_namespaces’ configuration to (’protect_me_’, re.compile(‘^protect_this$’))`.

Field ‘protect_this’ in ‘Model’ conflicts with protected namespace ‘re.compile(‘^protect_this$’)’. You may be able to solve this by setting the ‘protected_namespaces’ configuration to (’protect_me_’, ‘also_protect_’)`. ‘’’

```

While Pydantic will only emit a warning when an item is in a protected namespace but does not actually have a collision, an error _is_ raised if there is an actual collision with an existing attribute:

```python from pydantic import BaseModel, ConfigDict

try:

class Model(BaseModel):

model_validate: str

model_config = ConfigDict(protected_namespaces=(’model_’,))

except ValueError as e:

print(e) ‘’’ Field ‘model_validate’ conflicts with member <bound method BaseModel.model_validate of <class ‘pydantic.main.BaseModel’>> of protected namespace ‘model_’. ‘’’

```

/// version-changed | v2.10 The default protected namespaces was changed from (‘model_’,) to (‘model_validate’, ‘model_dump’), to allow for fields like model_id, model_name to be used. ///

hide_input_in_errors: bool#

Whether to hide inputs when printing errors. Defaults to False.

Pydantic shows the input value and type when it raises ValidationError during the validation.

```python from pydantic import BaseModel, ValidationError

class Model(BaseModel):

a: str

try:

Model(a=123)

except ValidationError as e:

print(e) ‘’’ 1 validation error for Model a

Input should be a valid string [type=string_type, input_value=123, input_type=int]

‘’’

```

You can hide the input value and type by setting the hide_input_in_errors config to True.

```python from pydantic import BaseModel, ConfigDict, ValidationError

class Model(BaseModel):

a: str model_config = ConfigDict(hide_input_in_errors=True)

try:

Model(a=123)

except ValidationError as e:

print(e) ‘’’ 1 validation error for Model a

Input should be a valid string [type=string_type]

‘’’

```

defer_build: bool#

Whether to defer model validator and serializer construction until the first model validation. Defaults to False.

This can be useful to avoid the overhead of building models which are only used nested within other models, or when you want to manually define type namespace via [Model.model_rebuild(_types_namespace=…)][pydantic.BaseModel.model_rebuild].

/// version-changed | v2.10 The setting also applies to [Pydantic dataclasses](../concepts/dataclasses.md) and [type adapters](../concepts/type_adapter.md). ///

plugin_settings: dict[str, object] | None#

A dict of settings for plugins. Defaults to None.

schema_generator: type[_GenerateSchema] | None#

The GenerateSchema class to use during core schema generation.

/// version-deprecated | v2.10 The GenerateSchema class is private and highly subject to change. ///

json_schema_serialization_defaults_required: bool#

Whether fields with default values should be marked as required in the serialization schema. Defaults to False.

This ensures that the serialization schema will reflect the fact a field with a default will always be present when serializing the model, even though it is not required for validation.

However, there are scenarios where this may be undesirable — in particular, if you want to share the schema between validation and serialization, and don’t mind fields with defaults being marked as not required during serialization. See [#7209](pydantic/pydantic#7209) for more details.

```python from pydantic import BaseModel, ConfigDict

class Model(BaseModel):

a: str = ‘a’

model_config = ConfigDict(json_schema_serialization_defaults_required=True)

print(Model.model_json_schema(mode=’validation’)) ‘’’ {

‘properties’: {‘a’: {‘default’: ‘a’, ‘title’: ‘A’, ‘type’: ‘string’}}, ‘title’: ‘Model’, ‘type’: ‘object’,

}#

print(Model.model_json_schema(mode=’serialization’)) ‘’’ {

‘properties’: {‘a’: {‘default’: ‘a’, ‘title’: ‘A’, ‘type’: ‘string’}}, ‘required’: [‘a’], ‘title’: ‘Model’, ‘type’: ‘object’,

}#

```

/// version-added | v2.4 ///

json_schema_mode_override: Literal['validation', 'serialization', None]#

If not None, the specified mode will be used to generate the JSON schema regardless of what mode was passed to the function call. Defaults to None.

This provides a way to force the JSON schema generation to reflect a specific mode, e.g., to always use the validation schema.

It can be useful when using frameworks (such as FastAPI) that may generate different schemas for validation and serialization that must both be referenced from the same schema; when this happens, we automatically append -Input to the definition reference for the validation schema and -Output to the definition reference for the serialization schema. By specifying a json_schema_mode_override though, this prevents the conflict between the validation and serialization schemas (since both will use the specified schema), and so prevents the suffixes from being added to the definition references.

```python from pydantic import BaseModel, ConfigDict, Json

class Model(BaseModel):

a: Json[int] # requires a string to validate, but will dump an int

print(Model.model_json_schema(mode=’serialization’)) ‘’’ {

‘properties’: {‘a’: {‘title’: ‘A’, ‘type’: ‘integer’}}, ‘required’: [‘a’], ‘title’: ‘Model’, ‘type’: ‘object’,

}#

class ForceInputModel(Model):

# the following ensures that even with mode=’serialization’, we # will get the schema that would be generated for validation. model_config = ConfigDict(json_schema_mode_override=’validation’)

print(ForceInputModel.model_json_schema(mode=’serialization’)) ‘’’ {

‘properties’: {
‘a’: {

‘contentMediaType’: ‘application/json’, ‘contentSchema’: {‘type’: ‘integer’}, ‘title’: ‘A’, ‘type’: ‘string’,

}

}, ‘required’: [‘a’], ‘title’: ‘ForceInputModel’, ‘type’: ‘object’,

}#

```

/// version-added | v2.4 ///

coerce_numbers_to_str: bool#

If True, enables automatic coercion of any Number type to str in “lax” (non-strict) mode. Defaults to False.

Pydantic doesn’t allow number types (int, float, Decimal) to be coerced as type str by default.

```python from decimal import Decimal

from pydantic import BaseModel, ConfigDict, ValidationError

class Model(BaseModel):

value: str

try:

print(Model(value=42))

except ValidationError as e:

print(e) ‘’’ 1 validation error for Model value

Input should be a valid string [type=string_type, input_value=42, input_type=int]

‘’’

class Model(BaseModel):

model_config = ConfigDict(coerce_numbers_to_str=True)

value: str

repr(Model(value=42).value) #> “42” repr(Model(value=42.13).value) #> “42.13” repr(Model(value=Decimal(‘42.13’)).value) #> “42.13” ```

regex_engine: Literal['rust-regex', 'python-re']#

The regex engine to be used for pattern validation. Defaults to ‘rust-regex’.

  • ‘rust-regex’ uses the [regex](https://docs.rs/regex) Rust crate, which is non-backtracking and therefore more DDoS resistant, but does not support all regex features.

  • ‘python-re’ use the [re][] module, which supports all regex features, but may be slower.

!!! note

If you use a compiled regex pattern, the ‘python-re’ engine will be used regardless of this setting. This is so that flags such as [re.IGNORECASE][] are respected.

```python from pydantic import BaseModel, ConfigDict, Field, ValidationError

class Model(BaseModel):

model_config = ConfigDict(regex_engine=’python-re’)

value: str = Field(pattern=r’^abc(?=def)’)

print(Model(value=’abcdef’).value) #> abcdef

try:

print(Model(value=’abxyzcdef’))

except ValidationError as e:

print(e) ‘’’ 1 validation error for Model value

String should match pattern ‘^abc(?=def)’ [type=string_pattern_mismatch, input_value=’abxyzcdef’, input_type=str]

‘’’

```

/// version-added | v2.5 ///

validation_error_cause: bool#

If True, Python exceptions that were part of a validation failure will be shown as an exception group as a cause. Can be useful for debugging. Defaults to False.

Note:

Python 3.10 and older don’t support exception groups natively. <=3.10, backport must be installed: pip install exceptiongroup.

Note:

The structure of validation errors are likely to change in future Pydantic versions. Pydantic offers no guarantees about their structure. Should be used for visual traceback debugging only.

/// version-added | v2.5 ///

use_attribute_docstrings: bool#

Whether docstrings of attributes (bare string literals immediately following the attribute declaration) should be used for field descriptions. Defaults to False.

```python from pydantic import BaseModel, ConfigDict, Field

class Model(BaseModel):

model_config = ConfigDict(use_attribute_docstrings=True)

x: str “”” Example of an attribute docstring “””

y: int = Field(description=”Description in Field”) “”” Description in Field overrides attribute docstring “””

print(Model.model_fields[“x”].description) # > Example of an attribute docstring print(Model.model_fields[“y”].description) # > Description in Field ``` This requires the source code of the class to be available at runtime.

!!! warning “Usage with TypedDict and stdlib dataclasses”

Due to current limitations, attribute docstrings detection may not work as expected when using [TypedDict][typing.TypedDict] and stdlib dataclasses, in particular when:

  • inheritance is being used.

  • multiple classes have the same name in the same source file (unless Python 3.13 or greater is used).

/// version-added | v2.7 ///

cache_strings: bool | Literal['all', 'keys', 'none']#

Whether to cache strings to avoid constructing new Python objects. Defaults to True.

Enabling this setting should significantly improve validation performance while increasing memory usage slightly.

  • True or ‘all’ (the default): cache all strings

  • ‘keys’: cache only dictionary keys

  • False or ‘none’: no caching

!!! note

True or ‘all’ is required to cache strings during general validation because validators don’t know if they’re in a key or a value.

!!! tip

If repeated strings are rare, it’s recommended to use ‘keys’ or ‘none’ to reduce memory usage, as the performance difference is minimal if repeated strings are rare.

/// version-added | v2.7 ///

validate_by_alias: bool#

Whether an aliased field may be populated by its alias. Defaults to True.

Here’s an example of disabling validation by alias:

```py from pydantic import BaseModel, ConfigDict, Field

class Model(BaseModel):

model_config = ConfigDict(validate_by_name=True, validate_by_alias=False)

my_field: str = Field(validation_alias=’my_alias’) # (1)!

m = Model(my_field=’foo’) # (2)! print(m) #> my_field=’foo’ ```

  1. The field ‘my_field’ has an alias ‘my_alias’.

  2. The model can only be populated by the attribute name ‘my_field’.

!!! warning

You cannot set both validate_by_alias and validate_by_name to False. This would make it impossible to populate an attribute.

See [usage errors](../errors/usage_errors.md#validate-by-alias-and-name-false) for an example.

If you set validate_by_alias to False, under the hood, Pydantic dynamically sets validate_by_name to True to ensure that validation can still occur.

/// version-added | v2.11 This setting was introduced in conjunction with [validate_by_name][pydantic.ConfigDict.validate_by_name] to empower users with more fine grained validation control. ///

validate_by_name: bool#

Whether an aliased field may be populated by its name as given by the model attribute. Defaults to False.

```python from pydantic import BaseModel, ConfigDict, Field

class Model(BaseModel):

model_config = ConfigDict(validate_by_name=True, validate_by_alias=True)

my_field: str = Field(validation_alias=’my_alias’) # (1)!

m = Model(my_alias=’foo’) # (2)! print(m) #> my_field=’foo’

m = Model(my_field=’foo’) # (3)! print(m) #> my_field=’foo’ ```

  1. The field ‘my_field’ has an alias ‘my_alias’.

  2. The model is populated by the alias ‘my_alias’.

  3. The model is populated by the attribute name ‘my_field’.

!!! warning

You cannot set both validate_by_alias and validate_by_name to False. This would make it impossible to populate an attribute.

See [usage errors](../errors/usage_errors.md#validate-by-alias-and-name-false) for an example.

/// version-added | v2.11 This setting was introduced in conjunction with [validate_by_alias][pydantic.ConfigDict.validate_by_alias] to empower users with more fine grained validation control. It is an alternative to [populate_by_name][pydantic.ConfigDict.populate_by_name], that enables validation by name and by alias. ///

serialize_by_alias: bool#

Whether an aliased field should be serialized by its alias. Defaults to False.

Note: In v2.11, serialize_by_alias was introduced to address the [popular request](pydantic/pydantic#8379) for consistency with alias behavior for validation and serialization settings. In v3, the default value is expected to change to True for consistency with the validation default.

```python from pydantic import BaseModel, ConfigDict, Field

class Model(BaseModel):

model_config = ConfigDict(serialize_by_alias=True)

my_field: str = Field(serialization_alias=’my_alias’) # (1)!

m = Model(my_field=’foo’) print(m.model_dump()) # (2)! #> {‘my_alias’: ‘foo’} ```

  1. The field ‘my_field’ has an alias ‘my_alias’.

  2. The model is serialized using the alias ‘my_alias’ for the ‘my_field’ attribute.

/// version-added | v2.11 This setting was introduced to address the [popular request](pydantic/pydantic#8379) for consistency with alias behavior for validation and serialization.

In v3, the default value is expected to change to True for consistency with the validation default. ///

url_preserve_empty_path: bool#

Whether to preserve empty URL paths when validating values for a URL type. Defaults to False.

```python from pydantic import AnyUrl, BaseModel, ConfigDict

class Model(BaseModel):

model_config = ConfigDict(url_preserve_empty_path=True)

url: AnyUrl

m = Model(url=’http://example.com’) print(m.url) #> http://example.com ```

/// version-added | v2.12 ///