簡體   English   中英

如何使用 PHP 按 SKU 獲取 Square Inventory?

[英]How to fetch Square Inventory By SKU using PHP?

我想從 Square Catalog 中獲取所有產品。

這是代碼:

require 'vendor/autoload.php';

use Square\SquareClient;
use Square\LocationsApi;
use Square\Exceptions\ApiException;
use Square\Http\ApiResponse;
use Square\Models\ListLocationsResponse;
use Square\Environment;


$client = new SquareClient([
    'accessToken' => '{{access_token}}',
    'environment' => Environment::SANDBOX,
]);


//Providing SKU
$object_ids = ['GFLR20L', '232GGGD'];
$body = new \Square\Models\BatchRetrieveCatalogObjectsRequest($object_ids);
$body->setIncludeRelatedObjects(true);

$api_response = $client->getCatalogApi()->batchRetrieveCatalogObjects($body);

if ($api_response->isSuccess()) {
    $result = $api_response->getResult();
} else {
    $errors = $api_response->getErrors();
}

Output:

object(Square\Models\BatchRetrieveCatalogObjectsResponse)#13 (3) 
{
  ["errors":"Square\Models\BatchRetrieveCatalogObjectsResponse":private] => NULL
  ["objects":"Square\Models\BatchRetrieveCatalogObjectsResponse":private] => NULL
  ["relatedObjects":"Square\Models\BatchRetrieveCatalogObjectsResponse":private] => NULL 
}

**> sjosey 發表建議:

我的 PHP 代碼:

正在尋找名稱為 Paper 的產品。**

$object_types = ['ITEM'];
$prefix_query = new \Square\Models\CatalogQueryPrefix('name', 'paper');

$query = new \Square\Models\CatalogQuery();
$query->setPrefixQuery($prefix_query);

> 在此處存儲值

$body = new \Square\Models\SearchCatalogObjectsRequest();
$body->setObjectTypes($object_types);
$body->setQuery($query);
$body->setLimit(100);

$api_response = $client->getCatalogApi()->searchCatalogObjects($body);

> 在此處獲取 api 響應

if ($api_response->isSuccess()) {
    $result = $api_response->getResult();
} else {
    $errors = $api_response->getErrors();
}

> 回聲結果

var_dump($result);

這是 output:

object(Square\Models\SearchCatalogObjectsResponse)#15 (5) { ["errors":"Square\Models\SearchCatalogObjectsResponse":private]=> NULL ["cursor":"Square\Models\SearchCatalogObjectsResponse":private]=> NULL ["objects":"Square\Models\SearchCatalogObjectsResponse":private]=> NULL ["relatedObjects":"Square\Models\SearchCatalogObjectsResponse":private]=> NULL ["latestTime":"Square\Models\SearchCatalogObjectsResponse":private]=> string(20) "1776-07-04T00:00:00Z" }

object_id與 SKU 不同; 它們是 Square 方面唯一生成的 ID。 您可能希望使用SearchCatalogObjects (POST /v2/catalog/search) 端點來按 SKU 進行搜索。 使用您的 SKU 之一的示例查詢將是:

{
  "query": {
    "exact_query": {
      "attribute_name": "sku",
      "attribute_value": "GFLR20L"
    }
  }
}

這將獲得您的目錄 object id,但如果您對庫存感興趣,您仍然需要使用另一個端點來獲取庫存,例如RetrieveInventoryCount (它以catalog_object_id作為參數)。

想出了解決辦法。 以下代碼按產品 IDS 獲取所有產品的列表。 該數組可用於根據要求設置數據(按 SKU 或任何東西)

require 'vendor/autoload.php';

use Square\SquareClient;
use Square\LocationsApi;
use Square\Exceptions\ApiException;
use Square\Http\ApiResponse;
use Square\Models\ListLocationsResponse;
use Square\Environment;

$client = new SquareClient([
    'accessToken' => '{{access_token}}',
    'environment' => Environment::PRODUCTION,
]);


$bag = [];
$cursor = null;
$ctr = 1;

$api_response = $client->getCatalogApi()->listCatalog($cursor, 'ITEM');

if ($api_response->isSuccess()) {
    $result = $api_response->getResult();
} else {
    $errors = $api_response->getErrors();
}

$g1 = $result;
$g2 = json_encode($g1);
$g3 = json_decode($g2);
$cursor = $g3->cursor;
$objects = $g3->objects;
$g4 = json_encode($objects);
$g5 = json_decode($g4);

foreach($g5 as $g51){
    $bag[$g51->id] = $g51;
}





while($cursor != null){

$api_response2 = $client->getCatalogApi()->listCatalog($cursor, 'ITEM');

if ($api_response2->isSuccess()) {
    $result2 = $api_response2->getResult();
} else {
    $errors2 = $api_response2->getErrors();
}

$g6 = $result2;
$g7 = json_encode($g6);
$g8 = json_decode($g7);
$cursor = $g8->cursor;
$objects2 = $g8->objects;
$g9 = json_encode($objects2);
$g10 = json_decode($g9);

foreach($g10 as $g101){
    $bag[$g101->id] = $g101;
}

}



var_dump(count($bag));

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM