Current Path: > > opt > > hc_python > lib > python3.12 > > site-packages > > > pydantic
Operation : Linux premium131.web-hosting.com 4.18.0-553.44.1.lve.el8.x86_64 #1 SMP Thu Mar 13 14:29:12 UTC 2025 x86_64 Software : Apache Server IP : 162.0.232.56 | Your IP: 216.73.216.111 Domains : 1034 Domain(s) Permission : [ 0755 ]
Name | Type | Size | Last Modified | Actions |
---|---|---|---|---|
__pycache__ | Directory | - | - | |
_internal | Directory | - | - | |
deprecated | Directory | - | - | |
experimental | Directory | - | - | |
plugin | Directory | - | - | |
v1 | Directory | - | - | |
__init__.py | File | 13931 bytes | April 04 2025 08:02:35. | |
_migration.py | File | 11913 bytes | April 04 2025 08:02:35. | |
alias_generators.py | File | 2124 bytes | April 04 2025 08:02:35. | |
aliases.py | File | 4819 bytes | April 04 2025 08:02:35. | |
annotated_handlers.py | File | 4353 bytes | April 04 2025 08:02:35. | |
class_validators.py | File | 148 bytes | April 04 2025 08:02:35. | |
color.py | File | 21494 bytes | April 04 2025 08:02:35. | |
config.py | File | 35112 bytes | April 04 2025 08:02:35. | |
dataclasses.py | File | 13909 bytes | April 04 2025 08:02:35. | |
datetime_parse.py | File | 150 bytes | April 04 2025 08:02:35. | |
decorator.py | File | 145 bytes | April 04 2025 08:02:35. | |
env_settings.py | File | 148 bytes | April 04 2025 08:02:35. | |
error_wrappers.py | File | 150 bytes | April 04 2025 08:02:35. | |
errors.py | File | 4835 bytes | April 04 2025 08:02:35. | |
fields.py | File | 51746 bytes | April 04 2025 08:02:35. | |
functional_serializers.py | File | 14616 bytes | April 04 2025 08:02:35. | |
functional_validators.py | File | 24224 bytes | April 04 2025 08:02:35. | |
generics.py | File | 144 bytes | April 04 2025 08:02:35. | |
json.py | File | 140 bytes | April 04 2025 08:02:35. | |
json_schema.py | File | 106297 bytes | April 04 2025 08:02:35. | |
main.py | File | 70106 bytes | April 04 2025 08:02:35. | |
mypy.py | File | 56972 bytes | April 04 2025 08:02:35. | |
networks.py | File | 22713 bytes | April 04 2025 08:02:35. | |
parse.py | File | 141 bytes | April 04 2025 08:02:35. | |
py.typed | File | 0 bytes | April 04 2025 08:02:35. | |
root_model.py | File | 6194 bytes | April 04 2025 08:02:35. | |
schema.py | File | 142 bytes | April 04 2025 08:02:35. | |
tools.py | File | 141 bytes | April 04 2025 08:02:35. | |
type_adapter.py | File | 24974 bytes | April 04 2025 08:02:35. | |
types.py | File | 95744 bytes | April 04 2025 08:02:35. | |
typing.py | File | 138 bytes | April 04 2025 08:02:35. | |
utils.py | File | 141 bytes | April 04 2025 08:02:35. | |
validate_call_decorator.py | File | 2127 bytes | April 04 2025 08:02:35. | |
validators.py | File | 146 bytes | April 04 2025 08:02:35. | |
version.py | File | 2442 bytes | April 04 2025 08:02:35. | |
warnings.py | File | 2711 bytes | April 04 2025 08:02:35. |
"""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
SILENT KILLER Tool