/* Options: Date: 2024-11-21 13:25:06 Version: 8.23 Tip: To override a DTO option, remove "//" prefix before updating BaseUrl: https://api.bokamera.se //GlobalNamespace: //MakePropertiesOptional: False //AddServiceStackTypes: True //AddResponseStatus: False //AddImplicitVersion: //AddDescriptionAsComments: True IncludeTypes: MessageLogQuery.* //ExcludeTypes: //DefaultImports: */ export interface IReturn { createResponse(): T; } // @DataContract export class QueryBase { /** @description 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) public Skip?: number; /** @description 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) public Take?: number; /** @description 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) public OrderBy: string; /** @description 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) public OrderByDesc: string; /** @description 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) public Include: string; // @DataMember(Order=6) public Fields: string; // @DataMember(Order=7) public Meta: { [index: string]: string; }; public constructor(init?: Partial) { (Object as any).assign(this, init); } } export class QueryDb extends QueryBase { public constructor(init?: Partial>) { super(init); (Object as any).assign(this, init); } } export interface ICompany { CompanyId?: string; } // @DataContract export class ResponseError { // @DataMember(Order=1) public ErrorCode: string; // @DataMember(Order=2) public FieldName: string; // @DataMember(Order=3) public Message: string; // @DataMember(Order=4) public Meta: { [index: string]: string; }; public constructor(init?: Partial) { (Object as any).assign(this, init); } } // @DataContract export class ResponseStatus { // @DataMember(Order=1) public ErrorCode: string; // @DataMember(Order=2) public Message: string; // @DataMember(Order=3) public StackTrace: string; // @DataMember(Order=4) public Errors: ResponseError[]; // @DataMember(Order=5) public Meta: { [index: string]: string; }; public constructor(init?: Partial) { (Object as any).assign(this, init); } } export class BaseModel { public constructor(init?: Partial) { (Object as any).assign(this, init); } } export class MessageLog extends BaseModel implements IMessageLog { public BookingId?: number; // @Required() public PublicMessage: boolean; // @Required() public MessageType: number; // @Required() public iCalAttachment: boolean; // @Required() public SenderName: string; public ModifiedDate?: string; public CorrelationId?: string; // @Required() public CompanyId: string; public Id: number; // @Required() public Receiver: string; // @Required() public Sender: string; public MessageTitle: string; // @Required() public MessageBody: string; public CreatedBy: string; // @Required() public Created: string; // @Required() public Sent: boolean; // @Required() public ToSendDate: string; public SentDate?: string; // @Required() public SendMethodId: number; public MessageCount?: number; public SMSStatus?: number; // @Required() public MessageRetries: number; public StorageUrl: string; public Language: string; public constructor(init?: Partial) { super(init); (Object as any).assign(this, init); } } export interface IMessageLog { CompanyId: string; Id: number; Receiver: string; Sender: string; MessageTitle: string; MessageBody: string; CreatedBy: string; Created: string; Sent: boolean; ToSendDate: string; SentDate?: string; SendMethodId: number; MessageCount?: number; SMSStatus?: number; MessageRetries: number; StorageUrl: string; } export class MessageLogQueryResponse { /** @description The message log id */ // @ApiMember(Description="The message log id") public Id: number; /** @description The booking id for the message (if connected to a booking). */ // @ApiMember(Description="The booking id for the message (if connected to a booking).") public BookingId?: number; /** @description The message receiver. Either a email or a mobile phone number. */ // @ApiMember(Description="The message receiver. Either a email or a mobile phone number.") public Receiver: string; /** @description Message Title. */ // @ApiMember(Description="Message Title.") public MessageTitle: string; /** @description Message Storage Url. */ // @ApiMember(Description="Message Storage Url.") public StorageUrl: string; /** @description Message Body. */ // @ApiMember(Description="Message Body.") public MessageBody: string; /** @description When message was created. */ // @ApiMember(Description="When message was created.") public Created: string; /** @description When the message will be sent. */ // @ApiMember(Description="When the message will be sent.") public ToSendDate: string; /** @description When the message was sent. */ // @ApiMember(Description="When the message was sent.") public SentDate?: string; /** @description If Message is sent */ // @ApiMember(Description="If Message is sent") public Sent: boolean; /** @description Number of retries to send the message */ // @ApiMember(Description="Number of retries to send the message") public MessageRetries: number; /** @description Send Method. 1 = Email, 2 = SMS */ // @ApiMember(Description="Send Method. 1 = Email, 2 = SMS") public SendMethodId: number; public constructor(init?: Partial) { (Object as any).assign(this, init); } } // @DataContract export class QueryResponse { // @DataMember(Order=1) public Offset: number; // @DataMember(Order=2) public Total: number; // @DataMember(Order=3) public Results: MessageLogQueryResponse[]; // @DataMember(Order=4) public Meta: { [index: string]: string; }; // @DataMember(Order=5) public ResponseStatus: ResponseStatus; public constructor(init?: Partial>) { (Object as any).assign(this, init); } } // @Route("/messages/log", "GET") // @ApiResponse(Description="You were unauthorized to call this service", StatusCode=401) // @ValidateRequest(Validator="IsAuthenticated") export class MessageLogQuery extends QueryDb implements IReturn>, ICompany { /** @description 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.", ParameterType="path") public CompanyId?: string; /** @description If you want to search on sent messages */ // @ApiMember(DataType="boolean", Description="If you want to search on sent messages", ParameterType="query") public Sent?: boolean; /** @description Message Id */ // @ApiMember(DataType="int", Description="Message Id", ParameterType="query") public Id?: number; /** @description If you want to search on a messages for a specific booking */ // @ApiMember(DataType="int", Description="If you want to search on a messages for a specific booking", ParameterType="query") public BookingId?: number; /** @description If you want to search on a messages for a specific receiver */ // @ApiMember(DataType="string", Description="If you want to search on a messages for a specific receiver", ParameterType="query") public Receiver: string; /** @description If you want to search on a messages created a specific date */ // @ApiMember(DataType="datetime", Description="If you want to search on a messages created a specific date", ParameterType="query") public Created?: string; /** @description If you want to search on a messages sent a specific date */ // @ApiMember(DataType="datetime", Description="If you want to search on a messages sent a specific date", ParameterType="query") public SentDate?: string; public ResponseStatus: ResponseStatus; public constructor(init?: Partial) { super(init); (Object as any).assign(this, init); } public getTypeName() { return 'MessageLogQuery'; } public getMethod() { return 'GET'; } public createResponse() { return new QueryResponse(); } }