""" Options: Date: 2025-10-24 22:27:32 Version: 8.30 Tip: To override a DTO option, remove "#" prefix before updating BaseUrl: https://api.sanctionssearch.com/v2 #GlobalNamespace: #AddServiceStackTypes: True #AddResponseStatus: False #AddImplicitVersion: #AddDescriptionAsComments: True IncludeTypes: AddSubUser.* #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 @dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE) @dataclass class Authentication: # @ApiMember(Description="The API User ID provided by us when you signed up to use our API. Can be provided in the request body, or as a header parameter (X-Api-User)", IsRequired=true, ParameterType="header, body") api_user_id: Optional[str] = None """ The API User ID provided by us when you signed up to use our API. Can be provided in the request body, or as a header parameter (X-Api-User) """ # @ApiMember(Description="The API User Key provided by us when you signed up to use our API. Can be provided in the request body, or as a header parameter (X-Api-Key)", IsRequired=true, ParameterType="header, body") api_user_key: Optional[str] = None """ The API User Key provided by us when you signed up to use our API. Can be provided in the request body, or as a header parameter (X-Api-Key) """ # @ApiMember(Description="The User ID of the user making the request (e.g. a sub user). This is optional but can be used to associate API requests with a specific user, thereby allowing user permissions to be enforced. Can be provided in the body, or as a header parameter (X-User-Id).", ParameterType="header, body") user_id: Optional[str] = None """ The User ID of the user making the request (e.g. a sub user). This is optional but can be used to associate API requests with a specific user, thereby allowing user permissions to be enforced. Can be provided in the body, or as a header parameter (X-User-Id). """ @dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE) @dataclass class BaseRequest(IBaseRequest): # @ApiMember(Description="The authentication credentials", IsRequired=true, ParameterType="header, body") authentication: Optional[Authentication] = None """ The authentication credentials """ class IBaseRequest: authentication: Optional[Authentication] = None @dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE) @dataclass class AddSubUserRequest: user_name: Optional[str] = None name: Optional[str] = None email: Optional[str] = None is_admin: bool = False can_resolve_searches: bool = False can_delete_searches: bool = False send_welcome_email: bool = False @dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE) @dataclass class BaseResponse(IBaseDataResponse, IHasResponseStatus): # @ApiMember(Description="The status of the response") response_status: Optional[ResponseStatus] = None """ The status of the response """ @dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE) @dataclass class ArrayOfUserNames(List[str]): pass @dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE) @dataclass class SubUser: # @ApiMember(Description="Is this user the main user (i.e. the user who created the account)") is_main_user: bool = False """ Is this user the main user (i.e. the user who created the account) """ # @ApiMember(Description="The sub user's id (GUID)") user_id: Optional[str] = None """ The sub user's id (GUID) """ # @ApiMember(Description="The sub user's UserName (i.e. the sign-in username)") user_name: Optional[str] = None """ The sub user's UserName (i.e. the sign-in username) """ # @ApiMember(Description="The sub user's name") name: Optional[str] = None """ The sub user's name """ # @ApiMember(Description="The sub user's email address") email: Optional[str] = None """ The sub user's email address """ # @ApiMember(Description="Does this sub user have admin privileges, such as managing purchases and sub users") is_admin: bool = False """ Does this sub user have admin privileges, such as managing purchases and sub users """ # @ApiMember(Description="Can this sub user resolve searches (UpdateSearch) they have access to") can_resolve_searches: bool = False """ Can this sub user resolve searches (UpdateSearch) they have access to """ # @ApiMember(Description="Can this sub user delete searches (DeleteSearch) they have access to") can_delete_searches: bool = False """ Can this sub user delete searches (DeleteSearch) they have access to """ # @ApiMember(Description="The user names for which searches will be made available to the sub user") permissions: Optional[ArrayOfUserNames] = None """ The user names for which searches will be made available to the sub user """ @dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE) @dataclass class AddSubUserData(BaseResponse): # @ApiMember(Description="The sub user") sub_user: Optional[SubUser] = None """ The sub user """ class IBaseDataResponse: response_status: Optional[ResponseStatus] = None class IHasResponseStatus: response_status: Optional[ResponseStatus] = None @dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE) @dataclass class AddSubUserResponse: # @ApiMember(Description="The response data") data: Optional[AddSubUserData] = None """ The response data """ # @Route("/subusers/create", "POST") @dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE) @dataclass class AddSubUser(BaseRequest, IReturn[AddSubUserResponse]): request: Optional[AddSubUserRequest] = None