Source code for scim2_models.attributes

from inspect import isclass
from typing import Annotated
from typing import Any
from typing import get_origin

from pydantic import Field

from .annotations import Mutability

# This import will work because we'll import this module after BaseModel is defined
from .base import BaseModel
from .reference import Reference


[docs] class ComplexAttribute(BaseModel): """A complex attribute as defined in :rfc:`RFC7643 §2.3.8 <7643#section-2.3.8>`.""" _attribute_urn: str | None = None
[docs] def get_attribute_urn(self, field_name: str) -> str: """Build the full URN of the attribute. See :rfc:`RFC7644 §3.10 <7644#section-3.10>`. """ alias = ( self.__class__.model_fields[field_name].serialization_alias or field_name ) return f"{self._attribute_urn}.{alias}"
[docs] class MultiValuedComplexAttribute(ComplexAttribute): type: str | None = None """A label indicating the attribute's function.""" primary: bool | None = None """A Boolean value indicating the 'primary' or preferred attribute value for this attribute. Per :rfc:`RFC 7643 §2.4 <7643#section-2.4>`, the primary attribute value ``True`` MUST appear no more than once in a multi-valued attribute list. """ display: Annotated[str | None, Mutability.immutable] = None """A human-readable name, primarily used for display purposes.""" value: Any | None = None """The value of an entitlement.""" ref: Reference[Any] | None = Field(None, serialization_alias="$ref") """The reference URI of a target resource, if the attribute is a reference."""
def is_complex_attribute(type_: type) -> bool: # issubclass raise a TypeError with 'Reference' on python < 3.11 return ( get_origin(type_) != Reference and isclass(type_) and issubclass(type_, ComplexAttribute) )