/* Options: Date: 2024-12-03 18:29:05 Version: 8.23 Tip: To override a DTO option, remove "//" prefix before updating BaseUrl: https://api.bokamera.se //Package: //AddServiceStackTypes: True //AddResponseStatus: False //AddImplicitVersion: //AddDescriptionAsComments: True IncludeTypes: ResourceTimeExceptionQuery.* //ExcludeTypes: //InitializeCollections: True //TreatTypesAsStrings: //DefaultImports: java.math.*,java.util.*,net.servicestack.client.*,com.google.gson.annotations.*,com.google.gson.reflect.* */ import java.math.* import java.util.* import net.servicestack.client.* import com.google.gson.annotations.* import com.google.gson.reflect.* @Route(Path="/timeexceptions", Verbs="GET") @ApiResponse(Description="You were unauthorized to call this service", StatusCode=401) // @ApiResponse(Description="You have too low privilegies to call this service", StatusCode=403) @ValidateRequest(Validator="IsAuthenticated") open class ResourceTimeExceptionQuery : QueryDb(), IReturn> { /** * The company id, if empty will use the company id for the user you are logged in with. */ @ApiMember(Description="The company id, if empty will use the company id for the user you are logged in with.") var CompanyId:UUID? = null /** * Enter the resource id's separated by comma that you want to see time exceptions for, if no value is given all time exceptions will be returned */ @ApiMember(Description="Enter the resource id's separated by comma that you want to see time exceptions for, if no value is given all time exceptions will be returned", ParameterType="query") var ResourceIds:ArrayList? = null /** * Start of interval to query for time exceptions. UTC+0 and parameter as defined by date-time - RFC3339 */ @ApiMember(DataType="dateTime", Description="Start of interval to query for time exceptions. UTC+0 and parameter as defined by date-time - RFC3339") var TimeExceptionStart:Date? = null /** * End of interval to query for time exceptions. UTC+0 and parameter as defined by date-time - RFC3339 */ @ApiMember(DataType="dateTime", Description="End of interval to query for time exceptions. UTC+0 and parameter as defined by date-time - RFC3339") var TimeExceptionEnd:Date? = null /** * Include only recurring time exceptions or not, if no value is given, all time exceptions will be returned */ @ApiMember(Description="Include only recurring time exceptions or not, if no value is given, all time exceptions will be returned", ParameterType="query") var IsRecurring:Boolean? = null /** * Include only time exceptions that are blocking, if no value is given, all time exceptions will be returned */ @ApiMember(Description="Include only time exceptions that are blocking, if no value is given, all time exceptions will be returned", ParameterType="query") var IsBlocking:Boolean? = null /** * If you want to include the resource details */ @ApiMember(DataType="boolean", Description="If you want to include the resource details", ParameterType="query") var IncludeResourceDetails:Boolean? = null /** * If you want to include google calendar sync status */ @ApiMember(DataType="boolean", Description="If you want to include google calendar sync status", ParameterType="query") var IncludeCalendarExportStatus:Boolean? = null /** * The max limit of records you want to retrieve, default is 200 */ @ApiMember(DataType="int", Description="The max limit of records you want to retrieve, default is 200", ParameterType="query") var MaxLimit:Int? = null companion object { private val responseType = object : TypeToken>(){}.type } override fun getResponseType(): Any? = ResourceTimeExceptionQuery.responseType } @DataContract open class QueryResponse { @DataMember(Order=1) var Offset:Int? = null @DataMember(Order=2) var Total:Int? = null @DataMember(Order=3) var Results:ArrayList = ArrayList() @DataMember(Order=4) var Meta:HashMap = HashMap() @DataMember(Order=5) var ResponseStatus:ResponseStatus? = null } open class QueryDb : QueryBase() { } enum class BookingStatusEnum(val value:Int) { Booked(1), Unbooked(2), Reserved(3), Canceled(4), AwaitingPayment(5), AwaitingPaymentNoTimeLimit(6), Payed(7), AwaitingPaymentRequestFromAdmin(8), AwaitingPaymentFromProvider(9), Invoiced(10), } open interface IInterval { var From:Date? var To:Date? } open class CustomFieldConfig : BaseModel() { @Ignore() var Values:ArrayList = ArrayList() var CustomField:CustomField? = null @Ignore() var RegEx:RegEx? = null @Ignore() var Services:ArrayList = ArrayList() var CustomFieldServiceRelation:ArrayList = ArrayList() @Required() var CompanyId:UUID? = null var Id:Int? = null var GroupId:Int? = null @Required() var FieldId:Int? = null @Required() var IconId:Int? = null var RegExId:Int? = null @Required() var Name:String? = null @Required() var Description:String? = null @Required() var Datatype:String? = null @Required() var MaxLength:Int? = null @Required() var IsPublic:Boolean? = null @Required() var IsHidden:Boolean? = null @Required() var IsMandatory:Boolean? = null var DefaultValue:String? = null var RegExErrorMessage:String? = null var MandatoryErrorMessage:String? = null var Width:Int? = null @Required() var MultipleLineText:Boolean? = null var ModifiedDate:Date? = null } open class Resource : BaseModel(), ICustomFieldTable, IBaseModelCreated, IBaseModelUpdated { @Ignore() var Priority:Int? = null @Ignore() var Schedules:IList? = null @Ignore() var Exceptions:IList? = null @Ignore() var Bookings:IList? = null @Ignore() var CustomFieldsConfig:IList? = null @Ignore() var CustomFieldsData:IList? = null @Required() var CompanyId:UUID? = null var Id:Int? = null @Required() var Name:String? = null @Required() var Active:Boolean? = null var Description:String? = null var ImageUrl:String? = null @Required() var UpdatedDate:Date? = null @Required() var CreatedDate:Date? = null @Required() var Color:String? = null var Email:String? = null var MobilePhone:String? = null var EmailNotification:Boolean? = null var SMSNotification:Boolean? = null @Required() var SendSMSReminder:Boolean? = null @Required() var SendEmailReminder:Boolean? = null var ModifiedDate:Date? = null var AccessGroup:String? = null var TextField1:String? = null var TextField2:String? = null var TextField3:String? = null var TextField4:String? = null var TextField5:String? = null var TextField6:String? = null var TextField7:String? = null var TextField8:String? = null var TextField9:String? = null var TextField10:String? = null var TextField11:String? = null var TextField12:String? = null var TextField13:String? = null var TextField14:String? = null var TextField15:String? = null var TextField16:String? = null var TextField17:String? = null var TextField18:String? = null var TextField19:String? = null var TextField20:String? = null } open class ResourceTimeException : BaseModel(), IInterval, IBaseModelCreated, IBaseModelUpdated { var DayOfWeeks:ArrayList = ArrayList() var Resources:ArrayList = ArrayList() @Ignore() var CalendarExport:CalendarExport? = null @Required() var CompanyId:UUID? = null var Id:Int? = null @Required() var ReasonText:String? = null @Required() var FromTime:TimeSpan? = null @Required() var ToTime:TimeSpan? = null @Required() var UpdatedDate:Date? = null @Required() var CreatedDate:Date? = null var Color:String? = null var ReasonTextPublic:String? = null @Required() var BlockTime:Boolean? = null @Required() var Private:Boolean? = null var ModifiedDate:Date? = null @Required() var From:Date? = null @Required() var To:Date? = null } open class CustomFieldDataResponse { var Id:Int? = null var Column:String? = null var Name:String? = null var Description:String? = null 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'") var DataType:String? = null } open class BookedCustomer { var Id:UUID? = null var Firstname:String? = null var Lastname:String? = null var Email:String? = null var Phone:String? = null var FacebookUserName:String? = null var ImageUrl:String? = null var CorporateIdentityNumber:String? = null var InvoiceAddress1:String? = null var InvoiceAddress2:String? = null var InvoiceCity:String? = null var InvoicePostalCode:String? = null var InvoiceCountryCode:String? = null } open class TimeExceptionReosurceDetails { /** * Ids of the resources that owns this exception */ @ApiMember(Description="Ids of the resources that owns this exception") var Id:Int? = null /** * Name of the resource */ @ApiMember(Description="Name of the resource") var Name:String? = null /** * Description of the resource */ @ApiMember(Description="Description of the resource") var Description:String? = null /** * Color of the resource */ @ApiMember(Description="Color of the resource") var Color:String? = null /** * Image of the resource */ @ApiMember(Description="Image of the resource") var ImageUrl:Uri? = null var ResponseStatus:ResponseStatus? = null } open class ExceptionCalendarExportStatus { var CalendarId:String? = null var ExceptionId:Int? = null var Synced:Boolean? = null } open class DayOfWeekDto { var DayOfWeekId:Int? = null var DotNetDayOfWeekId:Int? = null var DayOfWeek:String? = null } enum class ScheduleType { NotDefined, RecurringSchedule, DateSchedule, } @DataContract open class QueryBase { /** * Skip over a given number of elements in a sequence and then return the remainder. Use this when you need paging.

