/* Options: Date: 2025-09-13 18:25:20 Version: 8.80 Tip: To override a DTO option, remove "//" prefix before updating BaseUrl: https://api.bookmore.com //Package: //AddServiceStackTypes: True //AddResponseStatus: False //AddImplicitVersion: //AddDescriptionAsComments: True IncludeTypes: UpdateCustomer.* //ExcludeTypes: //InitializeCollections: False //TreatTypesAsStrings: //DefaultImports: java.math.*,java.util.*,java.io.InputStream,net.servicestack.client.* */ import java.math.* import java.util.* import java.io.InputStream import net.servicestack.client.* @Route(Path="/customers/{Id}", Verbs="PUT") @ApiResponse(Description="Returned if there is a validation error on the input parameters", StatusCode=400) // @ApiResponse(Description="Returned if the current user is not allowed to perform the action", StatusCode=401) @ValidateRequest(Validator="IsAuthenticated") open class UpdateCustomer : IReturn { /** * Enter the company and id for the customer, if blank company id and you are an admin, your company id will be used. */ @ApiMember(Description="Enter the company and id for the customer, if blank company id and you are an admin, your company id will be used.", ParameterType="query") open var CompanyId:UUID? = null /** * customer id */ @ApiMember(Description="customer id", IsRequired=true, ParameterType="path") open var Id:UUID? = null open var Firstname:String? = null open var Lastname:String? = null open var Phone:String? = null open var Email:String? = null /** * If Custom Fields are added to the customer, here you will send the id and the value for each custom field to be updated */ @ApiMember(Description="If Custom Fields are added to the customer, here you will send the id and the value for each custom field to be updated") open var CustomFields:ArrayList? = null /** * List of Access Keys */ @ApiMember(Description="List of Access Keys") open var AccessKeys:ArrayList? = null open var AccessKeysToDelete:ArrayList? = null open var SubscribedToNewsletter:Boolean? = null open var InvoiceAddress:InvoiceAddressToHandle? = null companion object { private val responseType = CustomerQueryResponse::class.java } override fun getResponseType(): Any? = UpdateCustomer.responseType } open class CustomerQueryResponse { open var Id:UUID? = null open var Firstname:String? = null open var Lastname:String? = null open var Email:String? = null open var Phone:String? = null open var ImageUrl:String? = null open var CustomFields:ArrayList? = null open var CustomFieldValues:ArrayList? = null open var Comments:ArrayList? = null open var AccessKeys:ArrayList? = null open var Updated:Date? = null open var Created:Date? = null open var ResponseStatus:Object? = null open var SubscribedToNewsletter:Boolean? = null open var InvoiceAddress:InvoiceAddressResponse? = null } open class AddCustomField { open var Id:Int? = null open var Value:String? = null } open class InvoiceAddressToHandle { open var CorporateIdentityNumber:String? = null open var InvoiceAddress1:String? = null open var InvoiceAddress2:String? = null open var InvoiceCity:String? = null open var InvoicePostalCode:String? = null open var InvoiceCountryCode:String? = null } open class AddUserAccessKey { /** * Specify 'Id' to update an existing access key, leave empty to create a new one */ @ApiMember(Description="Specify 'Id' to update an existing access key, leave empty to create a new one") open var Id:UUID? = null /** * The company ID associated with this access key */ @ApiMember(Description="The company ID associated with this access key") open var CompanyId:UUID? = null /** * The type of access key to create */ @ApiMember(Description="The type of access key to create") open var AccessKeyTypeId:Int? = null /** * The actual key value or token */ @ApiMember(Description="The actual key value or token") open var Value:String? = null /** * The customer ID this access key is associated with */ @ApiMember(Description="The customer ID this access key is associated with") open var CustomerId:UUID? = null /** * A description or note about this access key */ @ApiMember(Description="A description or note about this access key") open var Description:String? = null } open class DeleteUserAccessKey { /** * The unique identifier of the access key to delete */ @ApiMember(Description="The unique identifier of the access key to delete") open var Id:UUID? = null } open class InvoiceAddressResponse { open var InvoiceAddressId:UUID? = null open var UserId:UUID? = null open var CorporateIdentityNumber:String? = null open var InvoiceAddress1:String? = null open var InvoiceAddress2:String? = null open var InvoiceCity:String? = null open var InvoicePostalCode:String? = null open var InvoiceCountryCode:String? = null } open class CustomFieldConfigData { /** * Custom field id */ @ApiMember(Description="Custom field id") open var Id:Int? = null /** * Configuration name. Example: 'Number of persons'. */ @ApiMember(Description="Configuration name. Example: 'Number of persons'.") open var Name:String? = null /** * Custom field description. Example: 'For how many persons is this booking?' */ @ApiMember(Description="Custom field description. Example: 'For how many persons is this booking?'") open var Description:String? = null /** * Field width. Example: 20 for 20px */ @ApiMember(Description="Field width. Example: 20 for 20px") open var Width:Int? = null /** * Data field of custom field. Valid values are: TextBox, ... Example: 'TextBox' */ @ApiMember(Description="Data field of custom field. Valid values are: TextBox, ... Example: 'TextBox'") open var DataType:String? = null /** * Default value of the field. Example: '3' */ @ApiMember(Description="Default value of the field. Example: '3'") open var DefaultValue:String? = null /** * Determines if the field is required to have a value or not */ @ApiMember(Description="Determines if the field is required to have a value or not") open var IsMandatory:Boolean? = null /** * Error message shown to the user if the field data is required but not entered */ @ApiMember(Description="Error message shown to the user if the field data is required but not entered") open var MandatoryErrorMessage:String? = null /** * Max lenght of the field */ @ApiMember(Description="Max lenght of the field") open var MaxLength:Int? = null /** * If the field should have multiple lines */ @ApiMember(Description="If the field should have multiple lines") open var MultipleLineText:Boolean? = null /** * Regular expression used for validation of the field */ @ApiMember(Description="Regular expression used for validation of the field") open var RegEx:String? = null /** * Error message shown if the regular expression validation failed */ @ApiMember(Description="Error message shown if the regular expression validation failed") open var RegExErrorMessage:String? = null /** * The values to select from if Datatype is DropDown for this custom field */ @ApiMember(Description="The values to select from if Datatype is DropDown for this custom field") open var Values:ArrayList? = null } open class CustomFieldDataResponse { open var Id:Int? = null open var Column:String? = null open var Name:String? = null open var Description:String? = null open var Value:String? = null /** * Data field of custom field. Valid values are: TextBox, ... Example: 'TextBox' */ @ApiMember(Description="Data field of custom field. Valid values are: TextBox, ... Example: 'TextBox'") open var DataType:String? = null } open class UserAccessKeys : BaseModel() { @Required() open var CompanyId:UUID? = null @Required() open var AccessKeyTypeId:Int? = null @Required() open var Value:String? = null @Required() open var CustomerId:UUID? = null open var Description:String? = null @Required() open var Id:UUID? = null } open class BaseModel { } open class CustomFieldValueResponse { open var Value:String? = null } open class CustomerCommentsResponse { open var Id:Int? = null open var CustomerId:UUID? = null open var Comments:String? = null open var Updated:Date? = null open var Created:Date? = null open var ImageUrl:Uri? = null }