A fluent and object-oriented approach for using the Shopify API.
- Asset
- Customer
- Dispute
- Fulfillment
- FulfillmentService
- Image
- Metafield
- Order
- Product
- Risk
- Shop
- Theme
- Variant
- Webhook
PHP | Package |
---|---|
8 | 5.0.* |
7 | 4.0.* |
YOLO | dev-master |
composer require dan/shopify
The APIs all function alike, here is an example of usage of the products API.
$api = Dan\Shopify\Shopify::make($shop = 'shop-name.myshopify.com', $token = 'shpua_abc123');
// Shop information
$api->shop(); // array dictionary
// List of products
$api->products->get(); // array of array dictionaries
// Attach query parameters to a get request
$api->products->get(['created_at_min' => '2023-03-25']); // array of array dictionaries
// A specific product
$api->products('123456789')->get(); // array dictionary
// Get all variants for a product
$api->products('123456789')->variants->get(); // array of array dictionaries
// Get a specific variant for a specific product
$s->api2()->products('123456789')->variants('567891234')->get(); // array dictionary
// Append URI string to a get request
$api->orders('123456789')->get([], 'risks'); // array dictionary
// Create a product.
// See https://shopify.dev/docs/api/admin-rest/2023-01/resources/product#post-products
$api->products->post(['title' => 'Simple Test']); // array dictionary
// Update something specific on a product
$api->products('123456789')->put(['title' => 'My title changed.']); // array dictionary
The collection and model utilities that are available ->find(...)
and ->findMany(...)
for RESTful endpoints are NOT available for GraphQL.
Some endpoints are only available through Shopify's GraphQL library. This makes me sad because GraphQL is not as readable or intuitive as RESTful APIs, less people understand it, and it's harder to train people on. That said, if you want to jam out with your graphql, there is a client method to assist you.
For example, fetch delivery profiles (only available in GraphQL).
Note: You can safely use the
graphql(...)
helper method without any concern of changing the state on theDan\Shopify\Shopify::class
.
$query = "{
deliveryProfiles (first: 3) {
edges {
node {
id,
name,
}
}
}
}"
$api->graphql($query); // hipster
Shopify doesn't jam with regular old pagination, sigh ...
As of the 2019-10
API version, Shopify has removed per page pagination on their busiest endpoints.
With the deprecation of the per page pagination comes a new cursor based pagination.
You can use the next
method to get paged responses.
Example usage:
// First call to next can have all the usual query params you might want.
$api->orders->next(['limit' => 100, 'status' => 'closed');
// Further calls will have all query params preset except for limit.
$api->orders->next(['limit' => 100]);
There are multiple endpoints in the Shopify API that have support for metafields.
In effort to support them all, this API has been updated to allow chaining ->metafields
from any endpoint.
This won't always work as not every endpoint supports metafields, and any endpoint that doesn't support metafields will result in a 404
.
Below are examples of all the endpoints that support metafields.
// Get our API
$api = Dan\Shopify\Shopify::make($shop, $token);
// Store metafields
$api->metafields->get();
// Metafields on an Order
$api->orders($order_id)->metafields->get();
// Metafields on a Product
$api->products($product_id)->metafields->get();
// Metafields on a Variant
$api->products($product_id)->variants($variant_id)->metafields->get();
// Metafields on a Customer
$api->customers($customer_id)->metafields->get();
// Metafields can also be updated like all other endpoints
$api->products($product_id)->metafields($metafield_id)->put($data);
In your config/app.php
Requires for private app (env token) for single store usage of oauth (multiple stores)
Dan\Shopify\Integrations\Laravel\ShopifyServiceProvider::class,
If your app only interacts with a single store, there is a Facade that may come in handy.
'Shopify' => Dan\Shopify\Integrations\Laravel\ShopifyFacade::class,
SHOPIFY_DOMAIN=your-shop-name.myshopify.com
SHOPIFY_TOKEN=your-token-here
Empty or admin
defaults to oldest supported API, learn more
SHOPIFY_API_BASE="admin/api/2022-07"
It will be instantiated with your shop and token you set up in
config/shopify.php
Review the Basic Usage
above, using the Facade is more or less the same, except you're only interacting with the one store in your config.
// Facade same as $api->shop(), but for just the one store.
Shopify::shop();
// Facade same as $api->products->get(), but for just the one store.
Shopify::products()->get();
// Facade same as $api->products('123456789')->get(), but for just the one store.
Shopify::products('123456789')->get();
Making a public app using oauth, follow the Shopify docs to make your auth url, and use the following helper to retrieve your access token using the code from your callback.
Shopify::getAppInstallResponse(
'your_app_client_id',
'your_app_client_secret',
'shop_from_request',
'code_from_request'
);
// returns (object) ['access_token' => '...', 'scopes' => '...']
Dan\Shopify\Util::validAppHmac(
'hmac_from_request',
'your_app_client_secret',
['shop' => '...', 'timestamp' => '...', ...]
);
Dan\Shopify\Util::validWebhookHmac(
'hmac_from_request',
'your_app_client_secret',
file_get_contents('php://input')
);
- Artisan Command to create token
MIT.