lệnh gọi tài nguyên sản phẩm

Tài nguyên products mang lại nhiều sự linh hoạt và khả năng kiểm soát đối với hơn 60 thuộc tính sản phẩm.Có một số trường bắt buộc và bạn phải thêm các trường này để được phê duyệt hiển thị trên Google Mua sắm. Có một số trường không bắt buộc có thể trở thành trường bắt buộc dựa trên nhiều điều kiện, chẳng hạn như vị trí, loại sản phẩm, các phiên bản sản phẩm và gói sản phẩm. Để biết thêm thông tin về hơn 60 thông số không bắt buộc mà bạn có thể định cấu hình cho sản phẩm, hãy tham khảo Quy cách dữ liệu sản phẩm.

Tài nguyên products cho phép bạn insert, get, updatedelete một sản phẩm tại một thời điểm, đồng thời list tất cả sản phẩm trong cơ sở dữ liệu của Merchant Center.

Bạn có thể sử dụng tài nguyên productstatuses để kiểm tra trạng thái phê duyệt hoặc từ chối của một sản phẩm cụ thể cho một vị trí xuất hiện. Hãy tham khảo hướng dẫn về trạng thái sản phẩm để biết thêm thông tin về những sản phẩm có thể gặp vấn đề về chất lượng dữ liệu và những vấn đề đó có thể là gì.

Trong các ví dụ về API, chúng tôi sử dụng 3 sản phẩm: 2 áo thun Google và 1 mũ Google. Chúng tôi sử dụng một bộ dữ liệu sản phẩm tối thiểu xuất hiện trong bảng bên dưới để thực hiện các lệnh gọi tài nguyên products nhằm chèn, nhận, cập nhật, liệt kê và xoá các sản phẩm riêng lẻ cũng như các lô sản phẩm.

Bạn nên thiết lập thông tin về Phí vận chuyển và Thuế ở cấp tài khoản thay vì ở cấp sản phẩm.

Đối với tài khoản phụ nhiều người bán của Trang web thương mại, tất cả sản phẩm đều phải có trường external_seller_id. Hãy xem phần Mã nhận dạng sản phẩm để biết thêm thông tin.

id online:en:US:1111111111 online:en:US:2222222222 online:en:US:3333333333
offerId 1111111111 2222222222 3333333333
tiêu đề Áo thun Google màu đen Google Tee Green Mũ lưỡi trai Google
mô tả Áo thun Google màu đen Áo thun Google làm từ 100% cotton Google Sites phiên bản cũ
mã nhóm mặt hàng google_tee google_tee
liên kết http://my.site.com/blacktee http://my.site.com/greentee http://my.site.com/blackhat
điều kiện Mới Mới Mới
price 219.900 VND 219.900 VND 109.900 VND
độ khả dụng Còn hàng Còn hàng Còn hàng
imageLink https://shop.example.com/store/20160512512/assets/items/images/GGOEGXXX1100.jpg https://shop.example.com/store/20160512512/assets/items/images/GGOEGXXX0906.jpg https://shop.example.com/store/20160512512/assets/items/images/GGOEGHPB071610.jpg
gtin (mã số sản phẩm thương mại toàn cầu) 9504000059422 9504000059446 9504000059452
mpn (mã số linh kiện của nhà sản xuất) 00638NIC 00638ANG 00638ABC
thương hiệu Google Google Google
Danh mục sản phẩm của Google Quần áo & Phụ kiện > Quần áo Quần áo & Phụ kiện > Quần áo Quần áo & Phụ kiện > Phụ kiện quần áo > Mũ
màu đen xanh lục đen
size L M M
age_group người lớn người lớn người lớn
gender nam nam unisex
included_destination Mua sắm Trực tiếp, Quảng cáo Mua sắm Mua sắm Trực tiếp, Quảng cáo Mua sắm Shopping Actions

products.insert

Để chèn một sản phẩm, hãy sử dụng URL yêu cầu sau, chỉ định mã người bán và một nội dung JSON mẫu. Một thao tác chèn sẽ tạo ra sản phẩm mới. Nếu có giá trị cho các thuộc tính channel, contentLanguage, offerIdfeedLabel cho một sản phẩm nhất định, thì phương thức này sẽ cập nhật mục đó và thay thế tất cả dữ liệu từ các lệnh gọi API trước đó cho sản phẩm đó.

Những sản phẩm không được phép xuất hiện tại tất cả các vị trí trên 7 ngày sẽ tự động bị xoá.

Ví dụ minh hoạ này chèn một "Áo phông Google màu đen" mới vào các sản phẩm hiện có.

POST https://shoppingcontent.googleapis.com/content/v2.1/{merchantId}/products

Ví dụ về lệnh gọi nội dung yêu cầu cho products.insert:

{
 "kind": "content#product",
 "offerId": "1111111111",
 "title": "Google Tee Black",
 "description": "The Black Google Tee is available in unisex sizing.",
 "link": "http://my.site.com/blacktee/",
 "imageLink": "https://shop.example.com/.../images/GGOEGXXX1100.jpg",
 "contentLanguage": "en",
 "targetCountry": "US",
 "feedLabel": "US",
 "channel": "online",
 "ageGroup": "adult",
 "availability": "in stock",
 "availabilityDate": "2019-01-25T13:00:00-08:00",
 "brand": "Google",
 "color": "black",
 "condition": "new",
 "gender": "male",
 "googleProductCategory": "1604",
 "gtin": "608802531656",
 "itemGroupId": "google_tee",
 "mpn": "608802531656",
 "price": {
  "value": "21.99",
  "currency": "USD"
 },
 "sizes": [
  "Large"
 ]
}

Một sản phẩm cũng có thể có các thuộc tính tuỳ chỉnh được đặt trong nội dung JSON. Ví dụ: chúng ta có thể đặt một purchase_quantity_limit cho một sản phẩm duy nhất để giới hạn số lượng mặt hàng mà khách hàng có thể đặt hàng:

"customAttributes": [
 {
   "name": "purchase_quantity_limit",
   "value": "4"
 }
]

Xin lưu ý rằng bộ thuộc tính tuỳ chỉnh purchase_quantity_limit đặt hạn mức mua cho mỗi đơn đặt hàng của khách hàng đối với định nghĩa sản phẩm và cũng được nguồn cấp dữ liệu hỗ trợ. Thuộc tính này hiện đang ở giai đoạn thử nghiệm cho đến khi được API hỗ trợ đầy đủ. Người bán có thể thêm bất kỳ thuộc tính tuỳ chỉnh bổ sung nào nhưng không dẫn đến bất kỳ quy trình xử lý cụ thể nào của API.

Một lệnh gọi thành công sẽ trả về mã HTTP 200 và một nội dung phản hồi chứa tài nguyên sản phẩm được chèn chỉ có id, offerId, contentLanguage, feedLabelchannel được điền sẵn:

{
 "kind": "content#product",
 "id": "online:en:US:1111111111",
 "offerId": "1111111111",
 "contentLanguage": "en",
 "targetCountry": "US",
 "feedLabel": "US",
 "channel": "online"
}

products.get

Để lấy thông tin về một sản phẩm cụ thể trong cơ sở dữ liệu của Merchant Center, hãy sử dụng products.get. Có thể mất vài phút để một sản phẩm mới được chèn có sẵn thông qua lệnh gọi này.

Sử dụng URL và các thông số yêu cầu HTTP sau, mã người bán và mã sản phẩm (định dạng mã nhận dạng REST) cho sản phẩm mà bạn muốn nhận:

GET https://shoppingcontent.googleapis.com/content/v2.1/{merchantId}/products/{productId}

Lệnh gọi thành công sẽ trả về một HTTP 200 và "tài nguyên sản phẩm" trong nội dung phản hồi. Sau đây là dữ liệu sản phẩm mẫu được truy xuất từ một sản phẩm có mã nhận dạng online:en:US:1111111111:

{
 "kind": "content#product",
 "id": "online:en:US:1111111111",
 "offerId": "1111111111",
 "source": "api",
 "title": "Google Tee Black",
 "description": "The Black Google Tee is available in unisex sizing.",
 "link": "http://my.site.com/blacktee/",
 "imageLink": "https://shop.example.com/.../images/GGOEGXXX1100.jpg",
 "contentLanguage": "en",
 "targetCountry": "US",
 "feedLabel": "US",
 "channel": "online",
 "ageGroup": "adult",
 "availability": "in stock",
 "availabilityDate": "2019-01-25T13:00:00-08:00",
 "brand": "Google",
 "color": "black",
 "condition": "new",
 "gender": "male",
 "googleProductCategory": "1604",
 "gtin": "608802531656",
 "itemGroupId": "google_tee",
 "mpn": "608802531656",
 "price": {
  "value": "21.99",
  "currency": "USD"
 },
 "sizes": [
  "Large"
 ]
}

