BokaMera.API.Host

<back to all web services

GDPRCustomerQuery

Requires Authentication
Requires any of the roles:bookingsupplier-administrator-write, superadmin, bookingsupplier-administrator-read
The following routes are available for this service:
GET/gdpr/customers/{CustomerId}Get all customer information stored on the customerGet all information stored on the customer
"use strict";
export class GDPRCustomerBookingsResponse {
    /** @param {{CompanyId?:string,Id?:number,CustomerId?:string,ServiceId?:number,StatusId?:number,From?:string,To?:string,UnbookedOn?:string,UnbookedComments?:string,BookedComments?:string,BookedBy?:string,Comments?:string,TextField1?:string,TextField2?:string,TextField3?:string,TextField4?:string,TextField5?:string,TextField6?:string,TextField7?:string,TextField8?:string,TextField9?:string,TextField10?:string,TextField11?:string,TextField12?:string,TextField13?:string,TextField14?:string,TextField15?:string,TextField16?:string,TextField17?:string,TextField18?:string,TextField19?:string,TextField20?:string,UpdatedDate?:string,CreatedDate?:string,CommentsToCustomer?:string}} [init] */
    constructor(init) { Object.assign(this, init) }
    /**
     * @type {string}
     * @description The company ID associated with this booking */
    CompanyId;
    /**
     * @type {number}
     * @description The unique identifier of the booking */
    Id;
    /**
     * @type {string}
     * @description The customer ID associated with this booking */
    CustomerId;
    /**
     * @type {number}
     * @description The service ID for this booking */
    ServiceId;
    /**
     * @type {number}
     * @description The current status of the booking */
    StatusId;
    /**
     * @type {string}
     * @description The start date and time of the booking */
    From;
    /**
     * @type {string}
     * @description The end date and time of the booking */
    To;
    /**
     * @type {?string}
     * @description The date when the booking was cancelled or unbooked */
    UnbookedOn;
    /**
     * @type {string}
     * @description Comments added when the booking was cancelled */
    UnbookedComments;
    /**
     * @type {string}
     * @description Comments added when the booking was created */
    BookedComments;
    /**
     * @type {string}
     * @description The name of the person who made the booking */
    BookedBy;
    /**
     * @type {string}
     * @description General comments about the booking */
    Comments;
    /**
     * @type {string}
     * @description Custom text field 1 */
    TextField1;
    /**
     * @type {string}
     * @description Custom text field 2 */
    TextField2;
    /**
     * @type {string}
     * @description Custom text field 3 */
    TextField3;
    /**
     * @type {string}
     * @description Custom text field 4 */
    TextField4;
    /**
     * @type {string}
     * @description Custom text field 5 */
    TextField5;
    /**
     * @type {string}
     * @description Custom text field 6 */
    TextField6;
    /**
     * @type {string}
     * @description Custom text field 7 */
    TextField7;
    /**
     * @type {string}
     * @description Custom text field 8 */
    TextField8;
    /**
     * @type {string}
     * @description Custom text field 9 */
    TextField9;
    /**
     * @type {string}
     * @description Custom text field 10 */
    TextField10;
    /**
     * @type {string}
     * @description Custom text field 11 */
    TextField11;
    /**
     * @type {string}
     * @description Custom text field 12 */
    TextField12;
    /**
     * @type {string}
     * @description Custom text field 13 */
    TextField13;
    /**
     * @type {string}
     * @description Custom text field 14 */
    TextField14;
    /**
     * @type {string}
     * @description Custom text field 15 */
    TextField15;
    /**
     * @type {string}
     * @description Custom text field 16 */
    TextField16;
    /**
     * @type {string}
     * @description Custom text field 17 */
    TextField17;
    /**
     * @type {string}
     * @description Custom text field 18 */
    TextField18;
    /**
     * @type {string}
     * @description Custom text field 19 */
    TextField19;
    /**
     * @type {string}
     * @description Custom text field 20 */
    TextField20;
    /**
     * @type {string}
     * @description The date when the booking was last updated */
    UpdatedDate;
    /**
     * @type {string}
     * @description The date when the booking was created */
    CreatedDate;
    /**
     * @type {string}
     * @description Comments sent to the customer about this booking */
    CommentsToCustomer;
}
export class GDPRCustomerMessageLogResponse {
    /** @param {{CompanyId?:string,Id?:number,BookingId?:number,Receiver?:string,Sender?:string,MessageTitle?:string,MessageBody?:string,CreatedBy?:string,Created?:string,Sent?:boolean,SentDate?:string,SendMethodId?:number}} [init] */
    constructor(init) { Object.assign(this, init) }
    /**
     * @type {string}
     * @description The company ID associated with this message */
    CompanyId;
    /**
     * @type {number}
     * @description The unique identifier of the message */
    Id;
    /**
     * @type {?number}
     * @description The booking ID this message is related to, if any */
    BookingId;
    /**
     * @type {string}
     * @description The recipient of the message */
    Receiver;
    /**
     * @type {string}
     * @description The sender of the message */
    Sender;
    /**
     * @type {string}
     * @description The title or subject of the message */
    MessageTitle;
    /**
     * @type {string}
     * @description The body content of the message */
    MessageBody;
    /**
     * @type {string}
     * @description The name of the person who created the message */
    CreatedBy;
    /**
     * @type {string}
     * @description The date when the message was created */
    Created;
    /**
     * @type {boolean}
     * @description Whether the message was successfully sent */
    Sent;
    /**
     * @type {?string}
     * @description The date when the message was sent */
    SentDate;
    /**
     * @type {number}
     * @description The method used to send the message (e.g., email, SMS) */
    SendMethodId;
}
export class InvoiceAddressResponse {
    /** @param {{InvoiceAddressId?:string,UserId?:string,CorporateIdentityNumber?:string,InvoiceAddress1?:string,InvoiceAddress2?:string,InvoiceCity?:string,InvoicePostalCode?:string,InvoiceCountryCode?:string}} [init] */
    constructor(init) { Object.assign(this, init) }
    /** @type {string} */
    InvoiceAddressId;
    /** @type {?string} */
    UserId;
    /** @type {string} */
    CorporateIdentityNumber;
    /** @type {string} */
    InvoiceAddress1;
    /** @type {string} */
    InvoiceAddress2;
    /** @type {string} */
    InvoiceCity;
    /** @type {string} */
    InvoicePostalCode;
    /** @type {string} */
    InvoiceCountryCode;
}
export class UserProfileResponse {
    /** @param {{Id?:string,Firstname?:string,Lastname?:string,Phone?:string,Email?:string,InvoiceAddress?:InvoiceAddressResponse}} [init] */
    constructor(init) { Object.assign(this, init) }
    /** @type {string} */
    Id;
    /** @type {string} */
    Firstname;
    /** @type {string} */
    Lastname;
    /** @type {string} */
    Phone;
    /** @type {string} */
    Email;
    /** @type {InvoiceAddressResponse} */
    InvoiceAddress;
}
export class GDPRCustomerInfoResponse {
    /** @param {{UserId?:string,Firstname?:string,Lastname?:string,Phone?:string,Email?:string,Active?:boolean,FacebookUsername?:string,TextField1?:string,TextField2?:string,TextField3?:string,TextField4?:string,TextField5?:string,TextField6?:string,TextField7?:string,TextField8?:string,TextField9?:string,TextField10?:string,TextField11?:string,TextField12?:string,TextField13?:string,TextField14?:string,TextField15?:string,TextField16?:string,TextField17?:string,TextField18?:string,TextField19?:string,TextField20?:string,Updated?:string,Created?:string}} [init] */
    constructor(init) { Object.assign(this, init) }
    /**
     * @type {string}
     * @description The unique identifier of the user */
    UserId;
    /**
     * @type {string}
     * @description The user's first name */
    Firstname;
    /**
     * @type {string}
     * @description The user's last name */
    Lastname;
    /**
     * @type {string}
     * @description The user's phone number */
    Phone;
    /**
     * @type {string}
     * @description The user's email address */
    Email;
    /**
     * @type {boolean}
     * @description Whether the user account is currently active */
    Active;
    /**
     * @type {string}
     * @description The user's Facebook username */
    FacebookUsername;
    /**
     * @type {string}
     * @description Custom text field 1 */
    TextField1;
    /**
     * @type {string}
     * @description Custom text field 2 */
    TextField2;
    /**
     * @type {string}
     * @description Custom text field 3 */
    TextField3;
    /**
     * @type {string}
     * @description Custom text field 4 */
    TextField4;
    /**
     * @type {string}
     * @description Custom text field 5 */
    TextField5;
    /**
     * @type {string}
     * @description Custom text field 6 */
    TextField6;
    /**
     * @type {string}
     * @description Custom text field 7 */
    TextField7;
    /**
     * @type {string}
     * @description Custom text field 8 */
    TextField8;
    /**
     * @type {string}
     * @description Custom text field 9 */
    TextField9;
    /**
     * @type {string}
     * @description Custom text field 10 */
    TextField10;
    /**
     * @type {string}
     * @description Custom text field 11 */
    TextField11;
    /**
     * @type {string}
     * @description Custom text field 12 */
    TextField12;
    /**
     * @type {string}
     * @description Custom text field 13 */
    TextField13;
    /**
     * @type {string}
     * @description Custom text field 14 */
    TextField14;
    /**
     * @type {string}
     * @description Custom text field 15 */
    TextField15;
    /**
     * @type {string}
     * @description Custom text field 16 */
    TextField16;
    /**
     * @type {string}
     * @description Custom text field 17 */
    TextField17;
    /**
     * @type {string}
     * @description Custom text field 18 */
    TextField18;
    /**
     * @type {string}
     * @description Custom text field 19 */
    TextField19;
    /**
     * @type {string}
     * @description Custom text field 20 */
    TextField20;
    /**
     * @type {string}
     * @description The date when the customer information was last updated */
    Updated;
    /**
     * @type {string}
     * @description The date when the customer information was created */
    Created;
}
export class GDPRCustomerCommentsResponse {
    /** @param {{CompanyId?:string,Id?:number,CustomerId?:string,Comments?:string,Updated?:string,Created?:string,ImageUrl?:string}} [init] */
    constructor(init) { Object.assign(this, init) }
    /**
     * @type {string}
     * @description The company ID associated with this comment */
    CompanyId;
    /**
     * @type {number}
     * @description The unique identifier of the comment */
    Id;
    /**
     * @type {string}
     * @description The customer ID this comment is associated with */
    CustomerId;
    /**
     * @type {string}
     * @description The content of the comment */
    Comments;
    /**
     * @type {string}
     * @description The date when the comment was last updated */
    Updated;
    /**
     * @type {string}
     * @description The date when the comment was created */
    Created;
    /**
     * @type {string}
     * @description URL to any image associated with the comment */
    ImageUrl;
}
export class GDPRCustomerNewsletterLogResponse {
    /** @param {{CompanyId?:string,Id?:number,NewslettersId?:number,Receiver?:string,Sender?:string,MessageTitle?:string,MessageBody?:string,Sent?:boolean,Created?:string}} [init] */
    constructor(init) { Object.assign(this, init) }
    /**
     * @type {string}
     * @description The company ID associated with this newsletter */
    CompanyId;
    /**
     * @type {number}
     * @description The unique identifier of the newsletter log entry */
    Id;
    /**
     * @type {?number}
     * @description The newsletter ID this log entry is related to, if any */
    NewslettersId;
    /**
     * @type {string}
     * @description The recipient of the newsletter */
    Receiver;
    /**
     * @type {string}
     * @description The sender of the newsletter */
    Sender;
    /**
     * @type {string}
     * @description The title or subject of the newsletter */
    MessageTitle;
    /**
     * @type {string}
     * @description The body content of the newsletter */
    MessageBody;
    /**
     * @type {boolean}
     * @description Whether the newsletter was successfully sent */
    Sent;
    /**
     * @type {string}
     * @description The date when the newsletter was created */
    Created;
}
export class GDPRCustomerQueryResponse {
    /** @param {{Bookings?:GDPRCustomerBookingsResponse[],MessageLog?:GDPRCustomerMessageLogResponse[],UserProfile?:UserProfileResponse,Customer?:GDPRCustomerInfoResponse,CustomerComment?:GDPRCustomerCommentsResponse[],NewsletterLog?:GDPRCustomerNewsletterLogResponse[],ResponseStatus?:ResponseStatus}} [init] */
    constructor(init) { Object.assign(this, init) }
    /**
     * @type {GDPRCustomerBookingsResponse[]}
     * @description List of all bookings associated with the customer */
    Bookings;
    /**
     * @type {GDPRCustomerMessageLogResponse[]}
     * @description List of all message logs associated with the customer */
    MessageLog;
    /**
     * @type {UserProfileResponse}
     * @description The user profile information for the customer */
    UserProfile;
    /**
     * @type {GDPRCustomerInfoResponse}
     * @description Detailed customer information */
    Customer;
    /**
     * @type {GDPRCustomerCommentsResponse[]}
     * @description List of all comments associated with the customer */
    CustomerComment;
    /**
     * @type {GDPRCustomerNewsletterLogResponse[]}
     * @description List of all newsletter logs associated with the customer */
    NewsletterLog;
    /**
     * @type {ResponseStatus}
     * @description Response status information */
    ResponseStatus;
}
export class GDPRCustomerQuery {
    /** @param {{CompanyId?:string,CustomerId?:string}} [init] */
    constructor(init) { Object.assign(this, init) }
    /**
     * @type {string}
     * @description Enter the company and id you want to see the information for a resource, if blank company id and you are an admin, your company id will be used. If blank id, all resources will be shown  */
    CompanyId;
    /**
     * @type {string}
     * @description Id of the customer */
    CustomerId;
}

JavaScript GDPRCustomerQuery DTOs

To override the Content-type in your clients, use the HTTP Accept Header, append the .csv suffix or ?format=csv

HTTP + CSV

The following are sample HTTP requests and responses. The placeholders shown need to be replaced with actual values.

GET /gdpr/customers/{CustomerId} HTTP/1.1 
Host: testapi.bokamera.se 
Accept: text/csv
HTTP/1.1 200 OK
Content-Type: text/csv
Content-Length: length

{"Bookings":[{"Id":0,"ServiceId":0,"StatusId":0,"UnbookedOn":"0001-01-01T00:00:00","UnbookedComments":"String","BookedComments":"String","BookedBy":"String","Comments":"String","TextField1":"String","TextField2":"String","TextField3":"String","TextField4":"String","TextField5":"String","TextField6":"String","TextField7":"String","TextField8":"String","TextField9":"String","TextField10":"String","TextField11":"String","TextField12":"String","TextField13":"String","TextField14":"String","TextField15":"String","TextField16":"String","TextField17":"String","TextField18":"String","TextField19":"String","TextField20":"String","CommentsToCustomer":"String"}],"MessageLog":[{"Id":0,"BookingId":0,"Receiver":"String","Sender":"String","MessageTitle":"String","MessageBody":"String","CreatedBy":"String","Sent":false,"SentDate":"0001-01-01T00:00:00","SendMethodId":0}],"UserProfile":{"Firstname":"String","Lastname":"String","Phone":"String","Email":"String","InvoiceAddress":{"UserId":"00000000-0000-0000-0000-000000000000","CorporateIdentityNumber":"String","InvoiceAddress1":"String","InvoiceAddress2":"String","InvoiceCity":"String","InvoicePostalCode":"String","InvoiceCountryCode":"String"}},"Customer":{"Firstname":"String","Lastname":"String","Phone":"String","Email":"String","Active":false,"FacebookUsername":"String","TextField1":"String","TextField2":"String","TextField3":"String","TextField4":"String","TextField5":"String","TextField6":"String","TextField7":"String","TextField8":"String","TextField9":"String","TextField10":"String","TextField11":"String","TextField12":"String","TextField13":"String","TextField14":"String","TextField15":"String","TextField16":"String","TextField17":"String","TextField18":"String","TextField19":"String","TextField20":"String"},"CustomerComment":[{"Id":0,"Comments":"String"}],"NewsletterLog":[{"Id":0,"NewslettersId":0,"Receiver":"String","Sender":"String","MessageTitle":"String","MessageBody":"String","Sent":false}],"ResponseStatus":{"ErrorCode":"String","Message":"String","StackTrace":"String","Errors":[{"ErrorCode":"String","FieldName":"String","Message":"String","Meta":{"String":"String"}}],"Meta":{"String":"String"}}}