Skip to main content
Skip to main content

AdminCustomersResource

This class is used to send requests to Admin Customer API Routes. All its method are available in the JS Client under the medusa.admin.customers property.

All methods in this class require user authentication.

Customers can either be created when they register through the CustomersResource.create method, or created by the admin using the create method.

Related Guide: How to manage customers.

Methods

create

Create a customer as an admin.

Example
import Medusa from "@medusajs/medusa-js"
const medusa = new Medusa({ baseUrl: MEDUSA_BACKEND_URL, maxRetries: 3 })
// must be previously logged in or use api token
medusa.admin.customers
.create({
email: "user@example.com",
first_name: "Caterina",
last_name: "Yost",
password: "supersecret",
})
.then(({ customer }) => {
console.log(customer.id)
})
Parameters
payloadAdminPostCustomersReqRequired
The customer to create.
customHeadersRecord<string, any>Required
Custom headers to attach to the request.

Default: {}

Returns
ResponsePromiseResponsePromise<AdminCustomersRes>Required
Resolves to the customer's details.

list

Retrieve a list of Customers. The customers can be filtered by fields such as q or groups. The customers can also be paginated.

Example

To list customers:

import Medusa from "@medusajs/medusa-js"
const medusa = new Medusa({ baseUrl: MEDUSA_BACKEND_URL, maxRetries: 3 })
// must be previously logged in or use api token
medusa.admin.customers.list().then(({ customers, limit, offset, count }) => {
console.log(customers.length)
})

To specify relations that should be retrieved within the customers:

import Medusa from "@medusajs/medusa-js"
const medusa = new Medusa({ baseUrl: MEDUSA_BACKEND_URL, maxRetries: 3 })
// must be previously logged in or use api token
medusa.admin.customers
.list({
expand: "billing_address",
})
.then(({ customers, limit, offset, count }) => {
console.log(customers.length)
})

By default, only the first 50 records are retrieved. You can control pagination by specifying the limit and offset properties:

import Medusa from "@medusajs/medusa-js"
const medusa = new Medusa({ baseUrl: MEDUSA_BACKEND_URL, maxRetries: 3 })
// must be previously logged in or use api token
medusa.admin.customers
.list({
expand: "billing_address",
limit,
offset,
})
.then(({ customers, limit, offset, count }) => {
console.log(customers.length)
})
Parameters
Filters and pagination configurations to apply on the retrieved customers.
customHeadersRecord<string, any>Required
Custom headers to attach to the request.

Default: {}

Returns
ResponsePromiseResponsePromise<AdminCustomersListRes>Required
Resolves to the list of customers with pagination fields.

retrieve

Retrieve the details of a customer.

Example
import Medusa from "@medusajs/medusa-js"
const medusa = new Medusa({ baseUrl: MEDUSA_BACKEND_URL, maxRetries: 3 })
// must be previously logged in or use api token
medusa.admin.customers.retrieve(customerId).then(({ customer }) => {
console.log(customer.id)
})
Parameters
idstringRequired
The customer's ID.
customHeadersRecord<string, any>Required
Custom headers to attach to the request.

Default: {}

Returns
ResponsePromiseResponsePromise<AdminCustomersRes>Required
Resolves to the customer's details.

update

Update a customer's details.

Example
import Medusa from "@medusajs/medusa-js"
const medusa = new Medusa({ baseUrl: MEDUSA_BACKEND_URL, maxRetries: 3 })
// must be previously logged in or use api token
medusa.admin.customers
.update(customerId, {
first_name: "Dolly",
})
.then(({ customer }) => {
console.log(customer.id)
})
Parameters
idstringRequired
The customer's ID.
The attributes to update in the customer.
customHeadersRecord<string, any>Required
Custom headers to attach to the request.

Default: {}

Returns
ResponsePromiseResponsePromise<AdminCustomersRes>Required
Resolves to the customer's details.
Was this section helpful?