Example:
?skip=10&orderBy=Id */ @DataMember(Order=1) var Skip:Int? = null /** * Return a given number of elements in a sequence and then skip over the remainder. Use this when you need paging.

Example:
?take=20 */ @DataMember(Order=2) var Take:Int? = null /** * Comma separated list of fields to order by. Prefix the field name with a minus if you wan't to invert the sort for that field.

Example:
?orderBy=Id,-Age,FirstName */ @DataMember(Order=3) var OrderBy:String? = null /** * Comma separated list of fields to order by in descending order. Prefix the field name with a minus if you wan't to invert the sort for that field.

Example:
?orderByDesc=Id,-Age,FirstName */ @DataMember(Order=4) var OrderByDesc:String? = null /** * Include any of the aggregates AVG, COUNT, FIRST, LAST, MAX, MIN, SUM in your result set. The results will be returned in the meta field.

Example:
?include=COUNT(*) as Total

or multiple fields with
?include=Count(*) Total, Min(Age), AVG(Age) AverageAge

or unique with
?include=COUNT(DISTINCT LivingStatus) as UniqueStatus */ @DataMember(Order=5) var Include:String? = null @DataMember(Order=6) var Fields:String? = null @DataMember(Order=7) var Meta:HashMap = HashMap() } open class BaseModel { } open interface IBaseModelCreated { var CreatedDate:Date? } open interface IBaseModelUpdated { var UpdatedDate:Date? } open class CalendarExport : BaseModel() { @Required() var CompanyId:UUID? = null @Required() var BookingId:Int? = null @Required() var ExceptionId:Int? = null var CalendarSync:Boolean? = null var CalendarId:String? = null var IsExceptionDeleted:Boolean? = null var ModifiedDate:Date? = null var Id:Int? = null } open interface ICustomFieldTable { var CustomFieldsConfig:IList? var CustomFieldsData:IList? var TextField1:String? var TextField2:String? var TextField3:String? var TextField4:String? var TextField5:String? var TextField6:String? var TextField7:String? var TextField8:String? var TextField9:String? var TextField10:String? var TextField11:String? var TextField12:String? var TextField13:String? var TextField14:String? var TextField15:String? var TextField16:String? var TextField17:String? var TextField18:String? var TextField19:String? var TextField20:String? } open class CustomFieldValue : BaseModel() { @Required() var CompanyId:UUID? = null var Id:Int? = null @Required() var Value:String? = null @Required() var Active:Boolean? = null var SortOrder:Short? = null var ModifiedDate:Date? = null } open class CustomField : BaseModel() { @Required() var Table:String? = null @Required() var Column:String? = null @Required() var DataType:String? = null @Required() var Description:String? = null @Required() var Active:Boolean? = null var ModifiedDate:Date? = null var Id:Int? = null } open class RegEx : BaseModel() { @Required() var Name:String? = null @Required() var Description:String? = null @Required() var RegExCode:String? = null var ErrorMessage:String? = null var ModifiedDate:Date? = null var Id:Int? = null } open class CustomFieldServiceRelation : BaseModel() { @Required() var CompanyId:UUID? = null var Id:Int? = null @Required() var CustomFieldConfigId:Int? = null @Required() var ServiceId:Int? = null var ModifiedDate:Date? = null } open interface ISchedule { var Resources:IList? var Type:ScheduleType? var Active:Boolean? var IsResourceSpecific:Boolean? } open interface ITimeException : IInterval { var Id:Int? var ReasonText:String? var IsBlock:Boolean? var ReasonTextPublic:String? var IsRecurring:Boolean? var ResourceIds:ArrayList? } open interface IBookedTime : IInterval { var Id:Int? var ServiceId:Int? var BookedSpots:Int? var TotalSpots:Int? var PauseAfterInMinutes:Int? var Status:BookingStatusEnum? var StatusId:Int? var Customer:BookedCustomer? } open class ResourceTimeExceptionDayOfWeekRelation : BaseModel() { @Ignore() var DayOfWeek:BokaMeraDayOfWeek? = null @Required() var DayOfWeekId:Int? = null @Required() var CompanyId:UUID? = null @Required() var ResourceTimeExceptionId:Int? = null var ModifiedDate:Date? = null var Id:Int? = null } open class ResourceTimeExceptionResourceRelation : BaseModel() { @Ignore() var Resource:Resource? = null @Required() var CompanyId:UUID? = null @Required() var ResourceTimeExceptionId:Int? = null @Required() var ResourceId:Int? = null var Id:Int? = null var ModifiedDate:Date? = null } enum class BokaMeraDayOfWeek(val value:Int) { Monday(1), Tuesday(2), Wednesday(3), Thursday(4), Friday(5), Saturday(6), Sunday(7), } open class ResourceTimeExceptionQueryResponse { /** * Time exception id */ @ApiMember(Description="Time exception id") var Id:Int? = null /** * Time company id */ @ApiMember(Description="Time company id") var CompanyId:UUID? = null /** * If it's locked for editing for the logged in administrator */ @ApiMember(Description="If it's locked for editing for the logged in administrator") var Locked:Boolean? = null /** * Resources that owns this exception */ @ApiMember(Description="Resources that owns this exception") var ResourceIds:ArrayList? = null /** * Resources that owns this exception */ @ApiMember(Description="Resources that owns this exception") var Resources:ArrayList = ArrayList() /** * Indicates wheter or not the time exception is recurring */ @ApiMember(Description="Indicates wheter or not the time exception is recurring") var IsRecurring:Boolean? = null /** * Time exception starting timestamp */ @ApiMember(Description="Time exception starting timestamp") var From:Date? = null /** * Time exception ending timestamp */ @ApiMember(Description="Time exception ending timestamp") var To:Date? = null /** * If recurring then this value indicates the time of day when the time exception begins */ @ApiMember(Description="If recurring then this value indicates the time of day when the time exception begins") var FromTime:TimeSpan? = null /** * If recurring then this value indicates the time of day when the time exception ends */ @ApiMember(Description="If recurring then this value indicates the time of day when the time exception ends") var ToTime:TimeSpan? = null /** * The reason of the time exception, example: Vacation, doctors appointment, ... */ @ApiMember(Description="The reason of the time exception, example: Vacation, doctors appointment, ...") var ReasonText:String? = null /** * The reason of the time exception that could be public to customers, example: Vacation, Closed, Sick leave, ... */ @ApiMember(Description="The reason of the time exception that could be public to customers, example: Vacation, Closed, Sick leave, ...") var ReasonTextPublic:String? = null /** * What hexadecimal color code the exception should have in the scheduler */ @ApiMember(Description="What hexadecimal color code the exception should have in the scheduler") var Color:String? = null /** * If the time exception should block the time in the scheduler so it's not avaialable to book */ @ApiMember(Description="If the time exception should block the time in the scheduler so it's not avaialable to book") var BlockTime:Boolean? = null /** * If the ReasonText should only be visible to conncted resources. If false, all resources will be able to see it */ @ApiMember(Description="If the ReasonText should only be visible to conncted resources. If false, all resources will be able to see it") var Private:Boolean? = null /** * The status for export to calendars like Gcal */ @ApiMember(Description="The status for export to calendars like Gcal") var CalendarExportStatus:ExceptionCalendarExportStatus? = null /** * If recurring, an array indicating which days of the week the exception recures on where 1 = Monday .. 7 = Sunday. When recurring then the time portion of the Fields From and To indicates the time of day the recurrence occurs */ @ApiMember(Description="If recurring, an array indicating which days of the week the exception recures on where 1 = Monday .. 7 = Sunday. When recurring then the time portion of the Fields From and To indicates the time of day the recurrence occurs") var DaysOfWeek:ArrayList = ArrayList() /** * The datetime the exception was created */ @ApiMember(Description="The datetime the exception was created") var Created:Date? = null var ResponseStatus:ResponseStatus? = null }