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 .xml suffix or ?format=xml

HTTP + XML

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: api.bokamera.se 
Accept: application/xml
HTTP/1.1 200 OK
Content-Type: application/xml
Content-Length: length

<GDPRCustomerQueryResponse xmlns:i="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://schemas.datacontract.org/2004/07/BokaMera.API.ServiceModel.Dtos">
  <Bookings>
    <GDPRCustomerBookingsResponse>
      <BookedBy>String</BookedBy>
      <BookedComments>String</BookedComments>
      <Comments>String</Comments>
      <CommentsToCustomer>String</CommentsToCustomer>
      <CompanyId>00000000-0000-0000-0000-000000000000</CompanyId>
      <CreatedDate>0001-01-01T00:00:00</CreatedDate>
      <CustomerId>00000000-0000-0000-0000-000000000000</CustomerId>
      <From>0001-01-01T00:00:00</From>
      <Id>0</Id>
      <ServiceId>0</ServiceId>
      <StatusId>0</StatusId>
      <TextField1>String</TextField1>
      <TextField10>String</TextField10>
      <TextField11>String</TextField11>
      <TextField12>String</TextField12>
      <TextField13>String</TextField13>
      <TextField14>String</TextField14>
      <TextField15>String</TextField15>
      <TextField16>String</TextField16>
      <TextField17>String</TextField17>
      <TextField18>String</TextField18>
      <TextField19>String</TextField19>
      <TextField2>String</TextField2>
      <TextField20>String</TextField20>
      <TextField3>String</TextField3>
      <TextField4>String</TextField4>
      <TextField5>String</TextField5>
      <TextField6>String</TextField6>
      <TextField7>String</TextField7>
      <TextField8>String</TextField8>
      <TextField9>String</TextField9>
      <To>0001-01-01T00:00:00</To>
      <UnbookedComments>String</UnbookedComments>
      <UnbookedOn>0001-01-01T00:00:00</UnbookedOn>
      <UpdatedDate>0001-01-01T00:00:00</UpdatedDate>
    </GDPRCustomerBookingsResponse>
  </Bookings>
  <Customer>
    <Active>false</Active>
    <Created>0001-01-01T00:00:00</Created>
    <Email>String</Email>
    <FacebookUsername>String</FacebookUsername>
    <Firstname>String</Firstname>
    <Lastname>String</Lastname>
    <Phone>String</Phone>
    <TextField1>String</TextField1>
    <TextField10>String</TextField10>
    <TextField11>String</TextField11>
    <TextField12>String</TextField12>
    <TextField13>String</TextField13>
    <TextField14>String</TextField14>
    <TextField15>String</TextField15>
    <TextField16>String</TextField16>
    <TextField17>String</TextField17>
    <TextField18>String</TextField18>
    <TextField19>String</TextField19>
    <TextField2>String</TextField2>
    <TextField20>String</TextField20>
    <TextField3>String</TextField3>
    <TextField4>String</TextField4>
    <TextField5>String</TextField5>
    <TextField6>String</TextField6>
    <TextField7>String</TextField7>
    <TextField8>String</TextField8>
    <TextField9>String</TextField9>
    <Updated>0001-01-01T00:00:00</Updated>
    <UserId>00000000-0000-0000-0000-000000000000</UserId>
  </Customer>
  <CustomerComment>
    <GDPRCustomerCommentsResponse>
      <Comments>String</Comments>
      <CompanyId>00000000-0000-0000-0000-000000000000</CompanyId>
      <Created>0001-01-01T00:00:00</Created>
      <CustomerId>00000000-0000-0000-0000-000000000000</CustomerId>
      <Id>0</Id>
      <ImageUrl i:nil="true" />
      <Updated>0001-01-01T00:00:00</Updated>
    </GDPRCustomerCommentsResponse>
  </CustomerComment>
  <MessageLog>
    <GDPRCustomerMessageLogResponse>
      <BookingId>0</BookingId>
      <CompanyId>00000000-0000-0000-0000-000000000000</CompanyId>
      <Created>0001-01-01T00:00:00</Created>
      <CreatedBy>String</CreatedBy>
      <Id>0</Id>
      <MessageBody>String</MessageBody>
      <MessageTitle>String</MessageTitle>
      <Receiver>String</Receiver>
      <SendMethodId>0</SendMethodId>
      <Sender>String</Sender>
      <Sent>false</Sent>
      <SentDate>0001-01-01T00:00:00</SentDate>
    </GDPRCustomerMessageLogResponse>
  </MessageLog>
  <NewsletterLog>
    <GDPRCustomerNewsletterLogResponse>
      <CompanyId>00000000-0000-0000-0000-000000000000</CompanyId>
      <Created>0001-01-01T00:00:00</Created>
      <Id>0</Id>
      <MessageBody>String</MessageBody>
      <MessageTitle>String</MessageTitle>
      <NewslettersId>0</NewslettersId>
      <Receiver>String</Receiver>
      <Sender>String</Sender>
      <Sent>false</Sent>
    </GDPRCustomerNewsletterLogResponse>
  </NewsletterLog>
  <ResponseStatus xmlns:d2p1="http://schemas.servicestack.net/types">
    <d2p1:ErrorCode>String</d2p1:ErrorCode>
    <d2p1:Message>String</d2p1:Message>
    <d2p1:StackTrace>String</d2p1:StackTrace>
    <d2p1:Errors>
      <d2p1:ResponseError>
        <d2p1:ErrorCode>String</d2p1:ErrorCode>
        <d2p1:FieldName>String</d2p1:FieldName>
        <d2p1:Message>String</d2p1:Message>
        <d2p1:Meta xmlns:d5p1="http://schemas.microsoft.com/2003/10/Serialization/Arrays">
          <d5p1:KeyValueOfstringstring>
            <d5p1:Key>String</d5p1:Key>
            <d5p1:Value>String</d5p1:Value>
          </d5p1:KeyValueOfstringstring>
        </d2p1:Meta>
      </d2p1:ResponseError>
    </d2p1:Errors>
    <d2p1:Meta xmlns:d3p1="http://schemas.microsoft.com/2003/10/Serialization/Arrays">
      <d3p1:KeyValueOfstringstring>
        <d3p1:Key>String</d3p1:Key>
        <d3p1:Value>String</d3p1:Value>
      </d3p1:KeyValueOfstringstring>
    </d2p1:Meta>
  </ResponseStatus>
  <UserProfile>
    <Email>String</Email>
    <Firstname>String</Firstname>
    <Id>00000000-0000-0000-0000-000000000000</Id>
    <InvoiceAddress>
      <CorporateIdentityNumber>String</CorporateIdentityNumber>
      <InvoiceAddress1>String</InvoiceAddress1>
      <InvoiceAddress2>String</InvoiceAddress2>
      <InvoiceAddressId>00000000-0000-0000-0000-000000000000</InvoiceAddressId>
      <InvoiceCity>String</InvoiceCity>
      <InvoiceCountryCode>String</InvoiceCountryCode>
      <InvoicePostalCode>String</InvoicePostalCode>
      <UserId>00000000-0000-0000-0000-000000000000</UserId>
    </InvoiceAddress>
    <Lastname>String</Lastname>
    <Phone>String</Phone>
  </UserProfile>
</GDPRCustomerQueryResponse>