Once OAuth is complete, we can use the library's RestClient
to make an API call. To do that, you can create an instance of RestClient
using the current shop URL and session accessToken
to make requests to the Admin API.
The RestClient
offers the 4 core request methods: get
, delete
, post
, and put
, . These methods each take in an associated <method>RequestParams
object as their argument, each with a set of required and optional parameters. The tables below outline these params objects.
- The
get
method accepts aGetRequestParams
object, which accepts the following parameters:path
,type
,data
,query
,extraHeaders
, andtries
. - The
delete
method accepts aDeleteRequestParams
object, which has an identical strucuture toGetRequestParams
.
GetRequestParams
/ DeleteRequestParams
:
Parameter | Type | Required? | Default Value | Notes |
---|---|---|---|---|
path |
string |
True | none | The requested API endpoint path. This can be one of two formats:
|
data |
Record<string, unknown> | string |
False | none | The body of the request |
type |
DataType |
False | none | The type of data being sent in the body of the request (JSON , GraphQL , URLEncoded ) |
query |
Record<string, string | number> |
False | none | An optional query object to be appended to the request |
extraHeaders |
Record<string, string | number> |
False | none | Any additional headers you want to send with your request |
tries |
number |
False | 1 |
The maximum number of times to retry the request (must be >= 0) |
- The
post
method accepts aPostRequestParams
object, which differs fromget
in that both thetype
anddata
parameters are required, in addition to thepath
. - The
put
method accepts aPutRequestParams
object, which has an identical structure toPostRequestParams
.
PostRequestParams
/ PutRequestParams
:
Parameter | Type | Required? | Default Value | Notes |
---|---|---|---|---|
path |
string |
True | none | The requested API endpoint path. This can be one of two formats:
|
data |
Record<string, unknown> | string |
True | none | The body of the request |
type |
DataType |
True | none | The type of data being sent in the body of the request (JSON , GraphQL , URLEncoded ) |
query |
Record<string, string | number> |
False | none | An optional query object to be appended to the request |
extraHeaders |
Record<string, string | number> |
False | none | Any additional headers you want to send with your request |
tries |
number |
False | 1 |
The maximum number of times to retry the request (must be >= 0) |
We can run the code below in any endpoint where we have access to the request and response objects, optionally typing the body of the response.
// Example expected type for the response body
interface MyResponseBodyType {
products: { ... }
}
// Load the current session to get the `accessToken`.
const session = await Shopify.Utils.loadCurrentSession(req, res);
// Create a new client for the specified shop.
const client = new Shopify.Clients.Rest(session.shop, session.accessToken);
// Use `client.get` to request the specified Shopify REST API endpoint, in this case `products`.
const response = await client.get<MyResponseBodyType>({
path: 'products',
});
// response.body will be of type MyResponseBodyType
response.body.products...
// Load the current session to get the `accessToken`.
const session = await Shopify.Utils.loadCurrentSession(req, res);
// Create a new client for the specified shop.
const client = new Shopify.Clients.Rest(session.shop, session.accessToken);
// Build your post request body.
const body = {
...
};
// Use `client.post` to send your request to the specified Shopify REST API endpoint.
await client.post({
path: 'products',
data: body,
type: DataType.JSON,
});
for more information on the products
endpoint, check out our API reference guide.