kittycad.models.card_details
Classes
| 
 | The card details of a payment method. | 
- class kittycad.models.card_details.CardDetails(**data)[source][source]
- The card details of a payment method. - Create a new model by parsing and validating input data from keyword arguments. - Raises [ - ValidationError][pydantic_core.ValidationError] if the input data cannot be validated to form a valid model.- selfis explicitly positional-only to allow- selfas a field name.- __annotations__ = {'__class_vars__': 'ClassVar[set[str]]', '__private_attributes__': 'ClassVar[Dict[str, ModelPrivateAttr]]', '__pydantic_complete__': 'ClassVar[bool]', '__pydantic_computed_fields__': 'ClassVar[Dict[str, ComputedFieldInfo]]', '__pydantic_core_schema__': 'ClassVar[CoreSchema]', '__pydantic_custom_init__': 'ClassVar[bool]', '__pydantic_decorators__': 'ClassVar[_decorators.DecoratorInfos]', '__pydantic_extra__': 'dict[str, Any] | None', '__pydantic_fields__': 'ClassVar[Dict[str, FieldInfo]]', '__pydantic_fields_set__': 'set[str]', '__pydantic_generic_metadata__': 'ClassVar[_generics.PydanticGenericMetadata]', '__pydantic_parent_namespace__': 'ClassVar[Dict[str, Any] | None]', '__pydantic_post_init__': "ClassVar[None | Literal['model_post_init']]", '__pydantic_private__': 'dict[str, Any] | None', '__pydantic_root_model__': 'ClassVar[bool]', '__pydantic_serializer__': 'ClassVar[SchemaSerializer]', '__pydantic_validator__': 'ClassVar[SchemaValidator | PluggableSchemaValidator]', '__signature__': 'ClassVar[Signature]', 'brand': typing.Optional[str], 'checks': <class 'kittycad.models.payment_method_card_checks.PaymentMethodCardChecks'>, 'country': typing.Optional[str], 'exp_month': <class 'int'>, 'exp_year': <class 'int'>, 'fingerprint': typing.Optional[str], 'funding': typing.Optional[str], 'last4': typing.Optional[str], 'model_computed_fields': 'ClassVar[dict[str, ComputedFieldInfo]]', 'model_config': 'ClassVar[ConfigDict]', 'model_fields': 'ClassVar[dict[str, FieldInfo]]'}[source]
 - classmethod __class_getitem__(typevar_values)[source]
- Return type:
- type[- BaseModel] |- PydanticRecursiveRef
 
 - __class_vars__: ClassVar[set[str]] = {}[source]
- The names of the class variables defined on the model. 
 - classmethod __get_pydantic_core_schema__(source, handler, /)[source]
- Hook into generating the model’s CoreSchema. - Parameters:
- source ( - type[- BaseModel]) – The class we are generating a schema for. This will generally be the same as the- clsargument if this is a classmethod.
- handler ( - GetCoreSchemaHandler) – A callable that calls into Pydantic’s internal CoreSchema generation logic.
 
- Return type:
- Union[- InvalidSchema,- AnySchema,- NoneSchema,- BoolSchema,- IntSchema,- FloatSchema,- DecimalSchema,- StringSchema,- BytesSchema,- DateSchema,- TimeSchema,- DatetimeSchema,- TimedeltaSchema,- LiteralSchema,- EnumSchema,- IsInstanceSchema,- IsSubclassSchema,- CallableSchema,- ListSchema,- TupleSchema,- SetSchema,- FrozenSetSchema,- GeneratorSchema,- DictSchema,- AfterValidatorFunctionSchema,- BeforeValidatorFunctionSchema,- WrapValidatorFunctionSchema,- PlainValidatorFunctionSchema,- WithDefaultSchema,- NullableSchema,- UnionSchema,- TaggedUnionSchema,- ChainSchema,- LaxOrStrictSchema,- JsonOrPythonSchema,- TypedDictSchema,- ModelFieldsSchema,- ModelSchema,- DataclassArgsSchema,- DataclassSchema,- ArgumentsSchema,- CallSchema,- CustomErrorSchema,- JsonSchema,- UrlSchema,- MultiHostUrlSchema,- DefinitionsSchema,- DefinitionReferenceSchema,- UuidSchema,- ComplexSchema]
- Returns:
- A - pydantic-core- CoreSchema.
 
 - classmethod __get_pydantic_json_schema__(core_schema, handler, /)[source]
