Documentation

Overview

Package manufacturers provides access to the Manufacturer Center API.

For product documentation, see: https://developers.google.com/manufacturers/

Creating a client

Usage example:

import "google.golang.org/api/manufacturers/v1"
...
ctx := context.Background()
manufacturersService, err := manufacturers.NewService(ctx)

In this example, Google Application Default Credentials are used for authentication.

For information on how to create and obtain Application Default Credentials, see https://developers.google.com/identity/protocols/application-default-credentials.

Other authentication options

To use an API key for authentication (note: some APIs do not support API keys), use option.WithAPIKey:

manufacturersService, err := manufacturers.NewService(ctx, option.WithAPIKey("AIza..."))

To use an OAuth token (e.g., a user token obtained via a three-legged OAuth flow), use option.WithTokenSource:

config := &oauth2.Config{...}
// ...
token, err := config.Exchange(ctx, ...)
manufacturersService, err := manufacturers.NewService(ctx, option.WithTokenSource(config.TokenSource(ctx, token)))

See https://godoc.org/google.golang.org/api/option/ for details on options.

Index

Constants

View Source
const (
	// Manage your product listings for Google Manufacturer Center
	ManufacturercenterScope = "https://www.googleapis.com/auth/manufacturercenter"
)

    OAuth2 scopes used by this API.

    Variables

    This section is empty.

    Functions

    This section is empty.

    Types

    type AccountsProductsDeleteCall

    type AccountsProductsDeleteCall struct {
    	// contains filtered or unexported fields
    }

    func (*AccountsProductsDeleteCall) Context

      Context sets the context to be used in this call's Do method. Any pending HTTP request will be aborted if the provided context is canceled.

      func (*AccountsProductsDeleteCall) Do

        Do executes the "manufacturers.accounts.products.delete" call. Exactly one of *Empty or error will be non-nil. Any non-2xx status code is an error. Response headers are in either *Empty.ServerResponse.Header or (if a response was returned at all) in error.(*googleapi.Error).Header. Use googleapi.IsNotModified to check whether the returned error was because http.StatusNotModified was returned.

        func (*AccountsProductsDeleteCall) Fields

          Fields allows partial responses to be retrieved. See https://developers.google.com/gdata/docs/2.0/basics#PartialResponse for more information.

          func (*AccountsProductsDeleteCall) Header

            Header returns an http.Header that can be modified by the caller to add HTTP headers to the request.

            type AccountsProductsGetCall

            type AccountsProductsGetCall struct {
            	// contains filtered or unexported fields
            }

            func (*AccountsProductsGetCall) Context

              Context sets the context to be used in this call's Do method. Any pending HTTP request will be aborted if the provided context is canceled.

              func (*AccountsProductsGetCall) Do

                Do executes the "manufacturers.accounts.products.get" call. Exactly one of *Product or error will be non-nil. Any non-2xx status code is an error. Response headers are in either *Product.ServerResponse.Header or (if a response was returned at all) in error.(*googleapi.Error).Header. Use googleapi.IsNotModified to check whether the returned error was because http.StatusNotModified was returned.

                func (*AccountsProductsGetCall) Fields

                  Fields allows partial responses to be retrieved. See https://developers.google.com/gdata/docs/2.0/basics#PartialResponse for more information.

                  func (*AccountsProductsGetCall) Header

                  func (c *AccountsProductsGetCall) Header() http.Header

                    Header returns an http.Header that can be modified by the caller to add HTTP headers to the request.

                    func (*AccountsProductsGetCall) IfNoneMatch

                    func (c *AccountsProductsGetCall) IfNoneMatch(entityTag string) *AccountsProductsGetCall

                      IfNoneMatch sets the optional parameter which makes the operation fail if the object's ETag matches the given value. This is useful for getting updates only after the object has changed since the last request. Use googleapi.IsNotModified to check whether the response error from Do is the result of In-None-Match.

                      func (*AccountsProductsGetCall) Include

                      func (c *AccountsProductsGetCall) Include(include ...string) *AccountsProductsGetCall

                        Include sets the optional parameter "include": The information to be included in the response. Only sections listed here will be returned.

                        Possible values:

                        "UNKNOWN" - Unknown, never used.
                        "ATTRIBUTES" - Include the attributes of the product.
                        "ISSUES" - Include the issues of the product.
                        "DESTINATION_STATUSES" - Include the destination statuses of the
                        

                        product.

                        type AccountsProductsListCall

                        type AccountsProductsListCall struct {
                        	// contains filtered or unexported fields
                        }

                        func (*AccountsProductsListCall) Context

                          Context sets the context to be used in this call's Do method. Any pending HTTP request will be aborted if the provided context is canceled.

                          func (*AccountsProductsListCall) Do

                            Do executes the "manufacturers.accounts.products.list" call. Exactly one of *ListProductsResponse or error will be non-nil. Any non-2xx status code is an error. Response headers are in either *ListProductsResponse.ServerResponse.Header or (if a response was returned at all) in error.(*googleapi.Error).Header. Use googleapi.IsNotModified to check whether the returned error was because http.StatusNotModified was returned.

                            func (*AccountsProductsListCall) Fields

                              Fields allows partial responses to be retrieved. See https://developers.google.com/gdata/docs/2.0/basics#PartialResponse for more information.

                              func (*AccountsProductsListCall) Header

                              func (c *AccountsProductsListCall) Header() http.Header

                                Header returns an http.Header that can be modified by the caller to add HTTP headers to the request.

                                func (*AccountsProductsListCall) IfNoneMatch

                                func (c *AccountsProductsListCall) IfNoneMatch(entityTag string) *AccountsProductsListCall

                                  IfNoneMatch sets the optional parameter which makes the operation fail if the object's ETag matches the given value. This is useful for getting updates only after the object has changed since the last request. Use googleapi.IsNotModified to check whether the response error from Do is the result of In-None-Match.

                                  func (*AccountsProductsListCall) Include

                                    Include sets the optional parameter "include": The information to be included in the response. Only sections listed here will be returned.

                                    Possible values:

                                    "UNKNOWN" - Unknown, never used.
                                    "ATTRIBUTES" - Include the attributes of the product.
                                    "ISSUES" - Include the issues of the product.
                                    "DESTINATION_STATUSES" - Include the destination statuses of the
                                    

                                    product.

                                    func (*AccountsProductsListCall) PageSize

                                      PageSize sets the optional parameter "pageSize": Maximum number of product statuses to return in the response, used for paging.

                                      func (*AccountsProductsListCall) PageToken

                                      func (c *AccountsProductsListCall) PageToken(pageToken string) *AccountsProductsListCall

                                        PageToken sets the optional parameter "pageToken": The token returned by the previous request.

                                        func (*AccountsProductsListCall) Pages

                                          Pages invokes f for each page of results. A non-nil error returned from f will halt the iteration. The provided context supersedes any context provided to the Context method.

                                          type AccountsProductsService

                                          type AccountsProductsService struct {
                                          	// contains filtered or unexported fields
                                          }

                                          func NewAccountsProductsService

                                          func NewAccountsProductsService(s *Service) *AccountsProductsService

                                          func (*AccountsProductsService) Delete

                                            Delete: Deletes the product from a Manufacturer Center account.

                                            func (*AccountsProductsService) Get

                                              Get: Gets the product from a Manufacturer Center account, including product issues. A recently updated product takes around 15 minutes to process. Changes are only visible after it has been processed. While some issues may be available once the product has been processed, other issues may take days to appear.

                                              func (*AccountsProductsService) List

                                                List: Lists all the products in a Manufacturer Center account.

                                                func (*AccountsProductsService) Update

                                                func (r *AccountsProductsService) Update(parent string, name string, attributes *Attributes) *AccountsProductsUpdateCall

                                                  Update: Inserts or updates the attributes of the product in a Manufacturer Center account. Creates a product with the provided attributes. If the product already exists, then all attributes are replaced with the new ones. The checks at upload time are minimal. All required attributes need to be present for a product to be valid. Issues may show up later after the API has accepted a new upload for a product and it is possible to overwrite an existing valid product with an invalid product. To detect this, you should retrieve the product and check it for issues once the new version is available. Uploaded attributes first need to be processed before they can be retrieved. Until then, new products will be unavailable, and retrieval of previously uploaded products will return the original state of the product.

                                                  type AccountsProductsUpdateCall

                                                  type AccountsProductsUpdateCall struct {
                                                  	// contains filtered or unexported fields
                                                  }

                                                  func (*AccountsProductsUpdateCall) Context

                                                    Context sets the context to be used in this call's Do method. Any pending HTTP request will be aborted if the provided context is canceled.

                                                    func (*AccountsProductsUpdateCall) Do

                                                      Do executes the "manufacturers.accounts.products.update" call. Exactly one of *Empty or error will be non-nil. Any non-2xx status code is an error. Response headers are in either *Empty.ServerResponse.Header or (if a response was returned at all) in error.(*googleapi.Error).Header. Use googleapi.IsNotModified to check whether the returned error was because http.StatusNotModified was returned.

                                                      func (*AccountsProductsUpdateCall) Fields

                                                        Fields allows partial responses to be retrieved. See https://developers.google.com/gdata/docs/2.0/basics#PartialResponse for more information.

                                                        func (*AccountsProductsUpdateCall) Header

                                                          Header returns an http.Header that can be modified by the caller to add HTTP headers to the request.

                                                          type AccountsService

                                                          type AccountsService struct {
                                                          	Products *AccountsProductsService
                                                          	// contains filtered or unexported fields
                                                          }

                                                          func NewAccountsService

                                                          func NewAccountsService(s *Service) *AccountsService

                                                          type Attributes

                                                          type Attributes struct {
                                                          	// AdditionalImageLink: The additional images of the product. For more
                                                          	// information, see
                                                          	// https://support.google.com/manufacturers/answer/6124116#addlimage.
                                                          	AdditionalImageLink []*Image `json:"additionalImageLink,omitempty"`
                                                          
                                                          	// AgeGroup: The target age group of the product. For more information,
                                                          	// see https://support.google.com/manufacturers/answer/6124116#agegroup.
                                                          	AgeGroup string `json:"ageGroup,omitempty"`
                                                          
                                                          	// Brand: The brand name of the product. For more information, see
                                                          	// https://support.google.com/manufacturers/answer/6124116#brand.
                                                          	Brand string `json:"brand,omitempty"`
                                                          
                                                          	// Capacity: The capacity of the product. For more information, see
                                                          	// https://support.google.com/manufacturers/answer/6124116#capacity.
                                                          	Capacity *Capacity `json:"capacity,omitempty"`
                                                          
                                                          	// Color: The color of the product. For more information, see
                                                          	// https://support.google.com/manufacturers/answer/6124116#color.
                                                          	Color string `json:"color,omitempty"`
                                                          
                                                          	// Count: The count of the product. For more information, see
                                                          	// https://support.google.com/manufacturers/answer/6124116#count.
                                                          	Count *Count `json:"count,omitempty"`
                                                          
                                                          	// Description: The description of the product. For more information,
                                                          	// see
                                                          	// https://support.google.com/manufacturers/answer/6124116#description.
                                                          	Description string `json:"description,omitempty"`
                                                          
                                                          	// DisclosureDate: The disclosure date of the product. For more
                                                          	// information, see
                                                          	// https://support.google.com/manufacturers/answer/6124116#disclosure.
                                                          	DisclosureDate string `json:"disclosureDate,omitempty"`
                                                          
                                                          	// ExcludedDestination: A list of excluded destinations.
                                                          	ExcludedDestination []string `json:"excludedDestination,omitempty"`
                                                          
                                                          	// FeatureDescription: The rich format description of the product. For
                                                          	// more information, see
                                                          	// https://support.google.com/manufacturers/answer/6124116#featuredesc.
                                                          	FeatureDescription []*FeatureDescription `json:"featureDescription,omitempty"`
                                                          
                                                          	// Flavor: The flavor of the product. For more information, see
                                                          	// https://support.google.com/manufacturers/answer/6124116#flavor.
                                                          	Flavor string `json:"flavor,omitempty"`
                                                          
                                                          	// Format: The format of the product. For more information, see
                                                          	// https://support.google.com/manufacturers/answer/6124116#format.
                                                          	Format string `json:"format,omitempty"`
                                                          
                                                          	// Gender: The target gender of the product. For more information, see
                                                          	// https://support.google.com/manufacturers/answer/6124116#gender.
                                                          	Gender string `json:"gender,omitempty"`
                                                          
                                                          	// Gtin: The Global Trade Item Number (GTIN) of the product. For more
                                                          	// information, see
                                                          	// https://support.google.com/manufacturers/answer/6124116#gtin.
                                                          	Gtin []string `json:"gtin,omitempty"`
                                                          
                                                          	// ImageLink: The image of the product. For more information, see
                                                          	// https://support.google.com/manufacturers/answer/6124116#image.
                                                          	ImageLink *Image `json:"imageLink,omitempty"`
                                                          
                                                          	// IncludedDestination: A list of included destinations.
                                                          	IncludedDestination []string `json:"includedDestination,omitempty"`
                                                          
                                                          	// ItemGroupId: The item group id of the product. For more information,
                                                          	// see
                                                          	// https://support.google.com/manufacturers/answer/6124116#itemgroupid.
                                                          	ItemGroupId string `json:"itemGroupId,omitempty"`
                                                          
                                                          	// Material: The material of the product. For more information, see
                                                          	// https://support.google.com/manufacturers/answer/6124116#material.
                                                          	Material string `json:"material,omitempty"`
                                                          
                                                          	// Mpn: The Manufacturer Part Number (MPN) of the product. For more
                                                          	// information, see
                                                          	// https://support.google.com/manufacturers/answer/6124116#mpn.
                                                          	Mpn string `json:"mpn,omitempty"`
                                                          
                                                          	// Pattern: The pattern of the product. For more information, see
                                                          	// https://support.google.com/manufacturers/answer/6124116#pattern.
                                                          	Pattern string `json:"pattern,omitempty"`
                                                          
                                                          	// ProductDetail: The details of the product. For more information, see
                                                          	// https://support.google.com/manufacturers/answer/6124116#productdetail.
                                                          	ProductDetail []*ProductDetail `json:"productDetail,omitempty"`
                                                          
                                                          	// ProductHighlight: The product highlights. For more information, see
                                                          	// https://support.google.com/manufacturers/answer/10066942
                                                          	ProductHighlight []string `json:"productHighlight,omitempty"`
                                                          
                                                          	// ProductLine: The name of the group of products related to the
                                                          	// product. For more information, see
                                                          	// https://support.google.com/manufacturers/answer/6124116#productline.
                                                          	ProductLine string `json:"productLine,omitempty"`
                                                          
                                                          	// ProductName: The canonical name of the product. For more information,
                                                          	// see
                                                          	// https://support.google.com/manufacturers/answer/6124116#productname.
                                                          	ProductName string `json:"productName,omitempty"`
                                                          
                                                          	// ProductPageUrl: The URL of the detail page of the product. For more
                                                          	// information, see
                                                          	// https://support.google.com/manufacturers/answer/6124116#productpage.
                                                          	ProductPageUrl string `json:"productPageUrl,omitempty"`
                                                          
                                                          	// ProductType: The type or category of the product. For more
                                                          	// information, see
                                                          	// https://support.google.com/manufacturers/answer/6124116#producttype.
                                                          	ProductType []string `json:"productType,omitempty"`
                                                          
                                                          	// ReleaseDate: The release date of the product. For more information,
                                                          	// see https://support.google.com/manufacturers/answer/6124116#release.
                                                          	ReleaseDate string `json:"releaseDate,omitempty"`
                                                          
                                                          	// RichProductContent: Rich product content. For more information, see
                                                          	// https://support.google.com/manufacturers/answer/9389865
                                                          	RichProductContent []string `json:"richProductContent,omitempty"`
                                                          
                                                          	// Scent: The scent of the product. For more information, see
                                                          	// https://support.google.com/manufacturers/answer/6124116#scent.
                                                          	Scent string `json:"scent,omitempty"`
                                                          
                                                          	// Size: The size of the product. For more information, see
                                                          	// https://support.google.com/manufacturers/answer/6124116#size.
                                                          	Size string `json:"size,omitempty"`
                                                          
                                                          	// SizeSystem: The size system of the product. For more information, see
                                                          	// https://support.google.com/manufacturers/answer/6124116#sizesystem.
                                                          	SizeSystem string `json:"sizeSystem,omitempty"`
                                                          
                                                          	// SizeType: The size type of the product. For more information, see
                                                          	// https://support.google.com/manufacturers/answer/6124116#sizetype.
                                                          	SizeType string `json:"sizeType,omitempty"`
                                                          
                                                          	// SuggestedRetailPrice: The suggested retail price (MSRP) of the
                                                          	// product. For more information, see
                                                          	// https://support.google.com/manufacturers/answer/6124116#price.
                                                          	SuggestedRetailPrice *Price `json:"suggestedRetailPrice,omitempty"`
                                                          
                                                          	// TargetClientId: The target client id. Should only be used in the
                                                          	// accounts of the data partners.
                                                          	TargetClientId string `json:"targetClientId,omitempty"`
                                                          
                                                          	// Theme: The theme of the product. For more information, see
                                                          	// https://support.google.com/manufacturers/answer/6124116#theme.
                                                          	Theme string `json:"theme,omitempty"`
                                                          
                                                          	// Title: The title of the product. For more information, see
                                                          	// https://support.google.com/manufacturers/answer/6124116#title.
                                                          	Title string `json:"title,omitempty"`
                                                          
                                                          	// VideoLink: The videos of the product. For more information, see
                                                          	// https://support.google.com/manufacturers/answer/6124116#video.
                                                          	VideoLink []string `json:"videoLink,omitempty"`
                                                          
                                                          	// ForceSendFields is a list of field names (e.g. "AdditionalImageLink")
                                                          	// to unconditionally include in API requests. By default, fields with
                                                          	// empty values are omitted from API requests. However, any non-pointer,
                                                          	// non-interface field appearing in ForceSendFields will be sent to the
                                                          	// server regardless of whether the field is empty or not. This may be
                                                          	// used to include empty fields in Patch requests.
                                                          	ForceSendFields []string `json:"-"`
                                                          
                                                          	// NullFields is a list of field names (e.g. "AdditionalImageLink") to
                                                          	// include in API requests with the JSON null value. By default, fields
                                                          	// with empty values are omitted from API requests. However, any field
                                                          	// with an empty value appearing in NullFields will be sent to the
                                                          	// server as null. It is an error if a field in this list has a
                                                          	// non-empty value. This may be used to include null fields in Patch
                                                          	// requests.
                                                          	NullFields []string `json:"-"`
                                                          }

                                                            Attributes: Attributes of the product. For more information, see https://support.google.com/manufacturers/answer/6124116.

                                                            func (*Attributes) MarshalJSON

                                                            func (s *Attributes) MarshalJSON() ([]byte, error)

                                                            type Capacity

                                                            type Capacity struct {
                                                            	// Unit: The unit of the capacity, i.e., MB, GB, or TB.
                                                            	Unit string `json:"unit,omitempty"`
                                                            
                                                            	// Value: The numeric value of the capacity.
                                                            	Value int64 `json:"value,omitempty,string"`
                                                            
                                                            	// ForceSendFields is a list of field names (e.g. "Unit") to
                                                            	// unconditionally include in API requests. By default, fields with
                                                            	// empty values are omitted from API requests. However, any non-pointer,
                                                            	// non-interface field appearing in ForceSendFields will be sent to the
                                                            	// server regardless of whether the field is empty or not. This may be
                                                            	// used to include empty fields in Patch requests.
                                                            	ForceSendFields []string `json:"-"`
                                                            
                                                            	// NullFields is a list of field names (e.g. "Unit") to include in API
                                                            	// requests with the JSON null value. By default, fields with empty
                                                            	// values are omitted from API requests. However, any field with an
                                                            	// empty value appearing in NullFields will be sent to the server as
                                                            	// null. It is an error if a field in this list has a non-empty value.
                                                            	// This may be used to include null fields in Patch requests.
                                                            	NullFields []string `json:"-"`
                                                            }

                                                              Capacity: The capacity of a product. For more information, see https://support.google.com/manufacturers/answer/6124116#capacity.

                                                              func (*Capacity) MarshalJSON

                                                              func (s *Capacity) MarshalJSON() ([]byte, error)

                                                              type Count

                                                              type Count struct {
                                                              	// Unit: The unit in which these products are counted.
                                                              	Unit string `json:"unit,omitempty"`
                                                              
                                                              	// Value: The numeric value of the number of products in a package.
                                                              	Value int64 `json:"value,omitempty,string"`
                                                              
                                                              	// ForceSendFields is a list of field names (e.g. "Unit") to
                                                              	// unconditionally include in API requests. By default, fields with
                                                              	// empty values are omitted from API requests. However, any non-pointer,
                                                              	// non-interface field appearing in ForceSendFields will be sent to the
                                                              	// server regardless of whether the field is empty or not. This may be
                                                              	// used to include empty fields in Patch requests.
                                                              	ForceSendFields []string `json:"-"`
                                                              
                                                              	// NullFields is a list of field names (e.g. "Unit") to include in API
                                                              	// requests with the JSON null value. By default, fields with empty
                                                              	// values are omitted from API requests. However, any field with an
                                                              	// empty value appearing in NullFields will be sent to the server as
                                                              	// null. It is an error if a field in this list has a non-empty value.
                                                              	// This may be used to include null fields in Patch requests.
                                                              	NullFields []string `json:"-"`
                                                              }

                                                                Count: The number of products in a single package. For more information, see https://support.google.com/manufacturers/answer/6124116#count.

                                                                func (*Count) MarshalJSON

                                                                func (s *Count) MarshalJSON() ([]byte, error)

                                                                type DestinationStatus

                                                                type DestinationStatus struct {
                                                                	// Destination: The name of the destination.
                                                                	Destination string `json:"destination,omitempty"`
                                                                
                                                                	// Status: The status of the destination.
                                                                	//
                                                                	// Possible values:
                                                                	//   "UNKNOWN" - Unspecified status, never used.
                                                                	//   "ACTIVE" - The product is used for this destination.
                                                                	//   "PENDING" - The decision is still pending.
                                                                	//   "DISAPPROVED" - The product is disapproved. Please look at the
                                                                	// issues.
                                                                	Status string `json:"status,omitempty"`
                                                                
                                                                	// ForceSendFields is a list of field names (e.g. "Destination") to
                                                                	// unconditionally include in API requests. By default, fields with
                                                                	// empty values are omitted from API requests. However, any non-pointer,
                                                                	// non-interface field appearing in ForceSendFields will be sent to the
                                                                	// server regardless of whether the field is empty or not. This may be
                                                                	// used to include empty fields in Patch requests.
                                                                	ForceSendFields []string `json:"-"`
                                                                
                                                                	// NullFields is a list of field names (e.g. "Destination") to include
                                                                	// in API requests with the JSON null value. By default, fields with
                                                                	// empty values are omitted from API requests. However, any field with
                                                                	// an empty value appearing in NullFields will be sent to the server as
                                                                	// null. It is an error if a field in this list has a non-empty value.
                                                                	// This may be used to include null fields in Patch requests.
                                                                	NullFields []string `json:"-"`
                                                                }

                                                                  DestinationStatus: The destination status.

                                                                  func (*DestinationStatus) MarshalJSON

                                                                  func (s *DestinationStatus) MarshalJSON() ([]byte, error)

                                                                  type Empty

                                                                  type Empty struct {
                                                                  	// ServerResponse contains the HTTP response code and headers from the
                                                                  	// server.
                                                                  	googleapi.ServerResponse `json:"-"`
                                                                  }

                                                                    Empty: A generic empty message that you can re-use to avoid defining duplicated empty messages in your APIs. A typical example is to use it as the request or the response type of an API method. For instance: service Foo { rpc Bar(google.protobuf.Empty) returns (google.protobuf.Empty); } The JSON representation for `Empty` is empty JSON object `{}`.

                                                                    type FeatureDescription

                                                                    type FeatureDescription struct {
                                                                    	// Headline: A short description of the feature.
                                                                    	Headline string `json:"headline,omitempty"`
                                                                    
                                                                    	// Image: An optional image describing the feature.
                                                                    	Image *Image `json:"image,omitempty"`
                                                                    
                                                                    	// Text: A detailed description of the feature.
                                                                    	Text string `json:"text,omitempty"`
                                                                    
                                                                    	// ForceSendFields is a list of field names (e.g. "Headline") to
                                                                    	// unconditionally include in API requests. By default, fields with
                                                                    	// empty values are omitted from API requests. However, any non-pointer,
                                                                    	// non-interface field appearing in ForceSendFields will be sent to the
                                                                    	// server regardless of whether the field is empty or not. This may be
                                                                    	// used to include empty fields in Patch requests.
                                                                    	ForceSendFields []string `json:"-"`
                                                                    
                                                                    	// NullFields is a list of field names (e.g. "Headline") to include in
                                                                    	// API requests with the JSON null value. By default, fields with empty
                                                                    	// values are omitted from API requests. However, any field with an
                                                                    	// empty value appearing in NullFields will be sent to the server as
                                                                    	// null. It is an error if a field in this list has a non-empty value.
                                                                    	// This may be used to include null fields in Patch requests.
                                                                    	NullFields []string `json:"-"`
                                                                    }

                                                                      FeatureDescription: A feature description of the product. For more information, see https://support.google.com/manufacturers/answer/6124116#featuredesc.

                                                                      func (*FeatureDescription) MarshalJSON

                                                                      func (s *FeatureDescription) MarshalJSON() ([]byte, error)

                                                                      type Image

                                                                      type Image struct {
                                                                      	// ImageUrl: The URL of the image. For crawled images, this is the
                                                                      	// provided URL. For uploaded images, this is a serving URL from Google
                                                                      	// if the image has been processed successfully.
                                                                      	ImageUrl string `json:"imageUrl,omitempty"`
                                                                      
                                                                      	// Status: The status of the image. @OutputOnly
                                                                      	//
                                                                      	// Possible values:
                                                                      	//   "STATUS_UNSPECIFIED" - The image status is unspecified. Should not
                                                                      	// be used.
                                                                      	//   "PENDING_PROCESSING" - The image was uploaded and is being
                                                                      	// processed.
                                                                      	//   "PENDING_CRAWL" - The image crawl is still pending.
                                                                      	//   "OK" - The image was processed and it meets the requirements.
                                                                      	//   "ROBOTED" - The image URL is protected by robots.txt file and
                                                                      	// cannot be crawled.
                                                                      	//   "XROBOTED" - The image URL is protected by X-Robots-Tag and cannot
                                                                      	// be crawled.
                                                                      	//   "CRAWL_ERROR" - There was an error while crawling the image.
                                                                      	//   "PROCESSING_ERROR" - The image cannot be processed.
                                                                      	//   "DECODING_ERROR" - The image cannot be decoded.
                                                                      	//   "TOO_BIG" - The image is too big.
                                                                      	//   "CRAWL_SKIPPED" - The image was manually overridden and will not be
                                                                      	// crawled.
                                                                      	//   "HOSTLOADED" - The image crawl was postponed to avoid overloading
                                                                      	// the host.
                                                                      	//   "HTTP_404" - The image URL returned a "404 Not Found" error.
                                                                      	Status string `json:"status,omitempty"`
                                                                      
                                                                      	// Type: The type of the image, i.e., crawled or uploaded. @OutputOnly
                                                                      	//
                                                                      	// Possible values:
                                                                      	//   "TYPE_UNSPECIFIED" - Type is unspecified. Should not be used.
                                                                      	//   "CRAWLED" - The image was crawled from a provided URL.
                                                                      	//   "UPLOADED" - The image was uploaded.
                                                                      	Type string `json:"type,omitempty"`
                                                                      
                                                                      	// ForceSendFields is a list of field names (e.g. "ImageUrl") to
                                                                      	// unconditionally include in API requests. By default, fields with
                                                                      	// empty values are omitted from API requests. However, any non-pointer,
                                                                      	// non-interface field appearing in ForceSendFields will be sent to the
                                                                      	// server regardless of whether the field is empty or not. This may be
                                                                      	// used to include empty fields in Patch requests.
                                                                      	ForceSendFields []string `json:"-"`
                                                                      
                                                                      	// NullFields is a list of field names (e.g. "ImageUrl") to include in
                                                                      	// API requests with the JSON null value. By default, fields with empty
                                                                      	// values are omitted from API requests. However, any field with an
                                                                      	// empty value appearing in NullFields will be sent to the server as
                                                                      	// null. It is an error if a field in this list has a non-empty value.
                                                                      	// This may be used to include null fields in Patch requests.
                                                                      	NullFields []string `json:"-"`
                                                                      }

                                                                        Image: An image.

                                                                        func (*Image) MarshalJSON

                                                                        func (s *Image) MarshalJSON() ([]byte, error)

                                                                        type Issue

                                                                        type Issue struct {
                                                                        	// Attribute: If present, the attribute that triggered the issue. For
                                                                        	// more information about attributes, see
                                                                        	// https://support.google.com/manufacturers/answer/6124116.
                                                                        	Attribute string `json:"attribute,omitempty"`
                                                                        
                                                                        	// Description: Longer description of the issue focused on how to
                                                                        	// resolve it.
                                                                        	Description string `json:"description,omitempty"`
                                                                        
                                                                        	// Destination: The destination this issue applies to.
                                                                        	Destination string `json:"destination,omitempty"`
                                                                        
                                                                        	// Resolution: What needs to happen to resolve the issue.
                                                                        	//
                                                                        	// Possible values:
                                                                        	//   "RESOLUTION_UNSPECIFIED" - Unspecified resolution, never used.
                                                                        	//   "USER_ACTION" - The user who provided the data must act in order to
                                                                        	// resolve the issue (for example by correcting some data).
                                                                        	//   "PENDING_PROCESSING" - The issue will be resolved automatically
                                                                        	// (for example image crawl or Google review). No action is required
                                                                        	// now. Resolution might lead to another issue (for example if crawl
                                                                        	// fails).
                                                                        	Resolution string `json:"resolution,omitempty"`
                                                                        
                                                                        	// Severity: The severity of the issue.
                                                                        	//
                                                                        	// Possible values:
                                                                        	//   "SEVERITY_UNSPECIFIED" - Unspecified severity, never used.
                                                                        	//   "ERROR" - Error severity. The issue prevents the usage of the whole
                                                                        	// item.
                                                                        	//   "WARNING" - Warning severity. The issue is either one that prevents
                                                                        	// the usage of the attribute that triggered it or one that will soon
                                                                        	// prevent the usage of the whole item.
                                                                        	//   "INFO" - Info severity. The issue is one that doesn't require
                                                                        	// immediate attention. It is, for example, used to communicate which
                                                                        	// attributes are still pending review.
                                                                        	Severity string `json:"severity,omitempty"`
                                                                        
                                                                        	// Timestamp: The timestamp when this issue appeared.
                                                                        	Timestamp string `json:"timestamp,omitempty"`
                                                                        
                                                                        	// Title: Short title describing the nature of the issue.
                                                                        	Title string `json:"title,omitempty"`
                                                                        
                                                                        	// Type: The server-generated type of the issue, for example,
                                                                        	// “INCORRECT_TEXT_FORMATTING”, “IMAGE_NOT_SERVEABLE”, etc.
                                                                        	Type string `json:"type,omitempty"`
                                                                        
                                                                        	// ForceSendFields is a list of field names (e.g. "Attribute") to
                                                                        	// unconditionally include in API requests. By default, fields with
                                                                        	// empty values are omitted from API requests. However, any non-pointer,
                                                                        	// non-interface field appearing in ForceSendFields will be sent to the
                                                                        	// server regardless of whether the field is empty or not. This may be
                                                                        	// used to include empty fields in Patch requests.
                                                                        	ForceSendFields []string `json:"-"`
                                                                        
                                                                        	// NullFields is a list of field names (e.g. "Attribute") to include in
                                                                        	// API requests with the JSON null value. By default, fields with empty
                                                                        	// values are omitted from API requests. However, any field with an
                                                                        	// empty value appearing in NullFields will be sent to the server as
                                                                        	// null. It is an error if a field in this list has a non-empty value.
                                                                        	// This may be used to include null fields in Patch requests.
                                                                        	NullFields []string `json:"-"`
                                                                        }

                                                                          Issue: Product issue.

                                                                          func (*Issue) MarshalJSON

                                                                          func (s *Issue) MarshalJSON() ([]byte, error)

                                                                          type ListProductsResponse

                                                                          type ListProductsResponse struct {
                                                                          	// NextPageToken: The token for the retrieval of the next page of
                                                                          	// product statuses.
                                                                          	NextPageToken string `json:"nextPageToken,omitempty"`
                                                                          
                                                                          	// Products: List of the products.
                                                                          	Products []*Product `json:"products,omitempty"`
                                                                          
                                                                          	// ServerResponse contains the HTTP response code and headers from the
                                                                          	// server.
                                                                          	googleapi.ServerResponse `json:"-"`
                                                                          
                                                                          	// ForceSendFields is a list of field names (e.g. "NextPageToken") to
                                                                          	// unconditionally include in API requests. By default, fields with
                                                                          	// empty values are omitted from API requests. However, any non-pointer,
                                                                          	// non-interface field appearing in ForceSendFields will be sent to the
                                                                          	// server regardless of whether the field is empty or not. This may be
                                                                          	// used to include empty fields in Patch requests.
                                                                          	ForceSendFields []string `json:"-"`
                                                                          
                                                                          	// NullFields is a list of field names (e.g. "NextPageToken") to include
                                                                          	// in API requests with the JSON null value. By default, fields with
                                                                          	// empty values are omitted from API requests. However, any field with
                                                                          	// an empty value appearing in NullFields will be sent to the server as
                                                                          	// null. It is an error if a field in this list has a non-empty value.
                                                                          	// This may be used to include null fields in Patch requests.
                                                                          	NullFields []string `json:"-"`
                                                                          }

                                                                          func (*ListProductsResponse) MarshalJSON

                                                                          func (s *ListProductsResponse) MarshalJSON() ([]byte, error)

                                                                          type Price

                                                                          type Price struct {
                                                                          	// Amount: The numeric value of the price.
                                                                          	Amount string `json:"amount,omitempty"`
                                                                          
                                                                          	// Currency: The currency in which the price is denoted.
                                                                          	Currency string `json:"currency,omitempty"`
                                                                          
                                                                          	// ForceSendFields is a list of field names (e.g. "Amount") to
                                                                          	// unconditionally include in API requests. By default, fields with
                                                                          	// empty values are omitted from API requests. However, any non-pointer,
                                                                          	// non-interface field appearing in ForceSendFields will be sent to the
                                                                          	// server regardless of whether the field is empty or not. This may be
                                                                          	// used to include empty fields in Patch requests.
                                                                          	ForceSendFields []string `json:"-"`
                                                                          
                                                                          	// NullFields is a list of field names (e.g. "Amount") to include in API
                                                                          	// requests with the JSON null value. By default, fields with empty
                                                                          	// values are omitted from API requests. However, any field with an
                                                                          	// empty value appearing in NullFields will be sent to the server as
                                                                          	// null. It is an error if a field in this list has a non-empty value.
                                                                          	// This may be used to include null fields in Patch requests.
                                                                          	NullFields []string `json:"-"`
                                                                          }

                                                                            Price: A price.

                                                                            func (*Price) MarshalJSON

                                                                            func (s *Price) MarshalJSON() ([]byte, error)

                                                                            type Product

                                                                            type Product struct {
                                                                            	// Attributes: Attributes of the product uploaded to the Manufacturer
                                                                            	// Center. Manually edited attributes are taken into account.
                                                                            	Attributes *Attributes `json:"attributes,omitempty"`
                                                                            
                                                                            	// ContentLanguage: The content language of the product as a two-letter
                                                                            	// ISO 639-1 language code (for example, en).
                                                                            	ContentLanguage string `json:"contentLanguage,omitempty"`
                                                                            
                                                                            	// DestinationStatuses: The status of the destinations.
                                                                            	DestinationStatuses []*DestinationStatus `json:"destinationStatuses,omitempty"`
                                                                            
                                                                            	// Issues: A server-generated list of issues associated with the
                                                                            	// product.
                                                                            	Issues []*Issue `json:"issues,omitempty"`
                                                                            
                                                                            	// Name: Name in the format
                                                                            	// `{target_country}:{content_language}:{product_id}`. `target_country`
                                                                            	// - The target country of the product as a CLDR territory code (for
                                                                            	// example, US). `content_language` - The content language of the
                                                                            	// product as a two-letter ISO 639-1 language code (for example, en).
                                                                            	// `product_id` - The ID of the product. For more information, see
                                                                            	// https://support.google.com/manufacturers/answer/6124116#id.
                                                                            	Name string `json:"name,omitempty"`
                                                                            
                                                                            	// Parent: Parent ID in the format `accounts/{account_id}`. `account_id`
                                                                            	// - The ID of the Manufacturer Center account.
                                                                            	Parent string `json:"parent,omitempty"`
                                                                            
                                                                            	// ProductId: The ID of the product. For more information, see
                                                                            	// https://support.google.com/manufacturers/answer/6124116#id.
                                                                            	ProductId string `json:"productId,omitempty"`
                                                                            
                                                                            	// TargetCountry: The target country of the product as a CLDR territory
                                                                            	// code (for example, US).
                                                                            	TargetCountry string `json:"targetCountry,omitempty"`
                                                                            
                                                                            	// ServerResponse contains the HTTP response code and headers from the
                                                                            	// server.
                                                                            	googleapi.ServerResponse `json:"-"`
                                                                            
                                                                            	// ForceSendFields is a list of field names (e.g. "Attributes") to
                                                                            	// unconditionally include in API requests. By default, fields with
                                                                            	// empty values are omitted from API requests. However, any non-pointer,
                                                                            	// non-interface field appearing in ForceSendFields will be sent to the
                                                                            	// server regardless of whether the field is empty or not. This may be
                                                                            	// used to include empty fields in Patch requests.
                                                                            	ForceSendFields []string `json:"-"`
                                                                            
                                                                            	// NullFields is a list of field names (e.g. "Attributes") to include in
                                                                            	// API requests with the JSON null value. By default, fields with empty
                                                                            	// values are omitted from API requests. However, any field with an
                                                                            	// empty value appearing in NullFields will be sent to the server as
                                                                            	// null. It is an error if a field in this list has a non-empty value.
                                                                            	// This may be used to include null fields in Patch requests.
                                                                            	NullFields []string `json:"-"`
                                                                            }

                                                                              Product: Product data.

                                                                              func (*Product) MarshalJSON

                                                                              func (s *Product) MarshalJSON() ([]byte, error)

                                                                              type ProductDetail

                                                                              type ProductDetail struct {
                                                                              	// AttributeName: The name of the attribute.
                                                                              	AttributeName string `json:"attributeName,omitempty"`
                                                                              
                                                                              	// AttributeValue: The value of the attribute.
                                                                              	AttributeValue string `json:"attributeValue,omitempty"`
                                                                              
                                                                              	// SectionName: A short section name that can be reused between multiple
                                                                              	// product details.
                                                                              	SectionName string `json:"sectionName,omitempty"`
                                                                              
                                                                              	// ForceSendFields is a list of field names (e.g. "AttributeName") to
                                                                              	// unconditionally include in API requests. By default, fields with
                                                                              	// empty values are omitted from API requests. However, any non-pointer,
                                                                              	// non-interface field appearing in ForceSendFields will be sent to the
                                                                              	// server regardless of whether the field is empty or not. This may be
                                                                              	// used to include empty fields in Patch requests.
                                                                              	ForceSendFields []string `json:"-"`
                                                                              
                                                                              	// NullFields is a list of field names (e.g. "AttributeName") to include
                                                                              	// in API requests with the JSON null value. By default, fields with
                                                                              	// empty values are omitted from API requests. However, any field with
                                                                              	// an empty value appearing in NullFields will be sent to the server as
                                                                              	// null. It is an error if a field in this list has a non-empty value.
                                                                              	// This may be used to include null fields in Patch requests.
                                                                              	NullFields []string `json:"-"`
                                                                              }

                                                                                ProductDetail: A product detail of the product. For more information, see https://support.google.com/manufacturers/answer/6124116#productdetail.

                                                                                func (*ProductDetail) MarshalJSON

                                                                                func (s *ProductDetail) MarshalJSON() ([]byte, error)

                                                                                type Service

                                                                                type Service struct {
                                                                                	BasePath  string // API endpoint base URL
                                                                                	UserAgent string // optional additional User-Agent fragment
                                                                                
                                                                                	Accounts *AccountsService
                                                                                	// contains filtered or unexported fields
                                                                                }

                                                                                func New

                                                                                func New(client *http.Client) (*Service, error)

                                                                                  New creates a new Service. It uses the provided http.Client for requests.

                                                                                  Deprecated: please use NewService instead. To provide a custom HTTP client, use option.WithHTTPClient. If you are using google.golang.org/api/googleapis/transport.APIKey, use option.WithAPIKey with NewService instead.

                                                                                  func NewService

                                                                                  func NewService(ctx context.Context, opts ...option.ClientOption) (*Service, error)

                                                                                    NewService creates a new Service.