/* Options: Date: 2024-12-03 18:09:33 Version: 8.23 Tip: To override a DTO option, remove "//" prefix before updating BaseUrl: https://api.bokamera.se //GlobalNamespace: //MakePartial: True //MakeVirtual: True //MakeInternal: False //MakeDataContractsExtensible: False //AddNullableAnnotations: False //AddReturnMarker: True //AddDescriptionAsComments: True //AddDataContractAttributes: False //AddIndexesToDataMembers: False //AddGeneratedCodeAttributes: False //AddResponseStatus: False //AddImplicitVersion: //InitializeCollections: True //ExportValueTypes: False IncludeTypes: CreateLicense.* //ExcludeTypes: //AddNamespaces: //AddDefaultXmlNamespace: http://schemas.servicestack.net/types */ using System; using System.Collections; using System.Collections.Generic; using System.Runtime.Serialization; using ServiceStack; using ServiceStack.DataAnnotations; using System.Globalization; using ServiceStack.Data; using BokaMera.API.ServiceModel.Interfaces; using BokaMera.API.ServiceModel.Db; using BokaMera.API.ServiceModel.Dtos; using PaysonIntegrationCO2.Models.Enums; namespace BokaMera.API.ServiceModel.Db { public partial class BaseModel { } public partial class Country : BaseModel { [References(typeof(BokaMera.API.ServiceModel.Db.Currency))] public virtual string CurrencyId { get; set; } public virtual Currency CurrencyInfo { get; set; } [Required] public virtual string Name { get; set; } public virtual string Culture { get; set; } public virtual string TimeZone { get; set; } public virtual DateTimeOffset? ModifiedDate { get; set; } [Required] public virtual string Id { get; set; } } public partial class Currency : BaseModel { [Required] public virtual string Name { get; set; } [Required] public virtual string CurrencySign { get; set; } [Required] public virtual bool Active { get; set; } public virtual DateTimeOffset? ModifiedDate { get; set; } [Required] public virtual string Id { get; set; } } public partial class LicensePrice : BaseModel { [Ignore] public virtual Country Country { get; set; } [Ignore] public virtual bool MonthlyPayment { get; set; } [Required] public virtual int LicenseTypeId { get; set; } [Required] public virtual string CountryId { get; set; } [Required] public virtual int Price { get; set; } public virtual DateTimeOffset? ModifiedDate { get; set; } } } namespace BokaMera.API.ServiceModel.Dtos { public partial class BillingInformationResponse { public BillingInformationResponse() { BillingMethodOptions = new List{}; } /// ///The company id. /// [ApiMember(Description="The company id.")] public virtual Guid CompanyId { get; set; } /// ///The prefered billing method. /// [ApiMember(Description="The prefered billing method.", IsRequired=true)] public virtual int BillingMethodId { get; set; } /// ///The name that should be printed on the billing information, normally this would be your company name. /// [ApiMember(Description="The name that should be printed on the billing information, normally this would be your company name.")] public virtual string Name { get; set; } /// ///If you want to add the attention to the billing address. /// [ApiMember(Description="If you want to add the attention to the billing address.")] public virtual string Attention { get; set; } /// ///The street for the billing adress. This is required when having postal invoice as billing method. /// [ApiMember(Description="The street for the billing adress. This is required when having postal invoice as billing method.")] public virtual string Street1 { get; set; } /// ///The street for the billing adress. /// [ApiMember(Description="The street for the billing adress.")] public virtual string Street2 { get; set; } /// ///The zip code (postal code) for the billing adress. This is required when having postal invoice as billing method. /// [ApiMember(Description="The zip code (postal code) for the billing adress. This is required when having postal invoice as billing method.")] public virtual string ZipCode { get; set; } /// ///The city for the billing adress. This is required when having postal invoice as billing method. /// [ApiMember(Description="The city for the billing adress. This is required when having postal invoice as billing method.")] public virtual string City { get; set; } /// ///The country for the billing adress. This is required when having postal invoice as billing method. /// [ApiMember(Description="The country for the billing adress. This is required when having postal invoice as billing method.")] public virtual string CountryId { get; set; } /// ///The billing email. This is required when having email invoice as billing method. /// [ApiMember(Description="The billing email. This is required when having email invoice as billing method.")] public virtual string Email { get; set; } /// ///The company global location number. /// [ApiMember(Description="The company global location number.")] public virtual string GLN { get; set; } /// ///You're internal rereference. /// [ApiMember(Description="You're internal rereference.")] public virtual string ReferenceLine1 { get; set; } /// ///You're internal rereference. /// [ApiMember(Description="You're internal rereference.")] public virtual string ReferenceLine2 { get; set; } /// ///The billing payment terms in days. This is default 15 days. /// [ApiMember(Description="The billing payment terms in days. This is default 15 days.")] public virtual int PaymentTermsDays { get; set; } /// ///The company vat registration number. /// [ApiMember(Description="The company vat registration number.")] public virtual string VatRegistrationNumber { get; set; } /// ///The billing method options to choose from /// [ApiMember(Description="The billing method options to choose from")] public virtual List BillingMethodOptions { get; set; } } public partial class CompanyLicenseQueryResponse { public virtual int Id { get; set; } public virtual int TypeId { get; set; } public virtual LicenseTypeQueryResponse Type { get; set; } public virtual DateTime ValidFrom { get; set; } public virtual DateTime ValidTo { get; set; } public virtual string MetaData { get; set; } public virtual bool Active { get; set; } public virtual bool Canceled { get; set; } public virtual DateTime Updated { get; set; } public virtual DateTime Created { get; set; } } [Route("/licenses/company", "POST")] [ApiResponse(Description="You were unauthorized to call this service", StatusCode=401)] [ValidateRequest("IsAuthenticated")] public partial class CreateLicense : IReturn, ICompany { /// ///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.")] public virtual Guid? CompanyId { get; set; } /// ///Id of the license type /// [ApiMember(Description="Id of the license type", IsRequired=true)] public virtual int? TypeId { get; set; } /// ///Any metadata connected to the license. In example for domain license set the requested domain name here. /// [ApiMember(Description="Any metadata connected to the license. In example for domain license set the requested domain name here.", IsRequired=true)] public virtual string MetaData { get; set; } /// ///If you want to update your company billing information. Note, if no billing information is added before, you need to set this. /// [ApiMember(Description="If you want to update your company billing information. Note, if no billing information is added before, you need to set this.")] public virtual BillingInformationResponse BillingInformation { get; set; } } public partial class LicenseItemsResponse { public virtual int Id { get; set; } public virtual string Name { get; set; } public virtual int AllowedItems { get; set; } } public partial class LicenseTypeQueryResponse { public LicenseTypeQueryResponse() { Items = new List{}; Prices = new List{}; } /// ///The license type id /// [ApiMember(Description="The license type id")] public virtual int Id { get; set; } /// ///The license type name /// [ApiMember(Description="The license type name")] public virtual string Name { get; set; } /// ///The license type description /// [ApiMember(Description="The license type description")] public virtual string Description { get; set; } /// ///If the license type is not a standard license but instead an extra license option. An example would be sending new letter license. /// [ApiMember(Description="If the license type is not a standard license but instead an extra license option. An example would be sending new letter license.")] public virtual bool IsExtraLicenseOption { get; set; } /// ///The period of notice for the license in days. /// [ApiMember(Description="The period of notice for the license in days.")] public virtual int PeriodOfNoticeDays { get; set; } /// ///The license items for the license type /// [ApiMember(Description="The license items for the license type")] public virtual List Items { get; set; } /// ///The license prices in each country for the license type /// [ApiMember(Description="The license prices in each country for the license type")] public virtual List Prices { get; set; } } } namespace BokaMera.API.ServiceModel.Interfaces { public partial interface ICompany { Guid? CompanyId { get; set; } } } namespace PaysonIntegrationCO2.Models.Enums { public enum Currency { SEK = 1, EUR = 2, } }