Skip to content

Latest commit

 

History

History
551 lines (417 loc) · 18 KB

customers.md

File metadata and controls

551 lines (417 loc) · 18 KB

Customers

const customersApi = client.customersApi;

Class Name

CustomersApi

Methods

List Customers

Lists customer profiles associated with a Square account.

Under normal operating conditions, newly created or updated customer profiles become available for the listing operation in well under 30 seconds. Occasionally, propagation of the new or updated profiles can take closer to one minute or longer, especially during network incidents and outages.

async listCustomers(
  cursor?: string,
  limit?: number,
  sortField?: string,
  sortOrder?: string,
  requestOptions?: RequestOptions
): Promise<ApiResponse<ListCustomersResponse>>

Parameters

Parameter Type Tags Description
cursor string | undefined Query, Optional A pagination cursor returned by a previous call to this endpoint.
Provide this cursor to retrieve the next set of results for your original query.

For more information, see Pagination.
limit number | undefined Query, Optional The maximum number of results to return in a single page. This limit is advisory. The response might contain more or fewer results.
If the specified limit is less than 1 or greater than 100, Square returns a 400 VALUE_TOO_LOW or 400 VALUE_TOO_HIGH error. The default value is 100.

For more information, see Pagination.
sortField string | undefined Query, Optional Indicates how customers should be sorted.

The default value is DEFAULT.
sortOrder string | undefined Query, Optional Indicates whether customers should be sorted in ascending (ASC) or
descending (DESC) order.

The default value is ASC.
requestOptions RequestOptions | undefined Optional Pass additional request options.

Response Type

ListCustomersResponse

Example Usage

try {
  const { result, ...httpResponse } = await customersApi.listCustomers();
  // Get more response info...
  // const { statusCode, headers } = httpResponse;
} catch(error) {
  if (error instanceof ApiError) {
    const errors = error.result;
    // const { statusCode, headers } = error;
  }
}

Create Customer

Creates a new customer for a business.

You must provide at least one of the following values in your request to this endpoint:

  • given_name
  • family_name
  • company_name
  • email_address
  • phone_number
async createCustomer(
  body: CreateCustomerRequest,
  requestOptions?: RequestOptions
): Promise<ApiResponse<CreateCustomerResponse>>

Parameters

Parameter Type Tags Description
body CreateCustomerRequest Body, Required An object containing the fields to POST for the request.

See the corresponding object definition for field details.
requestOptions RequestOptions | undefined Optional Pass additional request options.

Response Type

CreateCustomerResponse

Example Usage

const contentType = null;
const bodyAddress: Address = {};
bodyAddress.addressLine1 = '500 Electric Ave';
bodyAddress.addressLine2 = 'Suite 600';
bodyAddress.locality = 'New York';
bodyAddress.administrativeDistrictLevel1 = 'NY';
bodyAddress.postalCode = '10003';
bodyAddress.country = 'US';

const body: CreateCustomerRequest = {};
body.givenName = 'Amelia';
body.familyName = 'Earhart';
body.emailAddress = '[email protected]';
body.address = bodyAddress;
body.phoneNumber = '1-212-555-4240';
body.referenceId = 'YOUR_REFERENCE_ID';
body.note = 'a customer';

try {
  const { result, ...httpResponse } = await customersApi.createCustomer(body);
  // Get more response info...
  // const { statusCode, headers } = httpResponse;
} catch(error) {
  if (error instanceof ApiError) {
    const errors = error.result;
    // const { statusCode, headers } = error;
  }
}

Search Customers

Searches the customer profiles associated with a Square account using a supported query filter.

Calling SearchCustomers without any explicit query filter returns all customer profiles ordered alphabetically based on given_name and family_name.

Under normal operating conditions, newly created or updated customer profiles become available for the search operation in well under 30 seconds. Occasionally, propagation of the new or updated profiles can take closer to one minute or longer, especially during network incidents and outages.

async searchCustomers(
  body: SearchCustomersRequest,
  requestOptions?: RequestOptions
): Promise<ApiResponse<SearchCustomersResponse>>

Parameters

Parameter Type Tags Description
body SearchCustomersRequest Body, Required An object containing the fields to POST for the request.

See the corresponding object definition for field details.
requestOptions RequestOptions | undefined Optional Pass additional request options.

Response Type

SearchCustomersResponse

Example Usage

const contentType = null;
const bodyQueryFilterCreationSourceValues: string[] = ['THIRD_PARTY'];
const bodyQueryFilterCreationSource: CustomerCreationSourceFilter = {};
bodyQueryFilterCreationSource.values = bodyQueryFilterCreationSourceValues;
bodyQueryFilterCreationSource.rule = 'INCLUDE';

const bodyQueryFilterCreatedAt: TimeRange = {};
bodyQueryFilterCreatedAt.startAt = '2018-01-01T00:00:00+00:00';
bodyQueryFilterCreatedAt.endAt = '2018-02-01T00:00:00+00:00';