products.update

Để cập nhật một sản phẩm, hãy sử dụng URL yêu cầu sau bằng phương thức PATCH, chỉ định mã người bán, mã sản phẩm và một phần nội dung JSON chứa dữ liệu bạn muốn cập nhật cho sản phẩm. Không giống như products.insert, yêu cầu bạn cung cấp tất cả các trường có thể áp dụng, products.update chỉ yêu cầu bạn chỉ định các trường mà bạn muốn thay đổi.

Để thêm hoặc sửa đổi một thuộc tính, hãy chỉ định trường có giá trị mới trong phần nội dung JSON. Ví dụ được minh hoạ sẽ cập nhật titledescription của "Áo thun Google màu đen" hiện có bằng dữ liệu sản phẩm được cung cấp trong nội dung yêu cầu, không thay đổi tất cả các trường khác.

PATCH https://shoppingcontent.googleapis.com/content/v2.1/{merchantId}/products/{productId}

Ví dụ về lệnh gọi nội dung yêu cầu cho products.update:

{
 "title": "Google Tee Black Limited Edition",
 "description": "The Limited Edition Tee is available in unisex sizing and features a retail fit."
}

Bạn chỉ có thể cập nhật các trường cấp cao nhất thông qua yêu cầu products.update. Nếu muốn cập nhật các trường lồng nhau, bạn phải cung cấp toàn bộ đối tượng cấp cao nhất.

Ví dụ được minh hoạ sẽ cập nhật đối tượng salePrice cấp cao nhất, bao gồm cả các trường lồng nhau của một sản phẩm hiện có, bằng dữ liệu sản phẩm được cung cấp trong phần nội dung yêu cầu, mà không ảnh hưởng đến tất cả các trường khác.

PATCH https://shoppingcontent.googleapis.com/content/v2.1/{merchantId}/products/{productId}
{
 "salePrice": {
  "value": "17.99",
  "currency": "USD"
 }
}

Để chọn một số trường nhất định cần cập nhật mà không cần thay đổi các trường khác có trong nội dung yêu cầu, bạn có thể chỉ định một updateMask. Tham số chuỗi truy vấn này phải là danh sách các trường được phân tách bằng dấu phẩy mà bạn muốn sửa đổi. updateMask rất hữu ích khi bạn muốn khẳng định rằng chỉ các trường được đặt tên sẽ được cập nhật. Việc không chỉ định updateMask tương đương với việc đánh dấu tất cả các trường trong yêu cầu cần cập nhật như trong ví dụ ở trên.

Ví dụ minh hoạ sẽ chỉ cập nhật descriptionavailability của một "Áo thun Google màu đen" hiện có bằng dữ liệu sản phẩm tương ứng được cung cấp trong nội dung yêu cầu, để nguyên tất cả các trường khác, bao gồm cả title.

PATCH https://shoppingcontent.googleapis.com/content/v2.1/{merchantId}/products/{productId}?updateMask=description,availability

Ví dụ về lệnh gọi nội dung yêu cầu cho products.update:

{
 "title": "Google Tee Black",
 "description": "This Limited Edition is out of print.",
 "availability": "out of stock"
}

Nếu một trường được cung cấp trong danh sách updateMask nhưng không có trong nội dung yêu cầu, thì trường đó sẽ bị xoá khỏi tài nguyên Product (nếu có).

Ví dụ minh hoạ sẽ sử dụng updateMask để xoá giá trị cho trường salePrice.

PATCH https://shoppingcontent.googleapis.com/content/v2.1/{merchantId}/products/{productId}?updateMask=salePrice

Nội dung yêu cầu mẫu không được bao gồm trường salePrice để xoá trường đó. Bạn cũng có thể không cung cấp nội dung hoặc cung cấp nội dung trống. Các trường khác sẽ không bị ảnh hưởng nếu chúng không xuất hiện trong updateMask.

Để sử dụng updateMask trong yêu cầu products.custombatch, bạn phải chỉ định updateMask trong phần nội dung của yêu cầu.

Ví dụ minh hoạ sẽ cập nhật priceavailability của "Áo phông Google màu đen" hiện có bằng cách sử dụng products.custombatch với dữ liệu sản phẩm được cung cấp trong mục nhập hàng loạt, không thay đổi tất cả các trường khác, bao gồm cả titledescription.