- Hook into generating the model’s JSON schema. - Parameters:
- core_schema ( - Union[- InvalidSchema,- AnySchema,- NoneSchema,- BoolSchema,- IntSchema,- FloatSchema,- DecimalSchema,- StringSchema,- BytesSchema,- DateSchema,- TimeSchema,- DatetimeSchema,- TimedeltaSchema,- LiteralSchema,- EnumSchema,- IsInstanceSchema,- IsSubclassSchema,- CallableSchema,- ListSchema,- TupleSchema,- SetSchema,- FrozenSetSchema,- GeneratorSchema,- DictSchema,- AfterValidatorFunctionSchema,- BeforeValidatorFunctionSchema,- WrapValidatorFunctionSchema,- PlainValidatorFunctionSchema,- WithDefaultSchema,- NullableSchema,- UnionSchema,- TaggedUnionSchema,- ChainSchema,- LaxOrStrictSchema,- JsonOrPythonSchema,- TypedDictSchema,- ModelFieldsSchema,- ModelSchema,- DataclassArgsSchema,- DataclassSchema,- ArgumentsSchema,- CallSchema,- CustomErrorSchema,- JsonSchema,- UrlSchema,- MultiHostUrlSchema,- DefinitionsSchema,- DefinitionReferenceSchema,- UuidSchema,- ComplexSchema]) – A- pydantic-coreCoreSchema. You can ignore this argument and call the handler with a new CoreSchema, wrap this CoreSchema (- {'type': 'nullable', 'schema': current_schema}), or just call the handler with the original schema.
- handler ( - GetJsonSchemaHandler) – Call into Pydantic’s internal JSON schema generation. This will raise a- pydantic.errors.PydanticInvalidForJsonSchemaif JSON schema generation fails. Since this gets called by- BaseModel.model_json_schemayou can override the- schema_generatorargument to that function to change JSON schema generation globally for a type.
 
- Return type:
- Returns:
- A JSON schema, as a Python object. 
 
 - __init__(**data)[source]
- Create a new model by parsing and validating input data from keyword arguments. - Raises [ - ValidationError][pydantic_core.ValidationError] if the input data cannot be validated to form a valid model.- selfis explicitly positional-only to allow- selfas a field name.
 - __pretty__(fmt, **kwargs)[source]
