/* Options: Date: 2025-09-15 01:49:02 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: LicenseTypeQuery.* //ExcludeTypes: //InitializeCollections: False //TreatTypesAsStrings: //DefaultImports: java.math.*,java.util.*,java.io.InputStream,net.servicestack.client.*,com.google.gson.annotations.*,com.google.gson.reflect.* */ import java.math.* import java.util.* import java.io.InputStream import net.servicestack.client.* import com.google.gson.annotations.* import com.google.gson.reflect.* @Route(Path="/licenses/types/", Verbs="GET") @ApiResponse(Description="You were unauthorized to call this service", StatusCode=401) open class LicenseTypeQuery : QueryDb(), IReturn> { /** * If you want to only select Extra license options */ @ApiMember(DataType="boolean", Description="If you want to only select Extra license options", ParameterType="query") open var ExtraLicenseOption:Boolean? = null /** * What country you want to list the prices for */ @ApiMember(DataType="string", Description="What country you want to list the prices for") open var CountryId:String? = null /** * If you want to include the connected license items */ @ApiMember(DataType="boolean", Description="If you want to include the connected license items", ParameterType="query") open var IncludeLicenseItems:Boolean? = null /** * If you want to include the connected licens prices */ @ApiMember(DataType="boolean", Description="If you want to include the connected licens prices", ParameterType="query") open var IncludeLicensePrices:Boolean? = null open var ResponseStatus:ResponseStatus? = null open var Active:Boolean? = null companion object { private val responseType = object : TypeToken>(){}.type } override fun getResponseType(): Any? = LicenseTypeQuery.responseType } @DataContract open class QueryResponse { @DataMember(Order=1) open var Offset:Int? = null @DataMember(Order=2) open var Total:Int? = null @DataMember(Order=3) open var Results:ArrayList? = null @DataMember(Order=4) open var Meta:HashMap? = null @DataMember(Order=5) open var ResponseStatus:ResponseStatus? = null } open class QueryDb : QueryBase() { } open class Country : BaseModel() { @References(Type=Currency::class) open var CurrencyId:String? = null open var CurrencyInfo:Currency? = null @Required() open var Name:String? = null open var Culture:String? = null open var TimeZone:String? = null open var ModifiedDate:Date? = null @Required() open var Id:String? = null } open class Currency : BaseModel() { @Required() open var Name:String? = null @Required() open var CurrencySign:String? = null @Required() open var Active:Boolean? = null open var ModifiedDate:Date? = null @Required() open var Id:String? = null } open class LicenseType : BaseModel() { @Ignore() open var LicenseItems:IList? = null @Ignore() open var Prices:IList? = null @Ignore() open var IsFree:Boolean? = null @Ignore() open var PeriodOfNoticeDays:Int? = null @Ignore() open var NextLicenseOption:LicenseType? = null @Required() open var Name:String? = null @Required() open var Description:String? = null @Required() open var ExtraLicenseOption:Boolean? = null open var ModifiedDate:Date? = null open var Active:Boolean? = null open var Id:Int? = null } open class LicenseInformationQueryResponse { open var Name:String? = null open var Description:String? = null open var Url:Uri? = null open var FreeEdition:Boolean? = null open var StartEdition:Boolean? = null open var ProEdition:Boolean? = null open var SmartEdition:Boolean? = null open var EnterpriseEdition:Boolean? = null open var FreeEditionValue:String? = null open var StartEditionValue:String? = null open var ProEditionValue:String? = null open var SmartEditionValue:String? = null open var EnterpriseEditionValue:String? = null open var LicenseInformationTypeId:Int? = null } @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) open 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) open 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) open 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) open 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) open var Include:String? = null @DataMember(Order=6) open var Fields:String? = null @DataMember(Order=7) open var Meta:HashMap? = null } open class BaseModel { } open class LicensePrice : BaseModel() { @Ignore() open var Country:Country? = null @Ignore() open var MonthlyPayment:Boolean? = null @Required() open var LicenseTypeId:Int? = null @Required() open var CountryId:String? = null @Required() open var Price:Int? = null open var ModifiedDate:Date? = null } open class LicenseTypeItem : BaseModel() { @Ignore() open var Name:String? = null @Ignore() open var LicenseType:LicenseType? = null @Required() open var LicenseTypesId:Int? = null @Required() open var LicenseItemsId:Int? = null @Required() open var NumberOfItems:Int? = null open var Id:Int? = null open var ModifiedDate:Date? = null } enum class Currency(val value:Int) { Sek(1), Eur(2), }