2017-05-11 16:39:54 +02:00
// Package manufacturers provides access to the Manufacturer Center API.
//
// See https://developers.google.com/manufacturers/
//
// Usage example:
//
// import "google.golang.org/api/manufacturers/v1"
// ...
// manufacturersService, err := manufacturers.New(oauthHttpClient)
package manufacturers // import "google.golang.org/api/manufacturers/v1"
import (
"bytes"
"encoding/json"
"errors"
"fmt"
context "golang.org/x/net/context"
ctxhttp "golang.org/x/net/context/ctxhttp"
gensupport "google.golang.org/api/gensupport"
googleapi "google.golang.org/api/googleapi"
"io"
"net/http"
"net/url"
"strconv"
"strings"
)
// Always reference these packages, just in case the auto-generated code
// below doesn't.
var _ = bytes . NewBuffer
var _ = strconv . Itoa
var _ = fmt . Sprintf
var _ = json . NewDecoder
var _ = io . Copy
var _ = url . Parse
var _ = gensupport . MarshalJSON
var _ = googleapi . Version
var _ = errors . New
var _ = strings . Replace
var _ = context . Canceled
var _ = ctxhttp . Do
const apiId = "manufacturers:v1"
const apiName = "manufacturers"
const apiVersion = "v1"
const basePath = "https://manufacturers.googleapis.com/"
// OAuth2 scopes used by this API.
const (
// Manage your product listings for Google Manufacturer Center
ManufacturercenterScope = "https://www.googleapis.com/auth/manufacturercenter"
)
func New ( client * http . Client ) ( * Service , error ) {
if client == nil {
return nil , errors . New ( "client is nil" )
}
s := & Service { client : client , BasePath : basePath }
s . Accounts = NewAccountsService ( s )
return s , nil
}
type Service struct {
client * http . Client
BasePath string // API endpoint base URL
UserAgent string // optional additional User-Agent fragment
Accounts * AccountsService
}
func ( s * Service ) userAgent ( ) string {
if s . UserAgent == "" {
return googleapi . UserAgent
}
return googleapi . UserAgent + " " + s . UserAgent
}
func NewAccountsService ( s * Service ) * AccountsService {
rs := & AccountsService { s : s }
rs . Products = NewAccountsProductsService ( s )
return rs
}
type AccountsService struct {
s * Service
Products * AccountsProductsService
}
func NewAccountsProductsService ( s * Service ) * AccountsProductsService {
rs := & AccountsProductsService { s : s }
return rs
}
type AccountsProductsService struct {
s * Service
}
// Attributes: Attributes of the product. For more information,
// see
// https://support.google.com/manufacturers/answer/6124116.
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#descriptio
// n.
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" `
2018-05-02 18:09:45 +02:00
// ExcludedDestination: A list of excluded destinations.
ExcludedDestination [ ] string ` json:"excludedDestination,omitempty" `
2017-05-11 16:39:54 +02:00
// FeatureDescription: The rich format description of the product. For
// more information,
// see
// https://support.google.com/manufacturers/answer/6124116#featuredes
// c.
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" `
2018-05-02 18:09:45 +02:00
// IncludedDestination: A list of included destinations.
IncludedDestination [ ] string ` json:"includedDestination,omitempty" `
2017-05-11 16:39:54 +02:00
// ItemGroupId: The item group id of the product. For more information,
// see
// https://support.google.com/manufacturers/answer/6124116#itemgroupi
// d.
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#productdet
// ail.
ProductDetail [ ] * ProductDetail ` json:"productDetail,omitempty" `
// ProductLine: The name of the group of products related to the
// product. For more
// information,
// see
// https://support.google.com/manufacturers/answer/6124116#productlin
// e.
ProductLine string ` json:"productLine,omitempty" `
// ProductName: The canonical name of the product. For more information,
// see
// https://support.google.com/manufacturers/answer/6124116#productnam
// e.
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#productpag
// e.
ProductPageUrl string ` json:"productPageUrl,omitempty" `
2018-01-16 14:20:59 +01:00
// ProductType: The type or category of the product. For more
// information,
2017-05-11 16:39:54 +02:00
// see
// https://support.google.com/manufacturers/answer/6124116#producttyp
// e.
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" `
// 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" `
2018-01-16 14:20:59 +01:00
// TargetClientId: The target client id. Should only be used in the
2017-09-30 16:27:27 +02:00
// accounts of the data
// partners.
2018-01-16 14:20:59 +01:00
TargetClientId string ` json:"targetClientId,omitempty" `
2017-09-30 16:27:27 +02:00
2017-05-11 16:39:54 +02:00
// 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:"-" `
}
func ( s * Attributes ) MarshalJSON ( ) ( [ ] byte , error ) {
2018-01-16 14:20:59 +01:00
type NoMethod Attributes
raw := NoMethod ( * s )
2017-05-11 16:39:54 +02:00
return gensupport . MarshalJSON ( raw , s . ForceSendFields , s . NullFields )
}
// Capacity: The capacity of a product. For more information,
// see
// https://support.google.com/manufacturers/answer/6124116#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:"-" `
}
func ( s * Capacity ) MarshalJSON ( ) ( [ ] byte , error ) {
2018-01-16 14:20:59 +01:00
type NoMethod Capacity
raw := NoMethod ( * s )
2017-05-11 16:39:54 +02:00
return gensupport . MarshalJSON ( raw , s . ForceSendFields , s . NullFields )
}
// Count: The number of products in a single package. For more
// information,
// see
// https://support.google.com/manufacturers/answer/6124116#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:"-" `
}
func ( s * Count ) MarshalJSON ( ) ( [ ] byte , error ) {
2018-01-16 14:20:59 +01:00
type NoMethod Count
raw := NoMethod ( * s )
2017-05-11 16:39:54 +02:00
return gensupport . MarshalJSON ( raw , s . ForceSendFields , s . NullFields )
}
2018-05-02 18:09:45 +02:00
// DestinationStatus: The destination status.
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:"-" `
}
func ( s * DestinationStatus ) MarshalJSON ( ) ( [ ] byte , error ) {
type NoMethod DestinationStatus
raw := NoMethod ( * s )
return gensupport . MarshalJSON ( raw , s . ForceSendFields , s . NullFields )
}
2017-07-23 09:51:42 +02:00
// 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 Empty struct {
// ServerResponse contains the HTTP response code and headers from the
// server.
googleapi . ServerResponse ` json:"-" `
}
2017-05-11 16:39:54 +02:00
// FeatureDescription: A feature description of the product. For more
// information,
// see
// https://support.google.com/manufacturers/answer/6124116#featuredes
// c.
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:"-" `
}
func ( s * FeatureDescription ) MarshalJSON ( ) ( [ ] byte , error ) {
2018-01-16 14:20:59 +01:00
type NoMethod FeatureDescription
raw := NoMethod ( * s )
2017-05-11 16:39:54 +02:00
return gensupport . MarshalJSON ( raw , s . ForceSendFields , s . NullFields )
}
// Image: An 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:
2018-01-16 14:20:59 +01:00
// "STATUS_UNSPECIFIED" - The image status is unspecified. Should not
// be used.
// "PENDING_PROCESSING" - The image was uploaded and is being
// processed.
2017-05-11 16:39:54 +02:00
// "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.
2018-01-16 14:20:59 +01:00
// "HOSTLOADED" - The image crawl was postponed to avoid overloading
// the host.
// "HTTP_404" - The image URL returned a "404 Not Found" error.
2017-05-11 16:39:54 +02:00
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:"-" `
}
func ( s * Image ) MarshalJSON ( ) ( [ ] byte , error ) {
2018-01-16 14:20:59 +01:00
type NoMethod Image
raw := NoMethod ( * s )
2017-05-11 16:39:54 +02:00
return gensupport . MarshalJSON ( raw , s . ForceSendFields , s . NullFields )
}
// Issue: Product 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" `
2018-03-19 16:51:38 +01:00
// Description: Longer description of the issue focused on how to
// resolve it.
2017-05-11 16:39:54 +02:00
Description string ` json:"description,omitempty" `
2018-05-02 18:09:45 +02:00
// 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" `
2017-05-11 16:39:54 +02:00
// 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" `
2018-05-02 18:09:45 +02:00
// Title: Short title describing the nature of the issue.
Title string ` json:"title,omitempty" `
2017-05-11 16:39:54 +02:00
// 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:"-" `
}
func ( s * Issue ) MarshalJSON ( ) ( [ ] byte , error ) {
2018-01-16 14:20:59 +01:00
type NoMethod Issue
raw := NoMethod ( * s )
2017-05-11 16:39:54 +02:00
return gensupport . MarshalJSON ( raw , s . ForceSendFields , s . NullFields )
}
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 ( s * ListProductsResponse ) MarshalJSON ( ) ( [ ] byte , error ) {
2018-01-16 14:20:59 +01:00
type NoMethod ListProductsResponse
raw := NoMethod ( * s )
2017-05-11 16:39:54 +02:00
return gensupport . MarshalJSON ( raw , s . ForceSendFields , s . NullFields )
}
// Price: A 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:"-" `
}
func ( s * Price ) MarshalJSON ( ) ( [ ] byte , error ) {
2018-01-16 14:20:59 +01:00
type NoMethod Price
raw := NoMethod ( * s )
2017-05-11 16:39:54 +02:00
return gensupport . MarshalJSON ( raw , s . ForceSendFields , s . NullFields )
}
// Product: Product data.
type Product struct {
2018-05-02 18:09:45 +02:00
// Attributes: Attributes of the product uploaded to the Manufacturer
// Center.
Attributes * Attributes ` json:"attributes,omitempty" `
2017-05-11 16:39:54 +02:00
// ContentLanguage: The content language of the product as a two-letter
// ISO 639-1 language code
// (for example, en).
ContentLanguage string ` json:"contentLanguage,omitempty" `
2018-05-02 18:09:45 +02:00
// DestinationStatuses: The status of the destinations.
DestinationStatuses [ ] * DestinationStatus ` json:"destinationStatuses,omitempty" `
2017-05-11 16:39:54 +02:00
// FinalAttributes: Final attributes of the product. The final
// attributes are obtained by
// overriding the uploaded attributes with the manually provided and
// deleted
// attributes. Google systems only process, evaluate, review, and/or use
// final
// attributes.
2018-05-02 18:09:45 +02:00
//
// This field is deprecated and will be removed end of July 2018. Please
// use
// attributes.
2017-05-11 16:39:54 +02:00
FinalAttributes * Attributes ` json:"finalAttributes,omitempty" `
// Issues: A server-generated list of issues associated with the
// product.
Issues [ ] * Issue ` json:"issues,omitempty" `
// ManuallyDeletedAttributes: Names of the attributes of the product
// deleted manually via the
// Manufacturer Center UI.
2018-05-02 18:09:45 +02:00
//
// This field is deprecated and will be removed end of July 2018. Please
// use
// attributes.
2017-05-11 16:39:54 +02:00
ManuallyDeletedAttributes [ ] string ` json:"manuallyDeletedAttributes,omitempty" `
// ManuallyProvidedAttributes: Attributes of the product provided
// manually via the Manufacturer Center UI.
2018-05-02 18:09:45 +02:00
//
// This field is deprecated and will be removed end of July 2018. Please
// use
// attributes.
2017-05-11 16:39:54 +02:00
ManuallyProvidedAttributes * Attributes ` json:"manuallyProvidedAttributes,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" `
// UploadedAttributes: Attributes of the product uploaded via the
// Manufacturer Center API or via
// feeds.
2018-05-02 18:09:45 +02:00
//
// This field is deprecated and will be removed end of July 2018. Please
// use
// attributes.
2017-05-11 16:39:54 +02:00
UploadedAttributes * Attributes ` json:"uploadedAttributes,omitempty" `
// ServerResponse contains the HTTP response code and headers from the
// server.
googleapi . ServerResponse ` json:"-" `
2018-05-02 18:09:45 +02:00
// ForceSendFields is a list of field names (e.g. "Attributes") to
2017-05-11 16:39:54 +02:00
// 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:"-" `
2018-05-02 18:09:45 +02:00
// 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.
2017-05-11 16:39:54 +02:00
NullFields [ ] string ` json:"-" `
}
func ( s * Product ) MarshalJSON ( ) ( [ ] byte , error ) {
2018-01-16 14:20:59 +01:00
type NoMethod Product
raw := NoMethod ( * s )
2017-05-11 16:39:54 +02:00
return gensupport . MarshalJSON ( raw , s . ForceSendFields , s . NullFields )
}
// ProductDetail: A product detail of the product. For more information,
// see
// https://support.google.com/manufacturers/answer/6124116#productdet
// ail.
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:"-" `
}
func ( s * ProductDetail ) MarshalJSON ( ) ( [ ] byte , error ) {
2018-01-16 14:20:59 +01:00
type NoMethod ProductDetail
raw := NoMethod ( * s )
2017-05-11 16:39:54 +02:00
return gensupport . MarshalJSON ( raw , s . ForceSendFields , s . NullFields )
}
2017-07-23 09:51:42 +02:00
// method id "manufacturers.accounts.products.delete":
type AccountsProductsDeleteCall struct {
s * Service
parent string
name string
urlParams_ gensupport . URLParams
ctx_ context . Context
header_ http . Header
}
// Delete: Deletes the product from a Manufacturer Center account.
func ( r * AccountsProductsService ) Delete ( parent string , name string ) * AccountsProductsDeleteCall {
c := & AccountsProductsDeleteCall { s : r . s , urlParams_ : make ( gensupport . URLParams ) }
c . parent = parent
c . name = name
return c
}
// Fields allows partial responses to be retrieved. See
// https://developers.google.com/gdata/docs/2.0/basics#PartialResponse
// for more information.
func ( c * AccountsProductsDeleteCall ) Fields ( s ... googleapi . Field ) * AccountsProductsDeleteCall {
c . urlParams_ . Set ( "fields" , googleapi . CombineFields ( s ) )
return c
}
// 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 ( c * AccountsProductsDeleteCall ) Context ( ctx context . Context ) * AccountsProductsDeleteCall {
c . ctx_ = ctx
return c
}
// Header returns an http.Header that can be modified by the caller to
// add HTTP headers to the request.
func ( c * AccountsProductsDeleteCall ) Header ( ) http . Header {
if c . header_ == nil {
c . header_ = make ( http . Header )
}
return c . header_
}
func ( c * AccountsProductsDeleteCall ) doRequest ( alt string ) ( * http . Response , error ) {
reqHeaders := make ( http . Header )
for k , v := range c . header_ {
reqHeaders [ k ] = v
}
reqHeaders . Set ( "User-Agent" , c . s . userAgent ( ) )
var body io . Reader = nil
c . urlParams_ . Set ( "alt" , alt )
urls := googleapi . ResolveRelative ( c . s . BasePath , "v1/{+parent}/products/{+name}" )
urls += "?" + c . urlParams_ . Encode ( )
req , _ := http . NewRequest ( "DELETE" , urls , body )
req . Header = reqHeaders
googleapi . Expand ( req . URL , map [ string ] string {
"parent" : c . parent ,
"name" : c . name ,
} )
return gensupport . SendRequest ( c . ctx_ , c . s . client , req )
}
// 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 ( c * AccountsProductsDeleteCall ) Do ( opts ... googleapi . CallOption ) ( * Empty , error ) {
gensupport . SetOptions ( c . urlParams_ , opts ... )
res , err := c . doRequest ( "json" )
if res != nil && res . StatusCode == http . StatusNotModified {
if res . Body != nil {
res . Body . Close ( )
}
return nil , & googleapi . Error {
Code : res . StatusCode ,
Header : res . Header ,
}
}
if err != nil {
return nil , err
}
defer googleapi . CloseBody ( res )
if err := googleapi . CheckResponse ( res ) ; err != nil {
return nil , err
}
ret := & Empty {
ServerResponse : googleapi . ServerResponse {
Header : res . Header ,
HTTPStatusCode : res . StatusCode ,
} ,
}
target := & ret
2018-01-16 14:20:59 +01:00
if err := gensupport . DecodeResponse ( target , res ) ; err != nil {
2017-07-23 09:51:42 +02:00
return nil , err
}
return ret , nil
// {
// "description": "Deletes the product from a Manufacturer Center account.",
// "flatPath": "v1/accounts/{accountsId}/products/{productsId}",
// "httpMethod": "DELETE",
// "id": "manufacturers.accounts.products.delete",
// "parameterOrder": [
// "parent",
// "name"
// ],
// "parameters": {
// "name": {
// "description": "Name in the format `{target_country}:{content_language}:{product_id}`.\n\n`target_country` - The target country of the product as a CLDR territory\n code (for example, US).\n\n`content_language` - The content language of the product as a two-letter\n ISO 639-1 language code (for example, en).\n\n`product_id` - The ID of the product. For more information, see\n https://support.google.com/manufacturers/answer/6124116#id.",
// "location": "path",
// "pattern": "^[^/]+$",
// "required": true,
// "type": "string"
// },
// "parent": {
// "description": "Parent ID in the format `accounts/{account_id}`.\n\n`account_id` - The ID of the Manufacturer Center account.",
// "location": "path",
// "pattern": "^accounts/[^/]+$",
// "required": true,
// "type": "string"
// }
// },
// "path": "v1/{+parent}/products/{+name}",
// "response": {
// "$ref": "Empty"
// },
// "scopes": [
// "https://www.googleapis.com/auth/manufacturercenter"
// ]
// }
}
2017-05-11 16:39:54 +02:00
// method id "manufacturers.accounts.products.get":
type AccountsProductsGetCall struct {
s * Service
parent string
name string
urlParams_ gensupport . URLParams
ifNoneMatch_ string
ctx_ context . Context
header_ http . Header
}
// Get: Gets the product from a Manufacturer Center account, including
// product
// issues.
2017-07-23 09:51:42 +02:00
//
2017-09-30 16:27:27 +02:00
// 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.
2017-05-11 16:39:54 +02:00
func ( r * AccountsProductsService ) Get ( parent string , name string ) * AccountsProductsGetCall {
c := & AccountsProductsGetCall { s : r . s , urlParams_ : make ( gensupport . URLParams ) }
c . parent = parent
c . name = name
return c
}
2018-05-02 18:09:45 +02:00
// Include sets the optional parameter "include": The information to be
// included in the response. Only sections listed here
// will be returned.
//
// If this parameter is not specified, ATTRIBUTES and ISSUES are
// returned.
// This behavior is temporary and will be removed once all clients are
// ready
// or at the latest end of July 2018. After that no sections will be
// returned.
//
// Possible values:
// "UNKNOWN"
// "ATTRIBUTES"
// "ISSUES"
// "DESTINATION_STATUSES"
func ( c * AccountsProductsGetCall ) Include ( include ... string ) * AccountsProductsGetCall {
c . urlParams_ . SetMulti ( "include" , append ( [ ] string { } , include ... ) )
return c
}
2017-05-11 16:39:54 +02:00
// Fields allows partial responses to be retrieved. See
// https://developers.google.com/gdata/docs/2.0/basics#PartialResponse
// for more information.
func ( c * AccountsProductsGetCall ) Fields ( s ... googleapi . Field ) * AccountsProductsGetCall {
c . urlParams_ . Set ( "fields" , googleapi . CombineFields ( s ) )
return c
}
// 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 ( c * AccountsProductsGetCall ) IfNoneMatch ( entityTag string ) * AccountsProductsGetCall {
c . ifNoneMatch_ = entityTag
return c
}
// 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 ( c * AccountsProductsGetCall ) Context ( ctx context . Context ) * AccountsProductsGetCall {
c . ctx_ = ctx
return c
}
// Header returns an http.Header that can be modified by the caller to
// add HTTP headers to the request.
func ( c * AccountsProductsGetCall ) Header ( ) http . Header {
if c . header_ == nil {
c . header_ = make ( http . Header )
}
return c . header_
}
func ( c * AccountsProductsGetCall ) doRequest ( alt string ) ( * http . Response , error ) {
reqHeaders := make ( http . Header )
for k , v := range c . header_ {
reqHeaders [ k ] = v
}
reqHeaders . Set ( "User-Agent" , c . s . userAgent ( ) )
if c . ifNoneMatch_ != "" {
reqHeaders . Set ( "If-None-Match" , c . ifNoneMatch_ )
}
var body io . Reader = nil
c . urlParams_ . Set ( "alt" , alt )
urls := googleapi . ResolveRelative ( c . s . BasePath , "v1/{+parent}/products/{+name}" )
urls += "?" + c . urlParams_ . Encode ( )
req , _ := http . NewRequest ( "GET" , urls , body )
req . Header = reqHeaders
googleapi . Expand ( req . URL , map [ string ] string {
"parent" : c . parent ,
"name" : c . name ,
} )
return gensupport . SendRequest ( c . ctx_ , c . s . client , req )
}
// 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 ( c * AccountsProductsGetCall ) Do ( opts ... googleapi . CallOption ) ( * Product , error ) {
gensupport . SetOptions ( c . urlParams_ , opts ... )
res , err := c . doRequest ( "json" )
if res != nil && res . StatusCode == http . StatusNotModified {
if res . Body != nil {
res . Body . Close ( )
}
return nil , & googleapi . Error {
Code : res . StatusCode ,
Header : res . Header ,
}
}
if err != nil {
return nil , err
}
defer googleapi . CloseBody ( res )
if err := googleapi . CheckResponse ( res ) ; err != nil {
return nil , err
}
ret := & Product {
ServerResponse : googleapi . ServerResponse {
Header : res . Header ,
HTTPStatusCode : res . StatusCode ,
} ,
}
target := & ret
2018-01-16 14:20:59 +01:00
if err := gensupport . DecodeResponse ( target , res ) ; err != nil {
2017-05-11 16:39:54 +02:00
return nil , err
}
return ret , nil
// {
2017-09-30 16:27:27 +02:00
// "description": "Gets the product from a Manufacturer Center account, including product\nissues.\n\nA recently updated product takes around 15 minutes to process. Changes are\nonly visible after it has been processed. While some issues may be\navailable once the product has been processed, other issues may take days\nto appear.",
2017-05-11 16:39:54 +02:00
// "flatPath": "v1/accounts/{accountsId}/products/{productsId}",
// "httpMethod": "GET",
// "id": "manufacturers.accounts.products.get",
// "parameterOrder": [
// "parent",
// "name"
// ],
// "parameters": {
2018-05-02 18:09:45 +02:00
// "include": {
// "description": "The information to be included in the response. Only sections listed here\nwill be returned.\n\nIf this parameter is not specified, ATTRIBUTES and ISSUES are returned.\nThis behavior is temporary and will be removed once all clients are ready\nor at the latest end of July 2018. After that no sections will be returned.",
// "enum": [
// "UNKNOWN",
// "ATTRIBUTES",
// "ISSUES",
// "DESTINATION_STATUSES"
// ],
// "location": "query",
// "repeated": true,
// "type": "string"
// },
2017-05-11 16:39:54 +02:00
// "name": {
// "description": "Name in the format `{target_country}:{content_language}:{product_id}`.\n\n`target_country` - The target country of the product as a CLDR territory\n code (for example, US).\n\n`content_language` - The content language of the product as a two-letter\n ISO 639-1 language code (for example, en).\n\n`product_id` - The ID of the product. For more information, see\n https://support.google.com/manufacturers/answer/6124116#id.",
// "location": "path",
// "pattern": "^[^/]+$",
// "required": true,
// "type": "string"
// },
// "parent": {
// "description": "Parent ID in the format `accounts/{account_id}`.\n\n`account_id` - The ID of the Manufacturer Center account.",
// "location": "path",
// "pattern": "^accounts/[^/]+$",
// "required": true,
// "type": "string"
// }
// },
// "path": "v1/{+parent}/products/{+name}",
// "response": {
// "$ref": "Product"
// },
// "scopes": [
// "https://www.googleapis.com/auth/manufacturercenter"
// ]
// }
}
// method id "manufacturers.accounts.products.list":
type AccountsProductsListCall struct {
s * Service
parent string
urlParams_ gensupport . URLParams
ifNoneMatch_ string
ctx_ context . Context
header_ http . Header
}
// List: Lists all the products in a Manufacturer Center account.
func ( r * AccountsProductsService ) List ( parent string ) * AccountsProductsListCall {
c := & AccountsProductsListCall { s : r . s , urlParams_ : make ( gensupport . URLParams ) }
c . parent = parent
return c
}
2018-05-02 18:09:45 +02:00
// Include sets the optional parameter "include": The information to be
// included in the response. Only sections listed here
// will be returned.
//
// If this parameter is not specified, ATTRIBUTES and ISSUES are
// returned.
// This behavior is temporary and will be removed once all clients are
// ready
// or at the latest end of July 2018. After that no sections will be
// returned.
//
// Possible values:
// "UNKNOWN"
// "ATTRIBUTES"
// "ISSUES"
// "DESTINATION_STATUSES"
func ( c * AccountsProductsListCall ) Include ( include ... string ) * AccountsProductsListCall {
c . urlParams_ . SetMulti ( "include" , append ( [ ] string { } , include ... ) )
return c
}
2017-05-11 16:39:54 +02:00
// PageSize sets the optional parameter "pageSize": Maximum number of
// product statuses to return in the response, used for
// paging.
func ( c * AccountsProductsListCall ) PageSize ( pageSize int64 ) * AccountsProductsListCall {
c . urlParams_ . Set ( "pageSize" , fmt . Sprint ( pageSize ) )
return c
}
// PageToken sets the optional parameter "pageToken": The token returned
// by the previous request.
func ( c * AccountsProductsListCall ) PageToken ( pageToken string ) * AccountsProductsListCall {
c . urlParams_ . Set ( "pageToken" , pageToken )
return c
}
// Fields allows partial responses to be retrieved. See
// https://developers.google.com/gdata/docs/2.0/basics#PartialResponse
// for more information.
func ( c * AccountsProductsListCall ) Fields ( s ... googleapi . Field ) * AccountsProductsListCall {
c . urlParams_ . Set ( "fields" , googleapi . CombineFields ( s ) )
return c
}
// 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 ( c * AccountsProductsListCall ) IfNoneMatch ( entityTag string ) * AccountsProductsListCall {
c . ifNoneMatch_ = entityTag
return c
}
// 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 ( c * AccountsProductsListCall ) Context ( ctx context . Context ) * AccountsProductsListCall {
c . ctx_ = ctx
return c
}
// Header returns an http.Header that can be modified by the caller to
// add HTTP headers to the request.
func ( c * AccountsProductsListCall ) Header ( ) http . Header {
if c . header_ == nil {
c . header_ = make ( http . Header )
}
return c . header_
}
func ( c * AccountsProductsListCall ) doRequest ( alt string ) ( * http . Response , error ) {
reqHeaders := make ( http . Header )
for k , v := range c . header_ {
reqHeaders [ k ] = v
}
reqHeaders . Set ( "User-Agent" , c . s . userAgent ( ) )
if c . ifNoneMatch_ != "" {
reqHeaders . Set ( "If-None-Match" , c . ifNoneMatch_ )
}
var body io . Reader = nil
c . urlParams_ . Set ( "alt" , alt )
urls := googleapi . ResolveRelative ( c . s . BasePath , "v1/{+parent}/products" )
urls += "?" + c . urlParams_ . Encode ( )
req , _ := http . NewRequest ( "GET" , urls , body )
req . Header = reqHeaders
googleapi . Expand ( req . URL , map [ string ] string {
"parent" : c . parent ,
} )
return gensupport . SendRequest ( c . ctx_ , c . s . client , req )
}
// 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 ( c * AccountsProductsListCall ) Do ( opts ... googleapi . CallOption ) ( * ListProductsResponse , error ) {
gensupport . SetOptions ( c . urlParams_ , opts ... )
res , err := c . doRequest ( "json" )
if res != nil && res . StatusCode == http . StatusNotModified {
if res . Body != nil {
res . Body . Close ( )
}
return nil , & googleapi . Error {
Code : res . StatusCode ,
Header : res . Header ,
}
}
if err != nil {
return nil , err
}
defer googleapi . CloseBody ( res )
if err := googleapi . CheckResponse ( res ) ; err != nil {
return nil , err
}
ret := & ListProductsResponse {
ServerResponse : googleapi . ServerResponse {
Header : res . Header ,
HTTPStatusCode : res . StatusCode ,
} ,
}
target := & ret
2018-01-16 14:20:59 +01:00
if err := gensupport . DecodeResponse ( target , res ) ; err != nil {
2017-05-11 16:39:54 +02:00
return nil , err
}
return ret , nil
// {
// "description": "Lists all the products in a Manufacturer Center account.",
// "flatPath": "v1/accounts/{accountsId}/products",
// "httpMethod": "GET",
// "id": "manufacturers.accounts.products.list",
// "parameterOrder": [
// "parent"
// ],
// "parameters": {
2018-05-02 18:09:45 +02:00
// "include": {
// "description": "The information to be included in the response. Only sections listed here\nwill be returned.\n\nIf this parameter is not specified, ATTRIBUTES and ISSUES are returned.\nThis behavior is temporary and will be removed once all clients are ready\nor at the latest end of July 2018. After that no sections will be returned.",
// "enum": [
// "UNKNOWN",
// "ATTRIBUTES",
// "ISSUES",
// "DESTINATION_STATUSES"
// ],
// "location": "query",
// "repeated": true,
// "type": "string"
// },
2017-05-11 16:39:54 +02:00
// "pageSize": {
// "description": "Maximum number of product statuses to return in the response, used for\npaging.",
// "format": "int32",
// "location": "query",
// "type": "integer"
// },
// "pageToken": {
// "description": "The token returned by the previous request.",
// "location": "query",
// "type": "string"
// },
// "parent": {
// "description": "Parent ID in the format `accounts/{account_id}`.\n\n`account_id` - The ID of the Manufacturer Center account.",
// "location": "path",
// "pattern": "^accounts/[^/]+$",
// "required": true,
// "type": "string"
// }
// },
// "path": "v1/{+parent}/products",
// "response": {
// "$ref": "ListProductsResponse"
// },
// "scopes": [
// "https://www.googleapis.com/auth/manufacturercenter"
// ]
// }
}
// 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.
func ( c * AccountsProductsListCall ) Pages ( ctx context . Context , f func ( * ListProductsResponse ) error ) error {
c . ctx_ = ctx
defer c . PageToken ( c . urlParams_ . Get ( "pageToken" ) ) // reset paging to original point
for {
x , err := c . Do ( )
if err != nil {
return err
}
if err := f ( x ) ; err != nil {
return err
}
if x . NextPageToken == "" {
return nil
}
c . PageToken ( x . NextPageToken )
}
}
2017-07-23 09:51:42 +02:00
// method id "manufacturers.accounts.products.update":
type AccountsProductsUpdateCall struct {
s * Service
parent string
name string
2018-03-19 16:51:38 +01:00
attributes * Attributes
2017-07-23 09:51:42 +02:00
urlParams_ gensupport . URLParams
ctx_ context . Context
header_ http . Header
}
2018-03-19 16:51:38 +01:00
// Update: Inserts or updates the attributes of the product in a
// Manufacturer Center
2017-07-23 09:51:42 +02:00
// account.
//
2018-03-19 16:51:38 +01:00
// 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
2017-07-23 09:51:42 +02:00
// the
2018-03-19 16:51:38 +01:00
// product and check it for issues once the new version is
// available.
2017-07-23 09:51:42 +02:00
//
2018-03-19 16:51:38 +01:00
// Uploaded attributes first need to be processed before they can
// be
2017-07-23 09:51:42 +02:00
// retrieved. Until then, new products will be unavailable, and
// retrieval
2018-03-19 16:51:38 +01:00
// of previously uploaded products will return the original state of
// the
// product.
func ( r * AccountsProductsService ) Update ( parent string , name string , attributes * Attributes ) * AccountsProductsUpdateCall {
2017-07-23 09:51:42 +02:00
c := & AccountsProductsUpdateCall { s : r . s , urlParams_ : make ( gensupport . URLParams ) }
c . parent = parent
c . name = name
2018-03-19 16:51:38 +01:00
c . attributes = attributes
2017-07-23 09:51:42 +02:00
return c
}
// Fields allows partial responses to be retrieved. See
// https://developers.google.com/gdata/docs/2.0/basics#PartialResponse
// for more information.
func ( c * AccountsProductsUpdateCall ) Fields ( s ... googleapi . Field ) * AccountsProductsUpdateCall {
c . urlParams_ . Set ( "fields" , googleapi . CombineFields ( s ) )
return c
}
// 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 ( c * AccountsProductsUpdateCall ) Context ( ctx context . Context ) * AccountsProductsUpdateCall {
c . ctx_ = ctx
return c
}
// Header returns an http.Header that can be modified by the caller to
// add HTTP headers to the request.
func ( c * AccountsProductsUpdateCall ) Header ( ) http . Header {
if c . header_ == nil {
c . header_ = make ( http . Header )
}
return c . header_
}
func ( c * AccountsProductsUpdateCall ) doRequest ( alt string ) ( * http . Response , error ) {
reqHeaders := make ( http . Header )
for k , v := range c . header_ {
reqHeaders [ k ] = v
}
reqHeaders . Set ( "User-Agent" , c . s . userAgent ( ) )
var body io . Reader = nil
2018-03-19 16:51:38 +01:00
body , err := googleapi . WithoutDataWrapper . JSONReader ( c . attributes )
2017-07-23 09:51:42 +02:00
if err != nil {
return nil , err
}
reqHeaders . Set ( "Content-Type" , "application/json" )
c . urlParams_ . Set ( "alt" , alt )
urls := googleapi . ResolveRelative ( c . s . BasePath , "v1/{+parent}/products/{+name}" )
urls += "?" + c . urlParams_ . Encode ( )
req , _ := http . NewRequest ( "PUT" , urls , body )
req . Header = reqHeaders
googleapi . Expand ( req . URL , map [ string ] string {
"parent" : c . parent ,
"name" : c . name ,
} )
return gensupport . SendRequest ( c . ctx_ , c . s . client , req )
}
// Do executes the "manufacturers.accounts.products.update" call.
2018-03-19 16:51:38 +01:00
// Exactly one of *Empty or error will be non-nil. Any non-2xx status
2017-07-23 09:51:42 +02:00
// code is an error. Response headers are in either
2018-03-19 16:51:38 +01:00
// *Empty.ServerResponse.Header or (if a response was returned at all)
2017-07-23 09:51:42 +02:00
// in error.(*googleapi.Error).Header. Use googleapi.IsNotModified to
// check whether the returned error was because http.StatusNotModified
// was returned.
2018-03-19 16:51:38 +01:00
func ( c * AccountsProductsUpdateCall ) Do ( opts ... googleapi . CallOption ) ( * Empty , error ) {
2017-07-23 09:51:42 +02:00
gensupport . SetOptions ( c . urlParams_ , opts ... )
res , err := c . doRequest ( "json" )
if res != nil && res . StatusCode == http . StatusNotModified {
if res . Body != nil {
res . Body . Close ( )
}
return nil , & googleapi . Error {
Code : res . StatusCode ,
Header : res . Header ,
}
}
if err != nil {
return nil , err
}
defer googleapi . CloseBody ( res )
if err := googleapi . CheckResponse ( res ) ; err != nil {
return nil , err
}
2018-03-19 16:51:38 +01:00
ret := & Empty {
2017-07-23 09:51:42 +02:00
ServerResponse : googleapi . ServerResponse {
Header : res . Header ,
HTTPStatusCode : res . StatusCode ,
} ,
}
target := & ret
2018-01-16 14:20:59 +01:00
if err := gensupport . DecodeResponse ( target , res ) ; err != nil {
2017-07-23 09:51:42 +02:00
return nil , err
}
return ret , nil
// {
2018-03-19 16:51:38 +01:00
// "description": "Inserts or updates the attributes of the product in a Manufacturer Center\naccount.\n\nCreates a product with the provided attributes. If the product already\nexists, then all attributes are replaced with the new ones. The checks at\nupload time are minimal. All required attributes need to be present for a\nproduct to be valid. Issues may show up later after the API has accepted a\nnew upload for a product and it is possible to overwrite an existing valid\nproduct with an invalid product. To detect this, you should retrieve the\nproduct and check it for issues once the new version is available.\n\nUploaded attributes first need to be processed before they can be\nretrieved. Until then, new products will be unavailable, and retrieval\nof previously uploaded products will return the original state of the\nproduct.",
2017-07-23 09:51:42 +02:00
// "flatPath": "v1/accounts/{accountsId}/products/{productsId}",
// "httpMethod": "PUT",
// "id": "manufacturers.accounts.products.update",
// "parameterOrder": [
// "parent",
// "name"
// ],
// "parameters": {
// "name": {
// "description": "Name in the format `{target_country}:{content_language}:{product_id}`.\n\n`target_country` - The target country of the product as a CLDR territory\n code (for example, US).\n\n`content_language` - The content language of the product as a two-letter\n ISO 639-1 language code (for example, en).\n\n`product_id` - The ID of the product. For more information, see\n https://support.google.com/manufacturers/answer/6124116#id.",
// "location": "path",
// "pattern": "^[^/]+$",
// "required": true,
// "type": "string"
// },
// "parent": {
// "description": "Parent ID in the format `accounts/{account_id}`.\n\n`account_id` - The ID of the Manufacturer Center account.",
// "location": "path",
// "pattern": "^accounts/[^/]+$",
// "required": true,
// "type": "string"
// }
// },
// "path": "v1/{+parent}/products/{+name}",
// "request": {
2018-03-19 16:51:38 +01:00
// "$ref": "Attributes"
2017-07-23 09:51:42 +02:00
// },
// "response": {
2018-03-19 16:51:38 +01:00
// "$ref": "Empty"
2017-07-23 09:51:42 +02:00
// },
// "scopes": [
// "https://www.googleapis.com/auth/manufacturercenter"
// ]
// }
}