""" Options: Date: 2025-08-04 00:03:57 Version: 8.40 Tip: To override a DTO option, remove "#" prefix before updating BaseUrl: https://active-ewebservice.biz/aeServices30/api #GlobalNamespace: #AddServiceStackTypes: True #AddResponseStatus: False #AddImplicitVersion: #AddDescriptionAsComments: True IncludeTypes: ContractFulfillmentRequest.* #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 BaseRequest: # @ApiMember(DataType="string", Description="This is your AIM API Key provided by Tri-Tech", IsRequired=true, Name="ApiKey", ParameterType="Header") api_key: Optional[str] = None """ This is your AIM API Key provided by Tri-Tech """ # @ApiMember(DataType="string", Description="The OAuthToken token return by AeServices30", IsRequired=true, Name="OAuthToken", ParameterType="Header") o_auth_token: Optional[str] = None """ The OAuthToken token return by AeServices30 """ # @ApiMember(DataType="string", Description="The Device ID of the Mobile Device. Not used for non-mobile devices.", Name="DeviceId", ParameterType="Header") device_id: Optional[str] = None """ The Device ID of the Mobile Device. Not used for non-mobile devices. """ # @ApiMember(DataType="string", Description="An identifier for your integration", IsRequired=true, Name="AppId", ParameterType="Header") app_id: Optional[str] = None """ An identifier for your integration """ @dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE) @dataclass class BaseSecureRequest(BaseRequest): # @ApiMember(DataType="string", Description="The Login Token return by the Security API. Required for secured calls.", Name="Token", ParameterType="Header") token: Optional[str] = None """ The Login Token return by the Security API. Required for secured calls. """ @dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE) @dataclass class DeliveredAccessory: id: int = 0 delivered: bool = False @dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE) @dataclass class Accessory: # @ApiMember(DataType="string", Description="The description to be used for the Accessory", IsRequired=true, Name="Desc", ParameterType="body") desc: Optional[str] = None """ The description to be used for the Accessory """ # @ApiMember(DataType="decimal", Description="The price to be used for the Accessory", Name="Price", ParameterType="body") price: Decimal = decimal.Decimal(0) """ The price to be used for the Accessory """ # @ApiMember(DataType="string", Description="The type of Accessory. A is Accessory, D is Delivery Option, and M is Maintenance", Name="Type", ParameterType="body") type: Optional[str] = None """ The type of Accessory. A is Accessory, D is Delivery Option, and M is Maintenance """ # @ApiMember(DataType="int", Description="The category # in AIM to be linked to this accessory.", Name="CatNum", ParameterType="body") cat_num: int = 0 """ The category # in AIM to be linked to this accessory. """ # @ApiMember(DataType="string", Description="A SKU or Package Deal package SKU can be sent here to link the accessory to that SKU or package.", Name="Sku", ParameterType="body") sku: Optional[str] = None """ A SKU or Package Deal package SKU can be sent here to link the accessory to that SKU or package. """ # @ApiMember(DataType="bool", Description="Internal Use Only", Name="Report", ParameterType="body") report: Optional[bool] = None """ Internal Use Only """ @dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE) @dataclass class UpdateContractObj: ref: Optional[str] = None serial: Optional[str] = None serial_pk: Optional[int] = None cash_price: Optional[Decimal] = None new_status: Optional[str] = None notes: Optional[str] = None delivery_date: Optional[datetime.datetime] = None delivered_accessories: Optional[List[DeliveredAccessory]] = None deleted_accessory_ids: Optional[List[int]] = None added_accessories: Optional[List[Accessory]] = None first_due: Optional[datetime.datetime] = None new_customer_acct: Optional[int] = None unlock: bool = False @dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE) @dataclass class UpdateContractErrorObj: ref: Optional[str] = None error_message: Optional[str] = None @dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE) @dataclass class BaseResponse: # @ApiMember(DataType="BaseResponseResult", Description="", Name="Status", ParameterType="body") status: Optional[BaseResponseResult] = None """ """ @dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE) @dataclass class ContractFulfillmentResponse(BaseResponse): mass_update_errors: Optional[List[UpdateContractErrorObj]] = None # @Route("/ContractFulfillment", "POST") # @Route("/C2BSetContractSerial", "POST") @dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE) @dataclass class ContractFulfillmentRequest(BaseSecureRequest, IReturn[ContractFulfillmentResponse]): """ ContractFulfillmentRequires active-e Contracts Service.This API call used to be named C2BSetContractSerial. """ ref: Optional[str] = None serial: Optional[str] = None serial_pk: Optional[int] = None cash_price: Optional[Decimal] = None new_status: Optional[str] = None notes: Optional[str] = None delivery_date: Optional[datetime.datetime] = None delivered_accessories: Optional[List[DeliveredAccessory]] = None deleted_accessory_ids: Optional[List[int]] = None added_accessories: Optional[List[Accessory]] = None first_due: Optional[datetime.datetime] = None customer_acct: Optional[int] = None unlock: bool = False mass_update_items: Optional[List[UpdateContractObj]] = None