__ __ __ __ _____ _ _ _____ _ _ _ | \/ | \ \ / / | __ \ (_) | | / ____| | | | | | \ / |_ __\ V / | |__) | __ ___ ____ _| |_ ___ | (___ | |__ ___| | | | |\/| | '__|> < | ___/ '__| \ \ / / _` | __/ _ \ \___ \| '_ \ / _ \ | | | | | | |_ / . \ | | | | | |\ V / (_| | || __/ ____) | | | | __/ | | |_| |_|_(_)_/ \_\ |_| |_| |_| \_/ \__,_|\__\___| |_____/|_| |_|\___V 2.1 if you need WebShell for Seo everyday contact me on Telegram Telegram Address : @jackleetFor_More_Tools:
"""Support for alias configurations."""
from __future__ import annotations
import dataclasses
from typing import Any, Callable, Literal
from pydantic_core import PydanticUndefined
from ._internal import _internal_dataclass
__all__ = ('AliasGenerator', 'AliasPath', 'AliasChoices')
@dataclasses.dataclass(**_internal_dataclass.slots_true)
class AliasPath:
"""Usage docs: https://docs.pydantic.dev/2.8/concepts/alias#aliaspath-and-aliaschoices
A data class used by `validation_alias` as a convenience to create aliases.
Attributes:
path: A list of string or integer aliases.
"""
path: list[int | str]
def __init__(self, first_arg: str, *args: str | int) -> None:
self.path = [first_arg] + list(args)
def convert_to_aliases(self) -> list[str | int]:
"""Converts arguments to a list of string or integer aliases.
Returns:
The list of aliases.
"""
return self.path
def search_dict_for_path(self, d: dict) -> Any:
"""Searches a dictionary for the path specified by the alias.
Returns:
The value at the specified path, or `PydanticUndefined` if the path is not found.
"""
v = d
for k in self.path:
if isinstance(v, str):
# disallow indexing into a str, like for AliasPath('x', 0) and x='abc'
return PydanticUndefined
try:
v = v[k]
except (KeyError, IndexError, TypeError):
return PydanticUndefined
return v
@dataclasses.dataclass(**_internal_dataclass.slots_true)
class AliasChoices:
"""Usage docs: https://docs.pydantic.dev/2.8/concepts/alias#aliaspath-and-aliaschoices
A data class used by `validation_alias` as a convenience to create aliases.
Attributes:
choices: A list containing a string or `AliasPath`.
"""
choices: list[str | AliasPath]
def __init__(self, first_choice: str | AliasPath, *choices: str | AliasPath) -> None:
self.choices = [first_choice] + list(choices)
def convert_to_aliases(self) -> list[list[str | int]]:
"""Converts arguments to a list of lists containing string or integer aliases.
Returns:
The list of aliases.
"""
aliases: list[list[str | int]] = []
for c in self.choices:
if isinstance(c, AliasPath):
aliases.append(c.convert_to_aliases())
else:
aliases.append([c])
return aliases
@dataclasses.dataclass(**_internal_dataclass.slots_true)
class AliasGenerator:
"""Usage docs: https://docs.pydantic.dev/2.8/concepts/alias#using-an-aliasgenerator
A data class used by `alias_generator` as a convenience to create various aliases.
Attributes:
alias: A callable that takes a field name and returns an alias for it.
validation_alias: A callable that takes a field name and returns a validation alias for it.
serialization_alias: A callable that takes a field name and returns a serialization alias for it.
"""
alias: Callable[[str], str] | None = None
validation_alias: Callable[[str], str | AliasPath | AliasChoices] | None = None
serialization_alias: Callable[[str], str] | None = None
def _generate_alias(
self,
alias_kind: Literal['alias', 'validation_alias', 'serialization_alias'],
allowed_types: tuple[type[str] | type[AliasPath] | type[AliasChoices], ...],
field_name: str,
) -> str | AliasPath | AliasChoices | None:
"""Generate an alias of the specified kind. Returns None if the alias generator is None.
Raises:
TypeError: If the alias generator produces an invalid type.
"""
alias = None
if alias_generator := getattr(self, alias_kind):
alias = alias_generator(field_name)
if alias and not isinstance(alias, allowed_types):
raise TypeError(
f'Invalid `{alias_kind}` type. `{alias_kind}` generator must produce one of `{allowed_types}`'
)
return alias
def generate_aliases(self, field_name: str) -> tuple[str | None, str | AliasPath | AliasChoices | None, str | None]:
"""Generate `alias`, `validation_alias`, and `serialization_alias` for a field.
Returns:
A tuple of three aliases - validation, alias, and serialization.
"""
alias = self._generate_alias('alias', (str,), field_name)
validation_alias = self._generate_alias('validation_alias', (str, AliasChoices, AliasPath), field_name)
serialization_alias = self._generate_alias('serialization_alias', (str,), field_name)
return alias, validation_alias, serialization_alias # type: ignore
| Name | Type | Size | Permission | Actions |
|---|---|---|---|---|
| __pycache__ | Folder | 0755 |
|
|
| _internal | Folder | 0755 |
|
|
| deprecated | Folder | 0755 |
|
|
| experimental | Folder | 0755 |
|
|
| plugin | Folder | 0755 |
|
|
| v1 | Folder | 0755 |
|
|
| __init__.py | File | 13.6 KB | 0644 |
|
| _migration.py | File | 11.63 KB | 0644 |
|
| alias_generators.py | File | 2.07 KB | 0644 |
|
| aliases.py | File | 4.71 KB | 0644 |
|
| annotated_handlers.py | File | 4.25 KB | 0644 |
|
| class_validators.py | File | 148 B | 0644 |
|
| color.py | File | 20.99 KB | 0644 |
|
| config.py | File | 34.29 KB | 0644 |
|
| dataclasses.py | File | 13.58 KB | 0644 |
|
| datetime_parse.py | File | 150 B | 0644 |
|
| decorator.py | File | 145 B | 0644 |
|
| env_settings.py | File | 148 B | 0644 |
|
| error_wrappers.py | File | 150 B | 0644 |
|
| errors.py | File | 4.72 KB | 0644 |
|
| fields.py | File | 50.53 KB | 0644 |
|
| functional_serializers.py | File | 14.27 KB | 0644 |
|
| functional_validators.py | File | 23.66 KB | 0644 |
|
| generics.py | File | 144 B | 0644 |
|
| json.py | File | 140 B | 0644 |
|
| json_schema.py | File | 103.81 KB | 0644 |
|
| main.py | File | 68.46 KB | 0644 |
|
| mypy.py | File | 55.64 KB | 0644 |
|
| networks.py | File | 22.18 KB | 0644 |
|
| parse.py | File | 141 B | 0644 |
|
| py.typed | File | 0 B | 0644 |
|
| root_model.py | File | 6.05 KB | 0644 |
|
| schema.py | File | 142 B | 0644 |
|
| tools.py | File | 141 B | 0644 |
|
| type_adapter.py | File | 24.39 KB | 0644 |
|
| types.py | File | 93.5 KB | 0644 |
|
| typing.py | File | 138 B | 0644 |
|
| utils.py | File | 141 B | 0644 |
|
| validate_call_decorator.py | File | 2.08 KB | 0644 |
|
| validators.py | File | 146 B | 0644 |
|
| version.py | File | 2.38 KB | 0644 |
|
| warnings.py | File | 2.65 KB | 0644 |
|