""" Options: Date: 2026-05-14 01:06:16 Version: 10.05 Tip: To override a DTO option, remove "#" prefix before updating BaseUrl: https://testapi.bokamera.se #GlobalNamespace: #AddServiceStackTypes: True #AddResponseStatus: False #AddImplicitVersion: #AddDescriptionAsComments: True IncludeTypes: UpdateWidgetConfiguration.* #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 Object = TypeVar('Object') class ICompany: company_id: Optional[str] = None @dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE) @dataclass class WidgetConfigurationResponse: id: Optional[str] = None company_id: Optional[str] = None name: Optional[str] = None slug: Optional[str] = None description: Optional[str] = None configuration: Optional[str] = None schema_version: int = 0 created_date: datetime.datetime = datetime.datetime(1, 1, 1) updated_date: Optional[datetime.datetime] = None response_status: Optional[ResponseStatus] = None # @Route("/widget/configuration/{Id}", "PUT") # @ApiResponse(Description="Returned if there is a validation error on the input parameters", StatusCode=400) # @ApiResponse(Description="Returned if the configuration was not found", StatusCode=404) # @ApiResponse(Description="Returned if the current user is not allowed to perform the action", StatusCode=401) # @ValidateRequest(Validator="IsAuthenticated") @dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE) @dataclass class UpdateWidgetConfiguration(IReturn[WidgetConfigurationResponse], ICompany): # @ApiMember(Description="The company id, if empty will use the company id for the user you are logged in with.") company_id: Optional[str] = None """ The company id, if empty will use the company id for the user you are logged in with. """ # @ApiMember(Description="The widget configuration id (6-character NanoID).", IsRequired=true, ParameterType="path") id: Optional[str] = None """ The widget configuration id (6-character NanoID). """ # @ApiMember(Description="The widget configuration name.", IsRequired=true) name: Optional[str] = None """ The widget configuration name. """ # @ApiMember(Description="Optional slug (URL-friendly identifier). The API will append the last 3 characters of the company ID. Example: 'hairsalon' becomes 'hairsalon-001'.") slug: Optional[str] = None """ Optional slug (URL-friendly identifier). The API will append the last 3 characters of the company ID. Example: 'hairsalon' becomes 'hairsalon-001'. """ # @ApiMember(Description="Optional description.") description: Optional[str] = None """ Optional description. """ # @ApiMember(Description="The widget configuration as a JSON string. Must validate against the schema for SchemaVersion.", IsRequired=true) configuration: Optional[str] = None """ The widget configuration as a JSON string. Must validate against the schema for SchemaVersion. """ # @ApiMember(Description="Version of the configuration schema this Configuration adheres to.", IsRequired=true) schema_version: int = 0 """ Version of the configuration schema this Configuration adheres to. """