POST https://shoppingcontent.googleapis.com/content/v2.1/products/batch
{
  "entries": [{
    "batchId": 1,
    "merchantId": "MERCHANT_ID",
    "productId": "online:en:US:1111111111",
    "method": "update",
    "product": {
      "title": "Google Tee Black",
      "description": "The Black Google Tee is available in unisex sizing.",
      "availability": "in stock",
      "price": {
        "value": "19.99",
        "currency": "USD"
      }
    },
    "updateMask": "availability,price"
  }]
}

products.delete

Để xoá một sản phẩm, hãy sử dụng products.delete với URL yêu cầu HTTP mẫu, mã người bán và mã sản phẩm (ở định dạng mã nhận dạng REST, chẳng hạn như online:en:US:1111111111) cho sản phẩm mà bạn muốn xoá:

DELETE https://shoppingcontent.googleapis.com/content/v2.1/{merchantId}/products/{productId}

Phản hồi thành công sẽ trả về một HTTP Status 204 mà không có nội dung phản hồi.

products.list

products.list liệt kê tất cả sản phẩm mà người bán có trong cơ sở dữ liệu của Merchant Center. Sử dụng URL yêu cầu sau:

GET https://shoppingcontent.googleapis.com/content/v2.1/{merchantId}/products

Một lệnh gọi thành công sẽ trả về HTTP 200 và dữ liệu JSON cho các sản phẩm trong khoá "resources".

Ba sản phẩm ví dụ sau đây sẽ được trả về:

{
 "kind": "content#productsListResponse",
 "resources": [
  {
   "kind": "content#product",
   "id": "online:en:US:1111111111",
   "offerId": "1111111111",
   "source": "api",
   "title": "Google Tee Black",
   "description": "The Black Google Tee is available in unisex sizing.",
   "link": "http://my.site.com/blacktee/",
   "imageLink": "https://shop.example.com/.../images/GGOEGXXX1100.jpg",
   "contentLanguage": "en",
   "targetCountry": "US",
   "feedLabel": "US",
   "channel": "online",
   "ageGroup": "adult",
   "availability": "in stock",
   "availabilityDate": "2019-01-25T13:00:00-08:00",
   "brand": "Google",
   "color": "black",
   "condition": "new",
   "gender": "male",
   "googleProductCategory": "1604",
   "gtin": "608802531656",
   "itemGroupId": "google_tee",
   "mpn": "608802531656",
   "price": {
    "value": "21.99",
    "currency": "USD"
   },
   "sizes": [
    "Large"
   ]
  },
  {
   "kind": "content#product",
   "id": "online:en:US:2222222222",
   "offerId": "2222222222",
   "source": "api",
   "title": "Google Tee Green",
   "description": "100% cotton jersey fabric sets this Google t-shirt above the crowd.
    Features the google logo across the chest. Unisex sizing.",
   "link": "http://my.site.com/greentee/",
   "imageLink": "https://shop.example.com/.../images/GGOEGXXX0906.jpg",
   "contentLanguage": "en",
   "targetCountry": "US",
   "feedLabel": "US",
   "channel": "online",
   "ageGroup": "adult",
   "availability": "in stock",
   "availabilityDate": "2019-01-25T13:00:00-08:00",
   "brand": "Google",
   "color": "green",
   "condition": "new",
   "gender": "male",
   "googleProductCategory": "1604",
   "gtin": "608802531649",
   "itemGroupId": "google_tee",
   "mpn": "608802531649",
   "price": {
    "value": "21.99",
    "currency": "USD"
   },
   "sizes": [
    "Medium"
   ]
  },
  {
   "kind": "content#product",
   "id": "online:en:US:3333333333",
   "offerId": "3333333333",
   "source": "api",
   "title": "Google Twill Cap",
   "description": "Classic urban styling distinguishes this Google cap.
    Retains its shape, even when not being worn.",
   "link": "http://my.site.com/blackhat/",
   "imageLink": "https://shop.example.com/.../images/GGOEGHPB071610.jpg",
   "contentLanguage": "en",
   "targetCountry": "US",
   "feedLabel": "US",
   "channel": "online",
   "ageGroup": "adult",
   "availability": "in stock",
   "availabilityDate": "2019-01-07T13:00:00-08:00",
   "brand": "Google",
   "color": "black",
   "condition": "new",
   "gender": "male",
   "googleProductCategory": "173",
   "gtin": "689355417246",
   "mpn": "689355417246",
   "price": {
    "value": "10.99",
    "currency": "USD"
   },
   "sizes": [
    "Medium"
   ]
  }
 ]
}