const bodyQueryFilterEmailAddress: CustomerTextFilter = {};
bodyQueryFilterEmailAddress.fuzzy = 'example.com';

const bodyQueryFilterGroupIdsAll: string[] = ['545AXB44B4XXWMVQ4W8SBT3HHF'];
const bodyQueryFilterGroupIds: FilterValue = {};
bodyQueryFilterGroupIds.all = bodyQueryFilterGroupIdsAll;

const bodyQueryFilter: CustomerFilter = {};
bodyQueryFilter.creationSource = bodyQueryFilterCreationSource;
bodyQueryFilter.createdAt = bodyQueryFilterCreatedAt;
bodyQueryFilter.emailAddress = bodyQueryFilterEmailAddress;
bodyQueryFilter.groupIds = bodyQueryFilterGroupIds;

const bodyQuerySort: CustomerSort = {};
bodyQuerySort.field = 'CREATED_AT';
bodyQuerySort.order = 'ASC';

const bodyQuery: CustomerQuery = {};
bodyQuery.filter = bodyQueryFilter;
bodyQuery.sort = bodyQuerySort;

const body: SearchCustomersRequest = {};
body.limit = 2;
body.query = bodyQuery;

try {
  const { result, ...httpResponse } = await customersApi.searchCustomers(body);
  // Get more response info...
  // const { statusCode, headers } = httpResponse;
} catch(error) {
  if (error instanceof ApiError) {
    const errors = error.result;
    // const { statusCode, headers } = error;
  }
}

Delete Customer

Deletes a customer profile from a business. This operation also unlinks any associated cards on file.

As a best practice, you should include the version field in the request to enable optimistic concurrency control. The value must be set to the current version of the customer profile.

To delete a customer profile that was created by merging existing profiles, you must use the ID of the newly created profile.

async deleteCustomer(
  customerId: string,
  version?: bigint,
  requestOptions?: RequestOptions
): Promise<ApiResponse<DeleteCustomerResponse>>

Parameters

Parameter Type Tags Description
customerId string Template, Required The ID of the customer to delete.
version bigint | undefined Query, Optional The current version of the customer profile.

As a best practice, you should include this parameter to enable optimistic concurrency control. For more information, see Delete a customer profile.
requestOptions RequestOptions | undefined Optional Pass additional request options.

Response Type

DeleteCustomerResponse

Example Usage

const customerId = 'customer_id8';
try {
  const { result, ...httpResponse } = await customersApi.deleteCustomer(customerId);
  // Get more response info...
  // const { statusCode, headers } = httpResponse;
} catch(error) {
  if (error instanceof ApiError) {
    const errors = error.result;
    // const { statusCode, headers } = error;
  }
}

Retrieve Customer

Returns details for a single customer.

async retrieveCustomer(
  customerId: string,
  requestOptions?: RequestOptions
): Promise<ApiResponse<RetrieveCustomerResponse>>

Parameters

Parameter Type Tags Description
customerId string Template, Required The ID of the customer to retrieve.
requestOptions RequestOptions | undefined Optional Pass additional request options.

Response Type

RetrieveCustomerResponse

Example Usage

const customerId = 'customer_id8';
try {
  const { result, ...httpResponse } = await customersApi.retrieveCustomer(customerId);
  // Get more response info...
  // const { statusCode, headers } = httpResponse;
} catch(error) {
  if (error instanceof ApiError) {
    const errors = error.result;
    // const { statusCode, headers } = error;
  }
}

Update Customer

Updates a customer profile. To change an attribute, specify the new value. To remove an attribute, specify the value as an empty string or empty object.

As a best practice, you should include the version field in the request to enable optimistic concurrency control. The value must be set to the current version of the customer profile.

To update a customer profile that was created by merging existing profiles, you must use the ID of the newly created profile.

You cannot use this endpoint to change cards on file. To make changes, use the Cards API or Gift Cards API.

async updateCustomer(
  customerId: string,
  body: UpdateCustomerRequest,
  requestOptions?: RequestOptions
): Promise<ApiResponse<UpdateCustomerResponse>>

Parameters

Parameter Type Tags Description
customerId string Template, Required The ID of the customer to update.
body UpdateCustomerRequest Body, Required An object containing the fields to POST for the request.

See the corresponding object definition for field details.
requestOptions RequestOptions | undefined Optional Pass additional request options.

Response Type

UpdateCustomerResponse

Example Usage

const customerId = 'customer_id8';
const contentType = null;
const body: UpdateCustomerRequest = {};
body.emailAddress = '[email protected]';
body.phoneNumber = '';
body.note = 'updated customer note';
body.version = 2;

