""" Options: Date: 2024-12-27 08:53:18 Version: 8.12 Tip: To override a DTO option, remove "#" prefix before updating BaseUrl: https://taxfiling.pwc.de #GlobalNamespace: #AddServiceStackTypes: True #AddResponseStatus: False #AddImplicitVersion: #AddDescriptionAsComments: True IncludeTypes: RetrieveCustomer.* #ExcludeTypes: #DefaultImports: datetime,decimal,marshmallow.fields:*,servicestack:*,typing:*,dataclasses:dataclass/field,dataclasses_json:dataclass_json/LetterCase/Undefined/config,enum:Enum/IntEnum #DataClass: #DataClassJson: """ import datetime import decimal from marshmallow.fields import * from servicestack import * from typing import * from dataclasses import dataclass, field from dataclasses_json import dataclass_json, LetterCase, Undefined, config from enum import Enum, IntEnum # @Api(Description="Represents a user account.") @dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE) @dataclass class Account(IHasUserName): """ Represents a user account. """ # @ApiMember(Description="The unique identifier of the user account.", IsRequired=true) id: int = 0 """ The unique identifier of the user account. """ # @ApiMember(Description="The position of this instance in a collection of 'Account' instances", IsRequired=true) index: int = 0 """ The position of this instance in a collection of 'Account' instances """ # @ApiMember(Description="The unique identifier of the customer associated with this account.", IsRequired=true) ref_id: Optional[int] = None """ The unique identifier of the customer associated with this account. """ # @ApiMember(Description="The string representation of the unique identifier of a reference that associates with this user account. This should have the same value as 'RefId'.") ref_id_str: Optional[str] = None """ The string representation of the unique identifier of a reference that associates with this user account. This should have the same value as 'RefId'. """ # @ApiMember(Description="The unique user name of the user account.", IsRequired=true) user_name: Optional[str] = None """ The unique user name of the user account. """ # @ApiMember(Description="The electronic mail address of the user account.") email: Optional[str] = None """ The electronic mail address of the user account. """ # @ApiMember(Description="The friendly name of the user account.") display_name: Optional[str] = None """ The friendly name of the user account. """ # @ApiMember(Description="The first name of the owner (natural person) of the user account.") first_name: Optional[str] = None """ The first name of the owner (natural person) of the user account. """ # @ApiMember(Description="The last name of the owner (natural person) of the user account.") last_name: Optional[str] = None """ The last name of the owner (natural person) of the user account. """ # @ApiMember(Description="The unique identifier of the customer associated with this account.") full_name: Optional[str] = None """ The unique identifier of the customer associated with this account. """ # @ApiMember(Description="The gender of the owner (natural person) of the user account.") gender: Optional[str] = None """ The gender of the owner (natural person) of the user account. """ # @ApiMember(Description="The language of the owner of teh user account.") language: Optional[str] = None """ The language of the owner of teh user account. """ # @ApiMember(Description="The company, where the user is an employee.") company: Optional[str] = None """ The company, where the user is an employee. """ # @ApiMember(Description="The profile URL of the user account.", IsRequired=true) profile_url: Optional[str] = None """ The profile URL of the user account. """ # @ApiMember(Description="The roles assigned to the user account.") roles: Optional[List[str]] = None """ The roles assigned to the user account. """ # @ApiMember(Description="The permissions assigned to the user account.") permissions: Optional[List[str]] = None """ The permissions assigned to the user account. """ # @ApiMember(Description="The primary e-mail address of the user.") primary_email: Optional[str] = None """ The primary e-mail address of the user. """ # @ApiMember(Description="Random data to enhance the security of the user password.") salt: Optional[str] = None """ Random data to enhance the security of the user password. """ # @ApiMember(Description="The hash value of the user password that the PBKDF2 algorithm produces.") password_hash: Optional[str] = None """ The hash value of the user password that the PBKDF2 algorithm produces. """ # @ApiMember(Description="The hash value of the user password that the DigestHa1 algorithm produces.") digest_ha1_hash: Optional[str] = None """ The hash value of the user password that the DigestHa1 algorithm produces. """ # @ApiMember(Description="The number of times the user account tried to sign in but failed.") invalid_login_attempts: int = 0 """ The number of times the user account tried to sign in but failed. """ # @ApiMember(Description="The last time the user account attempted a sign in.") last_login_attempt: Optional[datetime.datetime] = None """ The last time the user account attempted a sign in. """ # @ApiMember(Description="The date and time when the user acount was denied access.") locked_date: Optional[datetime.datetime] = None """ The date and time when the user acount was denied access. """ # @ApiMember(Description="The date and time when the user account was created.") created_date: datetime.datetime = datetime.datetime(1, 1, 1) """ The date and time when the user account was created. """ # @ApiMember(Description="The date and time when the user account was last modified.") modified_date: datetime.datetime = datetime.datetime(1, 1, 1) """ The date and time when the user account was last modified. """ # @ApiMember(Description="The telephone number of the owner of the user account.") phone_number: Optional[str] = None """ The telephone number of the owner of the user account. """ # @ApiMember(Description="The birth date of the owner of the user account") birth_date: Optional[datetime.datetime] = None """ The birth date of the owner of the user account """ # @ApiMember(Description="The string representation of the birth date of the user account.") birth_date_raw: Optional[str] = None """ The string representation of the birth date of the user account. """ # @ApiMember(Description="The mail address of the user account.") address: Optional[str] = None """ The mail address of the user account. """ # @ApiMember(Description="Additional information for the specified 'Address' of the user.") address2: Optional[str] = None """ Additional information for the specified 'Address' of the user. """ # @ApiMember(Description="The city of the owner of the user account.") city: Optional[str] = None """ The city of the owner of the user account. """ # @ApiMember(Description="The state of the owner of the user account.") state: Optional[str] = None """ The state of the owner of the user account. """ # @ApiMember(Description="The country of the owner of the user account. It is recommended to use the name of the associated 'Customer'.") country: Optional[str] = None """ The country of the owner of the user account. It is recommended to use the name of the associated 'Customer'. """ # @ApiMember(Description="The locale of the user account.") culture: Optional[str] = None """ The locale of the user account. """ # @ApiMember(Description="The mail address of the user account.") mail_address: Optional[str] = None """ The mail address of the user account. """ # @ApiMember(Description="The nickname of the user of the user account.") nickname: Optional[str] = None """ The nickname of the user of the user account. """ # @ApiMember(Description="The postal code of the user account.") postal_code: Optional[str] = None """ The postal code of the user account. """ # @ApiMember(Description="The time zone of the user of the user account.") time_zone: Optional[str] = None """ The time zone of the user of the user account. """ # @ApiMember(Description="Additional information to attach to the user account.") meta: Optional[Dict[str, str]] = None """ Additional information to attach to the user account. """ class CustomerType(str, Enum): INTERNAL = 'Internal' NETWORK = 'Network' EXTERNAL = 'External' # @Api(Description="Specifies a service request to retrieve a customer.") @dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE) @dataclass class RetrieveCustomerBase(IReturn[CustomerResponse], IGet): """ Specifies a service request to retrieve a customer. """ # @ApiMember(Description="The unique identifier of the customer to retrieve.") id: int = 0 """ The unique identifier of the customer to retrieve. """ # @ApiMember(Description="Should the related accounts of the customer be included in the retrieved account?") include_accounts: Optional[bool] = None """ Should the related accounts of the customer be included in the retrieved account? """ # @ApiMember(Description="Specifies the number of products to skip. Applicable only when 'IncludeAccounts' is true. ") skip_accounts: Optional[int] = None """ Specifies the number of products to skip. Applicable only when 'IncludeAccounts' is true. """ # @ApiMember(Description="Specifies the number of products to include. Applicable only when 'IncludeAccounts' is true. ") take_accounts: Optional[int] = None """ Specifies the number of products to include. Applicable only when 'IncludeAccounts' is true. """ @staticmethod def response_type(): return CustomerResponse # @Api(Description="Represents a customer (business organization or entrepreneur).") @dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE) @dataclass class Customer(IHasName): """ Represents a customer (business organization or entrepreneur). """ # @ApiMember(Description="The unique identifier of the customer.", IsRequired=true) id: int = 0 """ The unique identifier of the customer. """ # @ApiMember(Description="The position of this instance in a collection of 'Customer' instances", IsRequired=true) index: int = 0 """ The position of this instance in a collection of 'Customer' instances """ # @ApiMember(Description="Full name or organization name of customer.", IsRequired=true) # @Validate(Validator="NotEmpty") name: Optional[str] = None """ Full name or organization name of customer. """ # @ApiMember(Description="The country of residence or business of customer.") country: Optional[str] = None """ The country of residence or business of customer. """ # @ApiMember(Description="The type of customer.") type: Optional[CustomerType] = None """ The type of customer. """ # @ApiMember(Description="The list of user accounts associated with this customer.") # @Ignore() accounts: Optional[List[Account]] = None """ The list of user accounts associated with this customer. """ # @Api(Description="Specifies a base service response class that contains a structured error information.") @dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE) @dataclass class ServiceResponseBase: """ Specifies a base service response class that contains a structured error information. """ # @ApiMember(Description="Data structure that holds error information from a service operation.") response_status: Optional[ResponseStatus] = None """ Data structure that holds error information from a service operation. """ class IHasUserName: """ Specifies that a data type should have a 'UserName' property. """ user_name: Optional[str] = None class IHasName: """ Specifies that a data type should have a 'Name' property. """ name: Optional[str] = None """ The 'Name' property. """ # @Api(Description="Represents a response from a service operation that encapsulates customer data.") @dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE) @dataclass class CustomerResponse(ServiceResponseBase): """ Represents a response from a service operation that encapsulates customer data. """ # @ApiMember(Description="The customer data of the response.") customer: Optional[Customer] = None """ The customer data of the response. """ # @ApiMember(Description="The index position of the reponse in a collection, if it were returned together with other responses.") index: int = 0 """ The index position of the reponse in a collection, if it were returned together with other responses. """ # @ApiMember(Description="Data structure that holds error information from a service operation.") response_status: Optional[ResponseStatus] = None """ Data structure that holds error information from a service operation. """ # @Route("/sync/customers/{Id}", "GET") # @Api(Description="Represents a service request to retrieve a customer.") @dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE) @dataclass class RetrieveCustomer(RetrieveCustomerBase, IReturn[CustomerResponse]): """ Represents a service request to retrieve a customer. """ # @ApiMember(Description="The unique identifier of the customer to retrieve.") id: int = 0 """ The unique identifier of the customer to retrieve. """ # @ApiMember(Description="Should the related accounts of the customer be included in the retrieved account?") include_accounts: Optional[bool] = None """ Should the related accounts of the customer be included in the retrieved account? """ # @ApiMember(Description="Specifies the number of products to skip. Applicable only when 'IncludeAccounts' is true. ") skip_accounts: Optional[int] = None """ Specifies the number of products to skip. Applicable only when 'IncludeAccounts' is true. """ # @ApiMember(Description="Specifies the number of products to include. Applicable only when 'IncludeAccounts' is true. ") take_accounts: Optional[int] = None """ Specifies the number of products to include. Applicable only when 'IncludeAccounts' is true. """