from typing import Any, Dict, List, Optional, Union
from enum import Enum
from pydantic import BaseModel, Field
from .payment_initiation_consent_constraints import PaymentInitiationConsentConstraints
[docs]class PaymentInitiationConsent(BaseModel):
created_at: str
"""Consent creation timestamp, in [ISO 8601](https://wikipedia.org/wiki/ISO_8601) format."""
recipient_id: str
"""The ID of the recipient the payment consent is for."""
consent_id: str
"""The consent ID."""
status: str
"""The status of the payment consent.
`UNAUTHORISED`: Consent created, but requires user authorisation.
`REJECTED`: Consent authorisation was rejected by the user and/or the bank.
`AUTHORISED`: Consent is active and ready to be used.
`REVOKED`: Consent has been revoked and can no longer be used.
`EXPIRED`: Consent is no longer valid."""
reference: str
"""A reference for the payment consent."""
constraints: PaymentInitiationConsentConstraints
"""Limitations that will be applied to payments initiated using the payment consent."""
scopes: List[str]
"""An array of payment consent scopes."""
[docs] def json(self, **kwargs: Any) -> str:
"""Return a json string representation of the object. Takes same keyword arguments as pydantic.BaseModel.json"""
kwargs.setdefault("by_alias", True)
return super().json(**kwargs)
[docs] def dict(self, **kwargs: Any) -> Dict[str, Any]:
"""Return a dict representation of the object. Takes same keyword arguments as pydantic.BaseModel.dict"""
kwargs.setdefault("by_alias", True)
return super().dict(**kwargs)
[docs] @classmethod
def parse_obj(cls, data: Any) -> "PaymentInitiationConsent":
"""Parse a dict into the object. Takes same keyword arguments as pydantic.BaseModel.parse_obj"""
return super().parse_obj(data)
[docs] @classmethod
def parse_raw(cls, b: Union[bytes, str], **kwargs: Any) -> "PaymentInitiationConsent":
"""Parse a json string into the object. Takes same keyword arguments as pydantic.BaseModel.parse_raw"""
return super().parse_raw(b, **kwargs)