try {
  const { result, ...httpResponse } = await customersApi.updateCustomer(customerId, body);
  // Get more response info...
  // const { statusCode, headers } = httpResponse;
} catch(error) {
  if (error instanceof ApiError) {
    const errors = error.result;
    // const { statusCode, headers } = error;
  }
}

Create Customer Card

This endpoint is deprecated.

Adds a card on file to an existing customer.

As with charges, calls to CreateCustomerCard are idempotent. Multiple calls with the same card nonce return the same card record that was created with the provided nonce during the first call.

async createCustomerCard(
  customerId: string,
  body: CreateCustomerCardRequest,
  requestOptions?: RequestOptions
): Promise<ApiResponse<CreateCustomerCardResponse>>

Parameters

Parameter Type Tags Description
customerId string Template, Required The Square ID of the customer profile the card is linked to.
body CreateCustomerCardRequest Body, Required An object containing the fields to POST for the request.

See the corresponding object definition for field details.
requestOptions RequestOptions | undefined Optional Pass additional request options.

Response Type

CreateCustomerCardResponse

Example Usage

const customerId = 'customer_id8';
const contentType = null;
const bodyBillingAddress: Address = {};
bodyBillingAddress.addressLine1 = '500 Electric Ave';
bodyBillingAddress.addressLine2 = 'Suite 600';
bodyBillingAddress.locality = 'New York';
bodyBillingAddress.administrativeDistrictLevel1 = 'NY';
bodyBillingAddress.postalCode = '10003';
bodyBillingAddress.country = 'US';

const body: CreateCustomerCardRequest = {
  cardNonce: 'YOUR_CARD_NONCE',
};
body.billingAddress = bodyBillingAddress;
body.cardholderName = 'Amelia Earhart';

try {
  const { result, ...httpResponse } = await customersApi.createCustomerCard(customerId, body);
  // Get more response info...
  // const { statusCode, headers } = httpResponse;
} catch(error) {
  if (error instanceof ApiError) {
    const errors = error.result;
    // const { statusCode, headers } = error;
  }
}

Delete Customer Card

This endpoint is deprecated.

Removes a card on file from a customer.

async deleteCustomerCard(
  customerId: string,
  cardId: string,
  requestOptions?: RequestOptions
): Promise<ApiResponse<DeleteCustomerCardResponse>>

Parameters

Parameter Type Tags Description
customerId string Template, Required The ID of the customer that the card on file belongs to.
cardId string Template, Required The ID of the card on file to delete.
requestOptions RequestOptions | undefined Optional Pass additional request options.

Response Type

DeleteCustomerCardResponse

Example Usage

const customerId = 'customer_id8';
const cardId = 'card_id4';
try {
  const { result, ...httpResponse } = await customersApi.deleteCustomerCard(customerId, cardId);
  // Get more response info...
  // const { statusCode, headers } = httpResponse;
} catch(error) {
  if (error instanceof ApiError) {
    const errors = error.result;
    // const { statusCode, headers } = error;
  }
}

Remove Group From Customer

Removes a group membership from a customer.

The customer is identified by the customer_id value and the customer group is identified by the group_id value.

async removeGroupFromCustomer(
  customerId: string,
  groupId: string,
  requestOptions?: RequestOptions
): Promise<ApiResponse<RemoveGroupFromCustomerResponse>>

Parameters

Parameter Type Tags Description
customerId string Template, Required The ID of the customer to remove from the group.
groupId string Template, Required The ID of the customer group to remove the customer from.
requestOptions RequestOptions | undefined Optional Pass additional request options.

Response Type

RemoveGroupFromCustomerResponse

Example Usage

const customerId = 'customer_id8';
const groupId = 'group_id0';
try {
  const { result, ...httpResponse } = await customersApi.removeGroupFromCustomer(customerId, groupId);
  // Get more response info...
  // const { statusCode, headers } = httpResponse;
} catch(error) {
  if (error instanceof ApiError) {
    const errors = error.result;
    // const { statusCode, headers } = error;
  }
}

Add Group to Customer

Adds a group membership to a customer.

The customer is identified by the customer_id value and the customer group is identified by the group_id value.

async addGroupToCustomer(
  customerId: string,
  groupId: string,
  requestOptions?: RequestOptions
): Promise<ApiResponse<AddGroupToCustomerResponse>>

Parameters

Parameter Type Tags Description
customerId string Template, Required The ID of the customer to add to a group.
groupId string Template, Required The ID of the customer group to add the customer to.
requestOptions RequestOptions | undefined Optional Pass additional request options.

Response Type

AddGroupToCustomerResponse

Example Usage

const customerId = 'customer_id8';
const groupId = 'group_id0';
try {
  const { result, ...httpResponse } = await customersApi.addGroupToCustomer(customerId, groupId);
  // Get more response info...
  // const { statusCode, headers } = httpResponse;
} catch(error) {
  if (error instanceof ApiError) {
    const errors = error.result;
    // const { statusCode, headers } = error;
  }
}