Class: Google::Apis::RetailV2beta::GoogleCloudRetailV2betaProduct

Inherits:
Object
  • Object
show all
Includes:
Core::Hashable, Core::JsonObjectSupport
Defined in:
lib/google/apis/retail_v2beta/classes.rb,
lib/google/apis/retail_v2beta/representations.rb,
lib/google/apis/retail_v2beta/representations.rb

Overview

Product captures all metadata information of items to be recommended or searched.

Instance Attribute Summary collapse

Instance Method Summary collapse

Constructor Details

#initialize(**args) ⇒ GoogleCloudRetailV2betaProduct

Returns a new instance of GoogleCloudRetailV2betaProduct.



1668
1669
1670
# File 'lib/google/apis/retail_v2beta/classes.rb', line 1668

def initialize(**args)
   update!(**args)
end

Instance Attribute Details

#attributesHash<String,Google::Apis::RetailV2beta::GoogleCloudRetailV2betaCustomAttribute>

Highly encouraged. Extra product attributes to be included. For example, for products, this could include the store name, vendor, style, color, etc. These are very strong signals for recommendation model, thus we highly recommend providing the attributes here. Features that can take on one of a limited number of possible values. Two types of features can be set are: Textual features. some examples would be the brand/maker of a product, or country of a customer. Numerical features. Some examples would be the height/weight of a product, or age of a customer. For example: "vendor": `"text": ["vendor123", "vendor456"]`, "lengths_cm": `"numbers":[2.3, 15.4]`, "heights_cm": `"numbers" :[8.1, 6.4]`. This field needs to pass all below criteria, otherwise an INVALID_ARGUMENT error is returned: * Max entries count: 150 by default; 100 for Type.VARIANT. * The key must be a UTF-8 encoded string with a length limit of 128 characters. Corresponds to the JSON property attributes



1540
1541
1542
# File 'lib/google/apis/retail_v2beta/classes.rb', line 1540

def attributes
  @attributes
end

#availabilityString

The online availability of the Product. Default to Availability.IN_STOCK. Google Merchant Center Property availability. Schema.org Property Offer.availability. Corresponds to the JSON property availability

Returns:

  • (String)


1548
1549
1550
# File 'lib/google/apis/retail_v2beta/classes.rb', line 1548

def availability
  @availability
end

#available_quantityFixnum

The available quantity of the item. Corresponds to the JSON property availableQuantity

Returns:

  • (Fixnum)


1553
1554
1555
# File 'lib/google/apis/retail_v2beta/classes.rb', line 1553

def available_quantity
  @available_quantity
end

#available_timeString

The timestamp when this Product becomes available for recommendation. Corresponds to the JSON property availableTime

Returns:

  • (String)


1558
1559
1560
# File 'lib/google/apis/retail_v2beta/classes.rb', line 1558

def available_time
  @available_time
end

#categoriesArray<String>

Product categories. This field is repeated for supporting one product belonging to several parallel categories. Strongly recommended using the full path for better search / recommendation quality. To represent full path of category, use '>' sign to separate different hierarchies. If '>' is part of the category name, please replace it with other character(s). For example, if a shoes product belongs to both ["Shoes & Accessories" -> "Shoes"] and [" Sports & Fitness" -> "Athletic Clothing" -> "Shoes"], it could be represented as: "categories": [ "Shoes & Accessories > Shoes", "Sports & Fitness > Athletic Clothing > Shoes" ] Must be set for Type.PRIMARY Product otherwise an INVALID_ARGUMENT error is returned. At most 250 values are allowed per Product. Empty values are not allowed. Each value must be a UTF-8 encoded string with a length limit of 5,000 characters. Otherwise, an INVALID_ARGUMENT error is returned. Google Merchant Center property google_product_category. Schema.org property Product.category. [ mc_google_product_category]: https://support.google.com/merchants/answer/ 6324436 Corresponds to the JSON property categories

Returns:

  • (Array<String>)


1578
1579
1580
# File 'lib/google/apis/retail_v2beta/classes.rb', line 1578

def categories
  @categories
end

#descriptionString

Product description. This field must be a UTF-8 encoded string with a length limit of 5,000 characters. Otherwise, an INVALID_ARGUMENT error is returned. Google Merchant Center property description. schema.org property Product.description. Corresponds to the JSON property description

Returns:

  • (String)


1587
1588
1589
# File 'lib/google/apis/retail_v2beta/classes.rb', line 1587

def description
  @description
end

#idString

Immutable. Product identifier, which is the final component of name. For example, this field is "id_1", if name is projects/*/locations/global/ catalogs/default_catalog/branches/default_branch/products/id_1. This field must be a UTF-8 encoded string with a length limit of 128 characters. Otherwise, an INVALID_ARGUMENT error is returned. Google Merchant Center property id. Schema.org Property Product.sku. Corresponds to the JSON property id

Returns:

  • (String)


1598
1599
1600
# File 'lib/google/apis/retail_v2beta/classes.rb', line 1598

def id
  @id
end

#imagesArray<Google::Apis::RetailV2beta::GoogleCloudRetailV2betaImage>

Product images for the product.Highly recommended to put the main image to the first. A maximum of 300 images are allowed. Google Merchant Center property image_link. Schema.org property Product.image. Corresponds to the JSON property images



1606
1607
1608
# File 'lib/google/apis/retail_v2beta/classes.rb', line 1606

def images
  @images
end

#nameString

Immutable. Full resource name of the product, such as projects/*/locations/ global/catalogs/default_catalog/branches/default_branch/products/product_id. The branch ID must be "default_branch". Corresponds to the JSON property name

Returns:

  • (String)


1613
1614
1615
# File 'lib/google/apis/retail_v2beta/classes.rb', line 1613

def name
  @name
end

#price_infoGoogle::Apis::RetailV2beta::GoogleCloudRetailV2betaPriceInfo

The price information of a Product. Corresponds to the JSON property priceInfo



1618
1619
1620
# File 'lib/google/apis/retail_v2beta/classes.rb', line 1618

def price_info
  @price_info
end

#primary_product_idString

Variant group identifier. Must be an id, with the same parent branch with this product. Otherwise, an error is thrown. For Type.PRIMARY Products, this field can only be empty or set to the same value as id. For VARIANT Products, this field cannot be empty. A maximum of 2,000 products are allowed to share the same Type.PRIMARY Product. Otherwise, an INVALID_ARGUMENT error is returned. Google Merchant Center Property item_group_id. Schema.org Property Product.inProductGroupWithID. This field must be enabled before it can be used. Learn more. Corresponds to the JSON property primaryProductId

Returns:

  • (String)


1631
1632
1633
# File 'lib/google/apis/retail_v2beta/classes.rb', line 1631

def primary_product_id
  @primary_product_id
end

#tagsArray<String>

Custom tags associated with the product. At most 250 values are allowed per Product. This value must be a UTF-8 encoded string with a length limit of 1, 000 characters. Otherwise, an INVALID_ARGUMENT error is returned. This tag can be used for filtering recommendation results by passing the tag as part of the PredictRequest.filter. Google Merchant Center property custom_label_0–4. Corresponds to the JSON property tags

Returns:

  • (Array<String>)


1641
1642
1643
# File 'lib/google/apis/retail_v2beta/classes.rb', line 1641

def tags
  @tags
end

#titleString

Required. Product title. This field must be a UTF-8 encoded string with a length limit of 1,000 characters. Otherwise, an INVALID_ARGUMENT error is returned. Google Merchant Center property title. Schema.org property Product.name. Corresponds to the JSON property title

Returns:

  • (String)


1650
1651
1652
# File 'lib/google/apis/retail_v2beta/classes.rb', line 1650

def title
  @title
end

#typeString

Immutable. The type of the product. This field is output-only. Corresponds to the JSON property type

Returns:

  • (String)


1655
1656
1657
# File 'lib/google/apis/retail_v2beta/classes.rb', line 1655

def type
  @type
end

#uriString

Canonical URL directly linking to the product detail page. It is strongly recommended to provide a valid uri for the product, otherwise the service performance could be significantly degraded. This field must be a UTF-8 encoded string with a length limit of 5,000 characters. Otherwise, an INVALID_ARGUMENT error is returned. Google Merchant Center property link. Schema.org property Offer.url. Corresponds to the JSON property uri

Returns:

  • (String)


1666
1667
1668
# File 'lib/google/apis/retail_v2beta/classes.rb', line 1666

def uri
  @uri
end

Instance Method Details

#update!(**args) ⇒ Object

Update properties of this object



1673
1674
1675
1676
1677
1678
1679
1680
1681
1682
1683
1684
1685
1686
1687
1688
1689
# File 'lib/google/apis/retail_v2beta/classes.rb', line 1673

def update!(**args)
  @attributes = args[:attributes] if args.key?(:attributes)
  @availability = args[:availability] if args.key?(:availability)
  @available_quantity = args[:available_quantity] if args.key?(:available_quantity)
  @available_time = args[:available_time] if args.key?(:available_time)
  @categories = args[:categories] if args.key?(:categories)
  @description = args[:description] if args.key?(:description)
  @id = args[:id] if args.key?(:id)
  @images = args[:images] if args.key?(:images)
  @name = args[:name] if args.key?(:name)
  @price_info = args[:price_info] if args.key?(:price_info)
  @primary_product_id = args[:primary_product_id] if args.key?(:primary_product_id)
  @tags = args[:tags] if args.key?(:tags)
  @title = args[:title] if args.key?(:title)
  @type = args[:type] if args.key?(:type)
  @uri = args[:uri] if args.key?(:uri)
end