🚀 PHP SDK for the Shopify API
Install via composer
$ composer require slince/shopify-api-php
You first need to initialize the client. For that you need your Shop Name and AccessToken
require __DIR__ . '/vendor/autoload.php';
$credential = new Slince\Shopify\PublicAppCredential('Access Token');
// Or Private App
$credential = new Slince\Shopify\PrivateAppCredential('API KEY', 'PASSWORD', 'SHARED SECRET');
$client = new Slince\Shopify\Client($credential, 'your-store.myshopify.com', [
'metaCacheDir' => './tmp' // Metadata cache dir, required
]);
- Lists products
$products = $client->getProductManager()->findAll([
// Filter your product
'collection_id' => 841564295
'page' => 2
]);
- Get the specified product
$product = $client->getProductManager()->find(12800);
// Update the given product
$product = $client->getProductManager()->update(12800, [
"title" => "Burton Custom Freestyle 151",
"body_html" => "<strong>Good snowboard!<\/strong>",
"vendor"=> "Burton",
"product_type" => "Snowboard",
]);
- Creates a new product
$product = $client->getProductManager()->create([
"title" => "Burton Custom Freestyle 151",
"body_html" => "<strong>Good snowboard!<\/strong>",
"vendor"=> "Burton",
"product_type" => "Snowboard",
]);
- Removes the product by its id
$client->getProductManager()->remove(12800);
The product is an instance of Slince\Shopify\Manager\Product\Product
; You can access properties like following:
echo $product->getTitle();
echo $product->getCreatedAt(); // DateTime Object
//...
print_r($product->getVariants());
print_r($product->getImages());
Available managers:
- Article
- Asset
- Blog
- CarrierService
- Collect
- Comment
- Country
- CustomCollection
- Customer
- CustomerAddress
- CustomerSavedSearch
- DiscountCode
- Fulfillment
- FulfillmentService
- InventoryItem
- InventoryLevel
- Location
- Order
- OrderRisk
- Page
- Policy
- PriceRule
- Product
- ProductImage
- ProductVariant
- Province
- RecurringApplicationCharge
- Redirect
- Refund
- ScriptTag
- ShippingZone
- Shop
- SmartCollection
- Theme
- Transaction
- Webhook
You can access the manager like $client->getProductManager()
, $client->getOrderManager()
.
If you don't like to use managers, you can also manipulate data like this:
The returned value is just an array;
$products = $client->get('products', [
// Filter your products
]);
$product = $client->get('products/12800');
$product = $client->post('products', [
"product" => [
"title" => "Burton Custom Freestyle 151",
"body_html" => "<strong>Good snowboard!<\/strong>",
"vendor"=> "Burton",
"product_type" => "Snowboard",
"images" => [
[
"attachment" => "R0lGODlhAQABAIAAAAAAAAAAACH5BAEAAAAALAAAAAABAAEAAAICRAEAOw==\n"
]
]
]
]);
$product = $client->put('products/12800', [
"product" => [
"title" => "Burton Custom Freestyle 151",
"body_html" => "<strong>Good snowboard!<\/strong>",
"vendor"=> "Burton",
"product_type" => "Snowboard",
"images" => [
[
"attachment" => "R0lGODlhAQABAIAAAAAAAAAAACH5BAEAAAAALAAAAAABAAEAAAICRAEAOw==\n"
]
]
]
]);
$client->delete('products/12800');
The MIT license. See MIT