- Used by devtools (https://python-devtools.helpmanual.io/) to pretty print objects. 
 - __private_attributes__: ClassVar[Dict[str, ModelPrivateAttr]] = {}[source]
- Metadata about the private attributes of the model. 
 - __pydantic_complete__: ClassVar[bool] = True[source]
- Whether model building is completed, or if there are still undefined fields. 
 - __pydantic_computed_fields__: ClassVar[Dict[str, ComputedFieldInfo]] = {}[source]
- A dictionary of computed field names and their corresponding [ - ComputedFieldInfo][pydantic.fields.ComputedFieldInfo] objects.
 - __pydantic_core_schema__: ClassVar[CoreSchema] = {'cls': <class 'kittycad.models.card_details.CardDetails'>, 'config': {'title': 'CardDetails'}, 'custom_init': False, 'metadata': {'pydantic_js_functions': [<bound method BaseModel.__get_pydantic_json_schema__ of <class 'kittycad.models.card_details.CardDetails'>>]}, 'ref': 'kittycad.models.card_details.CardDetails:94239706385920', 'root_model': False, 'schema': {'computed_fields': [], 'fields': {'brand': {'metadata': {}, 'schema': {'default': None, 'schema': {'schema': {'type': 'str'}, 'type': 'nullable'}, 'type': 'default'}, 'type': 'model-field'}, 'checks': {'metadata': {}, 'schema': {'default': {}, 'schema': {'cls': <class 'kittycad.models.payment_method_card_checks.PaymentMethodCardChecks'>, 'config': {'title': 'PaymentMethodCardChecks'}, 'custom_init': False, 'metadata': {'pydantic_js_functions': [<bound method BaseModel.__get_pydantic_json_schema__ of <class 'kittycad.models.payment_method_card_checks.PaymentMethodCardChecks'>>]}, 'ref': 'kittycad.models.payment_method_card_checks.PaymentMethodCardChecks:94239706374032', 'root_model': False, 'schema': {'computed_fields': [], 'fields': {'address_line1_check': {'metadata': {}, 'schema': {'default': None, 'schema': {'schema': {'type': 'str'}, 'type': 'nullable'}, 'type': 'default'}, 'type': 'model-field'}, 'address_postal_code_check': {'metadata': {}, 'schema': {'default': None, 'schema': {'schema': {'type': 'str'}, 'type': 'nullable'}, 'type': 'default'}, 'type': 'model-field'}, 'cvc_check': {'metadata': {}, 'schema': {'default': None, 'schema': {'schema': {'type': 'str'}, 'type': 'nullable'}, 'type': 'default'}, 'type': 'model-field'}}, 'model_name': 'PaymentMethodCardChecks', 'type': 'model-fields'}, 'type': 'model'}, 'type': 'default'}, 'type': 'model-field'}, 'country': {'metadata': {}, 'schema': {'default': None, 'schema': {'schema': {'type': 'str'}, 'type': 'nullable'}, 'type': 'default'}, 'type': 'model-field'}, 'exp_month': {'metadata': {}, 'schema': {'default': 0, 'schema': {'type': 'int'}, 'type': 'default'}, 'type': 'model-field'}, 'exp_year': {'metadata': {}, 'schema': {'default': 0, 'schema': {'type': 'int'}, 'type': 'default'}, 'type': 'model-field'}, 'fingerprint': {'metadata': {}, 'schema': {'default': None, 'schema': {'schema': {'type': 'str'}, 'type': 'nullable'}, 'type': 'default'}, 'type': 'model-field'}, 'funding': {'metadata': {}, 'schema': {'default': None, 'schema': {'schema': {'type': 'str'}, 'type': 'nullable'}, 'type': 'default'}, 'type': 'model-field'}, 'last4': {'metadata': {}, 'schema': {'default': None, 'schema': {'schema': {'type': 'str'}, 'type': 'nullable'}, 'type': 'default'}, 'type': 'model-field'}}, 'model_name': 'CardDetails', 'type': 'model-fields'}, 'type': 'model'}[source]
- The core schema of the model. 
 - __pydantic_custom_init__: ClassVar[bool] = False[source]
- Whether the model has a custom - __init__method.
 - __pydantic_decorators__: ClassVar[_decorators.DecoratorInfos] = DecoratorInfos(validators={}, field_validators={}, root_validators={}, field_serializers={}, model_serializers={}, model_validators={}, computed_fields={})[source]
- Metadata containing the decorators defined on the model. This replaces - Model.__validators__and- Model.__root_validators__from Pydantic V1.
 - __pydantic_extra__: dict[str, Any] | None[source]
- A dictionary containing extra values, if [ - extra][pydantic.config.ConfigDict.extra] is set to- 'allow'.
 - __pydantic_fields__: ClassVar[Dict[str, FieldInfo]] = {'brand': FieldInfo(annotation=Union[str, NoneType], required=False, default=None), 'checks': FieldInfo(annotation=PaymentMethodCardChecks, required=False, default={}), 'country': FieldInfo(annotation=Union[str, NoneType], required=False, default=None), 'exp_month': FieldInfo(annotation=int, required=False, default=0), 'exp_year': FieldInfo(annotation=int, required=False, default=0), 'fingerprint': FieldInfo(annotation=Union[str, NoneType], required=False, default=None), 'funding': FieldInfo(annotation=Union[str, NoneType], required=False, default=None), 'last4': FieldInfo(annotation=Union[str, NoneType], required=False, default=None)}[source]
- A dictionary of field names and their corresponding [ - FieldInfo][pydantic.fields.FieldInfo] objects. This replaces- Model.__fields__from Pydantic V1.
 - __pydantic_generic_metadata__: ClassVar[_generics.PydanticGenericMetadata] = {'args': (), 'origin': None, 'parameters': ()}[source]
- Metadata for generic models; contains data used for a similar purpose to __args__, __origin__, __parameters__ in typing-module generics. May eventually be replaced by these. 
 - classmethod __pydantic_init_subclass__(**kwargs)[source]
- This is intended to behave just like - __init_subclass__, but is called by- ModelMetaclassonly after the class is actually fully initialized. In particular, attributes like- model_fieldswill be present when this is called.- This is necessary because - __init_subclass__will always be called by- type.__new__, and it would require a prohibitively large refactor to the- ModelMetaclassto ensure that- type.__new__was called in such a manner that the class would already be sufficiently initialized.- This will receive the same - kwargsthat would be passed to the standard- __init_subclass__, namely, any kwargs passed to the class definition that aren’t used internally by pydantic.
 - __pydantic_parent_namespace__: ClassVar[Dict[str, Any] | None] = None[source]
- Parent namespace of the model, used for automatic rebuilding of models. 
 - __pydantic_post_init__: ClassVar[None | Literal['model_post_init']] = None[source]
- The name of the post-init method for the model, if defined. 
 - __pydantic_private__: dict[str, Any] | None[source]
- Values of private attributes set on the model instance. 
 - __pydantic_root_model__: ClassVar[bool] = False[source]
- Whether the model is a [ - RootModel][pydantic.root_model.RootModel].
 - __pydantic_serializer__: ClassVar[SchemaSerializer] = SchemaSerializer(serializer=Model( ModelSerializer { class: Py( 0x000055b5e4390e00, ), serializer: Fields( GeneralFieldsSerializer { fields: { "fingerprint": SerField { key_py: Py( 0x00007f963631af30, ), alias: None, alias_py: None, serializer: Some( WithDefault( WithDefaultSerializer { default: Default( Py( 0x00007f963952d100, ), ), serializer: Nullable( NullableSerializer { serializer: Str( StrSerializer, ), }, ), }, ), ), required: true, }, "funding": SerField { key_py: Py( 0x00007f96357f0870, ), alias: None, alias_py: None, serializer: Some( WithDefault( WithDefaultSerializer { default: Default( Py( 0x00007f963952d100, ), ), serializer: Nullable( NullableSerializer { serializer: Str( StrSerializer, ), }, ), }, ), ), required: true, }, "country": SerField { key_py: Py( 0x00007f963579f390, ), alias: None, alias_py: None, serializer: Some( WithDefault( WithDefaultSerializer { default: Default( Py( 0x00007f963952d100, ), ), serializer: Nullable( NullableSerializer { serializer: Str( StrSerializer, ), }, ), }, ), ), required: true, }, "exp_year": SerField { key_py: Py( 0x00007f9634b40cf0, ), alias: None, alias_py: None, serializer: Some( WithDefault( WithDefaultSerializer { default: Default( Py( 0x00007f9639614b28, ), ), serializer: Int( IntSerializer, ), }, ), ), required: true, }, "exp_month": SerField { key_py: Py( 0x00007f9634b40d70, ), alias: None, alias_py: None, serializer: Some( WithDefault( WithDefaultSerializer { default: Default( Py( 0x00007f9639614b28, ), ), serializer: Int( IntSerializer, ), }, ), ), required: true, }, "checks": SerField { key_py: Py( 0x00007f9638749bc0, ), alias: None, alias_py: None, serializer: Some( WithDefault( WithDefaultSerializer { default: Default( Py( 0x00007f9634b4d4c0, ), ), serializer: Model( ModelSerializer { class: Py( 0x000055b5e438df90, ), serializer: Fields( GeneralFieldsSerializer { fields: { "address_line1_check": SerField { key_py: Py( 0x00007f9634b40970, ), alias: None, alias_py: None, serializer: Some( WithDefault( WithDefaultSerializer { default: Default( Py( 0x00007f963952d100, ), ), serializer: Nullable( NullableSerializer { serializer: Str( StrSerializer, ), }, ), }, ), ), required: true, }, "address_postal_code_check": SerField { key_py: Py( 0x00007f9634b48f30, ), alias: None, alias_py: None, serializer: Some( WithDefault( WithDefaultSerializer { default: Default( Py( 0x00007f963952d100, ), ), serializer: Nullable( NullableSerializer { serializer: Str( StrSerializer, ), }, ), }, ), ), required: true, }, "cvc_check": SerField { key_py: Py( 0x00007f9634b42070, ), alias: None, alias_py: None, serializer: Some( WithDefault( WithDefaultSerializer { default: Default( Py( 0x00007f963952d100, ), ), serializer: Nullable( NullableSerializer { serializer: Str( StrSerializer, ), }, ), }, ), ), required: true, }, }, computed_fields: Some( ComputedFields( [], ), ), mode: SimpleDict, extra_serializer: None, filter: SchemaFilter { include: None, exclude: None, }, required_fields: 3, }, ), has_extra: false, root_model: false, name: "PaymentMethodCardChecks", }, ), }, ), ), required: true, }, "brand": SerField { key_py: Py( 0x00007f96357a47b0, ), alias: None, alias_py: None, serializer: Some( WithDefault( WithDefaultSerializer { default: Default( Py( 0x00007f963952d100, ), ), serializer: Nullable( NullableSerializer { serializer: Str( StrSerializer, ), }, ), }, ), ), required: true, }, "last4": SerField { key_py: Py( 0x00007f96357a4720, ), alias: None, alias_py: None, serializer: Some( WithDefault( WithDefaultSerializer { default: Default( Py( 0x00007f963952d100, ), ), serializer: Nullable( NullableSerializer { serializer: Str( StrSerializer, ), }, ), }, ), ), required: true, }, }, computed_fields: Some( ComputedFields( [], ), ), mode: SimpleDict, extra_serializer: None, filter: SchemaFilter { include: None, exclude: None, }, required_fields: 8, }, ), has_extra: false, root_model: false, name: "CardDetails", }, ), definitions=[])[source]
- The - pydantic-core- SchemaSerializerused to dump instances of the model.
 - __pydantic_validator__: ClassVar[SchemaValidator | PluggableSchemaValidator] = SchemaValidator(title="CardDetails", validator=Model( ModelValidator { revalidate: Never, validator: ModelFields( ModelFieldsValidator { fields: [ Field { name: "brand", lookup_key: Simple { key: "brand", py_key: Py( 0x00007f96357f0c60, ), path: LookupPath( [ S( "brand", Py( 0x00007f96357f0c90, ), ), ], ), }, name_py: Py( 0x00007f96357a47b0, ), validator: WithDefault( WithDefaultValidator { default: Default( Py( 0x00007f963952d100, ), ), on_error: Raise, validator: Nullable( NullableValidator { validator: Str( StrValidator { strict: false, coerce_numbers_to_str: false, }, ), name: "nullable[str]", }, ), validate_default: false, copy_default: false, name: "default[nullable[str]]", undefined: Py( 0x00007f963748e3d0, ), }, ), frozen: false, }, Field { name: "checks", lookup_key: Simple { key: "checks", py_key: Py( 0x00007f96357f0cc0, ), path: LookupPath( [ S( "checks", Py( 0x00007f96357f0c30, ), ), ], ), }, name_py: Py( 0x00007f9638749bc0, ), validator: WithDefault( WithDefaultValidator { default: Default( Py( 0x00007f9634b4d4c0, ), ), on_error: Raise, validator: Model( ModelValidator { revalidate: Never, validator: ModelFields( ModelFieldsValidator { fields: [ Field { name: "address_line1_check", lookup_key: Simple { key: "address_line1_check", py_key: Py( 0x00007f9634b35670, ), path: LookupPath( [ S( "address_line1_check", Py( 0x00007f9634b356b0, ), ), ], ), }, name_py: Py( 0x00007f9634b40970, ), validator: WithDefault( WithDefaultValidator { default: Default( Py( 0x00007f963952d100, ), ), on_error: Raise, validator: Nullable( NullableValidator { validator: Str( StrValidator { strict: false, coerce_numbers_to_str: false, }, ), name: "nullable[str]", }, ), validate_default: false, copy_default: false, name: "default[nullable[str]]", undefined: Py( 0x00007f963748e3d0, ), }, ), frozen: false, }, Field { name: "address_postal_code_check", lookup_key: Simple { key: "address_postal_code_check", py_key: Py( 0x00007f9634b492f0, ), path: LookupPath( [ S( "address_postal_code_check", Py( 0x00007f9634b49390, ), ), ], ), }, name_py: Py( 0x00007f9634b48f30, ), validator: WithDefault( WithDefaultValidator { default: Default( Py( 0x00007f963952d100, ), ), on_error: Raise, validator: Nullable( NullableValidator { validator: Str( StrValidator { strict: false, coerce_numbers_to_str: false, }, ), name: "nullable[str]", }, ), validate_default: false, copy_default: false, name: "default[nullable[str]]", undefined: Py( 0x00007f963748e3d0, ), }, ), frozen: false, }, Field { name: "cvc_check", lookup_key: Simple { key: "cvc_check", py_key: Py( 0x00007f9634b355f0, ), path: LookupPath( [ S( "cvc_check", Py( 0x00007f9634b35630, ), ), ], ), }, name_py: Py( 0x00007f9634b42070, ), validator: WithDefault( WithDefaultValidator { default: Default( Py( 0x00007f963952d100, ), ), on_error: Raise, validator: Nullable( NullableValidator { validator: Str( StrValidator { strict: false, coerce_numbers_to_str: false, }, ), name: "nullable[str]", }, ), validate_default: false, copy_default: false, name: "default[nullable[str]]", undefined: Py( 0x00007f963748e3d0, ), }, ), frozen: false, }, ], model_name: "PaymentMethodCardChecks", extra_behavior: Ignore, extras_validator: None, strict: false, from_attributes: false, loc_by_alias: true, }, ), class: Py( 0x000055b5e438df90, ), generic_origin: None, post_init: None, frozen: false, custom_init: false, root_model: false, undefined: Py( 0x00007f963748e3d0, ), name: "PaymentMethodCardChecks", }, ), validate_default: false, copy_default: true, name: "default[PaymentMethodCardChecks]", undefined: Py( 0x00007f963748e3d0, ), }, ), frozen: false, }, Field { name: "country", lookup_key: Simple { key: "country", py_key: Py( 0x00007f96357f0d20, ), path: LookupPath( [ S( "country", Py( 0x00007f96357f0db0, ), ), ], ), }, name_py: Py( 0x00007f963579f390, ), validator: WithDefault( WithDefaultValidator { default: Default( Py( 0x00007f963952d100, ), ), on_error: Raise, validator: Nullable( NullableValidator { validator: Str( StrValidator { strict: false, coerce_numbers_to_str: false, }, ), name: "nullable[str]", }, ), validate_default: false, copy_default: false, name: "default[nullable[str]]", undefined: Py( 0x00007f963748e3d0, ), }, ), frozen: false, }, Field { name: "exp_month", lookup_key: Simple { key: "exp_month", py_key: Py( 0x00007f9634b355b0, ), path: LookupPath( [ S( "exp_month", Py( 0x00007f9634b35570, ), ), ], ), }, name_py: Py( 0x00007f9634b40d70, ), validator: WithDefault( WithDefaultValidator { default: Default( Py( 0x00007f9639614b28, ), ), on_error: Raise, validator: Int( IntValidator { strict: false, }, ), validate_default: false, copy_default: false, name: "default[int]", undefined: Py( 0x00007f963748e3d0, ), }, ), frozen: false, }, Field { name: "exp_year", lookup_key: Simple { key: "exp_year", py_key: Py( 0x00007f9634b35530, ), path: LookupPath( [ S( "exp_year", Py( 0x00007f9634b354f0, ), ), ], ), }, name_py: Py( 0x00007f9634b40cf0, ), validator: WithDefault( WithDefaultValidator { default: Default( Py( 0x00007f9639614b28, ), ), on_error: Raise, validator: Int( IntValidator { strict: false, }, ), validate_default: false, copy_default: false, name: "default[int]", undefined: Py( 0x00007f963748e3d0, ), }, ), frozen: false, }, Field { name: "fingerprint", lookup_key: Simple { key: "fingerprint", py_key: Py( 0x00007f9634b354b0, ), path: LookupPath( [ S( "fingerprint", Py( 0x00007f9634b35470, ), ), ], ), }, name_py: Py( 0x00007f963631af30, ), validator: WithDefault( WithDefaultValidator { default: Default( Py( 0x00007f963952d100, ), ), on_error: Raise, validator: Nullable( NullableValidator { validator: Str( StrValidator { strict: false, coerce_numbers_to_str: false, }, ), name: "nullable[str]", }, ), validate_default: false, copy_default: false, name: "default[nullable[str]]", undefined: Py( 0x00007f963748e3d0, ), }, ), frozen: false, }, Field { name: "funding", lookup_key: Simple { key: "funding", py_key: Py( 0x00007f96357f0d80, ), path: LookupPath( [ S( "funding", Py( 0x00007f96357f1020, ), ), ], ), }, name_py: Py( 0x00007f96357f0870, ), validator: WithDefault( WithDefaultValidator { default: Default( Py( 0x00007f963952d100, ), ), on_error: Raise, validator: Nullable( NullableValidator { validator: Str( StrValidator { strict: false, coerce_numbers_to_str: false, }, ), name: "nullable[str]", }, ), validate_default: false, copy_default: false, name: "default[nullable[str]]", undefined: Py( 0x00007f963748e3d0, ), }, ), frozen: false, }, Field { name: "last4", lookup_key: Simple { key: "last4", py_key: Py( 0x00007f96357f1050, ), path: LookupPath( [ S( "last4", Py( 0x00007f96357f1080, ), ), ], ), }, name_py: Py( 0x00007f96357a4720, ), validator: WithDefault( WithDefaultValidator { default: Default( Py( 0x00007f963952d100, ), ), on_error: Raise, validator: Nullable( NullableValidator { validator: Str( StrValidator { strict: false, coerce_numbers_to_str: false, }, ), name: "nullable[str]", }, ), validate_default: false, copy_default: false, name: "default[nullable[str]]", undefined: Py( 0x00007f963748e3d0, ), }, ), frozen: false, }, ], model_name: "CardDetails", extra_behavior: Ignore, extras_validator: None, strict: false, from_attributes: false, loc_by_alias: true, }, ), class: Py( 0x000055b5e4390e00, ), generic_origin: None, post_init: None, frozen: false, custom_init: false, root_model: false, undefined: Py( 0x00007f963748e3d0, ), name: "CardDetails", }, ), definitions=[], cache_strings=True)[source]
- The - pydantic-core- SchemaValidatorused to validate instances of the model.
 - __repr_recursion__(object)[source]
- Returns the string representation of a recursive object. - Return type:
 
 - __rich_repr__()[source]
- Used by Rich (https://rich.readthedocs.io/en/stable/pretty.html) to pretty print objects. 
 - __signature__: ClassVar[Signature] = <Signature (*, brand: Optional[str] = None, checks: kittycad.models.payment_method_card_checks.PaymentMethodCardChecks = {}, country: Optional[str] = None, exp_month: int = 0, exp_year: int = 0, fingerprint: Optional[str] = None, funding: Optional[str] = None, last4: Optional[str] = None) -> None>[source]
- The synthesized - __init__[- Signature][inspect.Signature] of the model.
 - __slots__ = ('__dict__', '__pydantic_fields_set__', '__pydantic_extra__', '__pydantic_private__')[source]
 - 
checks: PaymentMethodCardChecks[source]
 - copy(*, include=None, exclude=None, update=None, deep=False)[source]
- Returns a copy of the model. - !!! warning “Deprecated”
- This method is now deprecated; use - model_copyinstead.
 - If you need - includeor- exclude, use:- `python {test="skip" lint="skip"} data = self.model_dump(include=include, exclude=exclude, round_trip=True) data = {**data, **(update or {})} copied = self.model_validate(data) `- Parameters:
- include – Optional set or mapping specifying which fields to include in the copied model. 
- exclude – Optional set or mapping specifying which fields to exclude in the copied model. 
- update – Optional dictionary of field-value pairs to override field values in the copied model. 
- deep – If True, the values of fields that are Pydantic models will be deep-copied. 
 
- Returns:
- A copy of the model with included, excluded and updated fields as specified. 
 
 - dict(*, include=None, exclude=None, by_alias=False, exclude_unset=False, exclude_defaults=False, exclude_none=False)[source]
 - json(*, include=None, exclude=None, by_alias=False, exclude_unset=False, exclude_defaults=False, exclude_none=False, encoder=PydanticUndefined, models_as_dict=PydanticUndefined, **dumps_kwargs)[source]
- Return type:
 
 - model_config: ClassVar[ConfigDict] = {'protected_namespaces': ()}[source]
- Configuration for the model, should be a dictionary conforming to [ - ConfigDict][pydantic.config.ConfigDict].
 - classmethod model_construct(_fields_set=None, **values)[source]
- Creates a new instance of the - Modelclass with validated data.- Creates a new model setting - __dict__and- __pydantic_fields_set__from trusted or pre-validated data. Default values are respected, but no other validation is performed.- !!! note
- model_construct()generally respects the- model_config.extrasetting on the provided model. That is, if- model_config.extra == 'allow', then all extra passed values are added to the model instance’s- __dict__and- __pydantic_extra__fields. If- model_config.extra == 'ignore'(the default), then all extra passed values are ignored. Because no validation is performed with a call to- model_construct(), having- model_config.extra == 'forbid'does not result in an error if extra values are passed, but they will be ignored.
 - Parameters:
- _fields_set ( - set[- str] |- None) – A set of field names that were originally explicitly set during instantiation. If provided, this is directly used for the [- model_fields_set][pydantic.BaseModel.model_fields_set] attribute. Otherwise, the field names from the- valuesargument will be used.
- values ( - Any) – Trusted or pre-validated data dictionary.
 
- Return type:
- Self
- Returns:
- A new instance of the - Modelclass with validated data.
 
 - model_copy(*, update=None, deep=False)[source]
- Usage docs: https://docs.pydantic.dev/2.10/concepts/serialization/#model_copy - Returns a copy of the model. 
 - model_dump(*, mode='python', include=None, exclude=None, context=None, by_alias=False, exclude_unset=False, exclude_defaults=False, exclude_none=False, round_trip=False, warnings=True, serialize_as_any=False)[source]
- Usage docs: https://docs.pydantic.dev/2.10/concepts/serialization/#modelmodel_dump - Generate a dictionary representation of the model, optionally specifying which fields to include or exclude. - Parameters:
- mode ( - Union[- Literal[- 'json',- 'python'],- str]) – The mode in which- to_pythonshould run. If mode is ‘json’, the output will only contain JSON serializable types. If mode is ‘python’, the output may contain non-JSON-serializable Python objects.
- include ( - Union[- Set[- int],- Set[- str],- Mapping[- int,- Union[- Set[- int],- Set[- str],- Mapping[- int,- Union[IncEx,- bool]],- Mapping[- str,- Union[IncEx,- bool]],- bool]],- Mapping[- str,- Union[- Set[- int],- Set[- str],- Mapping[- int,- Union[IncEx,- bool]],- Mapping[- str,- Union[IncEx,- bool]],- bool]],- None]) – A set of fields to include in the output.
- exclude ( - Union[- Set[- int],- Set[- str],- Mapping[- int,- Union[- Set[- int],- Set[- str],- Mapping[- int,- Union[IncEx,- bool]],- Mapping[- str,- Union[IncEx,- bool]],- bool]],- Mapping[- str,- Union[- Set[- int],- Set[- str],- Mapping[- int,- Union[IncEx,- bool]],- Mapping[- str,- Union[IncEx,- bool]],- bool]],- None]) – A set of fields to exclude from the output.
- context ( - Any|- None) – Additional context to pass to the serializer.
- by_alias ( - bool) – Whether to use the field’s alias in the dictionary key if defined.
- exclude_unset ( - bool) – Whether to exclude fields that have not been explicitly set.
- exclude_defaults ( - bool) – Whether to exclude fields that are set to their default value.
- exclude_none ( - bool) – Whether to exclude fields that have a value of- None.
- round_trip ( - bool) – If True, dumped values should be valid as input for non-idempotent types such as Json[T].
- warnings ( - Union[- bool,- Literal[- 'none',- 'warn',- 'error']]) – How to handle serialization errors. False/”none” ignores them, True/”warn” logs errors, “error” raises a [- PydanticSerializationError][pydantic_core.PydanticSerializationError].
- serialize_as_any ( - bool) – Whether to serialize fields with duck-typing serialization behavior.
 
- Return type:
- Returns:
- A dictionary representation of the model. 
 
 - model_dump_json(*, indent=None, include=None, exclude=None, context=None, by_alias=False, exclude_unset=False, exclude_defaults=False, exclude_none=False, round_trip=False, warnings=True, serialize_as_any=False)[source]
- Usage docs: https://docs.pydantic.dev/2.10/concepts/serialization/#modelmodel_dump_json - Generates a JSON representation of the model using Pydantic’s - to_jsonmethod.- Parameters:
- indent ( - int|- None) – Indentation to use in the JSON output. If None is passed, the output will be compact.
- include ( - Union[- Set[- int],- Set[- str],- Mapping[- int,- Union[- Set[- int],- Set[- str],- Mapping[- int,- Union[IncEx,- bool]],- Mapping[- str,- Union[IncEx,- bool]],- bool]],- Mapping[- str,- Union[- Set[- int],- Set[- str],- Mapping[- int,- Union[IncEx,- bool]],- Mapping[- str,- Union[IncEx,- bool]],- bool]],- None]) – Field(s) to include in the JSON output.
- exclude ( - Union[- Set[- int],- Set[- str],- Mapping[- int,- Union[- Set[- int],- Set[- str],- Mapping[- int,- Union[IncEx,- bool]],- Mapping[- str,- Union[IncEx,- bool]],- bool]],- Mapping[- str,- Union[- Set[- int],- Set[- str],- Mapping[- int,- Union[IncEx,- bool]],- Mapping[- str,- Union[IncEx,- bool]],- bool]],- None]) – Field(s) to exclude from the JSON output.
- context ( - Any|- None) – Additional context to pass to the serializer.
- by_alias ( - bool) – Whether to serialize using field aliases.
- exclude_unset ( - bool) – Whether to exclude fields that have not been explicitly set.
- exclude_defaults ( - bool) – Whether to exclude fields that are set to their default value.
- exclude_none ( - bool) – Whether to exclude fields that have a value of- None.
- round_trip ( - bool) – If True, dumped values should be valid as input for non-idempotent types such as Json[T].
- warnings ( - Union[- bool,- Literal[- 'none',- 'warn',- 'error']]) – How to handle serialization errors. False/”none” ignores them, True/”warn” logs errors, “error” raises a [- PydanticSerializationError][pydantic_core.PydanticSerializationError].
- serialize_as_any ( - bool) – Whether to serialize fields with duck-typing serialization behavior.
 
- Return type:
- Returns:
- A JSON string representation of the model. 
 
 - property model_extra: dict[str, Any] | None[source]
- Get extra fields set during validation. - Returns:
- A dictionary of extra fields, or - Noneif- config.extrais not set to- "allow".
 
 - model_fields: ClassVar[dict[str, FieldInfo]] = {'brand': FieldInfo(annotation=Union[str, NoneType], required=False, default=None), 'checks': FieldInfo(annotation=PaymentMethodCardChecks, required=False, default={}), 'country': FieldInfo(annotation=Union[str, NoneType], required=False, default=None), 'exp_month': FieldInfo(annotation=int, required=False, default=0), 'exp_year': FieldInfo(annotation=int, required=False, default=0), 'fingerprint': FieldInfo(annotation=Union[str, NoneType], required=False, default=None), 'funding': FieldInfo(annotation=Union[str, NoneType], required=False, default=None), 'last4': FieldInfo(annotation=Union[str, NoneType], required=False, default=None)}[source]
 - property model_fields_set: set[str][source]
- Returns the set of fields that have been explicitly set on this model instance. - Returns:
- A set of strings representing the fields that have been set,
- i.e. that were not filled from defaults. 
 
 
 - classmethod model_json_schema(by_alias=True, ref_template='#/$defs/{model}', schema_generator=<class 'pydantic.json_schema.GenerateJsonSchema'>, mode='validation')[source]
- Generates a JSON schema for a model class. - Parameters:
- by_alias ( - bool) – Whether to use attribute aliases or not.
- ref_template ( - str) – The reference template.
- schema_generator ( - type[- GenerateJsonSchema]) – To override the logic used to generate the JSON schema, as a subclass of- GenerateJsonSchemawith your desired modifications
- mode ( - Literal[- 'validation',- 'serialization']) – The mode in which to generate the schema.
 
- Return type:
- Returns:
- The JSON schema for the given model class. 
 
 - classmethod model_parametrized_name(params)[source]
- Compute the class name for parametrizations of generic classes. - This method can be overridden to achieve a custom naming scheme for generic BaseModels. - Parameters:
- params ( - tuple[- type[- Any],- ...]) – Tuple of types of the class. Given a generic class- Modelwith 2 type variables and a concrete model- Model[str, int], the value- (str, int)would be passed to- params.
- Return type:
- Returns:
- String representing the new class where - paramsare passed to- clsas type variables.
- Raises:
- TypeError – Raised when trying to generate concrete names for non-generic models. 
 
 - model_post_init(_BaseModel__context)[source]
- Override this method to perform additional initialization after - __init__and- model_construct. This is useful if you want to do some validation that requires the entire model to be initialized.- Return type:
 
 - classmethod model_rebuild(*, force=False, raise_errors=True, _parent_namespace_depth=2, _types_namespace=None)[source]
- Try to rebuild the pydantic-core schema for the model. - This may be necessary when one of the annotations is a ForwardRef which could not be resolved during the initial attempt to build the schema, and automatic rebuilding fails. - Parameters:
- force ( - bool) – Whether to force the rebuilding of the model schema, defaults to- False.
- raise_errors ( - bool) – Whether to raise errors, defaults to- True.
- _parent_namespace_depth ( - int) – The depth level of the parent namespace, defaults to 2.
- _types_namespace ( - Optional[- Mapping[- str,- Any]]) – The types namespace, defaults to- None.
 
- Return type:
- Returns:
- Returns - Noneif the schema is already “complete” and rebuilding was not required. If rebuilding _was_ required, returns- Trueif rebuilding was successful, otherwise- False.
 
 - classmethod model_validate(obj, *, strict=None, from_attributes=None, context=None)[source]
- Validate a pydantic model instance. - Parameters:
- Raises:
- ValidationError – If the object could not be validated. 
- Return type:
- Self
- Returns:
- The validated model instance. 
 
 - classmethod model_validate_json(json_data, *, strict=None, context=None)[source]
- Usage docs: https://docs.pydantic.dev/2.10/concepts/json/#json-parsing - Validate the given JSON data against the Pydantic model. - Parameters:
- Return type:
- Self
- Returns:
- The validated Pydantic model. 
- Raises:
- ValidationError – If - json_datais not a JSON string or the object could not be validated.
 
 - classmethod model_validate_strings(obj, *, strict=None, context=None)[source]
- Validate the given object with string data against the Pydantic model. 
 - classmethod parse_file(path, *, content_type=None, encoding='utf8', proto=None, allow_pickle=False)[source]
- Return type:
- Self
 
 - classmethod parse_raw(b, *, content_type=None, encoding='utf8', proto=None, allow_pickle=False)[source]
- Return type:
- Self