forked from TrueCloudLab/distribution
11364 lines
370 KiB
Go
11364 lines
370 KiB
Go
|
// Package books provides access to the Books API.
|
||
|
//
|
||
|
// See https://developers.google.com/books/docs/v1/getting_started
|
||
|
//
|
||
|
// Usage example:
|
||
|
//
|
||
|
// import "google.golang.org/api/books/v1"
|
||
|
// ...
|
||
|
// booksService, err := books.New(oauthHttpClient)
|
||
|
package books // import "google.golang.org/api/books/v1"
|
||
|
|
||
|
import (
|
||
|
"bytes"
|
||
|
"encoding/json"
|
||
|
"errors"
|
||
|
"fmt"
|
||
|
"golang.org/x/net/context"
|
||
|
"golang.org/x/net/context/ctxhttp"
|
||
|
"google.golang.org/api/googleapi"
|
||
|
"google.golang.org/api/internal"
|
||
|
"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 _ = googleapi.Version
|
||
|
var _ = errors.New
|
||
|
var _ = strings.Replace
|
||
|
var _ = internal.MarshalJSON
|
||
|
var _ = context.Canceled
|
||
|
var _ = ctxhttp.Do
|
||
|
|
||
|
const apiId = "books:v1"
|
||
|
const apiName = "books"
|
||
|
const apiVersion = "v1"
|
||
|
const basePath = "https://www.googleapis.com/books/v1/"
|
||
|
|
||
|
// OAuth2 scopes used by this API.
|
||
|
const (
|
||
|
// Manage your books
|
||
|
BooksScope = "https://www.googleapis.com/auth/books"
|
||
|
)
|
||
|
|
||
|
func New(client *http.Client) (*Service, error) {
|
||
|
if client == nil {
|
||
|
return nil, errors.New("client is nil")
|
||
|
}
|
||
|
s := &Service{client: client, BasePath: basePath}
|
||
|
s.Bookshelves = NewBookshelvesService(s)
|
||
|
s.Cloudloading = NewCloudloadingService(s)
|
||
|
s.Dictionary = NewDictionaryService(s)
|
||
|
s.Layers = NewLayersService(s)
|
||
|
s.Myconfig = NewMyconfigService(s)
|
||
|
s.Mylibrary = NewMylibraryService(s)
|
||
|
s.Notification = NewNotificationService(s)
|
||
|
s.Onboarding = NewOnboardingService(s)
|
||
|
s.Personalizedstream = NewPersonalizedstreamService(s)
|
||
|
s.Promooffer = NewPromoofferService(s)
|
||
|
s.Volumes = NewVolumesService(s)
|
||
|
return s, nil
|
||
|
}
|
||
|
|
||
|
type Service struct {
|
||
|
client *http.Client
|
||
|
BasePath string // API endpoint base URL
|
||
|
UserAgent string // optional additional User-Agent fragment
|
||
|
|
||
|
Bookshelves *BookshelvesService
|
||
|
|
||
|
Cloudloading *CloudloadingService
|
||
|
|
||
|
Dictionary *DictionaryService
|
||
|
|
||
|
Layers *LayersService
|
||
|
|
||
|
Myconfig *MyconfigService
|
||
|
|
||
|
Mylibrary *MylibraryService
|
||
|
|
||
|
Notification *NotificationService
|
||
|
|
||
|
Onboarding *OnboardingService
|
||
|
|
||
|
Personalizedstream *PersonalizedstreamService
|
||
|
|
||
|
Promooffer *PromoofferService
|
||
|
|
||
|
Volumes *VolumesService
|
||
|
}
|
||
|
|
||
|
func (s *Service) userAgent() string {
|
||
|
if s.UserAgent == "" {
|
||
|
return googleapi.UserAgent
|
||
|
}
|
||
|
return googleapi.UserAgent + " " + s.UserAgent
|
||
|
}
|
||
|
|
||
|
func NewBookshelvesService(s *Service) *BookshelvesService {
|
||
|
rs := &BookshelvesService{s: s}
|
||
|
rs.Volumes = NewBookshelvesVolumesService(s)
|
||
|
return rs
|
||
|
}
|
||
|
|
||
|
type BookshelvesService struct {
|
||
|
s *Service
|
||
|
|
||
|
Volumes *BookshelvesVolumesService
|
||
|
}
|
||
|
|
||
|
func NewBookshelvesVolumesService(s *Service) *BookshelvesVolumesService {
|
||
|
rs := &BookshelvesVolumesService{s: s}
|
||
|
return rs
|
||
|
}
|
||
|
|
||
|
type BookshelvesVolumesService struct {
|
||
|
s *Service
|
||
|
}
|
||
|
|
||
|
func NewCloudloadingService(s *Service) *CloudloadingService {
|
||
|
rs := &CloudloadingService{s: s}
|
||
|
return rs
|
||
|
}
|
||
|
|
||
|
type CloudloadingService struct {
|
||
|
s *Service
|
||
|
}
|
||
|
|
||
|
func NewDictionaryService(s *Service) *DictionaryService {
|
||
|
rs := &DictionaryService{s: s}
|
||
|
return rs
|
||
|
}
|
||
|
|
||
|
type DictionaryService struct {
|
||
|
s *Service
|
||
|
}
|
||
|
|
||
|
func NewLayersService(s *Service) *LayersService {
|
||
|
rs := &LayersService{s: s}
|
||
|
rs.AnnotationData = NewLayersAnnotationDataService(s)
|
||
|
rs.VolumeAnnotations = NewLayersVolumeAnnotationsService(s)
|
||
|
return rs
|
||
|
}
|
||
|
|
||
|
type LayersService struct {
|
||
|
s *Service
|
||
|
|
||
|
AnnotationData *LayersAnnotationDataService
|
||
|
|
||
|
VolumeAnnotations *LayersVolumeAnnotationsService
|
||
|
}
|
||
|
|
||
|
func NewLayersAnnotationDataService(s *Service) *LayersAnnotationDataService {
|
||
|
rs := &LayersAnnotationDataService{s: s}
|
||
|
return rs
|
||
|
}
|
||
|
|
||
|
type LayersAnnotationDataService struct {
|
||
|
s *Service
|
||
|
}
|
||
|
|
||
|
func NewLayersVolumeAnnotationsService(s *Service) *LayersVolumeAnnotationsService {
|
||
|
rs := &LayersVolumeAnnotationsService{s: s}
|
||
|
return rs
|
||
|
}
|
||
|
|
||
|
type LayersVolumeAnnotationsService struct {
|
||
|
s *Service
|
||
|
}
|
||
|
|
||
|
func NewMyconfigService(s *Service) *MyconfigService {
|
||
|
rs := &MyconfigService{s: s}
|
||
|
return rs
|
||
|
}
|
||
|
|
||
|
type MyconfigService struct {
|
||
|
s *Service
|
||
|
}
|
||
|
|
||
|
func NewMylibraryService(s *Service) *MylibraryService {
|
||
|
rs := &MylibraryService{s: s}
|
||
|
rs.Annotations = NewMylibraryAnnotationsService(s)
|
||
|
rs.Bookshelves = NewMylibraryBookshelvesService(s)
|
||
|
rs.Readingpositions = NewMylibraryReadingpositionsService(s)
|
||
|
return rs
|
||
|
}
|
||
|
|
||
|
type MylibraryService struct {
|
||
|
s *Service
|
||
|
|
||
|
Annotations *MylibraryAnnotationsService
|
||
|
|
||
|
Bookshelves *MylibraryBookshelvesService
|
||
|
|
||
|
Readingpositions *MylibraryReadingpositionsService
|
||
|
}
|
||
|
|
||
|
func NewMylibraryAnnotationsService(s *Service) *MylibraryAnnotationsService {
|
||
|
rs := &MylibraryAnnotationsService{s: s}
|
||
|
return rs
|
||
|
}
|
||
|
|
||
|
type MylibraryAnnotationsService struct {
|
||
|
s *Service
|
||
|
}
|
||
|
|
||
|
func NewMylibraryBookshelvesService(s *Service) *MylibraryBookshelvesService {
|
||
|
rs := &MylibraryBookshelvesService{s: s}
|
||
|
rs.Volumes = NewMylibraryBookshelvesVolumesService(s)
|
||
|
return rs
|
||
|
}
|
||
|
|
||
|
type MylibraryBookshelvesService struct {
|
||
|
s *Service
|
||
|
|
||
|
Volumes *MylibraryBookshelvesVolumesService
|
||
|
}
|
||
|
|
||
|
func NewMylibraryBookshelvesVolumesService(s *Service) *MylibraryBookshelvesVolumesService {
|
||
|
rs := &MylibraryBookshelvesVolumesService{s: s}
|
||
|
return rs
|
||
|
}
|
||
|
|
||
|
type MylibraryBookshelvesVolumesService struct {
|
||
|
s *Service
|
||
|
}
|
||
|
|
||
|
func NewMylibraryReadingpositionsService(s *Service) *MylibraryReadingpositionsService {
|
||
|
rs := &MylibraryReadingpositionsService{s: s}
|
||
|
return rs
|
||
|
}
|
||
|
|
||
|
type MylibraryReadingpositionsService struct {
|
||
|
s *Service
|
||
|
}
|
||
|
|
||
|
func NewNotificationService(s *Service) *NotificationService {
|
||
|
rs := &NotificationService{s: s}
|
||
|
return rs
|
||
|
}
|
||
|
|
||
|
type NotificationService struct {
|
||
|
s *Service
|
||
|
}
|
||
|
|
||
|
func NewOnboardingService(s *Service) *OnboardingService {
|
||
|
rs := &OnboardingService{s: s}
|
||
|
return rs
|
||
|
}
|
||
|
|
||
|
type OnboardingService struct {
|
||
|
s *Service
|
||
|
}
|
||
|
|
||
|
func NewPersonalizedstreamService(s *Service) *PersonalizedstreamService {
|
||
|
rs := &PersonalizedstreamService{s: s}
|
||
|
return rs
|
||
|
}
|
||
|
|
||
|
type PersonalizedstreamService struct {
|
||
|
s *Service
|
||
|
}
|
||
|
|
||
|
func NewPromoofferService(s *Service) *PromoofferService {
|
||
|
rs := &PromoofferService{s: s}
|
||
|
return rs
|
||
|
}
|
||
|
|
||
|
type PromoofferService struct {
|
||
|
s *Service
|
||
|
}
|
||
|
|
||
|
func NewVolumesService(s *Service) *VolumesService {
|
||
|
rs := &VolumesService{s: s}
|
||
|
rs.Associated = NewVolumesAssociatedService(s)
|
||
|
rs.Mybooks = NewVolumesMybooksService(s)
|
||
|
rs.Recommended = NewVolumesRecommendedService(s)
|
||
|
rs.Useruploaded = NewVolumesUseruploadedService(s)
|
||
|
return rs
|
||
|
}
|
||
|
|
||
|
type VolumesService struct {
|
||
|
s *Service
|
||
|
|
||
|
Associated *VolumesAssociatedService
|
||
|
|
||
|
Mybooks *VolumesMybooksService
|
||
|
|
||
|
Recommended *VolumesRecommendedService
|
||
|
|
||
|
Useruploaded *VolumesUseruploadedService
|
||
|
}
|
||
|
|
||
|
func NewVolumesAssociatedService(s *Service) *VolumesAssociatedService {
|
||
|
rs := &VolumesAssociatedService{s: s}
|
||
|
return rs
|
||
|
}
|
||
|
|
||
|
type VolumesAssociatedService struct {
|
||
|
s *Service
|
||
|
}
|
||
|
|
||
|
func NewVolumesMybooksService(s *Service) *VolumesMybooksService {
|
||
|
rs := &VolumesMybooksService{s: s}
|
||
|
return rs
|
||
|
}
|
||
|
|
||
|
type VolumesMybooksService struct {
|
||
|
s *Service
|
||
|
}
|
||
|
|
||
|
func NewVolumesRecommendedService(s *Service) *VolumesRecommendedService {
|
||
|
rs := &VolumesRecommendedService{s: s}
|
||
|
return rs
|
||
|
}
|
||
|
|
||
|
type VolumesRecommendedService struct {
|
||
|
s *Service
|
||
|
}
|
||
|
|
||
|
func NewVolumesUseruploadedService(s *Service) *VolumesUseruploadedService {
|
||
|
rs := &VolumesUseruploadedService{s: s}
|
||
|
return rs
|
||
|
}
|
||
|
|
||
|
type VolumesUseruploadedService struct {
|
||
|
s *Service
|
||
|
}
|
||
|
|
||
|
type Annotation struct {
|
||
|
// AfterSelectedText: Anchor text after excerpt. For requests, if the
|
||
|
// user bookmarked a screen that has no flowing text on it, then this
|
||
|
// field should be empty.
|
||
|
AfterSelectedText string `json:"afterSelectedText,omitempty"`
|
||
|
|
||
|
// BeforeSelectedText: Anchor text before excerpt. For requests, if the
|
||
|
// user bookmarked a screen that has no flowing text on it, then this
|
||
|
// field should be empty.
|
||
|
BeforeSelectedText string `json:"beforeSelectedText,omitempty"`
|
||
|
|
||
|
// ClientVersionRanges: Selection ranges sent from the client.
|
||
|
ClientVersionRanges *AnnotationClientVersionRanges `json:"clientVersionRanges,omitempty"`
|
||
|
|
||
|
// Created: Timestamp for the created time of this annotation.
|
||
|
Created string `json:"created,omitempty"`
|
||
|
|
||
|
// CurrentVersionRanges: Selection ranges for the most recent content
|
||
|
// version.
|
||
|
CurrentVersionRanges *AnnotationCurrentVersionRanges `json:"currentVersionRanges,omitempty"`
|
||
|
|
||
|
// Data: User-created data for this annotation.
|
||
|
Data string `json:"data,omitempty"`
|
||
|
|
||
|
// Deleted: Indicates that this annotation is deleted.
|
||
|
Deleted bool `json:"deleted,omitempty"`
|
||
|
|
||
|
// HighlightStyle: The highlight style for this annotation.
|
||
|
HighlightStyle string `json:"highlightStyle,omitempty"`
|
||
|
|
||
|
// Id: Id of this annotation, in the form of a GUID.
|
||
|
Id string `json:"id,omitempty"`
|
||
|
|
||
|
// Kind: Resource type.
|
||
|
Kind string `json:"kind,omitempty"`
|
||
|
|
||
|
// LayerId: The layer this annotation is for.
|
||
|
LayerId string `json:"layerId,omitempty"`
|
||
|
|
||
|
LayerSummary *AnnotationLayerSummary `json:"layerSummary,omitempty"`
|
||
|
|
||
|
// PageIds: Pages that this annotation spans.
|
||
|
PageIds []string `json:"pageIds,omitempty"`
|
||
|
|
||
|
// SelectedText: Excerpt from the volume.
|
||
|
SelectedText string `json:"selectedText,omitempty"`
|
||
|
|
||
|
// SelfLink: URL to this resource.
|
||
|
SelfLink string `json:"selfLink,omitempty"`
|
||
|
|
||
|
// Updated: Timestamp for the last time this annotation was modified.
|
||
|
Updated string `json:"updated,omitempty"`
|
||
|
|
||
|
// VolumeId: The volume that this annotation belongs to.
|
||
|
VolumeId string `json:"volumeId,omitempty"`
|
||
|
|
||
|
// ServerResponse contains the HTTP response code and headers from the
|
||
|
// server.
|
||
|
googleapi.ServerResponse `json:"-"`
|
||
|
|
||
|
// ForceSendFields is a list of field names (e.g. "AfterSelectedText")
|
||
|
// 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:"-"`
|
||
|
}
|
||
|
|
||
|
func (s *Annotation) MarshalJSON() ([]byte, error) {
|
||
|
type noMethod Annotation
|
||
|
raw := noMethod(*s)
|
||
|
return internal.MarshalJSON(raw, s.ForceSendFields)
|
||
|
}
|
||
|
|
||
|
// AnnotationClientVersionRanges: Selection ranges sent from the client.
|
||
|
type AnnotationClientVersionRanges struct {
|
||
|
// CfiRange: Range in CFI format for this annotation sent by client.
|
||
|
CfiRange *BooksAnnotationsRange `json:"cfiRange,omitempty"`
|
||
|
|
||
|
// ContentVersion: Content version the client sent in.
|
||
|
ContentVersion string `json:"contentVersion,omitempty"`
|
||
|
|
||
|
// GbImageRange: Range in GB image format for this annotation sent by
|
||
|
// client.
|
||
|
GbImageRange *BooksAnnotationsRange `json:"gbImageRange,omitempty"`
|
||
|
|
||
|
// GbTextRange: Range in GB text format for this annotation sent by
|
||
|
// client.
|
||
|
GbTextRange *BooksAnnotationsRange `json:"gbTextRange,omitempty"`
|
||
|
|
||
|
// ImageCfiRange: Range in image CFI format for this annotation sent by
|
||
|
// client.
|
||
|
ImageCfiRange *BooksAnnotationsRange `json:"imageCfiRange,omitempty"`
|
||
|
|
||
|
// ForceSendFields is a list of field names (e.g. "CfiRange") 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:"-"`
|
||
|
}
|
||
|
|
||
|
func (s *AnnotationClientVersionRanges) MarshalJSON() ([]byte, error) {
|
||
|
type noMethod AnnotationClientVersionRanges
|
||
|
raw := noMethod(*s)
|
||
|
return internal.MarshalJSON(raw, s.ForceSendFields)
|
||
|
}
|
||
|
|
||
|
// AnnotationCurrentVersionRanges: Selection ranges for the most recent
|
||
|
// content version.
|
||
|
type AnnotationCurrentVersionRanges struct {
|
||
|
// CfiRange: Range in CFI format for this annotation for version above.
|
||
|
CfiRange *BooksAnnotationsRange `json:"cfiRange,omitempty"`
|
||
|
|
||
|
// ContentVersion: Content version applicable to ranges below.
|
||
|
ContentVersion string `json:"contentVersion,omitempty"`
|
||
|
|
||
|
// GbImageRange: Range in GB image format for this annotation for
|
||
|
// version above.
|
||
|
GbImageRange *BooksAnnotationsRange `json:"gbImageRange,omitempty"`
|
||
|
|
||
|
// GbTextRange: Range in GB text format for this annotation for version
|
||
|
// above.
|
||
|
GbTextRange *BooksAnnotationsRange `json:"gbTextRange,omitempty"`
|
||
|
|
||
|
// ImageCfiRange: Range in image CFI format for this annotation for
|
||
|
// version above.
|
||
|
ImageCfiRange *BooksAnnotationsRange `json:"imageCfiRange,omitempty"`
|
||
|
|
||
|
// ForceSendFields is a list of field names (e.g. "CfiRange") 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:"-"`
|
||
|
}
|
||
|
|
||
|
func (s *AnnotationCurrentVersionRanges) MarshalJSON() ([]byte, error) {
|
||
|
type noMethod AnnotationCurrentVersionRanges
|
||
|
raw := noMethod(*s)
|
||
|
return internal.MarshalJSON(raw, s.ForceSendFields)
|
||
|
}
|
||
|
|
||
|
type AnnotationLayerSummary struct {
|
||
|
// AllowedCharacterCount: Maximum allowed characters on this layer,
|
||
|
// especially for the "copy" layer.
|
||
|
AllowedCharacterCount int64 `json:"allowedCharacterCount,omitempty"`
|
||
|
|
||
|
// LimitType: Type of limitation on this layer. "limited" or "unlimited"
|
||
|
// for the "copy" layer.
|
||
|
LimitType string `json:"limitType,omitempty"`
|
||
|
|
||
|
// RemainingCharacterCount: Remaining allowed characters on this layer,
|
||
|
// especially for the "copy" layer.
|
||
|
RemainingCharacterCount int64 `json:"remainingCharacterCount,omitempty"`
|
||
|
|
||
|
// ForceSendFields is a list of field names (e.g.
|
||
|
// "AllowedCharacterCount") 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:"-"`
|
||
|
}
|
||
|
|
||
|
func (s *AnnotationLayerSummary) MarshalJSON() ([]byte, error) {
|
||
|
type noMethod AnnotationLayerSummary
|
||
|
raw := noMethod(*s)
|
||
|
return internal.MarshalJSON(raw, s.ForceSendFields)
|
||
|
}
|
||
|
|
||
|
type Annotationdata struct {
|
||
|
// AnnotationType: The type of annotation this data is for.
|
||
|
AnnotationType string `json:"annotationType,omitempty"`
|
||
|
|
||
|
Data interface{} `json:"data,omitempty"`
|
||
|
|
||
|
// EncodedData: Base64 encoded data for this annotation data.
|
||
|
EncodedData string `json:"encoded_data,omitempty"`
|
||
|
|
||
|
// Id: Unique id for this annotation data.
|
||
|
Id string `json:"id,omitempty"`
|
||
|
|
||
|
// Kind: Resource Type
|
||
|
Kind string `json:"kind,omitempty"`
|
||
|
|
||
|
// LayerId: The Layer id for this data. *
|
||
|
LayerId string `json:"layerId,omitempty"`
|
||
|
|
||
|
// SelfLink: URL for this resource. *
|
||
|
SelfLink string `json:"selfLink,omitempty"`
|
||
|
|
||
|
// Updated: Timestamp for the last time this data was updated. (RFC 3339
|
||
|
// UTC date-time format).
|
||
|
Updated string `json:"updated,omitempty"`
|
||
|
|
||
|
// VolumeId: The volume id for this data. *
|
||
|
VolumeId string `json:"volumeId,omitempty"`
|
||
|
|
||
|
// ServerResponse contains the HTTP response code and headers from the
|
||
|
// server.
|
||
|
googleapi.ServerResponse `json:"-"`
|
||
|
|
||
|
// ForceSendFields is a list of field names (e.g. "AnnotationType") 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:"-"`
|
||
|
}
|
||
|
|
||
|
func (s *Annotationdata) MarshalJSON() ([]byte, error) {
|
||
|
type noMethod Annotationdata
|
||
|
raw := noMethod(*s)
|
||
|
return internal.MarshalJSON(raw, s.ForceSendFields)
|
||
|
}
|
||
|
|
||
|
type Annotations struct {
|
||
|
// Items: A list of annotations.
|
||
|
Items []*Annotation `json:"items,omitempty"`
|
||
|
|
||
|
// Kind: Resource type.
|
||
|
Kind string `json:"kind,omitempty"`
|
||
|
|
||
|
// NextPageToken: Token to pass in for pagination for the next page.
|
||
|
// This will not be present if this request does not have more results.
|
||
|
NextPageToken string `json:"nextPageToken,omitempty"`
|
||
|
|
||
|
// TotalItems: Total number of annotations found. This may be greater
|
||
|
// than the number of notes returned in this response if results have
|
||
|
// been paginated.
|
||
|
TotalItems int64 `json:"totalItems,omitempty"`
|
||
|
|
||
|
// ServerResponse contains the HTTP response code and headers from the
|
||
|
// server.
|
||
|
googleapi.ServerResponse `json:"-"`
|
||
|
|
||
|
// ForceSendFields is a list of field names (e.g. "Items") 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:"-"`
|
||
|
}
|
||
|
|
||
|
func (s *Annotations) MarshalJSON() ([]byte, error) {
|
||
|
type noMethod Annotations
|
||
|
raw := noMethod(*s)
|
||
|
return internal.MarshalJSON(raw, s.ForceSendFields)
|
||
|
}
|
||
|
|
||
|
type AnnotationsSummary struct {
|
||
|
Kind string `json:"kind,omitempty"`
|
||
|
|
||
|
Layers []*AnnotationsSummaryLayers `json:"layers,omitempty"`
|
||
|
|
||
|
// ServerResponse contains the HTTP response code and headers from the
|
||
|
// server.
|
||
|
googleapi.ServerResponse `json:"-"`
|
||
|
|
||
|
// ForceSendFields is a list of field names (e.g. "Kind") 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:"-"`
|
||
|
}
|
||
|
|
||
|
func (s *AnnotationsSummary) MarshalJSON() ([]byte, error) {
|
||
|
type noMethod AnnotationsSummary
|
||
|
raw := noMethod(*s)
|
||
|
return internal.MarshalJSON(raw, s.ForceSendFields)
|
||
|
}
|
||
|
|
||
|
type AnnotationsSummaryLayers struct {
|
||
|
AllowedCharacterCount int64 `json:"allowedCharacterCount,omitempty"`
|
||
|
|
||
|
LayerId string `json:"layerId,omitempty"`
|
||
|
|
||
|
LimitType string `json:"limitType,omitempty"`
|
||
|
|
||
|
RemainingCharacterCount int64 `json:"remainingCharacterCount,omitempty"`
|
||
|
|
||
|
Updated string `json:"updated,omitempty"`
|
||
|
|
||
|
// ForceSendFields is a list of field names (e.g.
|
||
|
// "AllowedCharacterCount") 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:"-"`
|
||
|
}
|
||
|
|
||
|
func (s *AnnotationsSummaryLayers) MarshalJSON() ([]byte, error) {
|
||
|
type noMethod AnnotationsSummaryLayers
|
||
|
raw := noMethod(*s)
|
||
|
return internal.MarshalJSON(raw, s.ForceSendFields)
|
||
|
}
|
||
|
|
||
|
type Annotationsdata struct {
|
||
|
// Items: A list of Annotation Data.
|
||
|
Items []*Annotationdata `json:"items,omitempty"`
|
||
|
|
||
|
// Kind: Resource type
|
||
|
Kind string `json:"kind,omitempty"`
|
||
|
|
||
|
// NextPageToken: Token to pass in for pagination for the next page.
|
||
|
// This will not be present if this request does not have more results.
|
||
|
NextPageToken string `json:"nextPageToken,omitempty"`
|
||
|
|
||
|
// TotalItems: The total number of volume annotations found.
|
||
|
TotalItems int64 `json:"totalItems,omitempty"`
|
||
|
|
||
|
// ServerResponse contains the HTTP response code and headers from the
|
||
|
// server.
|
||
|
googleapi.ServerResponse `json:"-"`
|
||
|
|
||
|
// ForceSendFields is a list of field names (e.g. "Items") 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:"-"`
|
||
|
}
|
||
|
|
||
|
func (s *Annotationsdata) MarshalJSON() ([]byte, error) {
|
||
|
type noMethod Annotationsdata
|
||
|
raw := noMethod(*s)
|
||
|
return internal.MarshalJSON(raw, s.ForceSendFields)
|
||
|
}
|
||
|
|
||
|
type BooksAnnotationsRange struct {
|
||
|
// EndOffset: The offset from the ending position.
|
||
|
EndOffset string `json:"endOffset,omitempty"`
|
||
|
|
||
|
// EndPosition: The ending position for the range.
|
||
|
EndPosition string `json:"endPosition,omitempty"`
|
||
|
|
||
|
// StartOffset: The offset from the starting position.
|
||
|
StartOffset string `json:"startOffset,omitempty"`
|
||
|
|
||
|
// StartPosition: The starting position for the range.
|
||
|
StartPosition string `json:"startPosition,omitempty"`
|
||
|
|
||
|
// ForceSendFields is a list of field names (e.g. "EndOffset") 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:"-"`
|
||
|
}
|
||
|
|
||
|
func (s *BooksAnnotationsRange) MarshalJSON() ([]byte, error) {
|
||
|
type noMethod BooksAnnotationsRange
|
||
|
raw := noMethod(*s)
|
||
|
return internal.MarshalJSON(raw, s.ForceSendFields)
|
||
|
}
|
||
|
|
||
|
type BooksCloudloadingResource struct {
|
||
|
Author string `json:"author,omitempty"`
|
||
|
|
||
|
ProcessingState string `json:"processingState,omitempty"`
|
||
|
|
||
|
Title string `json:"title,omitempty"`
|
||
|
|
||
|
VolumeId string `json:"volumeId,omitempty"`
|
||
|
|
||
|
// ServerResponse contains the HTTP response code and headers from the
|
||
|
// server.
|
||
|
googleapi.ServerResponse `json:"-"`
|
||
|
|
||
|
// ForceSendFields is a list of field names (e.g. "Author") 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:"-"`
|
||
|
}
|
||
|
|
||
|
func (s *BooksCloudloadingResource) MarshalJSON() ([]byte, error) {
|
||
|
type noMethod BooksCloudloadingResource
|
||
|
raw := noMethod(*s)
|
||
|
return internal.MarshalJSON(raw, s.ForceSendFields)
|
||
|
}
|
||
|
|
||
|
type BooksVolumesRecommendedRateResponse struct {
|
||
|
ConsistencyToken string `json:"consistency_token,omitempty"`
|
||
|
|
||
|
// ServerResponse contains the HTTP response code and headers from the
|
||
|
// server.
|
||
|
googleapi.ServerResponse `json:"-"`
|
||
|
|
||
|
// ForceSendFields is a list of field names (e.g. "ConsistencyToken") 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:"-"`
|
||
|
}
|
||
|
|
||
|
func (s *BooksVolumesRecommendedRateResponse) MarshalJSON() ([]byte, error) {
|
||
|
type noMethod BooksVolumesRecommendedRateResponse
|
||
|
raw := noMethod(*s)
|
||
|
return internal.MarshalJSON(raw, s.ForceSendFields)
|
||
|
}
|
||
|
|
||
|
type Bookshelf struct {
|
||
|
// Access: Whether this bookshelf is PUBLIC or PRIVATE.
|
||
|
Access string `json:"access,omitempty"`
|
||
|
|
||
|
// Created: Created time for this bookshelf (formatted UTC timestamp
|
||
|
// with millisecond resolution).
|
||
|
Created string `json:"created,omitempty"`
|
||
|
|
||
|
// Description: Description of this bookshelf.
|
||
|
Description string `json:"description,omitempty"`
|
||
|
|
||
|
// Id: Id of this bookshelf, only unique by user.
|
||
|
Id int64 `json:"id,omitempty"`
|
||
|
|
||
|
// Kind: Resource type for bookshelf metadata.
|
||
|
Kind string `json:"kind,omitempty"`
|
||
|
|
||
|
// SelfLink: URL to this resource.
|
||
|
SelfLink string `json:"selfLink,omitempty"`
|
||
|
|
||
|
// Title: Title of this bookshelf.
|
||
|
Title string `json:"title,omitempty"`
|
||
|
|
||
|
// Updated: Last modified time of this bookshelf (formatted UTC
|
||
|
// timestamp with millisecond resolution).
|
||
|
Updated string `json:"updated,omitempty"`
|
||
|
|
||
|
// VolumeCount: Number of volumes in this bookshelf.
|
||
|
VolumeCount int64 `json:"volumeCount,omitempty"`
|
||
|
|
||
|
// VolumesLastUpdated: Last time a volume was added or removed from this
|
||
|
// bookshelf (formatted UTC timestamp with millisecond resolution).
|
||
|
VolumesLastUpdated string `json:"volumesLastUpdated,omitempty"`
|
||
|
|
||
|
// ServerResponse contains the HTTP response code and headers from the
|
||
|
// server.
|
||
|
googleapi.ServerResponse `json:"-"`
|
||
|
|
||
|
// ForceSendFields is a list of field names (e.g. "Access") 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:"-"`
|
||
|
}
|
||
|
|
||
|
func (s *Bookshelf) MarshalJSON() ([]byte, error) {
|
||
|
type noMethod Bookshelf
|
||
|
raw := noMethod(*s)
|
||
|
return internal.MarshalJSON(raw, s.ForceSendFields)
|
||
|
}
|
||
|
|
||
|
type Bookshelves struct {
|
||
|
// Items: A list of bookshelves.
|
||
|
Items []*Bookshelf `json:"items,omitempty"`
|
||
|
|
||
|
// Kind: Resource type.
|
||
|
Kind string `json:"kind,omitempty"`
|
||
|
|
||
|
// ServerResponse contains the HTTP response code and headers from the
|
||
|
// server.
|
||
|
googleapi.ServerResponse `json:"-"`
|
||
|
|
||
|
// ForceSendFields is a list of field names (e.g. "Items") 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:"-"`
|
||
|
}
|
||
|
|
||
|
func (s *Bookshelves) MarshalJSON() ([]byte, error) {
|
||
|
type noMethod Bookshelves
|
||
|
raw := noMethod(*s)
|
||
|
return internal.MarshalJSON(raw, s.ForceSendFields)
|
||
|
}
|
||
|
|
||
|
type Category struct {
|
||
|
// Items: A list of onboarding categories.
|
||
|
Items []*CategoryItems `json:"items,omitempty"`
|
||
|
|
||
|
// Kind: Resource type.
|
||
|
Kind string `json:"kind,omitempty"`
|
||
|
|
||
|
// ServerResponse contains the HTTP response code and headers from the
|
||
|
// server.
|
||
|
googleapi.ServerResponse `json:"-"`
|
||
|
|
||
|
// ForceSendFields is a list of field names (e.g. "Items") 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:"-"`
|
||
|
}
|
||
|
|
||
|
func (s *Category) MarshalJSON() ([]byte, error) {
|
||
|
type noMethod Category
|
||
|
raw := noMethod(*s)
|
||
|
return internal.MarshalJSON(raw, s.ForceSendFields)
|
||
|
}
|
||
|
|
||
|
type CategoryItems struct {
|
||
|
BadgeUrl string `json:"badgeUrl,omitempty"`
|
||
|
|
||
|
CategoryId string `json:"categoryId,omitempty"`
|
||
|
|
||
|
Name string `json:"name,omitempty"`
|
||
|
|
||
|
// ForceSendFields is a list of field names (e.g. "BadgeUrl") 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:"-"`
|
||
|
}
|
||
|
|
||
|
func (s *CategoryItems) MarshalJSON() ([]byte, error) {
|
||
|
type noMethod CategoryItems
|
||
|
raw := noMethod(*s)
|
||
|
return internal.MarshalJSON(raw, s.ForceSendFields)
|
||
|
}
|
||
|
|
||
|
type ConcurrentAccessRestriction struct {
|
||
|
// DeviceAllowed: Whether access is granted for this (user, device,
|
||
|
// volume).
|
||
|
DeviceAllowed bool `json:"deviceAllowed,omitempty"`
|
||
|
|
||
|
// Kind: Resource type.
|
||
|
Kind string `json:"kind,omitempty"`
|
||
|
|
||
|
// MaxConcurrentDevices: The maximum number of concurrent access
|
||
|
// licenses for this volume.
|
||
|
MaxConcurrentDevices int64 `json:"maxConcurrentDevices,omitempty"`
|
||
|
|
||
|
// Message: Error/warning message.
|
||
|
Message string `json:"message,omitempty"`
|
||
|
|
||
|
// Nonce: Client nonce for verification. Download access and
|
||
|
// client-validation only.
|
||
|
Nonce string `json:"nonce,omitempty"`
|
||
|
|
||
|
// ReasonCode: Error/warning reason code.
|
||
|
ReasonCode string `json:"reasonCode,omitempty"`
|
||
|
|
||
|
// Restricted: Whether this volume has any concurrent access
|
||
|
// restrictions.
|
||
|
Restricted bool `json:"restricted,omitempty"`
|
||
|
|
||
|
// Signature: Response signature.
|
||
|
Signature string `json:"signature,omitempty"`
|
||
|
|
||
|
// Source: Client app identifier for verification. Download access and
|
||
|
// client-validation only.
|
||
|
Source string `json:"source,omitempty"`
|
||
|
|
||
|
// TimeWindowSeconds: Time in seconds for license auto-expiration.
|
||
|
TimeWindowSeconds int64 `json:"timeWindowSeconds,omitempty"`
|
||
|
|
||
|
// VolumeId: Identifies the volume for which this entry applies.
|
||
|
VolumeId string `json:"volumeId,omitempty"`
|
||
|
|
||
|
// ForceSendFields is a list of field names (e.g. "DeviceAllowed") 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:"-"`
|
||
|
}
|
||
|
|
||
|
func (s *ConcurrentAccessRestriction) MarshalJSON() ([]byte, error) {
|
||
|
type noMethod ConcurrentAccessRestriction
|
||
|
raw := noMethod(*s)
|
||
|
return internal.MarshalJSON(raw, s.ForceSendFields)
|
||
|
}
|
||
|
|
||
|
type Dictlayerdata struct {
|
||
|
Common *DictlayerdataCommon `json:"common,omitempty"`
|
||
|
|
||
|
Dict *DictlayerdataDict `json:"dict,omitempty"`
|
||
|
|
||
|
Kind string `json:"kind,omitempty"`
|
||
|
|
||
|
// ForceSendFields is a list of field names (e.g. "Common") 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:"-"`
|
||
|
}
|
||
|
|
||
|
func (s *Dictlayerdata) MarshalJSON() ([]byte, error) {
|
||
|
type noMethod Dictlayerdata
|
||
|
raw := noMethod(*s)
|
||
|
return internal.MarshalJSON(raw, s.ForceSendFields)
|
||
|
}
|
||
|
|
||
|
type DictlayerdataCommon struct {
|
||
|
// Title: The display title and localized canonical name to use when
|
||
|
// searching for this entity on Google search.
|
||
|
Title string `json:"title,omitempty"`
|
||
|
|
||
|
// ForceSendFields is a list of field names (e.g. "Title") 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:"-"`
|
||
|
}
|
||
|
|
||
|
func (s *DictlayerdataCommon) MarshalJSON() ([]byte, error) {
|
||
|
type noMethod DictlayerdataCommon
|
||
|
raw := noMethod(*s)
|
||
|
return internal.MarshalJSON(raw, s.ForceSendFields)
|
||
|
}
|
||
|
|
||
|
type DictlayerdataDict struct {
|
||
|
// Source: The source, url and attribution for this dictionary data.
|
||
|
Source *DictlayerdataDictSource `json:"source,omitempty"`
|
||
|
|
||
|
Words []*DictlayerdataDictWords `json:"words,omitempty"`
|
||
|
|
||
|
// ForceSendFields is a list of field names (e.g. "Source") 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:"-"`
|
||
|
}
|
||
|
|
||
|
func (s *DictlayerdataDict) MarshalJSON() ([]byte, error) {
|
||
|
type noMethod DictlayerdataDict
|
||
|
raw := noMethod(*s)
|
||
|
return internal.MarshalJSON(raw, s.ForceSendFields)
|
||
|
}
|
||
|
|
||
|
// DictlayerdataDictSource: The source, url and attribution for this
|
||
|
// dictionary data.
|
||
|
type DictlayerdataDictSource struct {
|
||
|
Attribution string `json:"attribution,omitempty"`
|
||
|
|
||
|
Url string `json:"url,omitempty"`
|
||
|
|
||
|
// ForceSendFields is a list of field names (e.g. "Attribution") 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:"-"`
|
||
|
}
|
||
|
|
||
|
func (s *DictlayerdataDictSource) MarshalJSON() ([]byte, error) {
|
||
|
type noMethod DictlayerdataDictSource
|
||
|
raw := noMethod(*s)
|
||
|
return internal.MarshalJSON(raw, s.ForceSendFields)
|
||
|
}
|
||
|
|
||
|
type DictlayerdataDictWords struct {
|
||
|
Derivatives []*DictlayerdataDictWordsDerivatives `json:"derivatives,omitempty"`
|
||
|
|
||
|
Examples []*DictlayerdataDictWordsExamples `json:"examples,omitempty"`
|
||
|
|
||
|
Senses []*DictlayerdataDictWordsSenses `json:"senses,omitempty"`
|
||
|
|
||
|
// Source: The words with different meanings but not related words, e.g.
|
||
|
// "go" (game) and "go" (verb).
|
||
|
Source *DictlayerdataDictWordsSource `json:"source,omitempty"`
|
||
|
|
||
|
// ForceSendFields is a list of field names (e.g. "Derivatives") 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:"-"`
|
||
|
}
|
||
|
|
||
|
func (s *DictlayerdataDictWords) MarshalJSON() ([]byte, error) {
|
||
|
type noMethod DictlayerdataDictWords
|
||
|
raw := noMethod(*s)
|
||
|
return internal.MarshalJSON(raw, s.ForceSendFields)
|
||
|
}
|
||
|
|
||
|
type DictlayerdataDictWordsDerivatives struct {
|
||
|
Source *DictlayerdataDictWordsDerivativesSource `json:"source,omitempty"`
|
||
|
|
||
|
Text string `json:"text,omitempty"`
|
||
|
|
||
|
// ForceSendFields is a list of field names (e.g. "Source") 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:"-"`
|
||
|
}
|
||
|
|
||
|
func (s *DictlayerdataDictWordsDerivatives) MarshalJSON() ([]byte, error) {
|
||
|
type noMethod DictlayerdataDictWordsDerivatives
|
||
|
raw := noMethod(*s)
|
||
|
return internal.MarshalJSON(raw, s.ForceSendFields)
|
||
|
}
|
||
|
|
||
|
type DictlayerdataDictWordsDerivativesSource struct {
|
||
|
Attribution string `json:"attribution,omitempty"`
|
||
|
|
||
|
Url string `json:"url,omitempty"`
|
||
|
|
||
|
// ForceSendFields is a list of field names (e.g. "Attribution") 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:"-"`
|
||
|
}
|
||
|
|
||
|
func (s *DictlayerdataDictWordsDerivativesSource) MarshalJSON() ([]byte, error) {
|
||
|
type noMethod DictlayerdataDictWordsDerivativesSource
|
||
|
raw := noMethod(*s)
|
||
|
return internal.MarshalJSON(raw, s.ForceSendFields)
|
||
|
}
|
||
|
|
||
|
type DictlayerdataDictWordsExamples struct {
|
||
|
Source *DictlayerdataDictWordsExamplesSource `json:"source,omitempty"`
|
||
|
|
||
|
Text string `json:"text,omitempty"`
|
||
|
|
||
|
// ForceSendFields is a list of field names (e.g. "Source") 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:"-"`
|
||
|
}
|
||
|
|
||
|
func (s *DictlayerdataDictWordsExamples) MarshalJSON() ([]byte, error) {
|
||
|
type noMethod DictlayerdataDictWordsExamples
|
||
|
raw := noMethod(*s)
|
||
|
return internal.MarshalJSON(raw, s.ForceSendFields)
|
||
|
}
|
||
|
|
||
|
type DictlayerdataDictWordsExamplesSource struct {
|
||
|
Attribution string `json:"attribution,omitempty"`
|
||
|
|
||
|
Url string `json:"url,omitempty"`
|
||
|
|
||
|
// ForceSendFields is a list of field names (e.g. "Attribution") 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:"-"`
|
||
|
}
|
||
|
|
||
|
func (s *DictlayerdataDictWordsExamplesSource) MarshalJSON() ([]byte, error) {
|
||
|
type noMethod DictlayerdataDictWordsExamplesSource
|
||
|
raw := noMethod(*s)
|
||
|
return internal.MarshalJSON(raw, s.ForceSendFields)
|
||
|
}
|
||
|
|
||
|
type DictlayerdataDictWordsSenses struct {
|
||
|
Conjugations []*DictlayerdataDictWordsSensesConjugations `json:"conjugations,omitempty"`
|
||
|
|
||
|
Definitions []*DictlayerdataDictWordsSensesDefinitions `json:"definitions,omitempty"`
|
||
|
|
||
|
PartOfSpeech string `json:"partOfSpeech,omitempty"`
|
||
|
|
||
|
Pronunciation string `json:"pronunciation,omitempty"`
|
||
|
|
||
|
PronunciationUrl string `json:"pronunciationUrl,omitempty"`
|
||
|
|
||
|
Source *DictlayerdataDictWordsSensesSource `json:"source,omitempty"`
|
||
|
|
||
|
Syllabification string `json:"syllabification,omitempty"`
|
||
|
|
||
|
Synonyms []*DictlayerdataDictWordsSensesSynonyms `json:"synonyms,omitempty"`
|
||
|
|
||
|
// ForceSendFields is a list of field names (e.g. "Conjugations") 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:"-"`
|
||
|
}
|
||
|
|
||
|
func (s *DictlayerdataDictWordsSenses) MarshalJSON() ([]byte, error) {
|
||
|
type noMethod DictlayerdataDictWordsSenses
|
||
|
raw := noMethod(*s)
|
||
|
return internal.MarshalJSON(raw, s.ForceSendFields)
|
||
|
}
|
||
|
|
||
|
type DictlayerdataDictWordsSensesConjugations struct {
|
||
|
Type string `json:"type,omitempty"`
|
||
|
|
||
|
Value string `json:"value,omitempty"`
|
||
|
|
||
|
// ForceSendFields is a list of field names (e.g. "Type") 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:"-"`
|
||
|
}
|
||
|
|
||
|
func (s *DictlayerdataDictWordsSensesConjugations) MarshalJSON() ([]byte, error) {
|
||
|
type noMethod DictlayerdataDictWordsSensesConjugations
|
||
|
raw := noMethod(*s)
|
||
|
return internal.MarshalJSON(raw, s.ForceSendFields)
|
||
|
}
|
||
|
|
||
|
type DictlayerdataDictWordsSensesDefinitions struct {
|
||
|
Definition string `json:"definition,omitempty"`
|
||
|
|
||
|
Examples []*DictlayerdataDictWordsSensesDefinitionsExamples `json:"examples,omitempty"`
|
||
|
|
||
|
// ForceSendFields is a list of field names (e.g. "Definition") 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:"-"`
|
||
|
}
|
||
|
|
||
|
func (s *DictlayerdataDictWordsSensesDefinitions) MarshalJSON() ([]byte, error) {
|
||
|
type noMethod DictlayerdataDictWordsSensesDefinitions
|
||
|
raw := noMethod(*s)
|
||
|
return internal.MarshalJSON(raw, s.ForceSendFields)
|
||
|
}
|
||
|
|
||
|
type DictlayerdataDictWordsSensesDefinitionsExamples struct {
|
||
|
Source *DictlayerdataDictWordsSensesDefinitionsExamplesSource `json:"source,omitempty"`
|
||
|
|
||
|
Text string `json:"text,omitempty"`
|
||
|
|
||
|
// ForceSendFields is a list of field names (e.g. "Source") 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:"-"`
|
||
|
}
|
||
|
|
||
|
func (s *DictlayerdataDictWordsSensesDefinitionsExamples) MarshalJSON() ([]byte, error) {
|
||
|
type noMethod DictlayerdataDictWordsSensesDefinitionsExamples
|
||
|
raw := noMethod(*s)
|
||
|
return internal.MarshalJSON(raw, s.ForceSendFields)
|
||
|
}
|
||
|
|
||
|
type DictlayerdataDictWordsSensesDefinitionsExamplesSource struct {
|
||
|
Attribution string `json:"attribution,omitempty"`
|
||
|
|
||
|
Url string `json:"url,omitempty"`
|
||
|
|
||
|
// ForceSendFields is a list of field names (e.g. "Attribution") 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:"-"`
|
||
|
}
|
||
|
|
||
|
func (s *DictlayerdataDictWordsSensesDefinitionsExamplesSource) MarshalJSON() ([]byte, error) {
|
||
|
type noMethod DictlayerdataDictWordsSensesDefinitionsExamplesSource
|
||
|
raw := noMethod(*s)
|
||
|
return internal.MarshalJSON(raw, s.ForceSendFields)
|
||
|
}
|
||
|
|
||
|
type DictlayerdataDictWordsSensesSource struct {
|
||
|
Attribution string `json:"attribution,omitempty"`
|
||
|
|
||
|
Url string `json:"url,omitempty"`
|
||
|
|
||
|
// ForceSendFields is a list of field names (e.g. "Attribution") 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:"-"`
|
||
|
}
|
||
|
|
||
|
func (s *DictlayerdataDictWordsSensesSource) MarshalJSON() ([]byte, error) {
|
||
|
type noMethod DictlayerdataDictWordsSensesSource
|
||
|
raw := noMethod(*s)
|
||
|
return internal.MarshalJSON(raw, s.ForceSendFields)
|
||
|
}
|
||
|
|
||
|
type DictlayerdataDictWordsSensesSynonyms struct {
|
||
|
Source *DictlayerdataDictWordsSensesSynonymsSource `json:"source,omitempty"`
|
||
|
|
||
|
Text string `json:"text,omitempty"`
|
||
|
|
||
|
// ForceSendFields is a list of field names (e.g. "Source") 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:"-"`
|
||
|
}
|
||
|
|
||
|
func (s *DictlayerdataDictWordsSensesSynonyms) MarshalJSON() ([]byte, error) {
|
||
|
type noMethod DictlayerdataDictWordsSensesSynonyms
|
||
|
raw := noMethod(*s)
|
||
|
return internal.MarshalJSON(raw, s.ForceSendFields)
|
||
|
}
|
||
|
|
||
|
type DictlayerdataDictWordsSensesSynonymsSource struct {
|
||
|
Attribution string `json:"attribution,omitempty"`
|
||
|
|
||
|
Url string `json:"url,omitempty"`
|
||
|
|
||
|
// ForceSendFields is a list of field names (e.g. "Attribution") 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:"-"`
|
||
|
}
|
||
|
|
||
|
func (s *DictlayerdataDictWordsSensesSynonymsSource) MarshalJSON() ([]byte, error) {
|
||
|
type noMethod DictlayerdataDictWordsSensesSynonymsSource
|
||
|
raw := noMethod(*s)
|
||
|
return internal.MarshalJSON(raw, s.ForceSendFields)
|
||
|
}
|
||
|
|
||
|
// DictlayerdataDictWordsSource: The words with different meanings but
|
||
|
// not related words, e.g. "go" (game) and "go" (verb).
|
||
|
type DictlayerdataDictWordsSource struct {
|
||
|
Attribution string `json:"attribution,omitempty"`
|
||
|
|
||
|
Url string `json:"url,omitempty"`
|
||
|
|
||
|
// ForceSendFields is a list of field names (e.g. "Attribution") 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:"-"`
|
||
|
}
|
||
|
|
||
|
func (s *DictlayerdataDictWordsSource) MarshalJSON() ([]byte, error) {
|
||
|
type noMethod DictlayerdataDictWordsSource
|
||
|
raw := noMethod(*s)
|
||
|
return internal.MarshalJSON(raw, s.ForceSendFields)
|
||
|
}
|
||
|
|
||
|
type Discoveryclusters struct {
|
||
|
Clusters []*DiscoveryclustersClusters `json:"clusters,omitempty"`
|
||
|
|
||
|
// Kind: Resorce type.
|
||
|
Kind string `json:"kind,omitempty"`
|
||
|
|
||
|
TotalClusters int64 `json:"totalClusters,omitempty"`
|
||
|
|
||
|
// ServerResponse contains the HTTP response code and headers from the
|
||
|
// server.
|
||
|
googleapi.ServerResponse `json:"-"`
|
||
|
|
||
|
// ForceSendFields is a list of field names (e.g. "Clusters") 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:"-"`
|
||
|
}
|
||
|
|
||
|
func (s *Discoveryclusters) MarshalJSON() ([]byte, error) {
|
||
|
type noMethod Discoveryclusters
|
||
|
raw := noMethod(*s)
|
||
|
return internal.MarshalJSON(raw, s.ForceSendFields)
|
||
|
}
|
||
|
|
||
|
type DiscoveryclustersClusters struct {
|
||
|
BannerWithContentContainer *DiscoveryclustersClustersBannerWithContentContainer `json:"banner_with_content_container,omitempty"`
|
||
|
|
||
|
SubTitle string `json:"subTitle,omitempty"`
|
||
|
|
||
|
Title string `json:"title,omitempty"`
|
||
|
|
||
|
TotalVolumes int64 `json:"totalVolumes,omitempty"`
|
||
|
|
||
|
Uid string `json:"uid,omitempty"`
|
||
|
|
||
|
Volumes []*Volume `json:"volumes,omitempty"`
|
||
|
|
||
|
// ForceSendFields is a list of field names (e.g.
|
||
|
// "BannerWithContentContainer") 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:"-"`
|
||
|
}
|
||
|
|
||
|
func (s *DiscoveryclustersClusters) MarshalJSON() ([]byte, error) {
|
||
|
type noMethod DiscoveryclustersClusters
|
||
|
raw := noMethod(*s)
|
||
|
return internal.MarshalJSON(raw, s.ForceSendFields)
|
||
|
}
|
||
|
|
||
|
type DiscoveryclustersClustersBannerWithContentContainer struct {
|
||
|
FillColorArgb string `json:"fillColorArgb,omitempty"`
|
||
|
|
||
|
ImageUrl string `json:"imageUrl,omitempty"`
|
||
|
|
||
|
MaskColorArgb string `json:"maskColorArgb,omitempty"`
|
||
|
|
||
|
MoreButtonText string `json:"moreButtonText,omitempty"`
|
||
|
|
||
|
MoreButtonUrl string `json:"moreButtonUrl,omitempty"`
|
||
|
|
||
|
TextColorArgb string `json:"textColorArgb,omitempty"`
|
||
|
|
||
|
// ForceSendFields is a list of field names (e.g. "FillColorArgb") 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:"-"`
|
||
|
}
|
||
|
|
||
|
func (s *DiscoveryclustersClustersBannerWithContentContainer) MarshalJSON() ([]byte, error) {
|
||
|
type noMethod DiscoveryclustersClustersBannerWithContentContainer
|
||
|
raw := noMethod(*s)
|
||
|
return internal.MarshalJSON(raw, s.ForceSendFields)
|
||
|
}
|
||
|
|
||
|
type DownloadAccessRestriction struct {
|
||
|
// DeviceAllowed: If restricted, whether access is granted for this
|
||
|
// (user, device, volume).
|
||
|
DeviceAllowed bool `json:"deviceAllowed,omitempty"`
|
||
|
|
||
|
// DownloadsAcquired: If restricted, the number of content download
|
||
|
// licenses already acquired (including the requesting client, if
|
||
|
// licensed).
|
||
|
DownloadsAcquired int64 `json:"downloadsAcquired,omitempty"`
|
||
|
|
||
|
// JustAcquired: If deviceAllowed, whether access was just acquired with
|
||
|
// this request.
|
||
|
JustAcquired bool `json:"justAcquired,omitempty"`
|
||
|
|
||
|
// Kind: Resource type.
|
||
|
Kind string `json:"kind,omitempty"`
|
||
|
|
||
|
// MaxDownloadDevices: If restricted, the maximum number of content
|
||
|
// download licenses for this volume.
|
||
|
MaxDownloadDevices int64 `json:"maxDownloadDevices,omitempty"`
|
||
|
|
||
|
// Message: Error/warning message.
|
||
|
Message string `json:"message,omitempty"`
|
||
|
|
||
|
// Nonce: Client nonce for verification. Download access and
|
||
|
// client-validation only.
|
||
|
Nonce string `json:"nonce,omitempty"`
|
||
|
|
||
|
// ReasonCode: Error/warning reason code. Additional codes may be added
|
||
|
// in the future. 0 OK 100 ACCESS_DENIED_PUBLISHER_LIMIT 101
|
||
|
// ACCESS_DENIED_LIMIT 200 WARNING_USED_LAST_ACCESS
|
||
|
ReasonCode string `json:"reasonCode,omitempty"`
|
||
|
|
||
|
// Restricted: Whether this volume has any download access restrictions.
|
||
|
Restricted bool `json:"restricted,omitempty"`
|
||
|
|
||
|
// Signature: Response signature.
|
||
|
Signature string `json:"signature,omitempty"`
|
||
|
|
||
|
// Source: Client app identifier for verification. Download access and
|
||
|
// client-validation only.
|
||
|
Source string `json:"source,omitempty"`
|
||
|
|
||
|
// VolumeId: Identifies the volume for which this entry applies.
|
||
|
VolumeId string `json:"volumeId,omitempty"`
|
||
|
|
||
|
// ForceSendFields is a list of field names (e.g. "DeviceAllowed") 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:"-"`
|
||
|
}
|
||
|
|
||
|
func (s *DownloadAccessRestriction) MarshalJSON() ([]byte, error) {
|
||
|
type noMethod DownloadAccessRestriction
|
||
|
raw := noMethod(*s)
|
||
|
return internal.MarshalJSON(raw, s.ForceSendFields)
|
||
|
}
|
||
|
|
||
|
type DownloadAccesses struct {
|
||
|
// DownloadAccessList: A list of download access responses.
|
||
|
DownloadAccessList []*DownloadAccessRestriction `json:"downloadAccessList,omitempty"`
|
||
|
|
||
|
// Kind: Resource type.
|
||
|
Kind string `json:"kind,omitempty"`
|
||
|
|
||
|
// ServerResponse contains the HTTP response code and headers from the
|
||
|
// server.
|
||
|
googleapi.ServerResponse `json:"-"`
|
||
|
|
||
|
// ForceSendFields is a list of field names (e.g. "DownloadAccessList")
|
||
|
// 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:"-"`
|
||
|
}
|
||
|
|
||
|
func (s *DownloadAccesses) MarshalJSON() ([]byte, error) {
|
||
|
type noMethod DownloadAccesses
|
||
|
raw := noMethod(*s)
|
||
|
return internal.MarshalJSON(raw, s.ForceSendFields)
|
||
|
}
|
||
|
|
||
|
type Geolayerdata struct {
|
||
|
Common *GeolayerdataCommon `json:"common,omitempty"`
|
||
|
|
||
|
Geo *GeolayerdataGeo `json:"geo,omitempty"`
|
||
|
|
||
|
Kind string `json:"kind,omitempty"`
|
||
|
|
||
|
// ForceSendFields is a list of field names (e.g. "Common") 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:"-"`
|
||
|
}
|
||
|
|
||
|
func (s *Geolayerdata) MarshalJSON() ([]byte, error) {
|
||
|
type noMethod Geolayerdata
|
||
|
raw := noMethod(*s)
|
||
|
return internal.MarshalJSON(raw, s.ForceSendFields)
|
||
|
}
|
||
|
|
||
|
type GeolayerdataCommon struct {
|
||
|
// Lang: The language of the information url and description.
|
||
|
Lang string `json:"lang,omitempty"`
|
||
|
|
||
|
// PreviewImageUrl: The URL for the preview image information.
|
||
|
PreviewImageUrl string `json:"previewImageUrl,omitempty"`
|
||
|
|
||
|
// Snippet: The description for this location.
|
||
|
Snippet string `json:"snippet,omitempty"`
|
||
|
|
||
|
// SnippetUrl: The URL for information for this location. Ex: wikipedia
|
||
|
// link.
|
||
|
SnippetUrl string `json:"snippetUrl,omitempty"`
|
||
|
|
||
|
// Title: The display title and localized canonical name to use when
|
||
|
// searching for this entity on Google search.
|
||
|
Title string `json:"title,omitempty"`
|
||
|
|
||
|
// ForceSendFields is a list of field names (e.g. "Lang") 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:"-"`
|
||
|
}
|
||
|
|
||
|
func (s *GeolayerdataCommon) MarshalJSON() ([]byte, error) {
|
||
|
type noMethod GeolayerdataCommon
|
||
|
raw := noMethod(*s)
|
||
|
return internal.MarshalJSON(raw, s.ForceSendFields)
|
||
|
}
|
||
|
|
||
|
type GeolayerdataGeo struct {
|
||
|
// Boundary: The boundary of the location as a set of loops containing
|
||
|
// pairs of latitude, longitude coordinates.
|
||
|
Boundary [][]*GeolayerdataGeoBoundaryItem `json:"boundary,omitempty"`
|
||
|
|
||
|
// CachePolicy: The cache policy active for this data. EX: UNRESTRICTED,
|
||
|
// RESTRICTED, NEVER
|
||
|
CachePolicy string `json:"cachePolicy,omitempty"`
|
||
|
|
||
|
// CountryCode: The country code of the location.
|
||
|
CountryCode string `json:"countryCode,omitempty"`
|
||
|
|
||
|
// Latitude: The latitude of the location.
|
||
|
Latitude float64 `json:"latitude,omitempty"`
|
||
|
|
||
|
// Longitude: The longitude of the location.
|
||
|
Longitude float64 `json:"longitude,omitempty"`
|
||
|
|
||
|
// MapType: The type of map that should be used for this location. EX:
|
||
|
// HYBRID, ROADMAP, SATELLITE, TERRAIN
|
||
|
MapType string `json:"mapType,omitempty"`
|
||
|
|
||
|
// Viewport: The viewport for showing this location. This is a latitude,
|
||
|
// longitude rectangle.
|
||
|
Viewport *GeolayerdataGeoViewport `json:"viewport,omitempty"`
|
||
|
|
||
|
// Zoom: The Zoom level to use for the map. Zoom levels between 0 (the
|
||
|
// lowest zoom level, in which the entire world can be seen on one map)
|
||
|
// to 21+ (down to individual buildings). See:
|
||
|
// https://developers.google.com/maps/documentation/staticmaps/#Zoomlevels
|
||
|
Zoom int64 `json:"zoom,omitempty"`
|
||
|
|
||
|
// ForceSendFields is a list of field names (e.g. "Boundary") 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:"-"`
|
||
|
}
|
||
|
|
||
|
func (s *GeolayerdataGeo) MarshalJSON() ([]byte, error) {
|
||
|
type noMethod GeolayerdataGeo
|
||
|
raw := noMethod(*s)
|
||
|
return internal.MarshalJSON(raw, s.ForceSendFields)
|
||
|
}
|
||
|
|
||
|
type GeolayerdataGeoBoundaryItem struct {
|
||
|
Latitude int64 `json:"latitude,omitempty"`
|
||
|
|
||
|
Longitude int64 `json:"longitude,omitempty"`
|
||
|
|
||
|
// ForceSendFields is a list of field names (e.g. "Latitude") 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:"-"`
|
||
|
}
|
||
|
|
||
|
func (s *GeolayerdataGeoBoundaryItem) MarshalJSON() ([]byte, error) {
|
||
|
type noMethod GeolayerdataGeoBoundaryItem
|
||
|
raw := noMethod(*s)
|
||
|
return internal.MarshalJSON(raw, s.ForceSendFields)
|
||
|
}
|
||
|
|
||
|
// GeolayerdataGeoViewport: The viewport for showing this location. This
|
||
|
// is a latitude, longitude rectangle.
|
||
|
type GeolayerdataGeoViewport struct {
|
||
|
Hi *GeolayerdataGeoViewportHi `json:"hi,omitempty"`
|
||
|
|
||
|
Lo *GeolayerdataGeoViewportLo `json:"lo,omitempty"`
|
||
|
|
||
|
// ForceSendFields is a list of field names (e.g. "Hi") 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:"-"`
|
||
|
}
|
||
|
|
||
|
func (s *GeolayerdataGeoViewport) MarshalJSON() ([]byte, error) {
|
||
|
type noMethod GeolayerdataGeoViewport
|
||
|
raw := noMethod(*s)
|
||
|
return internal.MarshalJSON(raw, s.ForceSendFields)
|
||
|
}
|
||
|
|
||
|
type GeolayerdataGeoViewportHi struct {
|
||
|
Latitude float64 `json:"latitude,omitempty"`
|
||
|
|
||
|
Longitude float64 `json:"longitude,omitempty"`
|
||
|
|
||
|
// ForceSendFields is a list of field names (e.g. "Latitude") 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:"-"`
|
||
|
}
|
||
|
|
||
|
func (s *GeolayerdataGeoViewportHi) MarshalJSON() ([]byte, error) {
|
||
|
type noMethod GeolayerdataGeoViewportHi
|
||
|
raw := noMethod(*s)
|
||
|
return internal.MarshalJSON(raw, s.ForceSendFields)
|
||
|
}
|
||
|
|
||
|
type GeolayerdataGeoViewportLo struct {
|
||
|
Latitude float64 `json:"latitude,omitempty"`
|
||
|
|
||
|
Longitude float64 `json:"longitude,omitempty"`
|
||
|
|
||
|
// ForceSendFields is a list of field names (e.g. "Latitude") 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:"-"`
|
||
|
}
|
||
|
|
||
|
func (s *GeolayerdataGeoViewportLo) MarshalJSON() ([]byte, error) {
|
||
|
type noMethod GeolayerdataGeoViewportLo
|
||
|
raw := noMethod(*s)
|
||
|
return internal.MarshalJSON(raw, s.ForceSendFields)
|
||
|
}
|
||
|
|
||
|
type Layersummaries struct {
|
||
|
// Items: A list of layer summary items.
|
||
|
Items []*Layersummary `json:"items,omitempty"`
|
||
|
|
||
|
// Kind: Resource type.
|
||
|
Kind string `json:"kind,omitempty"`
|
||
|
|
||
|
// TotalItems: The total number of layer summaries found.
|
||
|
TotalItems int64 `json:"totalItems,omitempty"`
|
||
|
|
||
|
// ServerResponse contains the HTTP response code and headers from the
|
||
|
// server.
|
||
|
googleapi.ServerResponse `json:"-"`
|
||
|
|
||
|
// ForceSendFields is a list of field names (e.g. "Items") 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:"-"`
|
||
|
}
|
||
|
|
||
|
func (s *Layersummaries) MarshalJSON() ([]byte, error) {
|
||
|
type noMethod Layersummaries
|
||
|
raw := noMethod(*s)
|
||
|
return internal.MarshalJSON(raw, s.ForceSendFields)
|
||
|
}
|
||
|
|
||
|
type Layersummary struct {
|
||
|
// AnnotationCount: The number of annotations for this layer.
|
||
|
AnnotationCount int64 `json:"annotationCount,omitempty"`
|
||
|
|
||
|
// AnnotationTypes: The list of annotation types contained for this
|
||
|
// layer.
|
||
|
AnnotationTypes []string `json:"annotationTypes,omitempty"`
|
||
|
|
||
|
// AnnotationsDataLink: Link to get data for this annotation.
|
||
|
AnnotationsDataLink string `json:"annotationsDataLink,omitempty"`
|
||
|
|
||
|
// AnnotationsLink: The link to get the annotations for this layer.
|
||
|
AnnotationsLink string `json:"annotationsLink,omitempty"`
|
||
|
|
||
|
// ContentVersion: The content version this resource is for.
|
||
|
ContentVersion string `json:"contentVersion,omitempty"`
|
||
|
|
||
|
// DataCount: The number of data items for this layer.
|
||
|
DataCount int64 `json:"dataCount,omitempty"`
|
||
|
|
||
|
// Id: Unique id of this layer summary.
|
||
|
Id string `json:"id,omitempty"`
|
||
|
|
||
|
// Kind: Resource Type
|
||
|
Kind string `json:"kind,omitempty"`
|
||
|
|
||
|
// LayerId: The layer id for this summary.
|
||
|
LayerId string `json:"layerId,omitempty"`
|
||
|
|
||
|
// SelfLink: URL to this resource.
|
||
|
SelfLink string `json:"selfLink,omitempty"`
|
||
|
|
||
|
// Updated: Timestamp for the last time an item in this layer was
|
||
|
// updated. (RFC 3339 UTC date-time format).
|
||
|
Updated string `json:"updated,omitempty"`
|
||
|
|
||
|
// VolumeAnnotationsVersion: The current version of this layer's volume
|
||
|
// annotations. Note that this version applies only to the data in the
|
||
|
// books.layers.volumeAnnotations.* responses. The actual annotation
|
||
|
// data is versioned separately.
|
||
|
VolumeAnnotationsVersion string `json:"volumeAnnotationsVersion,omitempty"`
|
||
|
|
||
|
// VolumeId: The volume id this resource is for.
|
||
|
VolumeId string `json:"volumeId,omitempty"`
|
||
|
|
||
|
// ServerResponse contains the HTTP response code and headers from the
|
||
|
// server.
|
||
|
googleapi.ServerResponse `json:"-"`
|
||
|
|
||
|
// ForceSendFields is a list of field names (e.g. "AnnotationCount") 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:"-"`
|
||
|
}
|
||
|
|
||
|
func (s *Layersummary) MarshalJSON() ([]byte, error) {
|
||
|
type noMethod Layersummary
|
||
|
raw := noMethod(*s)
|
||
|
return internal.MarshalJSON(raw, s.ForceSendFields)
|
||
|
}
|
||
|
|
||
|
type Metadata struct {
|
||
|
// Items: A list of offline dictionary metadata.
|
||
|
Items []*MetadataItems `json:"items,omitempty"`
|
||
|
|
||
|
// Kind: Resource type.
|
||
|
Kind string `json:"kind,omitempty"`
|
||
|
|
||
|
// ServerResponse contains the HTTP response code and headers from the
|
||
|
// server.
|
||
|
googleapi.ServerResponse `json:"-"`
|
||
|
|
||
|
// ForceSendFields is a list of field names (e.g. "Items") 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:"-"`
|
||
|
}
|
||
|
|
||
|
func (s *Metadata) MarshalJSON() ([]byte, error) {
|
||
|
type noMethod Metadata
|
||
|
raw := noMethod(*s)
|
||
|
return internal.MarshalJSON(raw, s.ForceSendFields)
|
||
|
}
|
||
|
|
||
|
type MetadataItems struct {
|
||
|
DownloadUrl string `json:"download_url,omitempty"`
|
||
|
|
||
|
EncryptedKey string `json:"encrypted_key,omitempty"`
|
||
|
|
||
|
Language string `json:"language,omitempty"`
|
||
|
|
||
|
Size int64 `json:"size,omitempty,string"`
|
||
|
|
||
|
Version int64 `json:"version,omitempty,string"`
|
||
|
|
||
|
// ForceSendFields is a list of field names (e.g. "DownloadUrl") 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:"-"`
|
||
|
}
|
||
|
|
||
|
func (s *MetadataItems) MarshalJSON() ([]byte, error) {
|
||
|
type noMethod MetadataItems
|
||
|
raw := noMethod(*s)
|
||
|
return internal.MarshalJSON(raw, s.ForceSendFields)
|
||
|
}
|
||
|
|
||
|
type Notification struct {
|
||
|
Body string `json:"body,omitempty"`
|
||
|
|
||
|
IconUrl string `json:"iconUrl,omitempty"`
|
||
|
|
||
|
// Kind: Resource type.
|
||
|
Kind string `json:"kind,omitempty"`
|
||
|
|
||
|
LinkUrl string `json:"linkUrl,omitempty"`
|
||
|
|
||
|
Title string `json:"title,omitempty"`
|
||
|
|
||
|
// ServerResponse contains the HTTP response code and headers from the
|
||
|
// server.
|
||
|
googleapi.ServerResponse `json:"-"`
|
||
|
|
||
|
// ForceSendFields is a list of field names (e.g. "Body") 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:"-"`
|
||
|
}
|
||
|
|
||
|
func (s *Notification) MarshalJSON() ([]byte, error) {
|
||
|
type noMethod Notification
|
||
|
raw := noMethod(*s)
|
||
|
return internal.MarshalJSON(raw, s.ForceSendFields)
|
||
|
}
|
||
|
|
||
|
type Offers struct {
|
||
|
// Items: A list of offers.
|
||
|
Items []*OffersItems `json:"items,omitempty"`
|
||
|
|
||
|
// Kind: Resource type.
|
||
|
Kind string `json:"kind,omitempty"`
|
||
|
|
||
|
// ServerResponse contains the HTTP response code and headers from the
|
||
|
// server.
|
||
|
googleapi.ServerResponse `json:"-"`
|
||
|
|
||
|
// ForceSendFields is a list of field names (e.g. "Items") 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:"-"`
|
||
|
}
|
||
|
|
||
|
func (s *Offers) MarshalJSON() ([]byte, error) {
|
||
|
type noMethod Offers
|
||
|
raw := noMethod(*s)
|
||
|
return internal.MarshalJSON(raw, s.ForceSendFields)
|
||
|
}
|
||
|
|
||
|
type OffersItems struct {
|
||
|
ArtUrl string `json:"artUrl,omitempty"`
|
||
|
|
||
|
GservicesKey string `json:"gservicesKey,omitempty"`
|
||
|
|
||
|
Id string `json:"id,omitempty"`
|
||
|
|
||
|
Items []*OffersItemsItems `json:"items,omitempty"`
|
||
|
|
||
|
// ForceSendFields is a list of field names (e.g. "ArtUrl") 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:"-"`
|
||
|
}
|
||
|
|
||
|
func (s *OffersItems) MarshalJSON() ([]byte, error) {
|
||
|
type noMethod OffersItems
|
||
|
raw := noMethod(*s)
|
||
|
return internal.MarshalJSON(raw, s.ForceSendFields)
|
||
|
}
|
||
|
|
||
|
type OffersItemsItems struct {
|
||
|
Author string `json:"author,omitempty"`
|
||
|
|
||
|
CanonicalVolumeLink string `json:"canonicalVolumeLink,omitempty"`
|
||
|
|
||
|
CoverUrl string `json:"coverUrl,omitempty"`
|
||
|
|
||
|
Description string `json:"description,omitempty"`
|
||
|
|
||
|
Title string `json:"title,omitempty"`
|
||
|
|
||
|
VolumeId string `json:"volumeId,omitempty"`
|
||
|
|
||
|
// ForceSendFields is a list of field names (e.g. "Author") 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:"-"`
|
||
|
}
|
||
|
|
||
|
func (s *OffersItemsItems) MarshalJSON() ([]byte, error) {
|
||
|
type noMethod OffersItemsItems
|
||
|
raw := noMethod(*s)
|
||
|
return internal.MarshalJSON(raw, s.ForceSendFields)
|
||
|
}
|
||
|
|
||
|
type ReadingPosition struct {
|
||
|
// EpubCfiPosition: Position in an EPUB as a CFI.
|
||
|
EpubCfiPosition string `json:"epubCfiPosition,omitempty"`
|
||
|
|
||
|
// GbImagePosition: Position in a volume for image-based content.
|
||
|
GbImagePosition string `json:"gbImagePosition,omitempty"`
|
||
|
|
||
|
// GbTextPosition: Position in a volume for text-based content.
|
||
|
GbTextPosition string `json:"gbTextPosition,omitempty"`
|
||
|
|
||
|
// Kind: Resource type for a reading position.
|
||
|
Kind string `json:"kind,omitempty"`
|
||
|
|
||
|
// PdfPosition: Position in a PDF file.
|
||
|
PdfPosition string `json:"pdfPosition,omitempty"`
|
||
|
|
||
|
// Updated: Timestamp when this reading position was last updated
|
||
|
// (formatted UTC timestamp with millisecond resolution).
|
||
|
Updated string `json:"updated,omitempty"`
|
||
|
|
||
|
// VolumeId: Volume id associated with this reading position.
|
||
|
VolumeId string `json:"volumeId,omitempty"`
|
||
|
|
||
|
// ServerResponse contains the HTTP response code and headers from the
|
||
|
// server.
|
||
|
googleapi.ServerResponse `json:"-"`
|
||
|
|
||
|
// ForceSendFields is a list of field names (e.g. "EpubCfiPosition") 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:"-"`
|
||
|
}
|
||
|
|
||
|
func (s *ReadingPosition) MarshalJSON() ([]byte, error) {
|
||
|
type noMethod ReadingPosition
|
||
|
raw := noMethod(*s)
|
||
|
return internal.MarshalJSON(raw, s.ForceSendFields)
|
||
|
}
|
||
|
|
||
|
type RequestAccess struct {
|
||
|
// ConcurrentAccess: A concurrent access response.
|
||
|
ConcurrentAccess *ConcurrentAccessRestriction `json:"concurrentAccess,omitempty"`
|
||
|
|
||
|
// DownloadAccess: A download access response.
|
||
|
DownloadAccess *DownloadAccessRestriction `json:"downloadAccess,omitempty"`
|
||
|
|
||
|
// Kind: Resource type.
|
||
|
Kind string `json:"kind,omitempty"`
|
||
|
|
||
|
// ServerResponse contains the HTTP response code and headers from the
|
||
|
// server.
|
||
|
googleapi.ServerResponse `json:"-"`
|
||
|
|
||
|
// ForceSendFields is a list of field names (e.g. "ConcurrentAccess") 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:"-"`
|
||
|
}
|
||
|
|
||
|
func (s *RequestAccess) MarshalJSON() ([]byte, error) {
|
||
|
type noMethod RequestAccess
|
||
|
raw := noMethod(*s)
|
||
|
return internal.MarshalJSON(raw, s.ForceSendFields)
|
||
|
}
|
||
|
|
||
|
type Review struct {
|
||
|
// Author: Author of this review.
|
||
|
Author *ReviewAuthor `json:"author,omitempty"`
|
||
|
|
||
|
// Content: Review text.
|
||
|
Content string `json:"content,omitempty"`
|
||
|
|
||
|
// Date: Date of this review.
|
||
|
Date string `json:"date,omitempty"`
|
||
|
|
||
|
// FullTextUrl: URL for the full review text, for reviews gathered from
|
||
|
// the web.
|
||
|
FullTextUrl string `json:"fullTextUrl,omitempty"`
|
||
|
|
||
|
// Kind: Resource type for a review.
|
||
|
Kind string `json:"kind,omitempty"`
|
||
|
|
||
|
// Rating: Star rating for this review. Possible values are ONE, TWO,
|
||
|
// THREE, FOUR, FIVE or NOT_RATED.
|
||
|
Rating string `json:"rating,omitempty"`
|
||
|
|
||
|
// Source: Information regarding the source of this review, when the
|
||
|
// review is not from a Google Books user.
|
||
|
Source *ReviewSource `json:"source,omitempty"`
|
||
|
|
||
|
// Title: Title for this review.
|
||
|
Title string `json:"title,omitempty"`
|
||
|
|
||
|
// Type: Source type for this review. Possible values are EDITORIAL,
|
||
|
// WEB_USER or GOOGLE_USER.
|
||
|
Type string `json:"type,omitempty"`
|
||
|
|
||
|
// VolumeId: Volume that this review is for.
|
||
|
VolumeId string `json:"volumeId,omitempty"`
|
||
|
|
||
|
// ForceSendFields is a list of field names (e.g. "Author") 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:"-"`
|
||
|
}
|
||
|
|
||
|
func (s *Review) MarshalJSON() ([]byte, error) {
|
||
|
type noMethod Review
|
||
|
raw := noMethod(*s)
|
||
|
return internal.MarshalJSON(raw, s.ForceSendFields)
|
||
|
}
|
||
|
|
||
|
// ReviewAuthor: Author of this review.
|
||
|
type ReviewAuthor struct {
|
||
|
// DisplayName: Name of this person.
|
||
|
DisplayName string `json:"displayName,omitempty"`
|
||
|
|
||
|
// ForceSendFields is a list of field names (e.g. "DisplayName") 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:"-"`
|
||
|
}
|
||
|
|
||
|
func (s *ReviewAuthor) MarshalJSON() ([]byte, error) {
|
||
|
type noMethod ReviewAuthor
|
||
|
raw := noMethod(*s)
|
||
|
return internal.MarshalJSON(raw, s.ForceSendFields)
|
||
|
}
|
||
|
|
||
|
// ReviewSource: Information regarding the source of this review, when
|
||
|
// the review is not from a Google Books user.
|
||
|
type ReviewSource struct {
|
||
|
// Description: Name of the source.
|
||
|
Description string `json:"description,omitempty"`
|
||
|
|
||
|
// ExtraDescription: Extra text about the source of the review.
|
||
|
ExtraDescription string `json:"extraDescription,omitempty"`
|
||
|
|
||
|
// Url: URL of the source of the review.
|
||
|
Url string `json:"url,omitempty"`
|
||
|
|
||
|
// ForceSendFields is a list of field names (e.g. "Description") 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:"-"`
|
||
|
}
|
||
|
|
||
|
func (s *ReviewSource) MarshalJSON() ([]byte, error) {
|
||
|
type noMethod ReviewSource
|
||
|
raw := noMethod(*s)
|
||
|
return internal.MarshalJSON(raw, s.ForceSendFields)
|
||
|
}
|
||
|
|
||
|
type Usersettings struct {
|
||
|
// Kind: Resource type.
|
||
|
Kind string `json:"kind,omitempty"`
|
||
|
|
||
|
// NotesExport: User settings in sub-objects, each for different
|
||
|
// purposes.
|
||
|
NotesExport *UsersettingsNotesExport `json:"notesExport,omitempty"`
|
||
|
|
||
|
Notification *UsersettingsNotification `json:"notification,omitempty"`
|
||
|
|
||
|
// ServerResponse contains the HTTP response code and headers from the
|
||
|
// server.
|
||
|
googleapi.ServerResponse `json:"-"`
|
||
|
|
||
|
// ForceSendFields is a list of field names (e.g. "Kind") 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:"-"`
|
||
|
}
|
||
|
|
||
|
func (s *Usersettings) MarshalJSON() ([]byte, error) {
|
||
|
type noMethod Usersettings
|
||
|
raw := noMethod(*s)
|
||
|
return internal.MarshalJSON(raw, s.ForceSendFields)
|
||
|
}
|
||
|
|
||
|
// UsersettingsNotesExport: User settings in sub-objects, each for
|
||
|
// different purposes.
|
||
|
type UsersettingsNotesExport struct {
|
||
|
FolderName string `json:"folderName,omitempty"`
|
||
|
|
||
|
IsEnabled bool `json:"isEnabled,omitempty"`
|
||
|
|
||
|
// ForceSendFields is a list of field names (e.g. "FolderName") 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:"-"`
|
||
|
}
|
||
|
|
||
|
func (s *UsersettingsNotesExport) MarshalJSON() ([]byte, error) {
|
||
|
type noMethod UsersettingsNotesExport
|
||
|
raw := noMethod(*s)
|
||
|
return internal.MarshalJSON(raw, s.ForceSendFields)
|
||
|
}
|
||
|
|
||
|
type UsersettingsNotification struct {
|
||
|
MoreFromAuthors *UsersettingsNotificationMoreFromAuthors `json:"moreFromAuthors,omitempty"`
|
||
|
|
||
|
// ForceSendFields is a list of field names (e.g. "MoreFromAuthors") 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:"-"`
|
||
|
}
|
||
|
|
||
|
func (s *UsersettingsNotification) MarshalJSON() ([]byte, error) {
|
||
|
type noMethod UsersettingsNotification
|
||
|
raw := noMethod(*s)
|
||
|
return internal.MarshalJSON(raw, s.ForceSendFields)
|
||
|
}
|
||
|
|
||
|
type UsersettingsNotificationMoreFromAuthors struct {
|
||
|
OptedState string `json:"opted_state,omitempty"`
|
||
|
|
||
|
// ForceSendFields is a list of field names (e.g. "OptedState") 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:"-"`
|
||
|
}
|
||
|
|
||
|
func (s *UsersettingsNotificationMoreFromAuthors) MarshalJSON() ([]byte, error) {
|
||
|
type noMethod UsersettingsNotificationMoreFromAuthors
|
||
|
raw := noMethod(*s)
|
||
|
return internal.MarshalJSON(raw, s.ForceSendFields)
|
||
|
}
|
||
|
|
||
|
type Volume struct {
|
||
|
// AccessInfo: Any information about a volume related to reading or
|
||
|
// obtaining that volume text. This information can depend on country
|
||
|
// (books may be public domain in one country but not in another, e.g.).
|
||
|
AccessInfo *VolumeAccessInfo `json:"accessInfo,omitempty"`
|
||
|
|
||
|
// Etag: Opaque identifier for a specific version of a volume resource.
|
||
|
// (In LITE projection)
|
||
|
Etag string `json:"etag,omitempty"`
|
||
|
|
||
|
// Id: Unique identifier for a volume. (In LITE projection.)
|
||
|
Id string `json:"id,omitempty"`
|
||
|
|
||
|
// Kind: Resource type for a volume. (In LITE projection.)
|
||
|
Kind string `json:"kind,omitempty"`
|
||
|
|
||
|
// LayerInfo: What layers exist in this volume and high level
|
||
|
// information about them.
|
||
|
LayerInfo *VolumeLayerInfo `json:"layerInfo,omitempty"`
|
||
|
|
||
|
// RecommendedInfo: Recommendation related information for this volume.
|
||
|
RecommendedInfo *VolumeRecommendedInfo `json:"recommendedInfo,omitempty"`
|
||
|
|
||
|
// SaleInfo: Any information about a volume related to the eBookstore
|
||
|
// and/or purchaseability. This information can depend on the country
|
||
|
// where the request originates from (i.e. books may not be for sale in
|
||
|
// certain countries).
|
||
|
SaleInfo *VolumeSaleInfo `json:"saleInfo,omitempty"`
|
||
|
|
||
|
// SearchInfo: Search result information related to this volume.
|
||
|
SearchInfo *VolumeSearchInfo `json:"searchInfo,omitempty"`
|
||
|
|
||
|
// SelfLink: URL to this resource. (In LITE projection.)
|
||
|
SelfLink string `json:"selfLink,omitempty"`
|
||
|
|
||
|
// UserInfo: User specific information related to this volume. (e.g.
|
||
|
// page this user last read or whether they purchased this book)
|
||
|
UserInfo *VolumeUserInfo `json:"userInfo,omitempty"`
|
||
|
|
||
|
// VolumeInfo: General volume information.
|
||
|
VolumeInfo *VolumeVolumeInfo `json:"volumeInfo,omitempty"`
|
||
|
|
||
|
// ServerResponse contains the HTTP response code and headers from the
|
||
|
// server.
|
||
|
googleapi.ServerResponse `json:"-"`
|
||
|
|
||
|
// ForceSendFields is a list of field names (e.g. "AccessInfo") 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:"-"`
|
||
|
}
|
||
|
|
||
|
func (s *Volume) MarshalJSON() ([]byte, error) {
|
||
|
type noMethod Volume
|
||
|
raw := noMethod(*s)
|
||
|
return internal.MarshalJSON(raw, s.ForceSendFields)
|
||
|
}
|
||
|
|
||
|
// VolumeAccessInfo: Any information about a volume related to reading
|
||
|
// or obtaining that volume text. This information can depend on country
|
||
|
// (books may be public domain in one country but not in another, e.g.).
|
||
|
type VolumeAccessInfo struct {
|
||
|
// AccessViewStatus: Combines the access and viewability of this volume
|
||
|
// into a single status field for this user. Values can be
|
||
|
// FULL_PURCHASED, FULL_PUBLIC_DOMAIN, SAMPLE or NONE. (In LITE
|
||
|
// projection.)
|
||
|
AccessViewStatus string `json:"accessViewStatus,omitempty"`
|
||
|
|
||
|
// Country: The two-letter ISO_3166-1 country code for which this access
|
||
|
// information is valid. (In LITE projection.)
|
||
|
Country string `json:"country,omitempty"`
|
||
|
|
||
|
// DownloadAccess: Information about a volume's download license access
|
||
|
// restrictions.
|
||
|
DownloadAccess *DownloadAccessRestriction `json:"downloadAccess,omitempty"`
|
||
|
|
||
|
// DriveImportedContentLink: URL to the Google Drive viewer if this
|
||
|
// volume is uploaded by the user by selecting the file from Google
|
||
|
// Drive.
|
||
|
DriveImportedContentLink string `json:"driveImportedContentLink,omitempty"`
|
||
|
|
||
|
// Embeddable: Whether this volume can be embedded in a viewport using
|
||
|
// the Embedded Viewer API.
|
||
|
Embeddable bool `json:"embeddable,omitempty"`
|
||
|
|
||
|
// Epub: Information about epub content. (In LITE projection.)
|
||
|
Epub *VolumeAccessInfoEpub `json:"epub,omitempty"`
|
||
|
|
||
|
// ExplicitOfflineLicenseManagement: Whether this volume requires that
|
||
|
// the client explicitly request offline download license rather than
|
||
|
// have it done automatically when loading the content, if the client
|
||
|
// supports it.
|
||
|
ExplicitOfflineLicenseManagement bool `json:"explicitOfflineLicenseManagement,omitempty"`
|
||
|
|
||
|
// Pdf: Information about pdf content. (In LITE projection.)
|
||
|
Pdf *VolumeAccessInfoPdf `json:"pdf,omitempty"`
|
||
|
|
||
|
// PublicDomain: Whether or not this book is public domain in the
|
||
|
// country listed above.
|
||
|
PublicDomain bool `json:"publicDomain,omitempty"`
|
||
|
|
||
|
// QuoteSharingAllowed: Whether quote sharing is allowed for this
|
||
|
// volume.
|
||
|
QuoteSharingAllowed bool `json:"quoteSharingAllowed,omitempty"`
|
||
|
|
||
|
// TextToSpeechPermission: Whether text-to-speech is permitted for this
|
||
|
// volume. Values can be ALLOWED, ALLOWED_FOR_ACCESSIBILITY, or
|
||
|
// NOT_ALLOWED.
|
||
|
TextToSpeechPermission string `json:"textToSpeechPermission,omitempty"`
|
||
|
|
||
|
// ViewOrderUrl: For ordered but not yet processed orders, we give a URL
|
||
|
// that can be used to go to the appropriate Google Wallet page.
|
||
|
ViewOrderUrl string `json:"viewOrderUrl,omitempty"`
|
||
|
|
||
|
// Viewability: The read access of a volume. Possible values are
|
||
|
// PARTIAL, ALL_PAGES, NO_PAGES or UNKNOWN. This value depends on the
|
||
|
// country listed above. A value of PARTIAL means that the publisher has
|
||
|
// allowed some portion of the volume to be viewed publicly, without
|
||
|
// purchase. This can apply to eBooks as well as non-eBooks. Public
|
||
|
// domain books will always have a value of ALL_PAGES.
|
||
|
Viewability string `json:"viewability,omitempty"`
|
||
|
|
||
|
// WebReaderLink: URL to read this volume on the Google Books site. Link
|
||
|
// will not allow users to read non-viewable volumes.
|
||
|
WebReaderLink string `json:"webReaderLink,omitempty"`
|
||
|
|
||
|
// ForceSendFields is a list of field names (e.g. "AccessViewStatus") 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:"-"`
|
||
|
}
|
||
|
|
||
|
func (s *VolumeAccessInfo) MarshalJSON() ([]byte, error) {
|
||
|
type noMethod VolumeAccessInfo
|
||
|
raw := noMethod(*s)
|
||
|
return internal.MarshalJSON(raw, s.ForceSendFields)
|
||
|
}
|
||
|
|
||
|
// VolumeAccessInfoEpub: Information about epub content. (In LITE
|
||
|
// projection.)
|
||
|
type VolumeAccessInfoEpub struct {
|
||
|
// AcsTokenLink: URL to retrieve ACS token for epub download. (In LITE
|
||
|
// projection.)
|
||
|
AcsTokenLink string `json:"acsTokenLink,omitempty"`
|
||
|
|
||
|
// DownloadLink: URL to download epub. (In LITE projection.)
|
||
|
DownloadLink string `json:"downloadLink,omitempty"`
|
||
|
|
||
|
// IsAvailable: Is a flowing text epub available either as public domain
|
||
|
// or for purchase. (In LITE projection.)
|
||
|
IsAvailable bool `json:"isAvailable,omitempty"`
|
||
|
|
||
|
// ForceSendFields is a list of field names (e.g. "AcsTokenLink") 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:"-"`
|
||
|
}
|
||
|
|
||
|
func (s *VolumeAccessInfoEpub) MarshalJSON() ([]byte, error) {
|
||
|
type noMethod VolumeAccessInfoEpub
|
||
|
raw := noMethod(*s)
|
||
|
return internal.MarshalJSON(raw, s.ForceSendFields)
|
||
|
}
|
||
|
|
||
|
// VolumeAccessInfoPdf: Information about pdf content. (In LITE
|
||
|
// projection.)
|
||
|
type VolumeAccessInfoPdf struct {
|
||
|
// AcsTokenLink: URL to retrieve ACS token for pdf download. (In LITE
|
||
|
// projection.)
|
||
|
AcsTokenLink string `json:"acsTokenLink,omitempty"`
|
||
|
|
||
|
// DownloadLink: URL to download pdf. (In LITE projection.)
|
||
|
DownloadLink string `json:"downloadLink,omitempty"`
|
||
|
|
||
|
// IsAvailable: Is a scanned image pdf available either as public domain
|
||
|
// or for purchase. (In LITE projection.)
|
||
|
IsAvailable bool `json:"isAvailable,omitempty"`
|
||
|
|
||
|
// ForceSendFields is a list of field names (e.g. "AcsTokenLink") 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:"-"`
|
||
|
}
|
||
|
|
||
|
func (s *VolumeAccessInfoPdf) MarshalJSON() ([]byte, error) {
|
||
|
type noMethod VolumeAccessInfoPdf
|
||
|
raw := noMethod(*s)
|
||
|
return internal.MarshalJSON(raw, s.ForceSendFields)
|
||
|
}
|
||
|
|
||
|
// VolumeLayerInfo: What layers exist in this volume and high level
|
||
|
// information about them.
|
||
|
type VolumeLayerInfo struct {
|
||
|
// Layers: A layer should appear here if and only if the layer exists
|
||
|
// for this book.
|
||
|
Layers []*VolumeLayerInfoLayers `json:"layers,omitempty"`
|
||
|
|
||
|
// ForceSendFields is a list of field names (e.g. "Layers") 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:"-"`
|
||
|
}
|
||
|
|
||
|
func (s *VolumeLayerInfo) MarshalJSON() ([]byte, error) {
|
||
|
type noMethod VolumeLayerInfo
|
||
|
raw := noMethod(*s)
|
||
|
return internal.MarshalJSON(raw, s.ForceSendFields)
|
||
|
}
|
||
|
|
||
|
type VolumeLayerInfoLayers struct {
|
||
|
// LayerId: The layer id of this layer (e.g. "geo").
|
||
|
LayerId string `json:"layerId,omitempty"`
|
||
|
|
||
|
// VolumeAnnotationsVersion: The current version of this layer's volume
|
||
|
// annotations. Note that this version applies only to the data in the
|
||
|
// books.layers.volumeAnnotations.* responses. The actual annotation
|
||
|
// data is versioned separately.
|
||
|
VolumeAnnotationsVersion string `json:"volumeAnnotationsVersion,omitempty"`
|
||
|
|
||
|
// ForceSendFields is a list of field names (e.g. "LayerId") 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:"-"`
|
||
|
}
|
||
|
|
||
|
func (s *VolumeLayerInfoLayers) MarshalJSON() ([]byte, error) {
|
||
|
type noMethod VolumeLayerInfoLayers
|
||
|
raw := noMethod(*s)
|
||
|
return internal.MarshalJSON(raw, s.ForceSendFields)
|
||
|
}
|
||
|
|
||
|
// VolumeRecommendedInfo: Recommendation related information for this
|
||
|
// volume.
|
||
|
type VolumeRecommendedInfo struct {
|
||
|
// Explanation: A text explaining why this volume is recommended.
|
||
|
Explanation string `json:"explanation,omitempty"`
|
||
|
|
||
|
// ForceSendFields is a list of field names (e.g. "Explanation") 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:"-"`
|
||
|
}
|
||
|
|
||
|
func (s *VolumeRecommendedInfo) MarshalJSON() ([]byte, error) {
|
||
|
type noMethod VolumeRecommendedInfo
|
||
|
raw := noMethod(*s)
|
||
|
return internal.MarshalJSON(raw, s.ForceSendFields)
|
||
|
}
|
||
|
|
||
|
// VolumeSaleInfo: Any information about a volume related to the
|
||
|
// eBookstore and/or purchaseability. This information can depend on the
|
||
|
// country where the request originates from (i.e. books may not be for
|
||
|
// sale in certain countries).
|
||
|
type VolumeSaleInfo struct {
|
||
|
// BuyLink: URL to purchase this volume on the Google Books site. (In
|
||
|
// LITE projection)
|
||
|
BuyLink string `json:"buyLink,omitempty"`
|
||
|
|
||
|
// Country: The two-letter ISO_3166-1 country code for which this sale
|
||
|
// information is valid. (In LITE projection.)
|
||
|
Country string `json:"country,omitempty"`
|
||
|
|
||
|
// IsEbook: Whether or not this volume is an eBook (can be added to the
|
||
|
// My eBooks shelf).
|
||
|
IsEbook bool `json:"isEbook,omitempty"`
|
||
|
|
||
|
// ListPrice: Suggested retail price. (In LITE projection.)
|
||
|
ListPrice *VolumeSaleInfoListPrice `json:"listPrice,omitempty"`
|
||
|
|
||
|
// Offers: Offers available for this volume (sales and rentals).
|
||
|
Offers []*VolumeSaleInfoOffers `json:"offers,omitempty"`
|
||
|
|
||
|
// OnSaleDate: The date on which this book is available for sale.
|
||
|
OnSaleDate string `json:"onSaleDate,omitempty"`
|
||
|
|
||
|
// RetailPrice: The actual selling price of the book. This is the same
|
||
|
// as the suggested retail or list price unless there are offers or
|
||
|
// discounts on this volume. (In LITE projection.)
|
||
|
RetailPrice *VolumeSaleInfoRetailPrice `json:"retailPrice,omitempty"`
|
||
|
|
||
|
// Saleability: Whether or not this book is available for sale or
|
||
|
// offered for free in the Google eBookstore for the country listed
|
||
|
// above. Possible values are FOR_SALE, FOR_RENTAL_ONLY,
|
||
|
// FOR_SALE_AND_RENTAL, FREE, NOT_FOR_SALE, or FOR_PREORDER.
|
||
|
Saleability string `json:"saleability,omitempty"`
|
||
|
|
||
|
// ForceSendFields is a list of field names (e.g. "BuyLink") 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:"-"`
|
||
|
}
|
||
|
|
||
|
func (s *VolumeSaleInfo) MarshalJSON() ([]byte, error) {
|
||
|
type noMethod VolumeSaleInfo
|
||
|
raw := noMethod(*s)
|
||
|
return internal.MarshalJSON(raw, s.ForceSendFields)
|
||
|
}
|
||
|
|
||
|
// VolumeSaleInfoListPrice: Suggested retail price. (In LITE
|
||
|
// projection.)
|
||
|
type VolumeSaleInfoListPrice struct {
|
||
|
// Amount: Amount in the currency listed below. (In LITE projection.)
|
||
|
Amount float64 `json:"amount,omitempty"`
|
||
|
|
||
|
// CurrencyCode: An ISO 4217, three-letter currency code. (In LITE
|
||
|
// projection.)
|
||
|
CurrencyCode string `json:"currencyCode,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:"-"`
|
||
|
}
|
||
|
|
||
|
func (s *VolumeSaleInfoListPrice) MarshalJSON() ([]byte, error) {
|
||
|
type noMethod VolumeSaleInfoListPrice
|
||
|
raw := noMethod(*s)
|
||
|
return internal.MarshalJSON(raw, s.ForceSendFields)
|
||
|
}
|
||
|
|
||
|
type VolumeSaleInfoOffers struct {
|
||
|
// FinskyOfferType: The finsky offer type (e.g., PURCHASE=0 RENTAL=3)
|
||
|
FinskyOfferType int64 `json:"finskyOfferType,omitempty"`
|
||
|
|
||
|
// ListPrice: Offer list (=undiscounted) price in Micros.
|
||
|
ListPrice *VolumeSaleInfoOffersListPrice `json:"listPrice,omitempty"`
|
||
|
|
||
|
// RentalDuration: The rental duration (for rental offers only).
|
||
|
RentalDuration *VolumeSaleInfoOffersRentalDuration `json:"rentalDuration,omitempty"`
|
||
|
|
||
|
// RetailPrice: Offer retail (=discounted) price in Micros
|
||
|
RetailPrice *VolumeSaleInfoOffersRetailPrice `json:"retailPrice,omitempty"`
|
||
|
|
||
|
// ForceSendFields is a list of field names (e.g. "FinskyOfferType") 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:"-"`
|
||
|
}
|
||
|
|
||
|
func (s *VolumeSaleInfoOffers) MarshalJSON() ([]byte, error) {
|
||
|
type noMethod VolumeSaleInfoOffers
|
||
|
raw := noMethod(*s)
|
||
|
return internal.MarshalJSON(raw, s.ForceSendFields)
|
||
|
}
|
||
|
|
||
|
// VolumeSaleInfoOffersListPrice: Offer list (=undiscounted) price in
|
||
|
// Micros.
|
||
|
type VolumeSaleInfoOffersListPrice struct {
|
||
|
AmountInMicros float64 `json:"amountInMicros,omitempty"`
|
||
|
|
||
|
CurrencyCode string `json:"currencyCode,omitempty"`
|
||
|
|
||
|
// ForceSendFields is a list of field names (e.g. "AmountInMicros") 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:"-"`
|
||
|
}
|
||
|
|
||
|
func (s *VolumeSaleInfoOffersListPrice) MarshalJSON() ([]byte, error) {
|
||
|
type noMethod VolumeSaleInfoOffersListPrice
|
||
|
raw := noMethod(*s)
|
||
|
return internal.MarshalJSON(raw, s.ForceSendFields)
|
||
|
}
|
||
|
|
||
|
// VolumeSaleInfoOffersRentalDuration: The rental duration (for rental
|
||
|
// offers only).
|
||
|
type VolumeSaleInfoOffersRentalDuration struct {
|
||
|
Count float64 `json:"count,omitempty"`
|
||
|
|
||
|
Unit string `json:"unit,omitempty"`
|
||
|
|
||
|
// ForceSendFields is a list of field names (e.g. "Count") 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:"-"`
|
||
|
}
|
||
|
|
||
|
func (s *VolumeSaleInfoOffersRentalDuration) MarshalJSON() ([]byte, error) {
|
||
|
type noMethod VolumeSaleInfoOffersRentalDuration
|
||
|
raw := noMethod(*s)
|
||
|
return internal.MarshalJSON(raw, s.ForceSendFields)
|
||
|
}
|
||
|
|
||
|
// VolumeSaleInfoOffersRetailPrice: Offer retail (=discounted) price in
|
||
|
// Micros
|
||
|
type VolumeSaleInfoOffersRetailPrice struct {
|
||
|
AmountInMicros float64 `json:"amountInMicros,omitempty"`
|
||
|
|
||
|
CurrencyCode string `json:"currencyCode,omitempty"`
|
||
|
|
||
|
// ForceSendFields is a list of field names (e.g. "AmountInMicros") 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:"-"`
|
||
|
}
|
||
|
|
||
|
func (s *VolumeSaleInfoOffersRetailPrice) MarshalJSON() ([]byte, error) {
|
||
|
type noMethod VolumeSaleInfoOffersRetailPrice
|
||
|
raw := noMethod(*s)
|
||
|
return internal.MarshalJSON(raw, s.ForceSendFields)
|
||
|
}
|
||
|
|
||
|
// VolumeSaleInfoRetailPrice: The actual selling price of the book. This
|
||
|
// is the same as the suggested retail or list price unless there are
|
||
|
// offers or discounts on this volume. (In LITE projection.)
|
||
|
type VolumeSaleInfoRetailPrice struct {
|
||
|
// Amount: Amount in the currency listed below. (In LITE projection.)
|
||
|
Amount float64 `json:"amount,omitempty"`
|
||
|
|
||
|
// CurrencyCode: An ISO 4217, three-letter currency code. (In LITE
|
||
|
// projection.)
|
||
|
CurrencyCode string `json:"currencyCode,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:"-"`
|
||
|
}
|
||
|
|
||
|
func (s *VolumeSaleInfoRetailPrice) MarshalJSON() ([]byte, error) {
|
||
|
type noMethod VolumeSaleInfoRetailPrice
|
||
|
raw := noMethod(*s)
|
||
|
return internal.MarshalJSON(raw, s.ForceSendFields)
|
||
|
}
|
||
|
|
||
|
// VolumeSearchInfo: Search result information related to this volume.
|
||
|
type VolumeSearchInfo struct {
|
||
|
// TextSnippet: A text snippet containing the search query.
|
||
|
TextSnippet string `json:"textSnippet,omitempty"`
|
||
|
|
||
|
// ForceSendFields is a list of field names (e.g. "TextSnippet") 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:"-"`
|
||
|
}
|
||
|
|
||
|
func (s *VolumeSearchInfo) MarshalJSON() ([]byte, error) {
|
||
|
type noMethod VolumeSearchInfo
|
||
|
raw := noMethod(*s)
|
||
|
return internal.MarshalJSON(raw, s.ForceSendFields)
|
||
|
}
|
||
|
|
||
|
// VolumeUserInfo: User specific information related to this volume.
|
||
|
// (e.g. page this user last read or whether they purchased this book)
|
||
|
type VolumeUserInfo struct {
|
||
|
// AcquisitionType: How this volume was acquired.
|
||
|
AcquisitionType int64 `json:"acquisitionType,omitempty"`
|
||
|
|
||
|
// Copy: Copy/Paste accounting information.
|
||
|
Copy *VolumeUserInfoCopy `json:"copy,omitempty"`
|
||
|
|
||
|
// EntitlementType: Whether this volume is purchased, sample, pd
|
||
|
// download etc.
|
||
|
EntitlementType int64 `json:"entitlementType,omitempty"`
|
||
|
|
||
|
// IsInMyBooks: Whether or not this volume is currently in "my books."
|
||
|
IsInMyBooks bool `json:"isInMyBooks,omitempty"`
|
||
|
|
||
|
// IsPreordered: Whether or not this volume was pre-ordered by the
|
||
|
// authenticated user making the request. (In LITE projection.)
|
||
|
IsPreordered bool `json:"isPreordered,omitempty"`
|
||
|
|
||
|
// IsPurchased: Whether or not this volume was purchased by the
|
||
|
// authenticated user making the request. (In LITE projection.)
|
||
|
IsPurchased bool `json:"isPurchased,omitempty"`
|
||
|
|
||
|
// IsUploaded: Whether or not this volume was user uploaded.
|
||
|
IsUploaded bool `json:"isUploaded,omitempty"`
|
||
|
|
||
|
// ReadingPosition: The user's current reading position in the volume,
|
||
|
// if one is available. (In LITE projection.)
|
||
|
ReadingPosition *ReadingPosition `json:"readingPosition,omitempty"`
|
||
|
|
||
|
// RentalPeriod: Period during this book is/was a valid rental.
|
||
|
RentalPeriod *VolumeUserInfoRentalPeriod `json:"rentalPeriod,omitempty"`
|
||
|
|
||
|
// RentalState: Whether this book is an active or an expired rental.
|
||
|
RentalState string `json:"rentalState,omitempty"`
|
||
|
|
||
|
// Review: This user's review of this volume, if one exists.
|
||
|
Review *Review `json:"review,omitempty"`
|
||
|
|
||
|
// Updated: Timestamp when this volume was last modified by a user
|
||
|
// action, such as a reading position update, volume purchase or writing
|
||
|
// a review. (RFC 3339 UTC date-time format).
|
||
|
Updated string `json:"updated,omitempty"`
|
||
|
|
||
|
UserUploadedVolumeInfo *VolumeUserInfoUserUploadedVolumeInfo `json:"userUploadedVolumeInfo,omitempty"`
|
||
|
|
||
|
// ForceSendFields is a list of field names (e.g. "AcquisitionType") 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:"-"`
|
||
|
}
|
||
|
|
||
|
func (s *VolumeUserInfo) MarshalJSON() ([]byte, error) {
|
||
|
type noMethod VolumeUserInfo
|
||
|
raw := noMethod(*s)
|
||
|
return internal.MarshalJSON(raw, s.ForceSendFields)
|
||
|
}
|
||
|
|
||
|
// VolumeUserInfoCopy: Copy/Paste accounting information.
|
||
|
type VolumeUserInfoCopy struct {
|
||
|
AllowedCharacterCount int64 `json:"allowedCharacterCount,omitempty"`
|
||
|
|
||
|
LimitType string `json:"limitType,omitempty"`
|
||
|
|
||
|
RemainingCharacterCount int64 `json:"remainingCharacterCount,omitempty"`
|
||
|
|
||
|
Updated string `json:"updated,omitempty"`
|
||
|
|
||
|
// ForceSendFields is a list of field names (e.g.
|
||
|
// "AllowedCharacterCount") 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:"-"`
|
||
|
}
|
||
|
|
||
|
func (s *VolumeUserInfoCopy) MarshalJSON() ([]byte, error) {
|
||
|
type noMethod VolumeUserInfoCopy
|
||
|
raw := noMethod(*s)
|
||
|
return internal.MarshalJSON(raw, s.ForceSendFields)
|
||
|
}
|
||
|
|
||
|
// VolumeUserInfoRentalPeriod: Period during this book is/was a valid
|
||
|
// rental.
|
||
|
type VolumeUserInfoRentalPeriod struct {
|
||
|
EndUtcSec int64 `json:"endUtcSec,omitempty,string"`
|
||
|
|
||
|
StartUtcSec int64 `json:"startUtcSec,omitempty,string"`
|
||
|
|
||
|
// ForceSendFields is a list of field names (e.g. "EndUtcSec") 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:"-"`
|
||
|
}
|
||
|
|
||
|
func (s *VolumeUserInfoRentalPeriod) MarshalJSON() ([]byte, error) {
|
||
|
type noMethod VolumeUserInfoRentalPeriod
|
||
|
raw := noMethod(*s)
|
||
|
return internal.MarshalJSON(raw, s.ForceSendFields)
|
||
|
}
|
||
|
|
||
|
type VolumeUserInfoUserUploadedVolumeInfo struct {
|
||
|
ProcessingState string `json:"processingState,omitempty"`
|
||
|
|
||
|
// ForceSendFields is a list of field names (e.g. "ProcessingState") 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:"-"`
|
||
|
}
|
||
|
|
||
|
func (s *VolumeUserInfoUserUploadedVolumeInfo) MarshalJSON() ([]byte, error) {
|
||
|
type noMethod VolumeUserInfoUserUploadedVolumeInfo
|
||
|
raw := noMethod(*s)
|
||
|
return internal.MarshalJSON(raw, s.ForceSendFields)
|
||
|
}
|
||
|
|
||
|
// VolumeVolumeInfo: General volume information.
|
||
|
type VolumeVolumeInfo struct {
|
||
|
// AllowAnonLogging: Whether anonymous logging should be allowed.
|
||
|
AllowAnonLogging bool `json:"allowAnonLogging,omitempty"`
|
||
|
|
||
|
// Authors: The names of the authors and/or editors for this volume. (In
|
||
|
// LITE projection)
|
||
|
Authors []string `json:"authors,omitempty"`
|
||
|
|
||
|
// AverageRating: The mean review rating for this volume. (min = 1.0,
|
||
|
// max = 5.0)
|
||
|
AverageRating float64 `json:"averageRating,omitempty"`
|
||
|
|
||
|
// CanonicalVolumeLink: Canonical URL for a volume. (In LITE
|
||
|
// projection.)
|
||
|
CanonicalVolumeLink string `json:"canonicalVolumeLink,omitempty"`
|
||
|
|
||
|
// Categories: A list of subject categories, such as "Fiction",
|
||
|
// "Suspense", etc.
|
||
|
Categories []string `json:"categories,omitempty"`
|
||
|
|
||
|
// ContentVersion: An identifier for the version of the volume content
|
||
|
// (text & images). (In LITE projection)
|
||
|
ContentVersion string `json:"contentVersion,omitempty"`
|
||
|
|
||
|
// Description: A synopsis of the volume. The text of the description is
|
||
|
// formatted in HTML and includes simple formatting elements, such as b,
|
||
|
// i, and br tags. (In LITE projection.)
|
||
|
Description string `json:"description,omitempty"`
|
||
|
|
||
|
// Dimensions: Physical dimensions of this volume.
|
||
|
Dimensions *VolumeVolumeInfoDimensions `json:"dimensions,omitempty"`
|
||
|
|
||
|
// ImageLinks: A list of image links for all the sizes that are
|
||
|
// available. (In LITE projection.)
|
||
|
ImageLinks *VolumeVolumeInfoImageLinks `json:"imageLinks,omitempty"`
|
||
|
|
||
|
// IndustryIdentifiers: Industry standard identifiers for this volume.
|
||
|
IndustryIdentifiers []*VolumeVolumeInfoIndustryIdentifiers `json:"industryIdentifiers,omitempty"`
|
||
|
|
||
|
// InfoLink: URL to view information about this volume on the Google
|
||
|
// Books site. (In LITE projection)
|
||
|
InfoLink string `json:"infoLink,omitempty"`
|
||
|
|
||
|
// Language: Best language for this volume (based on content). It is the
|
||
|
// two-letter ISO 639-1 code such as 'fr', 'en', etc.
|
||
|
Language string `json:"language,omitempty"`
|
||
|
|
||
|
// MainCategory: The main category to which this volume belongs. It will
|
||
|
// be the category from the categories list returned below that has the
|
||
|
// highest weight.
|
||
|
MainCategory string `json:"mainCategory,omitempty"`
|
||
|
|
||
|
MaturityRating string `json:"maturityRating,omitempty"`
|
||
|
|
||
|
// PageCount: Total number of pages as per publisher metadata.
|
||
|
PageCount int64 `json:"pageCount,omitempty"`
|
||
|
|
||
|
// PreviewLink: URL to preview this volume on the Google Books site.
|
||
|
PreviewLink string `json:"previewLink,omitempty"`
|
||
|
|
||
|
// PrintType: Type of publication of this volume. Possible values are
|
||
|
// BOOK or MAGAZINE.
|
||
|
PrintType string `json:"printType,omitempty"`
|
||
|
|
||
|
// PrintedPageCount: Total number of printed pages in generated pdf
|
||
|
// representation.
|
||
|
PrintedPageCount int64 `json:"printedPageCount,omitempty"`
|
||
|
|
||
|
// PublishedDate: Date of publication. (In LITE projection.)
|
||
|
PublishedDate string `json:"publishedDate,omitempty"`
|
||
|
|
||
|
// Publisher: Publisher of this volume. (In LITE projection.)
|
||
|
Publisher string `json:"publisher,omitempty"`
|
||
|
|
||
|
// RatingsCount: The number of review ratings for this volume.
|
||
|
RatingsCount int64 `json:"ratingsCount,omitempty"`
|
||
|
|
||
|
// ReadingModes: The reading modes available for this volume.
|
||
|
ReadingModes interface{} `json:"readingModes,omitempty"`
|
||
|
|
||
|
// SamplePageCount: Total number of sample pages as per publisher
|
||
|
// metadata.
|
||
|
SamplePageCount int64 `json:"samplePageCount,omitempty"`
|
||
|
|
||
|
// Subtitle: Volume subtitle. (In LITE projection.)
|
||
|
Subtitle string `json:"subtitle,omitempty"`
|
||
|
|
||
|
// Title: Volume title. (In LITE projection.)
|
||
|
Title string `json:"title,omitempty"`
|
||
|
|
||
|
// ForceSendFields is a list of field names (e.g. "AllowAnonLogging") 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:"-"`
|
||
|
}
|
||
|
|
||
|
func (s *VolumeVolumeInfo) MarshalJSON() ([]byte, error) {
|
||
|
type noMethod VolumeVolumeInfo
|
||
|
raw := noMethod(*s)
|
||
|
return internal.MarshalJSON(raw, s.ForceSendFields)
|
||
|
}
|
||
|
|
||
|
// VolumeVolumeInfoDimensions: Physical dimensions of this volume.
|
||
|
type VolumeVolumeInfoDimensions struct {
|
||
|
// Height: Height or length of this volume (in cm).
|
||
|
Height string `json:"height,omitempty"`
|
||
|
|
||
|
// Thickness: Thickness of this volume (in cm).
|
||
|
Thickness string `json:"thickness,omitempty"`
|
||
|
|
||
|
// Width: Width of this volume (in cm).
|
||
|
Width string `json:"width,omitempty"`
|
||
|
|
||
|
// ForceSendFields is a list of field names (e.g. "Height") 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:"-"`
|
||
|
}
|
||
|
|
||
|
func (s *VolumeVolumeInfoDimensions) MarshalJSON() ([]byte, error) {
|
||
|
type noMethod VolumeVolumeInfoDimensions
|
||
|
raw := noMethod(*s)
|
||
|
return internal.MarshalJSON(raw, s.ForceSendFields)
|
||
|
}
|
||
|
|
||
|
// VolumeVolumeInfoImageLinks: A list of image links for all the sizes
|
||
|
// that are available. (In LITE projection.)
|
||
|
type VolumeVolumeInfoImageLinks struct {
|
||
|
// ExtraLarge: Image link for extra large size (width of ~1280 pixels).
|
||
|
// (In LITE projection)
|
||
|
ExtraLarge string `json:"extraLarge,omitempty"`
|
||
|
|
||
|
// Large: Image link for large size (width of ~800 pixels). (In LITE
|
||
|
// projection)
|
||
|
Large string `json:"large,omitempty"`
|
||
|
|
||
|
// Medium: Image link for medium size (width of ~575 pixels). (In LITE
|
||
|
// projection)
|
||
|
Medium string `json:"medium,omitempty"`
|
||
|
|
||
|
// Small: Image link for small size (width of ~300 pixels). (In LITE
|
||
|
// projection)
|
||
|
Small string `json:"small,omitempty"`
|
||
|
|
||
|
// SmallThumbnail: Image link for small thumbnail size (width of ~80
|
||
|
// pixels). (In LITE projection)
|
||
|
SmallThumbnail string `json:"smallThumbnail,omitempty"`
|
||
|
|
||
|
// Thumbnail: Image link for thumbnail size (width of ~128 pixels). (In
|
||
|
// LITE projection)
|
||
|
Thumbnail string `json:"thumbnail,omitempty"`
|
||
|
|
||
|
// ForceSendFields is a list of field names (e.g. "ExtraLarge") 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:"-"`
|
||
|
}
|
||
|
|
||
|
func (s *VolumeVolumeInfoImageLinks) MarshalJSON() ([]byte, error) {
|
||
|
type noMethod VolumeVolumeInfoImageLinks
|
||
|
raw := noMethod(*s)
|
||
|
return internal.MarshalJSON(raw, s.ForceSendFields)
|
||
|
}
|
||
|
|
||
|
type VolumeVolumeInfoIndustryIdentifiers struct {
|
||
|
// Identifier: Industry specific volume identifier.
|
||
|
Identifier string `json:"identifier,omitempty"`
|
||
|
|
||
|
// Type: Identifier type. Possible values are ISBN_10, ISBN_13, ISSN and
|
||
|
// OTHER.
|
||
|
Type string `json:"type,omitempty"`
|
||
|
|
||
|
// ForceSendFields is a list of field names (e.g. "Identifier") 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:"-"`
|
||
|
}
|
||
|
|
||
|
func (s *VolumeVolumeInfoIndustryIdentifiers) MarshalJSON() ([]byte, error) {
|
||
|
type noMethod VolumeVolumeInfoIndustryIdentifiers
|
||
|
raw := noMethod(*s)
|
||
|
return internal.MarshalJSON(raw, s.ForceSendFields)
|
||
|
}
|
||
|
|
||
|
type Volume2 struct {
|
||
|
// Items: A list of volumes.
|
||
|
Items []*Volume `json:"items,omitempty"`
|
||
|
|
||
|
// Kind: Resource type.
|
||
|
Kind string `json:"kind,omitempty"`
|
||
|
|
||
|
NextPageToken string `json:"nextPageToken,omitempty"`
|
||
|
|
||
|
// ServerResponse contains the HTTP response code and headers from the
|
||
|
// server.
|
||
|
googleapi.ServerResponse `json:"-"`
|
||
|
|
||
|
// ForceSendFields is a list of field names (e.g. "Items") 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:"-"`
|
||
|
}
|
||
|
|
||
|
func (s *Volume2) MarshalJSON() ([]byte, error) {
|
||
|
type noMethod Volume2
|
||
|
raw := noMethod(*s)
|
||
|
return internal.MarshalJSON(raw, s.ForceSendFields)
|
||
|
}
|
||
|
|
||
|
type Volumeannotation struct {
|
||
|
// AnnotationDataId: The annotation data id for this volume annotation.
|
||
|
AnnotationDataId string `json:"annotationDataId,omitempty"`
|
||
|
|
||
|
// AnnotationDataLink: Link to get data for this annotation.
|
||
|
AnnotationDataLink string `json:"annotationDataLink,omitempty"`
|
||
|
|
||
|
// AnnotationType: The type of annotation this is.
|
||
|
AnnotationType string `json:"annotationType,omitempty"`
|
||
|
|
||
|
// ContentRanges: The content ranges to identify the selected text.
|
||
|
ContentRanges *VolumeannotationContentRanges `json:"contentRanges,omitempty"`
|
||
|
|
||
|
// Data: Data for this annotation.
|
||
|
Data string `json:"data,omitempty"`
|
||
|
|
||
|
// Deleted: Indicates that this annotation is deleted.
|
||
|
Deleted bool `json:"deleted,omitempty"`
|
||
|
|
||
|
// Id: Unique id of this volume annotation.
|
||
|
Id string `json:"id,omitempty"`
|
||
|
|
||
|
// Kind: Resource Type
|
||
|
Kind string `json:"kind,omitempty"`
|
||
|
|
||
|
// LayerId: The Layer this annotation is for.
|
||
|
LayerId string `json:"layerId,omitempty"`
|
||
|
|
||
|
// PageIds: Pages the annotation spans.
|
||
|
PageIds []string `json:"pageIds,omitempty"`
|
||
|
|
||
|
// SelectedText: Excerpt from the volume.
|
||
|
SelectedText string `json:"selectedText,omitempty"`
|
||
|
|
||
|
// SelfLink: URL to this resource.
|
||
|
SelfLink string `json:"selfLink,omitempty"`
|
||
|
|
||
|
// Updated: Timestamp for the last time this anntoation was updated.
|
||
|
// (RFC 3339 UTC date-time format).
|
||
|
Updated string `json:"updated,omitempty"`
|
||
|
|
||
|
// VolumeId: The Volume this annotation is for.
|
||
|
VolumeId string `json:"volumeId,omitempty"`
|
||
|
|
||
|
// ServerResponse contains the HTTP response code and headers from the
|
||
|
// server.
|
||
|
googleapi.ServerResponse `json:"-"`
|
||
|
|
||
|
// ForceSendFields is a list of field names (e.g. "AnnotationDataId") 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:"-"`
|
||
|
}
|
||
|
|
||
|
func (s *Volumeannotation) MarshalJSON() ([]byte, error) {
|
||
|
type noMethod Volumeannotation
|
||
|
raw := noMethod(*s)
|
||
|
return internal.MarshalJSON(raw, s.ForceSendFields)
|
||
|
}
|
||
|
|
||
|
// VolumeannotationContentRanges: The content ranges to identify the
|
||
|
// selected text.
|
||
|
type VolumeannotationContentRanges struct {
|
||
|
// CfiRange: Range in CFI format for this annotation for version above.
|
||
|
CfiRange *BooksAnnotationsRange `json:"cfiRange,omitempty"`
|
||
|
|
||
|
// ContentVersion: Content version applicable to ranges below.
|
||
|
ContentVersion string `json:"contentVersion,omitempty"`
|
||
|
|
||
|
// GbImageRange: Range in GB image format for this annotation for
|
||
|
// version above.
|
||
|
GbImageRange *BooksAnnotationsRange `json:"gbImageRange,omitempty"`
|
||
|
|
||
|
// GbTextRange: Range in GB text format for this annotation for version
|
||
|
// above.
|
||
|
GbTextRange *BooksAnnotationsRange `json:"gbTextRange,omitempty"`
|
||
|
|
||
|
// ForceSendFields is a list of field names (e.g. "CfiRange") 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:"-"`
|
||
|
}
|
||
|
|
||
|
func (s *VolumeannotationContentRanges) MarshalJSON() ([]byte, error) {
|
||
|
type noMethod VolumeannotationContentRanges
|
||
|
raw := noMethod(*s)
|
||
|
return internal.MarshalJSON(raw, s.ForceSendFields)
|
||
|
}
|
||
|
|
||
|
type Volumeannotations struct {
|
||
|
// Items: A list of volume annotations.
|
||
|
Items []*Volumeannotation `json:"items,omitempty"`
|
||
|
|
||
|
// Kind: Resource type
|
||
|
Kind string `json:"kind,omitempty"`
|
||
|
|
||
|
// NextPageToken: Token to pass in for pagination for the next page.
|
||
|
// This will not be present if this request does not have more results.
|
||
|
NextPageToken string `json:"nextPageToken,omitempty"`
|
||
|
|
||
|
// TotalItems: The total number of volume annotations found.
|
||
|
TotalItems int64 `json:"totalItems,omitempty"`
|
||
|
|
||
|
// Version: The version string for all of the volume annotations in this
|
||
|
// layer (not just the ones in this response). Note: the version string
|
||
|
// doesn't apply to the annotation data, just the information in this
|
||
|
// response (e.g. the location of annotations in the book).
|
||
|
Version string `json:"version,omitempty"`
|
||
|
|
||
|
// ServerResponse contains the HTTP response code and headers from the
|
||
|
// server.
|
||
|
googleapi.ServerResponse `json:"-"`
|
||
|
|
||
|
// ForceSendFields is a list of field names (e.g. "Items") 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:"-"`
|
||
|
}
|
||
|
|
||
|
func (s *Volumeannotations) MarshalJSON() ([]byte, error) {
|
||
|
type noMethod Volumeannotations
|
||
|
raw := noMethod(*s)
|
||
|
return internal.MarshalJSON(raw, s.ForceSendFields)
|
||
|
}
|
||
|
|
||
|
type Volumes struct {
|
||
|
// Items: A list of volumes.
|
||
|
Items []*Volume `json:"items,omitempty"`
|
||
|
|
||
|
// Kind: Resource type.
|
||
|
Kind string `json:"kind,omitempty"`
|
||
|
|
||
|
// TotalItems: Total number of volumes found. This might be greater than
|
||
|
// the number of volumes returned in this response if results have been
|
||
|
// paginated.
|
||
|
TotalItems int64 `json:"totalItems,omitempty"`
|
||
|
|
||
|
// ServerResponse contains the HTTP response code and headers from the
|
||
|
// server.
|
||
|
googleapi.ServerResponse `json:"-"`
|
||
|
|
||
|
// ForceSendFields is a list of field names (e.g. "Items") 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:"-"`
|
||
|
}
|
||
|
|
||
|
func (s *Volumes) MarshalJSON() ([]byte, error) {
|
||
|
type noMethod Volumes
|
||
|
raw := noMethod(*s)
|
||
|
return internal.MarshalJSON(raw, s.ForceSendFields)
|
||
|
}
|
||
|
|
||
|
// method id "books.bookshelves.get":
|
||
|
|
||
|
type BookshelvesGetCall struct {
|
||
|
s *Service
|
||
|
userId string
|
||
|
shelf string
|
||
|
opt_ map[string]interface{}
|
||
|
ctx_ context.Context
|
||
|
}
|
||
|
|
||
|
// Get: Retrieves metadata for a specific bookshelf for the specified
|
||
|
// user.
|
||
|
func (r *BookshelvesService) Get(userId string, shelf string) *BookshelvesGetCall {
|
||
|
c := &BookshelvesGetCall{s: r.s, opt_: make(map[string]interface{})}
|
||
|
c.userId = userId
|
||
|
c.shelf = shelf
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
// Source sets the optional parameter "source": String to identify the
|
||
|
// originator of this request.
|
||
|
func (c *BookshelvesGetCall) Source(source string) *BookshelvesGetCall {
|
||
|
c.opt_["source"] = source
|
||
|
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 *BookshelvesGetCall) Fields(s ...googleapi.Field) *BookshelvesGetCall {
|
||
|
c.opt_["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 *BookshelvesGetCall) IfNoneMatch(entityTag string) *BookshelvesGetCall {
|
||
|
c.opt_["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 *BookshelvesGetCall) Context(ctx context.Context) *BookshelvesGetCall {
|
||
|
c.ctx_ = ctx
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
func (c *BookshelvesGetCall) doRequest(alt string) (*http.Response, error) {
|
||
|
var body io.Reader = nil
|
||
|
params := make(url.Values)
|
||
|
params.Set("alt", alt)
|
||
|
if v, ok := c.opt_["source"]; ok {
|
||
|
params.Set("source", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if v, ok := c.opt_["fields"]; ok {
|
||
|
params.Set("fields", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
urls := googleapi.ResolveRelative(c.s.BasePath, "users/{userId}/bookshelves/{shelf}")
|
||
|
urls += "?" + params.Encode()
|
||
|
req, _ := http.NewRequest("GET", urls, body)
|
||
|
googleapi.Expand(req.URL, map[string]string{
|
||
|
"userId": c.userId,
|
||
|
"shelf": c.shelf,
|
||
|
})
|
||
|
req.Header.Set("User-Agent", c.s.userAgent())
|
||
|
if v, ok := c.opt_["ifNoneMatch"]; ok {
|
||
|
req.Header.Set("If-None-Match", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if c.ctx_ != nil {
|
||
|
return ctxhttp.Do(c.ctx_, c.s.client, req)
|
||
|
}
|
||
|
return c.s.client.Do(req)
|
||
|
}
|
||
|
|
||
|
// Do executes the "books.bookshelves.get" call.
|
||
|
// Exactly one of *Bookshelf or error will be non-nil. Any non-2xx
|
||
|
// status code is an error. Response headers are in either
|
||
|
// *Bookshelf.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 *BookshelvesGetCall) Do() (*Bookshelf, error) {
|
||
|
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 := &Bookshelf{
|
||
|
ServerResponse: googleapi.ServerResponse{
|
||
|
Header: res.Header,
|
||
|
HTTPStatusCode: res.StatusCode,
|
||
|
},
|
||
|
}
|
||
|
if err := json.NewDecoder(res.Body).Decode(&ret); err != nil {
|
||
|
return nil, err
|
||
|
}
|
||
|
return ret, nil
|
||
|
// {
|
||
|
// "description": "Retrieves metadata for a specific bookshelf for the specified user.",
|
||
|
// "httpMethod": "GET",
|
||
|
// "id": "books.bookshelves.get",
|
||
|
// "parameterOrder": [
|
||
|
// "userId",
|
||
|
// "shelf"
|
||
|
// ],
|
||
|
// "parameters": {
|
||
|
// "shelf": {
|
||
|
// "description": "ID of bookshelf to retrieve.",
|
||
|
// "location": "path",
|
||
|
// "required": true,
|
||
|
// "type": "string"
|
||
|
// },
|
||
|
// "source": {
|
||
|
// "description": "String to identify the originator of this request.",
|
||
|
// "location": "query",
|
||
|
// "type": "string"
|
||
|
// },
|
||
|
// "userId": {
|
||
|
// "description": "ID of user for whom to retrieve bookshelves.",
|
||
|
// "location": "path",
|
||
|
// "required": true,
|
||
|
// "type": "string"
|
||
|
// }
|
||
|
// },
|
||
|
// "path": "users/{userId}/bookshelves/{shelf}",
|
||
|
// "response": {
|
||
|
// "$ref": "Bookshelf"
|
||
|
// },
|
||
|
// "scopes": [
|
||
|
// "https://www.googleapis.com/auth/books"
|
||
|
// ]
|
||
|
// }
|
||
|
|
||
|
}
|
||
|
|
||
|
// method id "books.bookshelves.list":
|
||
|
|
||
|
type BookshelvesListCall struct {
|
||
|
s *Service
|
||
|
userId string
|
||
|
opt_ map[string]interface{}
|
||
|
ctx_ context.Context
|
||
|
}
|
||
|
|
||
|
// List: Retrieves a list of public bookshelves for the specified user.
|
||
|
func (r *BookshelvesService) List(userId string) *BookshelvesListCall {
|
||
|
c := &BookshelvesListCall{s: r.s, opt_: make(map[string]interface{})}
|
||
|
c.userId = userId
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
// Source sets the optional parameter "source": String to identify the
|
||
|
// originator of this request.
|
||
|
func (c *BookshelvesListCall) Source(source string) *BookshelvesListCall {
|
||
|
c.opt_["source"] = source
|
||
|
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 *BookshelvesListCall) Fields(s ...googleapi.Field) *BookshelvesListCall {
|
||
|
c.opt_["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 *BookshelvesListCall) IfNoneMatch(entityTag string) *BookshelvesListCall {
|
||
|
c.opt_["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 *BookshelvesListCall) Context(ctx context.Context) *BookshelvesListCall {
|
||
|
c.ctx_ = ctx
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
func (c *BookshelvesListCall) doRequest(alt string) (*http.Response, error) {
|
||
|
var body io.Reader = nil
|
||
|
params := make(url.Values)
|
||
|
params.Set("alt", alt)
|
||
|
if v, ok := c.opt_["source"]; ok {
|
||
|
params.Set("source", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if v, ok := c.opt_["fields"]; ok {
|
||
|
params.Set("fields", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
urls := googleapi.ResolveRelative(c.s.BasePath, "users/{userId}/bookshelves")
|
||
|
urls += "?" + params.Encode()
|
||
|
req, _ := http.NewRequest("GET", urls, body)
|
||
|
googleapi.Expand(req.URL, map[string]string{
|
||
|
"userId": c.userId,
|
||
|
})
|
||
|
req.Header.Set("User-Agent", c.s.userAgent())
|
||
|
if v, ok := c.opt_["ifNoneMatch"]; ok {
|
||
|
req.Header.Set("If-None-Match", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if c.ctx_ != nil {
|
||
|
return ctxhttp.Do(c.ctx_, c.s.client, req)
|
||
|
}
|
||
|
return c.s.client.Do(req)
|
||
|
}
|
||
|
|
||
|
// Do executes the "books.bookshelves.list" call.
|
||
|
// Exactly one of *Bookshelves or error will be non-nil. Any non-2xx
|
||
|
// status code is an error. Response headers are in either
|
||
|
// *Bookshelves.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 *BookshelvesListCall) Do() (*Bookshelves, error) {
|
||
|
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 := &Bookshelves{
|
||
|
ServerResponse: googleapi.ServerResponse{
|
||
|
Header: res.Header,
|
||
|
HTTPStatusCode: res.StatusCode,
|
||
|
},
|
||
|
}
|
||
|
if err := json.NewDecoder(res.Body).Decode(&ret); err != nil {
|
||
|
return nil, err
|
||
|
}
|
||
|
return ret, nil
|
||
|
// {
|
||
|
// "description": "Retrieves a list of public bookshelves for the specified user.",
|
||
|
// "httpMethod": "GET",
|
||
|
// "id": "books.bookshelves.list",
|
||
|
// "parameterOrder": [
|
||
|
// "userId"
|
||
|
// ],
|
||
|
// "parameters": {
|
||
|
// "source": {
|
||
|
// "description": "String to identify the originator of this request.",
|
||
|
// "location": "query",
|
||
|
// "type": "string"
|
||
|
// },
|
||
|
// "userId": {
|
||
|
// "description": "ID of user for whom to retrieve bookshelves.",
|
||
|
// "location": "path",
|
||
|
// "required": true,
|
||
|
// "type": "string"
|
||
|
// }
|
||
|
// },
|
||
|
// "path": "users/{userId}/bookshelves",
|
||
|
// "response": {
|
||
|
// "$ref": "Bookshelves"
|
||
|
// },
|
||
|
// "scopes": [
|
||
|
// "https://www.googleapis.com/auth/books"
|
||
|
// ]
|
||
|
// }
|
||
|
|
||
|
}
|
||
|
|
||
|
// method id "books.bookshelves.volumes.list":
|
||
|
|
||
|
type BookshelvesVolumesListCall struct {
|
||
|
s *Service
|
||
|
userId string
|
||
|
shelf string
|
||
|
opt_ map[string]interface{}
|
||
|
ctx_ context.Context
|
||
|
}
|
||
|
|
||
|
// List: Retrieves volumes in a specific bookshelf for the specified
|
||
|
// user.
|
||
|
func (r *BookshelvesVolumesService) List(userId string, shelf string) *BookshelvesVolumesListCall {
|
||
|
c := &BookshelvesVolumesListCall{s: r.s, opt_: make(map[string]interface{})}
|
||
|
c.userId = userId
|
||
|
c.shelf = shelf
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
// MaxResults sets the optional parameter "maxResults": Maximum number
|
||
|
// of results to return
|
||
|
func (c *BookshelvesVolumesListCall) MaxResults(maxResults int64) *BookshelvesVolumesListCall {
|
||
|
c.opt_["maxResults"] = maxResults
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
// ShowPreorders sets the optional parameter "showPreorders": Set to
|
||
|
// true to show pre-ordered books. Defaults to false.
|
||
|
func (c *BookshelvesVolumesListCall) ShowPreorders(showPreorders bool) *BookshelvesVolumesListCall {
|
||
|
c.opt_["showPreorders"] = showPreorders
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
// Source sets the optional parameter "source": String to identify the
|
||
|
// originator of this request.
|
||
|
func (c *BookshelvesVolumesListCall) Source(source string) *BookshelvesVolumesListCall {
|
||
|
c.opt_["source"] = source
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
// StartIndex sets the optional parameter "startIndex": Index of the
|
||
|
// first element to return (starts at 0)
|
||
|
func (c *BookshelvesVolumesListCall) StartIndex(startIndex int64) *BookshelvesVolumesListCall {
|
||
|
c.opt_["startIndex"] = startIndex
|
||
|
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 *BookshelvesVolumesListCall) Fields(s ...googleapi.Field) *BookshelvesVolumesListCall {
|
||
|
c.opt_["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 *BookshelvesVolumesListCall) IfNoneMatch(entityTag string) *BookshelvesVolumesListCall {
|
||
|
c.opt_["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 *BookshelvesVolumesListCall) Context(ctx context.Context) *BookshelvesVolumesListCall {
|
||
|
c.ctx_ = ctx
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
func (c *BookshelvesVolumesListCall) doRequest(alt string) (*http.Response, error) {
|
||
|
var body io.Reader = nil
|
||
|
params := make(url.Values)
|
||
|
params.Set("alt", alt)
|
||
|
if v, ok := c.opt_["maxResults"]; ok {
|
||
|
params.Set("maxResults", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if v, ok := c.opt_["showPreorders"]; ok {
|
||
|
params.Set("showPreorders", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if v, ok := c.opt_["source"]; ok {
|
||
|
params.Set("source", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if v, ok := c.opt_["startIndex"]; ok {
|
||
|
params.Set("startIndex", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if v, ok := c.opt_["fields"]; ok {
|
||
|
params.Set("fields", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
urls := googleapi.ResolveRelative(c.s.BasePath, "users/{userId}/bookshelves/{shelf}/volumes")
|
||
|
urls += "?" + params.Encode()
|
||
|
req, _ := http.NewRequest("GET", urls, body)
|
||
|
googleapi.Expand(req.URL, map[string]string{
|
||
|
"userId": c.userId,
|
||
|
"shelf": c.shelf,
|
||
|
})
|
||
|
req.Header.Set("User-Agent", c.s.userAgent())
|
||
|
if v, ok := c.opt_["ifNoneMatch"]; ok {
|
||
|
req.Header.Set("If-None-Match", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if c.ctx_ != nil {
|
||
|
return ctxhttp.Do(c.ctx_, c.s.client, req)
|
||
|
}
|
||
|
return c.s.client.Do(req)
|
||
|
}
|
||
|
|
||
|
// Do executes the "books.bookshelves.volumes.list" call.
|
||
|
// Exactly one of *Volumes or error will be non-nil. Any non-2xx status
|
||
|
// code is an error. Response headers are in either
|
||
|
// *Volumes.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 *BookshelvesVolumesListCall) Do() (*Volumes, error) {
|
||
|
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 := &Volumes{
|
||
|
ServerResponse: googleapi.ServerResponse{
|
||
|
Header: res.Header,
|
||
|
HTTPStatusCode: res.StatusCode,
|
||
|
},
|
||
|
}
|
||
|
if err := json.NewDecoder(res.Body).Decode(&ret); err != nil {
|
||
|
return nil, err
|
||
|
}
|
||
|
return ret, nil
|
||
|
// {
|
||
|
// "description": "Retrieves volumes in a specific bookshelf for the specified user.",
|
||
|
// "httpMethod": "GET",
|
||
|
// "id": "books.bookshelves.volumes.list",
|
||
|
// "parameterOrder": [
|
||
|
// "userId",
|
||
|
// "shelf"
|
||
|
// ],
|
||
|
// "parameters": {
|
||
|
// "maxResults": {
|
||
|
// "description": "Maximum number of results to return",
|
||
|
// "format": "uint32",
|
||
|
// "location": "query",
|
||
|
// "minimum": "0",
|
||
|
// "type": "integer"
|
||
|
// },
|
||
|
// "shelf": {
|
||
|
// "description": "ID of bookshelf to retrieve volumes.",
|
||
|
// "location": "path",
|
||
|
// "required": true,
|
||
|
// "type": "string"
|
||
|
// },
|
||
|
// "showPreorders": {
|
||
|
// "description": "Set to true to show pre-ordered books. Defaults to false.",
|
||
|
// "location": "query",
|
||
|
// "type": "boolean"
|
||
|
// },
|
||
|
// "source": {
|
||
|
// "description": "String to identify the originator of this request.",
|
||
|
// "location": "query",
|
||
|
// "type": "string"
|
||
|
// },
|
||
|
// "startIndex": {
|
||
|
// "description": "Index of the first element to return (starts at 0)",
|
||
|
// "format": "uint32",
|
||
|
// "location": "query",
|
||
|
// "minimum": "0",
|
||
|
// "type": "integer"
|
||
|
// },
|
||
|
// "userId": {
|
||
|
// "description": "ID of user for whom to retrieve bookshelf volumes.",
|
||
|
// "location": "path",
|
||
|
// "required": true,
|
||
|
// "type": "string"
|
||
|
// }
|
||
|
// },
|
||
|
// "path": "users/{userId}/bookshelves/{shelf}/volumes",
|
||
|
// "response": {
|
||
|
// "$ref": "Volumes"
|
||
|
// },
|
||
|
// "scopes": [
|
||
|
// "https://www.googleapis.com/auth/books"
|
||
|
// ]
|
||
|
// }
|
||
|
|
||
|
}
|
||
|
|
||
|
// method id "books.cloudloading.addBook":
|
||
|
|
||
|
type CloudloadingAddBookCall struct {
|
||
|
s *Service
|
||
|
opt_ map[string]interface{}
|
||
|
ctx_ context.Context
|
||
|
}
|
||
|
|
||
|
// AddBook:
|
||
|
func (r *CloudloadingService) AddBook() *CloudloadingAddBookCall {
|
||
|
c := &CloudloadingAddBookCall{s: r.s, opt_: make(map[string]interface{})}
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
// DriveDocumentId sets the optional parameter "drive_document_id": A
|
||
|
// drive document id. The upload_client_token must not be set.
|
||
|
func (c *CloudloadingAddBookCall) DriveDocumentId(driveDocumentId string) *CloudloadingAddBookCall {
|
||
|
c.opt_["drive_document_id"] = driveDocumentId
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
// MimeType sets the optional parameter "mime_type": The document MIME
|
||
|
// type. It can be set only if the drive_document_id is set.
|
||
|
func (c *CloudloadingAddBookCall) MimeType(mimeType string) *CloudloadingAddBookCall {
|
||
|
c.opt_["mime_type"] = mimeType
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
// Name sets the optional parameter "name": The document name. It can be
|
||
|
// set only if the drive_document_id is set.
|
||
|
func (c *CloudloadingAddBookCall) Name(name string) *CloudloadingAddBookCall {
|
||
|
c.opt_["name"] = name
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
// UploadClientToken sets the optional parameter "upload_client_token":
|
||
|
func (c *CloudloadingAddBookCall) UploadClientToken(uploadClientToken string) *CloudloadingAddBookCall {
|
||
|
c.opt_["upload_client_token"] = uploadClientToken
|
||
|
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 *CloudloadingAddBookCall) Fields(s ...googleapi.Field) *CloudloadingAddBookCall {
|
||
|
c.opt_["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 *CloudloadingAddBookCall) Context(ctx context.Context) *CloudloadingAddBookCall {
|
||
|
c.ctx_ = ctx
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
func (c *CloudloadingAddBookCall) doRequest(alt string) (*http.Response, error) {
|
||
|
var body io.Reader = nil
|
||
|
params := make(url.Values)
|
||
|
params.Set("alt", alt)
|
||
|
if v, ok := c.opt_["drive_document_id"]; ok {
|
||
|
params.Set("drive_document_id", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if v, ok := c.opt_["mime_type"]; ok {
|
||
|
params.Set("mime_type", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if v, ok := c.opt_["name"]; ok {
|
||
|
params.Set("name", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if v, ok := c.opt_["upload_client_token"]; ok {
|
||
|
params.Set("upload_client_token", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if v, ok := c.opt_["fields"]; ok {
|
||
|
params.Set("fields", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
urls := googleapi.ResolveRelative(c.s.BasePath, "cloudloading/addBook")
|
||
|
urls += "?" + params.Encode()
|
||
|
req, _ := http.NewRequest("POST", urls, body)
|
||
|
googleapi.SetOpaque(req.URL)
|
||
|
req.Header.Set("User-Agent", c.s.userAgent())
|
||
|
if c.ctx_ != nil {
|
||
|
return ctxhttp.Do(c.ctx_, c.s.client, req)
|
||
|
}
|
||
|
return c.s.client.Do(req)
|
||
|
}
|
||
|
|
||
|
// Do executes the "books.cloudloading.addBook" call.
|
||
|
// Exactly one of *BooksCloudloadingResource or error will be non-nil.
|
||
|
// Any non-2xx status code is an error. Response headers are in either
|
||
|
// *BooksCloudloadingResource.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 *CloudloadingAddBookCall) Do() (*BooksCloudloadingResource, error) {
|
||
|
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 := &BooksCloudloadingResource{
|
||
|
ServerResponse: googleapi.ServerResponse{
|
||
|
Header: res.Header,
|
||
|
HTTPStatusCode: res.StatusCode,
|
||
|
},
|
||
|
}
|
||
|
if err := json.NewDecoder(res.Body).Decode(&ret); err != nil {
|
||
|
return nil, err
|
||
|
}
|
||
|
return ret, nil
|
||
|
// {
|
||
|
// "description": "",
|
||
|
// "httpMethod": "POST",
|
||
|
// "id": "books.cloudloading.addBook",
|
||
|
// "parameters": {
|
||
|
// "drive_document_id": {
|
||
|
// "description": "A drive document id. The upload_client_token must not be set.",
|
||
|
// "location": "query",
|
||
|
// "type": "string"
|
||
|
// },
|
||
|
// "mime_type": {
|
||
|
// "description": "The document MIME type. It can be set only if the drive_document_id is set.",
|
||
|
// "location": "query",
|
||
|
// "type": "string"
|
||
|
// },
|
||
|
// "name": {
|
||
|
// "description": "The document name. It can be set only if the drive_document_id is set.",
|
||
|
// "location": "query",
|
||
|
// "type": "string"
|
||
|
// },
|
||
|
// "upload_client_token": {
|
||
|
// "location": "query",
|
||
|
// "type": "string"
|
||
|
// }
|
||
|
// },
|
||
|
// "path": "cloudloading/addBook",
|
||
|
// "response": {
|
||
|
// "$ref": "BooksCloudloadingResource"
|
||
|
// },
|
||
|
// "scopes": [
|
||
|
// "https://www.googleapis.com/auth/books"
|
||
|
// ]
|
||
|
// }
|
||
|
|
||
|
}
|
||
|
|
||
|
// method id "books.cloudloading.deleteBook":
|
||
|
|
||
|
type CloudloadingDeleteBookCall struct {
|
||
|
s *Service
|
||
|
volumeId string
|
||
|
opt_ map[string]interface{}
|
||
|
ctx_ context.Context
|
||
|
}
|
||
|
|
||
|
// DeleteBook: Remove the book and its contents
|
||
|
func (r *CloudloadingService) DeleteBook(volumeId string) *CloudloadingDeleteBookCall {
|
||
|
c := &CloudloadingDeleteBookCall{s: r.s, opt_: make(map[string]interface{})}
|
||
|
c.volumeId = volumeId
|
||
|
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 *CloudloadingDeleteBookCall) Fields(s ...googleapi.Field) *CloudloadingDeleteBookCall {
|
||
|
c.opt_["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 *CloudloadingDeleteBookCall) Context(ctx context.Context) *CloudloadingDeleteBookCall {
|
||
|
c.ctx_ = ctx
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
func (c *CloudloadingDeleteBookCall) doRequest(alt string) (*http.Response, error) {
|
||
|
var body io.Reader = nil
|
||
|
params := make(url.Values)
|
||
|
params.Set("alt", alt)
|
||
|
params.Set("volumeId", fmt.Sprintf("%v", c.volumeId))
|
||
|
if v, ok := c.opt_["fields"]; ok {
|
||
|
params.Set("fields", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
urls := googleapi.ResolveRelative(c.s.BasePath, "cloudloading/deleteBook")
|
||
|
urls += "?" + params.Encode()
|
||
|
req, _ := http.NewRequest("POST", urls, body)
|
||
|
googleapi.SetOpaque(req.URL)
|
||
|
req.Header.Set("User-Agent", c.s.userAgent())
|
||
|
if c.ctx_ != nil {
|
||
|
return ctxhttp.Do(c.ctx_, c.s.client, req)
|
||
|
}
|
||
|
return c.s.client.Do(req)
|
||
|
}
|
||
|
|
||
|
// Do executes the "books.cloudloading.deleteBook" call.
|
||
|
func (c *CloudloadingDeleteBookCall) Do() error {
|
||
|
res, err := c.doRequest("json")
|
||
|
if err != nil {
|
||
|
return err
|
||
|
}
|
||
|
defer googleapi.CloseBody(res)
|
||
|
if err := googleapi.CheckResponse(res); err != nil {
|
||
|
return err
|
||
|
}
|
||
|
return nil
|
||
|
// {
|
||
|
// "description": "Remove the book and its contents",
|
||
|
// "httpMethod": "POST",
|
||
|
// "id": "books.cloudloading.deleteBook",
|
||
|
// "parameterOrder": [
|
||
|
// "volumeId"
|
||
|
// ],
|
||
|
// "parameters": {
|
||
|
// "volumeId": {
|
||
|
// "description": "The id of the book to be removed.",
|
||
|
// "location": "query",
|
||
|
// "required": true,
|
||
|
// "type": "string"
|
||
|
// }
|
||
|
// },
|
||
|
// "path": "cloudloading/deleteBook",
|
||
|
// "scopes": [
|
||
|
// "https://www.googleapis.com/auth/books"
|
||
|
// ]
|
||
|
// }
|
||
|
|
||
|
}
|
||
|
|
||
|
// method id "books.cloudloading.updateBook":
|
||
|
|
||
|
type CloudloadingUpdateBookCall struct {
|
||
|
s *Service
|
||
|
bookscloudloadingresource *BooksCloudloadingResource
|
||
|
opt_ map[string]interface{}
|
||
|
ctx_ context.Context
|
||
|
}
|
||
|
|
||
|
// UpdateBook:
|
||
|
func (r *CloudloadingService) UpdateBook(bookscloudloadingresource *BooksCloudloadingResource) *CloudloadingUpdateBookCall {
|
||
|
c := &CloudloadingUpdateBookCall{s: r.s, opt_: make(map[string]interface{})}
|
||
|
c.bookscloudloadingresource = bookscloudloadingresource
|
||
|
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 *CloudloadingUpdateBookCall) Fields(s ...googleapi.Field) *CloudloadingUpdateBookCall {
|
||
|
c.opt_["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 *CloudloadingUpdateBookCall) Context(ctx context.Context) *CloudloadingUpdateBookCall {
|
||
|
c.ctx_ = ctx
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
func (c *CloudloadingUpdateBookCall) doRequest(alt string) (*http.Response, error) {
|
||
|
var body io.Reader = nil
|
||
|
body, err := googleapi.WithoutDataWrapper.JSONReader(c.bookscloudloadingresource)
|
||
|
if err != nil {
|
||
|
return nil, err
|
||
|
}
|
||
|
ctype := "application/json"
|
||
|
params := make(url.Values)
|
||
|
params.Set("alt", alt)
|
||
|
if v, ok := c.opt_["fields"]; ok {
|
||
|
params.Set("fields", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
urls := googleapi.ResolveRelative(c.s.BasePath, "cloudloading/updateBook")
|
||
|
urls += "?" + params.Encode()
|
||
|
req, _ := http.NewRequest("POST", urls, body)
|
||
|
googleapi.SetOpaque(req.URL)
|
||
|
req.Header.Set("Content-Type", ctype)
|
||
|
req.Header.Set("User-Agent", c.s.userAgent())
|
||
|
if c.ctx_ != nil {
|
||
|
return ctxhttp.Do(c.ctx_, c.s.client, req)
|
||
|
}
|
||
|
return c.s.client.Do(req)
|
||
|
}
|
||
|
|
||
|
// Do executes the "books.cloudloading.updateBook" call.
|
||
|
// Exactly one of *BooksCloudloadingResource or error will be non-nil.
|
||
|
// Any non-2xx status code is an error. Response headers are in either
|
||
|
// *BooksCloudloadingResource.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 *CloudloadingUpdateBookCall) Do() (*BooksCloudloadingResource, error) {
|
||
|
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 := &BooksCloudloadingResource{
|
||
|
ServerResponse: googleapi.ServerResponse{
|
||
|
Header: res.Header,
|
||
|
HTTPStatusCode: res.StatusCode,
|
||
|
},
|
||
|
}
|
||
|
if err := json.NewDecoder(res.Body).Decode(&ret); err != nil {
|
||
|
return nil, err
|
||
|
}
|
||
|
return ret, nil
|
||
|
// {
|
||
|
// "description": "",
|
||
|
// "httpMethod": "POST",
|
||
|
// "id": "books.cloudloading.updateBook",
|
||
|
// "path": "cloudloading/updateBook",
|
||
|
// "request": {
|
||
|
// "$ref": "BooksCloudloadingResource"
|
||
|
// },
|
||
|
// "response": {
|
||
|
// "$ref": "BooksCloudloadingResource"
|
||
|
// },
|
||
|
// "scopes": [
|
||
|
// "https://www.googleapis.com/auth/books"
|
||
|
// ]
|
||
|
// }
|
||
|
|
||
|
}
|
||
|
|
||
|
// method id "books.dictionary.listOfflineMetadata":
|
||
|
|
||
|
type DictionaryListOfflineMetadataCall struct {
|
||
|
s *Service
|
||
|
cpksver string
|
||
|
opt_ map[string]interface{}
|
||
|
ctx_ context.Context
|
||
|
}
|
||
|
|
||
|
// ListOfflineMetadata: Returns a list of offline dictionary metadata
|
||
|
// available
|
||
|
func (r *DictionaryService) ListOfflineMetadata(cpksver string) *DictionaryListOfflineMetadataCall {
|
||
|
c := &DictionaryListOfflineMetadataCall{s: r.s, opt_: make(map[string]interface{})}
|
||
|
c.cpksver = cpksver
|
||
|
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 *DictionaryListOfflineMetadataCall) Fields(s ...googleapi.Field) *DictionaryListOfflineMetadataCall {
|
||
|
c.opt_["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 *DictionaryListOfflineMetadataCall) IfNoneMatch(entityTag string) *DictionaryListOfflineMetadataCall {
|
||
|
c.opt_["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 *DictionaryListOfflineMetadataCall) Context(ctx context.Context) *DictionaryListOfflineMetadataCall {
|
||
|
c.ctx_ = ctx
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
func (c *DictionaryListOfflineMetadataCall) doRequest(alt string) (*http.Response, error) {
|
||
|
var body io.Reader = nil
|
||
|
params := make(url.Values)
|
||
|
params.Set("alt", alt)
|
||
|
params.Set("cpksver", fmt.Sprintf("%v", c.cpksver))
|
||
|
if v, ok := c.opt_["fields"]; ok {
|
||
|
params.Set("fields", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
urls := googleapi.ResolveRelative(c.s.BasePath, "dictionary/listOfflineMetadata")
|
||
|
urls += "?" + params.Encode()
|
||
|
req, _ := http.NewRequest("GET", urls, body)
|
||
|
googleapi.SetOpaque(req.URL)
|
||
|
req.Header.Set("User-Agent", c.s.userAgent())
|
||
|
if v, ok := c.opt_["ifNoneMatch"]; ok {
|
||
|
req.Header.Set("If-None-Match", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if c.ctx_ != nil {
|
||
|
return ctxhttp.Do(c.ctx_, c.s.client, req)
|
||
|
}
|
||
|
return c.s.client.Do(req)
|
||
|
}
|
||
|
|
||
|
// Do executes the "books.dictionary.listOfflineMetadata" call.
|
||
|
// Exactly one of *Metadata or error will be non-nil. Any non-2xx status
|
||
|
// code is an error. Response headers are in either
|
||
|
// *Metadata.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 *DictionaryListOfflineMetadataCall) Do() (*Metadata, error) {
|
||
|
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 := &Metadata{
|
||
|
ServerResponse: googleapi.ServerResponse{
|
||
|
Header: res.Header,
|
||
|
HTTPStatusCode: res.StatusCode,
|
||
|
},
|
||
|
}
|
||
|
if err := json.NewDecoder(res.Body).Decode(&ret); err != nil {
|
||
|
return nil, err
|
||
|
}
|
||
|
return ret, nil
|
||
|
// {
|
||
|
// "description": "Returns a list of offline dictionary metadata available",
|
||
|
// "httpMethod": "GET",
|
||
|
// "id": "books.dictionary.listOfflineMetadata",
|
||
|
// "parameterOrder": [
|
||
|
// "cpksver"
|
||
|
// ],
|
||
|
// "parameters": {
|
||
|
// "cpksver": {
|
||
|
// "description": "The device/version ID from which to request the data.",
|
||
|
// "location": "query",
|
||
|
// "required": true,
|
||
|
// "type": "string"
|
||
|
// }
|
||
|
// },
|
||
|
// "path": "dictionary/listOfflineMetadata",
|
||
|
// "response": {
|
||
|
// "$ref": "Metadata"
|
||
|
// },
|
||
|
// "scopes": [
|
||
|
// "https://www.googleapis.com/auth/books"
|
||
|
// ]
|
||
|
// }
|
||
|
|
||
|
}
|
||
|
|
||
|
// method id "books.layers.get":
|
||
|
|
||
|
type LayersGetCall struct {
|
||
|
s *Service
|
||
|
volumeId string
|
||
|
summaryId string
|
||
|
opt_ map[string]interface{}
|
||
|
ctx_ context.Context
|
||
|
}
|
||
|
|
||
|
// Get: Gets the layer summary for a volume.
|
||
|
func (r *LayersService) Get(volumeId string, summaryId string) *LayersGetCall {
|
||
|
c := &LayersGetCall{s: r.s, opt_: make(map[string]interface{})}
|
||
|
c.volumeId = volumeId
|
||
|
c.summaryId = summaryId
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
// ContentVersion sets the optional parameter "contentVersion": The
|
||
|
// content version for the requested volume.
|
||
|
func (c *LayersGetCall) ContentVersion(contentVersion string) *LayersGetCall {
|
||
|
c.opt_["contentVersion"] = contentVersion
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
// Source sets the optional parameter "source": String to identify the
|
||
|
// originator of this request.
|
||
|
func (c *LayersGetCall) Source(source string) *LayersGetCall {
|
||
|
c.opt_["source"] = source
|
||
|
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 *LayersGetCall) Fields(s ...googleapi.Field) *LayersGetCall {
|
||
|
c.opt_["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 *LayersGetCall) IfNoneMatch(entityTag string) *LayersGetCall {
|
||
|
c.opt_["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 *LayersGetCall) Context(ctx context.Context) *LayersGetCall {
|
||
|
c.ctx_ = ctx
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
func (c *LayersGetCall) doRequest(alt string) (*http.Response, error) {
|
||
|
var body io.Reader = nil
|
||
|
params := make(url.Values)
|
||
|
params.Set("alt", alt)
|
||
|
if v, ok := c.opt_["contentVersion"]; ok {
|
||
|
params.Set("contentVersion", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if v, ok := c.opt_["source"]; ok {
|
||
|
params.Set("source", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if v, ok := c.opt_["fields"]; ok {
|
||
|
params.Set("fields", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
urls := googleapi.ResolveRelative(c.s.BasePath, "volumes/{volumeId}/layersummary/{summaryId}")
|
||
|
urls += "?" + params.Encode()
|
||
|
req, _ := http.NewRequest("GET", urls, body)
|
||
|
googleapi.Expand(req.URL, map[string]string{
|
||
|
"volumeId": c.volumeId,
|
||
|
"summaryId": c.summaryId,
|
||
|
})
|
||
|
req.Header.Set("User-Agent", c.s.userAgent())
|
||
|
if v, ok := c.opt_["ifNoneMatch"]; ok {
|
||
|
req.Header.Set("If-None-Match", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if c.ctx_ != nil {
|
||
|
return ctxhttp.Do(c.ctx_, c.s.client, req)
|
||
|
}
|
||
|
return c.s.client.Do(req)
|
||
|
}
|
||
|
|
||
|
// Do executes the "books.layers.get" call.
|
||
|
// Exactly one of *Layersummary or error will be non-nil. Any non-2xx
|
||
|
// status code is an error. Response headers are in either
|
||
|
// *Layersummary.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 *LayersGetCall) Do() (*Layersummary, error) {
|
||
|
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 := &Layersummary{
|
||
|
ServerResponse: googleapi.ServerResponse{
|
||
|
Header: res.Header,
|
||
|
HTTPStatusCode: res.StatusCode,
|
||
|
},
|
||
|
}
|
||
|
if err := json.NewDecoder(res.Body).Decode(&ret); err != nil {
|
||
|
return nil, err
|
||
|
}
|
||
|
return ret, nil
|
||
|
// {
|
||
|
// "description": "Gets the layer summary for a volume.",
|
||
|
// "httpMethod": "GET",
|
||
|
// "id": "books.layers.get",
|
||
|
// "parameterOrder": [
|
||
|
// "volumeId",
|
||
|
// "summaryId"
|
||
|
// ],
|
||
|
// "parameters": {
|
||
|
// "contentVersion": {
|
||
|
// "description": "The content version for the requested volume.",
|
||
|
// "location": "query",
|
||
|
// "type": "string"
|
||
|
// },
|
||
|
// "source": {
|
||
|
// "description": "String to identify the originator of this request.",
|
||
|
// "location": "query",
|
||
|
// "type": "string"
|
||
|
// },
|
||
|
// "summaryId": {
|
||
|
// "description": "The ID for the layer to get the summary for.",
|
||
|
// "location": "path",
|
||
|
// "required": true,
|
||
|
// "type": "string"
|
||
|
// },
|
||
|
// "volumeId": {
|
||
|
// "description": "The volume to retrieve layers for.",
|
||
|
// "location": "path",
|
||
|
// "required": true,
|
||
|
// "type": "string"
|
||
|
// }
|
||
|
// },
|
||
|
// "path": "volumes/{volumeId}/layersummary/{summaryId}",
|
||
|
// "response": {
|
||
|
// "$ref": "Layersummary"
|
||
|
// },
|
||
|
// "scopes": [
|
||
|
// "https://www.googleapis.com/auth/books"
|
||
|
// ]
|
||
|
// }
|
||
|
|
||
|
}
|
||
|
|
||
|
// method id "books.layers.list":
|
||
|
|
||
|
type LayersListCall struct {
|
||
|
s *Service
|
||
|
volumeId string
|
||
|
opt_ map[string]interface{}
|
||
|
ctx_ context.Context
|
||
|
}
|
||
|
|
||
|
// List: List the layer summaries for a volume.
|
||
|
func (r *LayersService) List(volumeId string) *LayersListCall {
|
||
|
c := &LayersListCall{s: r.s, opt_: make(map[string]interface{})}
|
||
|
c.volumeId = volumeId
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
// ContentVersion sets the optional parameter "contentVersion": The
|
||
|
// content version for the requested volume.
|
||
|
func (c *LayersListCall) ContentVersion(contentVersion string) *LayersListCall {
|
||
|
c.opt_["contentVersion"] = contentVersion
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
// MaxResults sets the optional parameter "maxResults": Maximum number
|
||
|
// of results to return
|
||
|
func (c *LayersListCall) MaxResults(maxResults int64) *LayersListCall {
|
||
|
c.opt_["maxResults"] = maxResults
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
// PageToken sets the optional parameter "pageToken": The value of the
|
||
|
// nextToken from the previous page.
|
||
|
func (c *LayersListCall) PageToken(pageToken string) *LayersListCall {
|
||
|
c.opt_["pageToken"] = pageToken
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
// Source sets the optional parameter "source": String to identify the
|
||
|
// originator of this request.
|
||
|
func (c *LayersListCall) Source(source string) *LayersListCall {
|
||
|
c.opt_["source"] = source
|
||
|
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 *LayersListCall) Fields(s ...googleapi.Field) *LayersListCall {
|
||
|
c.opt_["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 *LayersListCall) IfNoneMatch(entityTag string) *LayersListCall {
|
||
|
c.opt_["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 *LayersListCall) Context(ctx context.Context) *LayersListCall {
|
||
|
c.ctx_ = ctx
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
func (c *LayersListCall) doRequest(alt string) (*http.Response, error) {
|
||
|
var body io.Reader = nil
|
||
|
params := make(url.Values)
|
||
|
params.Set("alt", alt)
|
||
|
if v, ok := c.opt_["contentVersion"]; ok {
|
||
|
params.Set("contentVersion", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if v, ok := c.opt_["maxResults"]; ok {
|
||
|
params.Set("maxResults", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if v, ok := c.opt_["pageToken"]; ok {
|
||
|
params.Set("pageToken", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if v, ok := c.opt_["source"]; ok {
|
||
|
params.Set("source", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if v, ok := c.opt_["fields"]; ok {
|
||
|
params.Set("fields", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
urls := googleapi.ResolveRelative(c.s.BasePath, "volumes/{volumeId}/layersummary")
|
||
|
urls += "?" + params.Encode()
|
||
|
req, _ := http.NewRequest("GET", urls, body)
|
||
|
googleapi.Expand(req.URL, map[string]string{
|
||
|
"volumeId": c.volumeId,
|
||
|
})
|
||
|
req.Header.Set("User-Agent", c.s.userAgent())
|
||
|
if v, ok := c.opt_["ifNoneMatch"]; ok {
|
||
|
req.Header.Set("If-None-Match", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if c.ctx_ != nil {
|
||
|
return ctxhttp.Do(c.ctx_, c.s.client, req)
|
||
|
}
|
||
|
return c.s.client.Do(req)
|
||
|
}
|
||
|
|
||
|
// Do executes the "books.layers.list" call.
|
||
|
// Exactly one of *Layersummaries or error will be non-nil. Any non-2xx
|
||
|
// status code is an error. Response headers are in either
|
||
|
// *Layersummaries.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 *LayersListCall) Do() (*Layersummaries, error) {
|
||
|
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 := &Layersummaries{
|
||
|
ServerResponse: googleapi.ServerResponse{
|
||
|
Header: res.Header,
|
||
|
HTTPStatusCode: res.StatusCode,
|
||
|
},
|
||
|
}
|
||
|
if err := json.NewDecoder(res.Body).Decode(&ret); err != nil {
|
||
|
return nil, err
|
||
|
}
|
||
|
return ret, nil
|
||
|
// {
|
||
|
// "description": "List the layer summaries for a volume.",
|
||
|
// "httpMethod": "GET",
|
||
|
// "id": "books.layers.list",
|
||
|
// "parameterOrder": [
|
||
|
// "volumeId"
|
||
|
// ],
|
||
|
// "parameters": {
|
||
|
// "contentVersion": {
|
||
|
// "description": "The content version for the requested volume.",
|
||
|
// "location": "query",
|
||
|
// "type": "string"
|
||
|
// },
|
||
|
// "maxResults": {
|
||
|
// "description": "Maximum number of results to return",
|
||
|
// "format": "uint32",
|
||
|
// "location": "query",
|
||
|
// "maximum": "200",
|
||
|
// "minimum": "0",
|
||
|
// "type": "integer"
|
||
|
// },
|
||
|
// "pageToken": {
|
||
|
// "description": "The value of the nextToken from the previous page.",
|
||
|
// "location": "query",
|
||
|
// "type": "string"
|
||
|
// },
|
||
|
// "source": {
|
||
|
// "description": "String to identify the originator of this request.",
|
||
|
// "location": "query",
|
||
|
// "type": "string"
|
||
|
// },
|
||
|
// "volumeId": {
|
||
|
// "description": "The volume to retrieve layers for.",
|
||
|
// "location": "path",
|
||
|
// "required": true,
|
||
|
// "type": "string"
|
||
|
// }
|
||
|
// },
|
||
|
// "path": "volumes/{volumeId}/layersummary",
|
||
|
// "response": {
|
||
|
// "$ref": "Layersummaries"
|
||
|
// },
|
||
|
// "scopes": [
|
||
|
// "https://www.googleapis.com/auth/books"
|
||
|
// ]
|
||
|
// }
|
||
|
|
||
|
}
|
||
|
|
||
|
// method id "books.layers.annotationData.get":
|
||
|
|
||
|
type LayersAnnotationDataGetCall struct {
|
||
|
s *Service
|
||
|
volumeId string
|
||
|
layerId string
|
||
|
annotationDataId string
|
||
|
contentVersion string
|
||
|
opt_ map[string]interface{}
|
||
|
ctx_ context.Context
|
||
|
}
|
||
|
|
||
|
// Get: Gets the annotation data.
|
||
|
func (r *LayersAnnotationDataService) Get(volumeId string, layerId string, annotationDataId string, contentVersion string) *LayersAnnotationDataGetCall {
|
||
|
c := &LayersAnnotationDataGetCall{s: r.s, opt_: make(map[string]interface{})}
|
||
|
c.volumeId = volumeId
|
||
|
c.layerId = layerId
|
||
|
c.annotationDataId = annotationDataId
|
||
|
c.contentVersion = contentVersion
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
// AllowWebDefinitions sets the optional parameter
|
||
|
// "allowWebDefinitions": For the dictionary layer. Whether or not to
|
||
|
// allow web definitions.
|
||
|
func (c *LayersAnnotationDataGetCall) AllowWebDefinitions(allowWebDefinitions bool) *LayersAnnotationDataGetCall {
|
||
|
c.opt_["allowWebDefinitions"] = allowWebDefinitions
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
// H sets the optional parameter "h": The requested pixel height for any
|
||
|
// images. If height is provided width must also be provided.
|
||
|
func (c *LayersAnnotationDataGetCall) H(h int64) *LayersAnnotationDataGetCall {
|
||
|
c.opt_["h"] = h
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
// Locale sets the optional parameter "locale": The locale information
|
||
|
// for the data. ISO-639-1 language and ISO-3166-1 country code. Ex:
|
||
|
// 'en_US'.
|
||
|
func (c *LayersAnnotationDataGetCall) Locale(locale string) *LayersAnnotationDataGetCall {
|
||
|
c.opt_["locale"] = locale
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
// Scale sets the optional parameter "scale": The requested scale for
|
||
|
// the image.
|
||
|
func (c *LayersAnnotationDataGetCall) Scale(scale int64) *LayersAnnotationDataGetCall {
|
||
|
c.opt_["scale"] = scale
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
// Source sets the optional parameter "source": String to identify the
|
||
|
// originator of this request.
|
||
|
func (c *LayersAnnotationDataGetCall) Source(source string) *LayersAnnotationDataGetCall {
|
||
|
c.opt_["source"] = source
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
// W sets the optional parameter "w": The requested pixel width for any
|
||
|
// images. If width is provided height must also be provided.
|
||
|
func (c *LayersAnnotationDataGetCall) W(w int64) *LayersAnnotationDataGetCall {
|
||
|
c.opt_["w"] = w
|
||
|
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 *LayersAnnotationDataGetCall) Fields(s ...googleapi.Field) *LayersAnnotationDataGetCall {
|
||
|
c.opt_["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 *LayersAnnotationDataGetCall) IfNoneMatch(entityTag string) *LayersAnnotationDataGetCall {
|
||
|
c.opt_["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 *LayersAnnotationDataGetCall) Context(ctx context.Context) *LayersAnnotationDataGetCall {
|
||
|
c.ctx_ = ctx
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
func (c *LayersAnnotationDataGetCall) doRequest(alt string) (*http.Response, error) {
|
||
|
var body io.Reader = nil
|
||
|
params := make(url.Values)
|
||
|
params.Set("alt", alt)
|
||
|
params.Set("contentVersion", fmt.Sprintf("%v", c.contentVersion))
|
||
|
if v, ok := c.opt_["allowWebDefinitions"]; ok {
|
||
|
params.Set("allowWebDefinitions", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if v, ok := c.opt_["h"]; ok {
|
||
|
params.Set("h", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if v, ok := c.opt_["locale"]; ok {
|
||
|
params.Set("locale", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if v, ok := c.opt_["scale"]; ok {
|
||
|
params.Set("scale", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if v, ok := c.opt_["source"]; ok {
|
||
|
params.Set("source", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if v, ok := c.opt_["w"]; ok {
|
||
|
params.Set("w", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if v, ok := c.opt_["fields"]; ok {
|
||
|
params.Set("fields", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
urls := googleapi.ResolveRelative(c.s.BasePath, "volumes/{volumeId}/layers/{layerId}/data/{annotationDataId}")
|
||
|
urls += "?" + params.Encode()
|
||
|
req, _ := http.NewRequest("GET", urls, body)
|
||
|
googleapi.Expand(req.URL, map[string]string{
|
||
|
"volumeId": c.volumeId,
|
||
|
"layerId": c.layerId,
|
||
|
"annotationDataId": c.annotationDataId,
|
||
|
})
|
||
|
req.Header.Set("User-Agent", c.s.userAgent())
|
||
|
if v, ok := c.opt_["ifNoneMatch"]; ok {
|
||
|
req.Header.Set("If-None-Match", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if c.ctx_ != nil {
|
||
|
return ctxhttp.Do(c.ctx_, c.s.client, req)
|
||
|
}
|
||
|
return c.s.client.Do(req)
|
||
|
}
|
||
|
|
||
|
// Do executes the "books.layers.annotationData.get" call.
|
||
|
// Exactly one of *Annotationdata or error will be non-nil. Any non-2xx
|
||
|
// status code is an error. Response headers are in either
|
||
|
// *Annotationdata.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 *LayersAnnotationDataGetCall) Do() (*Annotationdata, error) {
|
||
|
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 := &Annotationdata{
|
||
|
ServerResponse: googleapi.ServerResponse{
|
||
|
Header: res.Header,
|
||
|
HTTPStatusCode: res.StatusCode,
|
||
|
},
|
||
|
}
|
||
|
if err := json.NewDecoder(res.Body).Decode(&ret); err != nil {
|
||
|
return nil, err
|
||
|
}
|
||
|
return ret, nil
|
||
|
// {
|
||
|
// "description": "Gets the annotation data.",
|
||
|
// "httpMethod": "GET",
|
||
|
// "id": "books.layers.annotationData.get",
|
||
|
// "parameterOrder": [
|
||
|
// "volumeId",
|
||
|
// "layerId",
|
||
|
// "annotationDataId",
|
||
|
// "contentVersion"
|
||
|
// ],
|
||
|
// "parameters": {
|
||
|
// "allowWebDefinitions": {
|
||
|
// "description": "For the dictionary layer. Whether or not to allow web definitions.",
|
||
|
// "location": "query",
|
||
|
// "type": "boolean"
|
||
|
// },
|
||
|
// "annotationDataId": {
|
||
|
// "description": "The ID of the annotation data to retrieve.",
|
||
|
// "location": "path",
|
||
|
// "required": true,
|
||
|
// "type": "string"
|
||
|
// },
|
||
|
// "contentVersion": {
|
||
|
// "description": "The content version for the volume you are trying to retrieve.",
|
||
|
// "location": "query",
|
||
|
// "required": true,
|
||
|
// "type": "string"
|
||
|
// },
|
||
|
// "h": {
|
||
|
// "description": "The requested pixel height for any images. If height is provided width must also be provided.",
|
||
|
// "format": "int32",
|
||
|
// "location": "query",
|
||
|
// "type": "integer"
|
||
|
// },
|
||
|
// "layerId": {
|
||
|
// "description": "The ID for the layer to get the annotations.",
|
||
|
// "location": "path",
|
||
|
// "required": true,
|
||
|
// "type": "string"
|
||
|
// },
|
||
|
// "locale": {
|
||
|
// "description": "The locale information for the data. ISO-639-1 language and ISO-3166-1 country code. Ex: 'en_US'.",
|
||
|
// "location": "query",
|
||
|
// "type": "string"
|
||
|
// },
|
||
|
// "scale": {
|
||
|
// "description": "The requested scale for the image.",
|
||
|
// "format": "int32",
|
||
|
// "location": "query",
|
||
|
// "minimum": "0",
|
||
|
// "type": "integer"
|
||
|
// },
|
||
|
// "source": {
|
||
|
// "description": "String to identify the originator of this request.",
|
||
|
// "location": "query",
|
||
|
// "type": "string"
|
||
|
// },
|
||
|
// "volumeId": {
|
||
|
// "description": "The volume to retrieve annotations for.",
|
||
|
// "location": "path",
|
||
|
// "required": true,
|
||
|
// "type": "string"
|
||
|
// },
|
||
|
// "w": {
|
||
|
// "description": "The requested pixel width for any images. If width is provided height must also be provided.",
|
||
|
// "format": "int32",
|
||
|
// "location": "query",
|
||
|
// "type": "integer"
|
||
|
// }
|
||
|
// },
|
||
|
// "path": "volumes/{volumeId}/layers/{layerId}/data/{annotationDataId}",
|
||
|
// "response": {
|
||
|
// "$ref": "Annotationdata"
|
||
|
// },
|
||
|
// "scopes": [
|
||
|
// "https://www.googleapis.com/auth/books"
|
||
|
// ]
|
||
|
// }
|
||
|
|
||
|
}
|
||
|
|
||
|
// method id "books.layers.annotationData.list":
|
||
|
|
||
|
type LayersAnnotationDataListCall struct {
|
||
|
s *Service
|
||
|
volumeId string
|
||
|
layerId string
|
||
|
contentVersion string
|
||
|
opt_ map[string]interface{}
|
||
|
ctx_ context.Context
|
||
|
}
|
||
|
|
||
|
// List: Gets the annotation data for a volume and layer.
|
||
|
func (r *LayersAnnotationDataService) List(volumeId string, layerId string, contentVersion string) *LayersAnnotationDataListCall {
|
||
|
c := &LayersAnnotationDataListCall{s: r.s, opt_: make(map[string]interface{})}
|
||
|
c.volumeId = volumeId
|
||
|
c.layerId = layerId
|
||
|
c.contentVersion = contentVersion
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
// AnnotationDataId sets the optional parameter "annotationDataId": The
|
||
|
// list of Annotation Data Ids to retrieve. Pagination is ignored if
|
||
|
// this is set.
|
||
|
func (c *LayersAnnotationDataListCall) AnnotationDataId(annotationDataId string) *LayersAnnotationDataListCall {
|
||
|
c.opt_["annotationDataId"] = annotationDataId
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
// H sets the optional parameter "h": The requested pixel height for any
|
||
|
// images. If height is provided width must also be provided.
|
||
|
func (c *LayersAnnotationDataListCall) H(h int64) *LayersAnnotationDataListCall {
|
||
|
c.opt_["h"] = h
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
// Locale sets the optional parameter "locale": The locale information
|
||
|
// for the data. ISO-639-1 language and ISO-3166-1 country code. Ex:
|
||
|
// 'en_US'.
|
||
|
func (c *LayersAnnotationDataListCall) Locale(locale string) *LayersAnnotationDataListCall {
|
||
|
c.opt_["locale"] = locale
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
// MaxResults sets the optional parameter "maxResults": Maximum number
|
||
|
// of results to return
|
||
|
func (c *LayersAnnotationDataListCall) MaxResults(maxResults int64) *LayersAnnotationDataListCall {
|
||
|
c.opt_["maxResults"] = maxResults
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
// PageToken sets the optional parameter "pageToken": The value of the
|
||
|
// nextToken from the previous page.
|
||
|
func (c *LayersAnnotationDataListCall) PageToken(pageToken string) *LayersAnnotationDataListCall {
|
||
|
c.opt_["pageToken"] = pageToken
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
// Scale sets the optional parameter "scale": The requested scale for
|
||
|
// the image.
|
||
|
func (c *LayersAnnotationDataListCall) Scale(scale int64) *LayersAnnotationDataListCall {
|
||
|
c.opt_["scale"] = scale
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
// Source sets the optional parameter "source": String to identify the
|
||
|
// originator of this request.
|
||
|
func (c *LayersAnnotationDataListCall) Source(source string) *LayersAnnotationDataListCall {
|
||
|
c.opt_["source"] = source
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
// UpdatedMax sets the optional parameter "updatedMax": RFC 3339
|
||
|
// timestamp to restrict to items updated prior to this timestamp
|
||
|
// (exclusive).
|
||
|
func (c *LayersAnnotationDataListCall) UpdatedMax(updatedMax string) *LayersAnnotationDataListCall {
|
||
|
c.opt_["updatedMax"] = updatedMax
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
// UpdatedMin sets the optional parameter "updatedMin": RFC 3339
|
||
|
// timestamp to restrict to items updated since this timestamp
|
||
|
// (inclusive).
|
||
|
func (c *LayersAnnotationDataListCall) UpdatedMin(updatedMin string) *LayersAnnotationDataListCall {
|
||
|
c.opt_["updatedMin"] = updatedMin
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
// W sets the optional parameter "w": The requested pixel width for any
|
||
|
// images. If width is provided height must also be provided.
|
||
|
func (c *LayersAnnotationDataListCall) W(w int64) *LayersAnnotationDataListCall {
|
||
|
c.opt_["w"] = w
|
||
|
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 *LayersAnnotationDataListCall) Fields(s ...googleapi.Field) *LayersAnnotationDataListCall {
|
||
|
c.opt_["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 *LayersAnnotationDataListCall) IfNoneMatch(entityTag string) *LayersAnnotationDataListCall {
|
||
|
c.opt_["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 *LayersAnnotationDataListCall) Context(ctx context.Context) *LayersAnnotationDataListCall {
|
||
|
c.ctx_ = ctx
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
func (c *LayersAnnotationDataListCall) doRequest(alt string) (*http.Response, error) {
|
||
|
var body io.Reader = nil
|
||
|
params := make(url.Values)
|
||
|
params.Set("alt", alt)
|
||
|
params.Set("contentVersion", fmt.Sprintf("%v", c.contentVersion))
|
||
|
if v, ok := c.opt_["annotationDataId"]; ok {
|
||
|
params.Set("annotationDataId", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if v, ok := c.opt_["h"]; ok {
|
||
|
params.Set("h", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if v, ok := c.opt_["locale"]; ok {
|
||
|
params.Set("locale", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if v, ok := c.opt_["maxResults"]; ok {
|
||
|
params.Set("maxResults", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if v, ok := c.opt_["pageToken"]; ok {
|
||
|
params.Set("pageToken", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if v, ok := c.opt_["scale"]; ok {
|
||
|
params.Set("scale", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if v, ok := c.opt_["source"]; ok {
|
||
|
params.Set("source", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if v, ok := c.opt_["updatedMax"]; ok {
|
||
|
params.Set("updatedMax", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if v, ok := c.opt_["updatedMin"]; ok {
|
||
|
params.Set("updatedMin", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if v, ok := c.opt_["w"]; ok {
|
||
|
params.Set("w", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if v, ok := c.opt_["fields"]; ok {
|
||
|
params.Set("fields", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
urls := googleapi.ResolveRelative(c.s.BasePath, "volumes/{volumeId}/layers/{layerId}/data")
|
||
|
urls += "?" + params.Encode()
|
||
|
req, _ := http.NewRequest("GET", urls, body)
|
||
|
googleapi.Expand(req.URL, map[string]string{
|
||
|
"volumeId": c.volumeId,
|
||
|
"layerId": c.layerId,
|
||
|
})
|
||
|
req.Header.Set("User-Agent", c.s.userAgent())
|
||
|
if v, ok := c.opt_["ifNoneMatch"]; ok {
|
||
|
req.Header.Set("If-None-Match", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if c.ctx_ != nil {
|
||
|
return ctxhttp.Do(c.ctx_, c.s.client, req)
|
||
|
}
|
||
|
return c.s.client.Do(req)
|
||
|
}
|
||
|
|
||
|
// Do executes the "books.layers.annotationData.list" call.
|
||
|
// Exactly one of *Annotationsdata or error will be non-nil. Any non-2xx
|
||
|
// status code is an error. Response headers are in either
|
||
|
// *Annotationsdata.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 *LayersAnnotationDataListCall) Do() (*Annotationsdata, error) {
|
||
|
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 := &Annotationsdata{
|
||
|
ServerResponse: googleapi.ServerResponse{
|
||
|
Header: res.Header,
|
||
|
HTTPStatusCode: res.StatusCode,
|
||
|
},
|
||
|
}
|
||
|
if err := json.NewDecoder(res.Body).Decode(&ret); err != nil {
|
||
|
return nil, err
|
||
|
}
|
||
|
return ret, nil
|
||
|
// {
|
||
|
// "description": "Gets the annotation data for a volume and layer.",
|
||
|
// "httpMethod": "GET",
|
||
|
// "id": "books.layers.annotationData.list",
|
||
|
// "parameterOrder": [
|
||
|
// "volumeId",
|
||
|
// "layerId",
|
||
|
// "contentVersion"
|
||
|
// ],
|
||
|
// "parameters": {
|
||
|
// "annotationDataId": {
|
||
|
// "description": "The list of Annotation Data Ids to retrieve. Pagination is ignored if this is set.",
|
||
|
// "location": "query",
|
||
|
// "repeated": true,
|
||
|
// "type": "string"
|
||
|
// },
|
||
|
// "contentVersion": {
|
||
|
// "description": "The content version for the requested volume.",
|
||
|
// "location": "query",
|
||
|
// "required": true,
|
||
|
// "type": "string"
|
||
|
// },
|
||
|
// "h": {
|
||
|
// "description": "The requested pixel height for any images. If height is provided width must also be provided.",
|
||
|
// "format": "int32",
|
||
|
// "location": "query",
|
||
|
// "type": "integer"
|
||
|
// },
|
||
|
// "layerId": {
|
||
|
// "description": "The ID for the layer to get the annotation data.",
|
||
|
// "location": "path",
|
||
|
// "required": true,
|
||
|
// "type": "string"
|
||
|
// },
|
||
|
// "locale": {
|
||
|
// "description": "The locale information for the data. ISO-639-1 language and ISO-3166-1 country code. Ex: 'en_US'.",
|
||
|
// "location": "query",
|
||
|
// "type": "string"
|
||
|
// },
|
||
|
// "maxResults": {
|
||
|
// "description": "Maximum number of results to return",
|
||
|
// "format": "uint32",
|
||
|
// "location": "query",
|
||
|
// "maximum": "200",
|
||
|
// "minimum": "0",
|
||
|
// "type": "integer"
|
||
|
// },
|
||
|
// "pageToken": {
|
||
|
// "description": "The value of the nextToken from the previous page.",
|
||
|
// "location": "query",
|
||
|
// "type": "string"
|
||
|
// },
|
||
|
// "scale": {
|
||
|
// "description": "The requested scale for the image.",
|
||
|
// "format": "int32",
|
||
|
// "location": "query",
|
||
|
// "minimum": "0",
|
||
|
// "type": "integer"
|
||
|
// },
|
||
|
// "source": {
|
||
|
// "description": "String to identify the originator of this request.",
|
||
|
// "location": "query",
|
||
|
// "type": "string"
|
||
|
// },
|
||
|
// "updatedMax": {
|
||
|
// "description": "RFC 3339 timestamp to restrict to items updated prior to this timestamp (exclusive).",
|
||
|
// "location": "query",
|
||
|
// "type": "string"
|
||
|
// },
|
||
|
// "updatedMin": {
|
||
|
// "description": "RFC 3339 timestamp to restrict to items updated since this timestamp (inclusive).",
|
||
|
// "location": "query",
|
||
|
// "type": "string"
|
||
|
// },
|
||
|
// "volumeId": {
|
||
|
// "description": "The volume to retrieve annotation data for.",
|
||
|
// "location": "path",
|
||
|
// "required": true,
|
||
|
// "type": "string"
|
||
|
// },
|
||
|
// "w": {
|
||
|
// "description": "The requested pixel width for any images. If width is provided height must also be provided.",
|
||
|
// "format": "int32",
|
||
|
// "location": "query",
|
||
|
// "type": "integer"
|
||
|
// }
|
||
|
// },
|
||
|
// "path": "volumes/{volumeId}/layers/{layerId}/data",
|
||
|
// "response": {
|
||
|
// "$ref": "Annotationsdata"
|
||
|
// },
|
||
|
// "scopes": [
|
||
|
// "https://www.googleapis.com/auth/books"
|
||
|
// ]
|
||
|
// }
|
||
|
|
||
|
}
|
||
|
|
||
|
// method id "books.layers.volumeAnnotations.get":
|
||
|
|
||
|
type LayersVolumeAnnotationsGetCall struct {
|
||
|
s *Service
|
||
|
volumeId string
|
||
|
layerId string
|
||
|
annotationId string
|
||
|
opt_ map[string]interface{}
|
||
|
ctx_ context.Context
|
||
|
}
|
||
|
|
||
|
// Get: Gets the volume annotation.
|
||
|
func (r *LayersVolumeAnnotationsService) Get(volumeId string, layerId string, annotationId string) *LayersVolumeAnnotationsGetCall {
|
||
|
c := &LayersVolumeAnnotationsGetCall{s: r.s, opt_: make(map[string]interface{})}
|
||
|
c.volumeId = volumeId
|
||
|
c.layerId = layerId
|
||
|
c.annotationId = annotationId
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
// Locale sets the optional parameter "locale": The locale information
|
||
|
// for the data. ISO-639-1 language and ISO-3166-1 country code. Ex:
|
||
|
// 'en_US'.
|
||
|
func (c *LayersVolumeAnnotationsGetCall) Locale(locale string) *LayersVolumeAnnotationsGetCall {
|
||
|
c.opt_["locale"] = locale
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
// Source sets the optional parameter "source": String to identify the
|
||
|
// originator of this request.
|
||
|
func (c *LayersVolumeAnnotationsGetCall) Source(source string) *LayersVolumeAnnotationsGetCall {
|
||
|
c.opt_["source"] = source
|
||
|
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 *LayersVolumeAnnotationsGetCall) Fields(s ...googleapi.Field) *LayersVolumeAnnotationsGetCall {
|
||
|
c.opt_["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 *LayersVolumeAnnotationsGetCall) IfNoneMatch(entityTag string) *LayersVolumeAnnotationsGetCall {
|
||
|
c.opt_["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 *LayersVolumeAnnotationsGetCall) Context(ctx context.Context) *LayersVolumeAnnotationsGetCall {
|
||
|
c.ctx_ = ctx
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
func (c *LayersVolumeAnnotationsGetCall) doRequest(alt string) (*http.Response, error) {
|
||
|
var body io.Reader = nil
|
||
|
params := make(url.Values)
|
||
|
params.Set("alt", alt)
|
||
|
if v, ok := c.opt_["locale"]; ok {
|
||
|
params.Set("locale", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if v, ok := c.opt_["source"]; ok {
|
||
|
params.Set("source", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if v, ok := c.opt_["fields"]; ok {
|
||
|
params.Set("fields", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
urls := googleapi.ResolveRelative(c.s.BasePath, "volumes/{volumeId}/layers/{layerId}/annotations/{annotationId}")
|
||
|
urls += "?" + params.Encode()
|
||
|
req, _ := http.NewRequest("GET", urls, body)
|
||
|
googleapi.Expand(req.URL, map[string]string{
|
||
|
"volumeId": c.volumeId,
|
||
|
"layerId": c.layerId,
|
||
|
"annotationId": c.annotationId,
|
||
|
})
|
||
|
req.Header.Set("User-Agent", c.s.userAgent())
|
||
|
if v, ok := c.opt_["ifNoneMatch"]; ok {
|
||
|
req.Header.Set("If-None-Match", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if c.ctx_ != nil {
|
||
|
return ctxhttp.Do(c.ctx_, c.s.client, req)
|
||
|
}
|
||
|
return c.s.client.Do(req)
|
||
|
}
|
||
|
|
||
|
// Do executes the "books.layers.volumeAnnotations.get" call.
|
||
|
// Exactly one of *Volumeannotation or error will be non-nil. Any
|
||
|
// non-2xx status code is an error. Response headers are in either
|
||
|
// *Volumeannotation.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 *LayersVolumeAnnotationsGetCall) Do() (*Volumeannotation, error) {
|
||
|
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 := &Volumeannotation{
|
||
|
ServerResponse: googleapi.ServerResponse{
|
||
|
Header: res.Header,
|
||
|
HTTPStatusCode: res.StatusCode,
|
||
|
},
|
||
|
}
|
||
|
if err := json.NewDecoder(res.Body).Decode(&ret); err != nil {
|
||
|
return nil, err
|
||
|
}
|
||
|
return ret, nil
|
||
|
// {
|
||
|
// "description": "Gets the volume annotation.",
|
||
|
// "httpMethod": "GET",
|
||
|
// "id": "books.layers.volumeAnnotations.get",
|
||
|
// "parameterOrder": [
|
||
|
// "volumeId",
|
||
|
// "layerId",
|
||
|
// "annotationId"
|
||
|
// ],
|
||
|
// "parameters": {
|
||
|
// "annotationId": {
|
||
|
// "description": "The ID of the volume annotation to retrieve.",
|
||
|
// "location": "path",
|
||
|
// "required": true,
|
||
|
// "type": "string"
|
||
|
// },
|
||
|
// "layerId": {
|
||
|
// "description": "The ID for the layer to get the annotations.",
|
||
|
// "location": "path",
|
||
|
// "required": true,
|
||
|
// "type": "string"
|
||
|
// },
|
||
|
// "locale": {
|
||
|
// "description": "The locale information for the data. ISO-639-1 language and ISO-3166-1 country code. Ex: 'en_US'.",
|
||
|
// "location": "query",
|
||
|
// "type": "string"
|
||
|
// },
|
||
|
// "source": {
|
||
|
// "description": "String to identify the originator of this request.",
|
||
|
// "location": "query",
|
||
|
// "type": "string"
|
||
|
// },
|
||
|
// "volumeId": {
|
||
|
// "description": "The volume to retrieve annotations for.",
|
||
|
// "location": "path",
|
||
|
// "required": true,
|
||
|
// "type": "string"
|
||
|
// }
|
||
|
// },
|
||
|
// "path": "volumes/{volumeId}/layers/{layerId}/annotations/{annotationId}",
|
||
|
// "response": {
|
||
|
// "$ref": "Volumeannotation"
|
||
|
// },
|
||
|
// "scopes": [
|
||
|
// "https://www.googleapis.com/auth/books"
|
||
|
// ]
|
||
|
// }
|
||
|
|
||
|
}
|
||
|
|
||
|
// method id "books.layers.volumeAnnotations.list":
|
||
|
|
||
|
type LayersVolumeAnnotationsListCall struct {
|
||
|
s *Service
|
||
|
volumeId string
|
||
|
layerId string
|
||
|
contentVersion string
|
||
|
opt_ map[string]interface{}
|
||
|
ctx_ context.Context
|
||
|
}
|
||
|
|
||
|
// List: Gets the volume annotations for a volume and layer.
|
||
|
func (r *LayersVolumeAnnotationsService) List(volumeId string, layerId string, contentVersion string) *LayersVolumeAnnotationsListCall {
|
||
|
c := &LayersVolumeAnnotationsListCall{s: r.s, opt_: make(map[string]interface{})}
|
||
|
c.volumeId = volumeId
|
||
|
c.layerId = layerId
|
||
|
c.contentVersion = contentVersion
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
// EndOffset sets the optional parameter "endOffset": The end offset to
|
||
|
// end retrieving data from.
|
||
|
func (c *LayersVolumeAnnotationsListCall) EndOffset(endOffset string) *LayersVolumeAnnotationsListCall {
|
||
|
c.opt_["endOffset"] = endOffset
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
// EndPosition sets the optional parameter "endPosition": The end
|
||
|
// position to end retrieving data from.
|
||
|
func (c *LayersVolumeAnnotationsListCall) EndPosition(endPosition string) *LayersVolumeAnnotationsListCall {
|
||
|
c.opt_["endPosition"] = endPosition
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
// Locale sets the optional parameter "locale": The locale information
|
||
|
// for the data. ISO-639-1 language and ISO-3166-1 country code. Ex:
|
||
|
// 'en_US'.
|
||
|
func (c *LayersVolumeAnnotationsListCall) Locale(locale string) *LayersVolumeAnnotationsListCall {
|
||
|
c.opt_["locale"] = locale
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
// MaxResults sets the optional parameter "maxResults": Maximum number
|
||
|
// of results to return
|
||
|
func (c *LayersVolumeAnnotationsListCall) MaxResults(maxResults int64) *LayersVolumeAnnotationsListCall {
|
||
|
c.opt_["maxResults"] = maxResults
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
// PageToken sets the optional parameter "pageToken": The value of the
|
||
|
// nextToken from the previous page.
|
||
|
func (c *LayersVolumeAnnotationsListCall) PageToken(pageToken string) *LayersVolumeAnnotationsListCall {
|
||
|
c.opt_["pageToken"] = pageToken
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
// ShowDeleted sets the optional parameter "showDeleted": Set to true to
|
||
|
// return deleted annotations. updatedMin must be in the request to use
|
||
|
// this. Defaults to false.
|
||
|
func (c *LayersVolumeAnnotationsListCall) ShowDeleted(showDeleted bool) *LayersVolumeAnnotationsListCall {
|
||
|
c.opt_["showDeleted"] = showDeleted
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
// Source sets the optional parameter "source": String to identify the
|
||
|
// originator of this request.
|
||
|
func (c *LayersVolumeAnnotationsListCall) Source(source string) *LayersVolumeAnnotationsListCall {
|
||
|
c.opt_["source"] = source
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
// StartOffset sets the optional parameter "startOffset": The start
|
||
|
// offset to start retrieving data from.
|
||
|
func (c *LayersVolumeAnnotationsListCall) StartOffset(startOffset string) *LayersVolumeAnnotationsListCall {
|
||
|
c.opt_["startOffset"] = startOffset
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
// StartPosition sets the optional parameter "startPosition": The start
|
||
|
// position to start retrieving data from.
|
||
|
func (c *LayersVolumeAnnotationsListCall) StartPosition(startPosition string) *LayersVolumeAnnotationsListCall {
|
||
|
c.opt_["startPosition"] = startPosition
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
// UpdatedMax sets the optional parameter "updatedMax": RFC 3339
|
||
|
// timestamp to restrict to items updated prior to this timestamp
|
||
|
// (exclusive).
|
||
|
func (c *LayersVolumeAnnotationsListCall) UpdatedMax(updatedMax string) *LayersVolumeAnnotationsListCall {
|
||
|
c.opt_["updatedMax"] = updatedMax
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
// UpdatedMin sets the optional parameter "updatedMin": RFC 3339
|
||
|
// timestamp to restrict to items updated since this timestamp
|
||
|
// (inclusive).
|
||
|
func (c *LayersVolumeAnnotationsListCall) UpdatedMin(updatedMin string) *LayersVolumeAnnotationsListCall {
|
||
|
c.opt_["updatedMin"] = updatedMin
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
// VolumeAnnotationsVersion sets the optional parameter
|
||
|
// "volumeAnnotationsVersion": The version of the volume annotations
|
||
|
// that you are requesting.
|
||
|
func (c *LayersVolumeAnnotationsListCall) VolumeAnnotationsVersion(volumeAnnotationsVersion string) *LayersVolumeAnnotationsListCall {
|
||
|
c.opt_["volumeAnnotationsVersion"] = volumeAnnotationsVersion
|
||
|
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 *LayersVolumeAnnotationsListCall) Fields(s ...googleapi.Field) *LayersVolumeAnnotationsListCall {
|
||
|
c.opt_["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 *LayersVolumeAnnotationsListCall) IfNoneMatch(entityTag string) *LayersVolumeAnnotationsListCall {
|
||
|
c.opt_["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 *LayersVolumeAnnotationsListCall) Context(ctx context.Context) *LayersVolumeAnnotationsListCall {
|
||
|
c.ctx_ = ctx
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
func (c *LayersVolumeAnnotationsListCall) doRequest(alt string) (*http.Response, error) {
|
||
|
var body io.Reader = nil
|
||
|
params := make(url.Values)
|
||
|
params.Set("alt", alt)
|
||
|
params.Set("contentVersion", fmt.Sprintf("%v", c.contentVersion))
|
||
|
if v, ok := c.opt_["endOffset"]; ok {
|
||
|
params.Set("endOffset", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if v, ok := c.opt_["endPosition"]; ok {
|
||
|
params.Set("endPosition", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if v, ok := c.opt_["locale"]; ok {
|
||
|
params.Set("locale", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if v, ok := c.opt_["maxResults"]; ok {
|
||
|
params.Set("maxResults", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if v, ok := c.opt_["pageToken"]; ok {
|
||
|
params.Set("pageToken", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if v, ok := c.opt_["showDeleted"]; ok {
|
||
|
params.Set("showDeleted", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if v, ok := c.opt_["source"]; ok {
|
||
|
params.Set("source", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if v, ok := c.opt_["startOffset"]; ok {
|
||
|
params.Set("startOffset", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if v, ok := c.opt_["startPosition"]; ok {
|
||
|
params.Set("startPosition", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if v, ok := c.opt_["updatedMax"]; ok {
|
||
|
params.Set("updatedMax", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if v, ok := c.opt_["updatedMin"]; ok {
|
||
|
params.Set("updatedMin", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if v, ok := c.opt_["volumeAnnotationsVersion"]; ok {
|
||
|
params.Set("volumeAnnotationsVersion", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if v, ok := c.opt_["fields"]; ok {
|
||
|
params.Set("fields", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
urls := googleapi.ResolveRelative(c.s.BasePath, "volumes/{volumeId}/layers/{layerId}")
|
||
|
urls += "?" + params.Encode()
|
||
|
req, _ := http.NewRequest("GET", urls, body)
|
||
|
googleapi.Expand(req.URL, map[string]string{
|
||
|
"volumeId": c.volumeId,
|
||
|
"layerId": c.layerId,
|
||
|
})
|
||
|
req.Header.Set("User-Agent", c.s.userAgent())
|
||
|
if v, ok := c.opt_["ifNoneMatch"]; ok {
|
||
|
req.Header.Set("If-None-Match", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if c.ctx_ != nil {
|
||
|
return ctxhttp.Do(c.ctx_, c.s.client, req)
|
||
|
}
|
||
|
return c.s.client.Do(req)
|
||
|
}
|
||
|
|
||
|
// Do executes the "books.layers.volumeAnnotations.list" call.
|
||
|
// Exactly one of *Volumeannotations or error will be non-nil. Any
|
||
|
// non-2xx status code is an error. Response headers are in either
|
||
|
// *Volumeannotations.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 *LayersVolumeAnnotationsListCall) Do() (*Volumeannotations, error) {
|
||
|
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 := &Volumeannotations{
|
||
|
ServerResponse: googleapi.ServerResponse{
|
||
|
Header: res.Header,
|
||
|
HTTPStatusCode: res.StatusCode,
|
||
|
},
|
||
|
}
|
||
|
if err := json.NewDecoder(res.Body).Decode(&ret); err != nil {
|
||
|
return nil, err
|
||
|
}
|
||
|
return ret, nil
|
||
|
// {
|
||
|
// "description": "Gets the volume annotations for a volume and layer.",
|
||
|
// "httpMethod": "GET",
|
||
|
// "id": "books.layers.volumeAnnotations.list",
|
||
|
// "parameterOrder": [
|
||
|
// "volumeId",
|
||
|
// "layerId",
|
||
|
// "contentVersion"
|
||
|
// ],
|
||
|
// "parameters": {
|
||
|
// "contentVersion": {
|
||
|
// "description": "The content version for the requested volume.",
|
||
|
// "location": "query",
|
||
|
// "required": true,
|
||
|
// "type": "string"
|
||
|
// },
|
||
|
// "endOffset": {
|
||
|
// "description": "The end offset to end retrieving data from.",
|
||
|
// "location": "query",
|
||
|
// "type": "string"
|
||
|
// },
|
||
|
// "endPosition": {
|
||
|
// "description": "The end position to end retrieving data from.",
|
||
|
// "location": "query",
|
||
|
// "type": "string"
|
||
|
// },
|
||
|
// "layerId": {
|
||
|
// "description": "The ID for the layer to get the annotations.",
|
||
|
// "location": "path",
|
||
|
// "required": true,
|
||
|
// "type": "string"
|
||
|
// },
|
||
|
// "locale": {
|
||
|
// "description": "The locale information for the data. ISO-639-1 language and ISO-3166-1 country code. Ex: 'en_US'.",
|
||
|
// "location": "query",
|
||
|
// "type": "string"
|
||
|
// },
|
||
|
// "maxResults": {
|
||
|
// "description": "Maximum number of results to return",
|
||
|
// "format": "uint32",
|
||
|
// "location": "query",
|
||
|
// "maximum": "200",
|
||
|
// "minimum": "0",
|
||
|
// "type": "integer"
|
||
|
// },
|
||
|
// "pageToken": {
|
||
|
// "description": "The value of the nextToken from the previous page.",
|
||
|
// "location": "query",
|
||
|
// "type": "string"
|
||
|
// },
|
||
|
// "showDeleted": {
|
||
|
// "description": "Set to true to return deleted annotations. updatedMin must be in the request to use this. Defaults to false.",
|
||
|
// "location": "query",
|
||
|
// "type": "boolean"
|
||
|
// },
|
||
|
// "source": {
|
||
|
// "description": "String to identify the originator of this request.",
|
||
|
// "location": "query",
|
||
|
// "type": "string"
|
||
|
// },
|
||
|
// "startOffset": {
|
||
|
// "description": "The start offset to start retrieving data from.",
|
||
|
// "location": "query",
|
||
|
// "type": "string"
|
||
|
// },
|
||
|
// "startPosition": {
|
||
|
// "description": "The start position to start retrieving data from.",
|
||
|
// "location": "query",
|
||
|
// "type": "string"
|
||
|
// },
|
||
|
// "updatedMax": {
|
||
|
// "description": "RFC 3339 timestamp to restrict to items updated prior to this timestamp (exclusive).",
|
||
|
// "location": "query",
|
||
|
// "type": "string"
|
||
|
// },
|
||
|
// "updatedMin": {
|
||
|
// "description": "RFC 3339 timestamp to restrict to items updated since this timestamp (inclusive).",
|
||
|
// "location": "query",
|
||
|
// "type": "string"
|
||
|
// },
|
||
|
// "volumeAnnotationsVersion": {
|
||
|
// "description": "The version of the volume annotations that you are requesting.",
|
||
|
// "location": "query",
|
||
|
// "type": "string"
|
||
|
// },
|
||
|
// "volumeId": {
|
||
|
// "description": "The volume to retrieve annotations for.",
|
||
|
// "location": "path",
|
||
|
// "required": true,
|
||
|
// "type": "string"
|
||
|
// }
|
||
|
// },
|
||
|
// "path": "volumes/{volumeId}/layers/{layerId}",
|
||
|
// "response": {
|
||
|
// "$ref": "Volumeannotations"
|
||
|
// },
|
||
|
// "scopes": [
|
||
|
// "https://www.googleapis.com/auth/books"
|
||
|
// ]
|
||
|
// }
|
||
|
|
||
|
}
|
||
|
|
||
|
// method id "books.myconfig.getUserSettings":
|
||
|
|
||
|
type MyconfigGetUserSettingsCall struct {
|
||
|
s *Service
|
||
|
opt_ map[string]interface{}
|
||
|
ctx_ context.Context
|
||
|
}
|
||
|
|
||
|
// GetUserSettings: Gets the current settings for the user.
|
||
|
func (r *MyconfigService) GetUserSettings() *MyconfigGetUserSettingsCall {
|
||
|
c := &MyconfigGetUserSettingsCall{s: r.s, opt_: make(map[string]interface{})}
|
||
|
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 *MyconfigGetUserSettingsCall) Fields(s ...googleapi.Field) *MyconfigGetUserSettingsCall {
|
||
|
c.opt_["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 *MyconfigGetUserSettingsCall) IfNoneMatch(entityTag string) *MyconfigGetUserSettingsCall {
|
||
|
c.opt_["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 *MyconfigGetUserSettingsCall) Context(ctx context.Context) *MyconfigGetUserSettingsCall {
|
||
|
c.ctx_ = ctx
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
func (c *MyconfigGetUserSettingsCall) doRequest(alt string) (*http.Response, error) {
|
||
|
var body io.Reader = nil
|
||
|
params := make(url.Values)
|
||
|
params.Set("alt", alt)
|
||
|
if v, ok := c.opt_["fields"]; ok {
|
||
|
params.Set("fields", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
urls := googleapi.ResolveRelative(c.s.BasePath, "myconfig/getUserSettings")
|
||
|
urls += "?" + params.Encode()
|
||
|
req, _ := http.NewRequest("GET", urls, body)
|
||
|
googleapi.SetOpaque(req.URL)
|
||
|
req.Header.Set("User-Agent", c.s.userAgent())
|
||
|
if v, ok := c.opt_["ifNoneMatch"]; ok {
|
||
|
req.Header.Set("If-None-Match", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if c.ctx_ != nil {
|
||
|
return ctxhttp.Do(c.ctx_, c.s.client, req)
|
||
|
}
|
||
|
return c.s.client.Do(req)
|
||
|
}
|
||
|
|
||
|
// Do executes the "books.myconfig.getUserSettings" call.
|
||
|
// Exactly one of *Usersettings or error will be non-nil. Any non-2xx
|
||
|
// status code is an error. Response headers are in either
|
||
|
// *Usersettings.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 *MyconfigGetUserSettingsCall) Do() (*Usersettings, error) {
|
||
|
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 := &Usersettings{
|
||
|
ServerResponse: googleapi.ServerResponse{
|
||
|
Header: res.Header,
|
||
|
HTTPStatusCode: res.StatusCode,
|
||
|
},
|
||
|
}
|
||
|
if err := json.NewDecoder(res.Body).Decode(&ret); err != nil {
|
||
|
return nil, err
|
||
|
}
|
||
|
return ret, nil
|
||
|
// {
|
||
|
// "description": "Gets the current settings for the user.",
|
||
|
// "httpMethod": "GET",
|
||
|
// "id": "books.myconfig.getUserSettings",
|
||
|
// "path": "myconfig/getUserSettings",
|
||
|
// "response": {
|
||
|
// "$ref": "Usersettings"
|
||
|
// },
|
||
|
// "scopes": [
|
||
|
// "https://www.googleapis.com/auth/books"
|
||
|
// ]
|
||
|
// }
|
||
|
|
||
|
}
|
||
|
|
||
|
// method id "books.myconfig.releaseDownloadAccess":
|
||
|
|
||
|
type MyconfigReleaseDownloadAccessCall struct {
|
||
|
s *Service
|
||
|
volumeIds []string
|
||
|
cpksver string
|
||
|
opt_ map[string]interface{}
|
||
|
ctx_ context.Context
|
||
|
}
|
||
|
|
||
|
// ReleaseDownloadAccess: Release downloaded content access restriction.
|
||
|
func (r *MyconfigService) ReleaseDownloadAccess(volumeIds []string, cpksver string) *MyconfigReleaseDownloadAccessCall {
|
||
|
c := &MyconfigReleaseDownloadAccessCall{s: r.s, opt_: make(map[string]interface{})}
|
||
|
c.volumeIds = volumeIds
|
||
|
c.cpksver = cpksver
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
// Locale sets the optional parameter "locale": ISO-639-1, ISO-3166-1
|
||
|
// codes for message localization, i.e. en_US.
|
||
|
func (c *MyconfigReleaseDownloadAccessCall) Locale(locale string) *MyconfigReleaseDownloadAccessCall {
|
||
|
c.opt_["locale"] = locale
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
// Source sets the optional parameter "source": String to identify the
|
||
|
// originator of this request.
|
||
|
func (c *MyconfigReleaseDownloadAccessCall) Source(source string) *MyconfigReleaseDownloadAccessCall {
|
||
|
c.opt_["source"] = source
|
||
|
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 *MyconfigReleaseDownloadAccessCall) Fields(s ...googleapi.Field) *MyconfigReleaseDownloadAccessCall {
|
||
|
c.opt_["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 *MyconfigReleaseDownloadAccessCall) Context(ctx context.Context) *MyconfigReleaseDownloadAccessCall {
|
||
|
c.ctx_ = ctx
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
func (c *MyconfigReleaseDownloadAccessCall) doRequest(alt string) (*http.Response, error) {
|
||
|
var body io.Reader = nil
|
||
|
params := make(url.Values)
|
||
|
params.Set("alt", alt)
|
||
|
params.Set("cpksver", fmt.Sprintf("%v", c.cpksver))
|
||
|
for _, v := range c.volumeIds {
|
||
|
params.Add("volumeIds", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if v, ok := c.opt_["locale"]; ok {
|
||
|
params.Set("locale", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if v, ok := c.opt_["source"]; ok {
|
||
|
params.Set("source", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if v, ok := c.opt_["fields"]; ok {
|
||
|
params.Set("fields", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
urls := googleapi.ResolveRelative(c.s.BasePath, "myconfig/releaseDownloadAccess")
|
||
|
urls += "?" + params.Encode()
|
||
|
req, _ := http.NewRequest("POST", urls, body)
|
||
|
googleapi.SetOpaque(req.URL)
|
||
|
req.Header.Set("User-Agent", c.s.userAgent())
|
||
|
if c.ctx_ != nil {
|
||
|
return ctxhttp.Do(c.ctx_, c.s.client, req)
|
||
|
}
|
||
|
return c.s.client.Do(req)
|
||
|
}
|
||
|
|
||
|
// Do executes the "books.myconfig.releaseDownloadAccess" call.
|
||
|
// Exactly one of *DownloadAccesses or error will be non-nil. Any
|
||
|
// non-2xx status code is an error. Response headers are in either
|
||
|
// *DownloadAccesses.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 *MyconfigReleaseDownloadAccessCall) Do() (*DownloadAccesses, error) {
|
||
|
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 := &DownloadAccesses{
|
||
|
ServerResponse: googleapi.ServerResponse{
|
||
|
Header: res.Header,
|
||
|
HTTPStatusCode: res.StatusCode,
|
||
|
},
|
||
|
}
|
||
|
if err := json.NewDecoder(res.Body).Decode(&ret); err != nil {
|
||
|
return nil, err
|
||
|
}
|
||
|
return ret, nil
|
||
|
// {
|
||
|
// "description": "Release downloaded content access restriction.",
|
||
|
// "httpMethod": "POST",
|
||
|
// "id": "books.myconfig.releaseDownloadAccess",
|
||
|
// "parameterOrder": [
|
||
|
// "volumeIds",
|
||
|
// "cpksver"
|
||
|
// ],
|
||
|
// "parameters": {
|
||
|
// "cpksver": {
|
||
|
// "description": "The device/version ID from which to release the restriction.",
|
||
|
// "location": "query",
|
||
|
// "required": true,
|
||
|
// "type": "string"
|
||
|
// },
|
||
|
// "locale": {
|
||
|
// "description": "ISO-639-1, ISO-3166-1 codes for message localization, i.e. en_US.",
|
||
|
// "location": "query",
|
||
|
// "type": "string"
|
||
|
// },
|
||
|
// "source": {
|
||
|
// "description": "String to identify the originator of this request.",
|
||
|
// "location": "query",
|
||
|
// "type": "string"
|
||
|
// },
|
||
|
// "volumeIds": {
|
||
|
// "description": "The volume(s) to release restrictions for.",
|
||
|
// "location": "query",
|
||
|
// "repeated": true,
|
||
|
// "required": true,
|
||
|
// "type": "string"
|
||
|
// }
|
||
|
// },
|
||
|
// "path": "myconfig/releaseDownloadAccess",
|
||
|
// "response": {
|
||
|
// "$ref": "DownloadAccesses"
|
||
|
// },
|
||
|
// "scopes": [
|
||
|
// "https://www.googleapis.com/auth/books"
|
||
|
// ]
|
||
|
// }
|
||
|
|
||
|
}
|
||
|
|
||
|
// method id "books.myconfig.requestAccess":
|
||
|
|
||
|
type MyconfigRequestAccessCall struct {
|
||
|
s *Service
|
||
|
source string
|
||
|
volumeId string
|
||
|
nonce string
|
||
|
cpksver string
|
||
|
opt_ map[string]interface{}
|
||
|
ctx_ context.Context
|
||
|
}
|
||
|
|
||
|
// RequestAccess: Request concurrent and download access restrictions.
|
||
|
func (r *MyconfigService) RequestAccess(source string, volumeId string, nonce string, cpksver string) *MyconfigRequestAccessCall {
|
||
|
c := &MyconfigRequestAccessCall{s: r.s, opt_: make(map[string]interface{})}
|
||
|
c.source = source
|
||
|
c.volumeId = volumeId
|
||
|
c.nonce = nonce
|
||
|
c.cpksver = cpksver
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
// LicenseTypes sets the optional parameter "licenseTypes": The type of
|
||
|
// access license to request. If not specified, the default is BOTH.
|
||
|
//
|
||
|
// Possible values:
|
||
|
// "BOTH" - Both concurrent and download licenses.
|
||
|
// "CONCURRENT" - Concurrent access license.
|
||
|
// "DOWNLOAD" - Offline download access license.
|
||
|
func (c *MyconfigRequestAccessCall) LicenseTypes(licenseTypes string) *MyconfigRequestAccessCall {
|
||
|
c.opt_["licenseTypes"] = licenseTypes
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
// Locale sets the optional parameter "locale": ISO-639-1, ISO-3166-1
|
||
|
// codes for message localization, i.e. en_US.
|
||
|
func (c *MyconfigRequestAccessCall) Locale(locale string) *MyconfigRequestAccessCall {
|
||
|
c.opt_["locale"] = locale
|
||
|
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 *MyconfigRequestAccessCall) Fields(s ...googleapi.Field) *MyconfigRequestAccessCall {
|
||
|
c.opt_["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 *MyconfigRequestAccessCall) Context(ctx context.Context) *MyconfigRequestAccessCall {
|
||
|
c.ctx_ = ctx
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
func (c *MyconfigRequestAccessCall) doRequest(alt string) (*http.Response, error) {
|
||
|
var body io.Reader = nil
|
||
|
params := make(url.Values)
|
||
|
params.Set("alt", alt)
|
||
|
params.Set("cpksver", fmt.Sprintf("%v", c.cpksver))
|
||
|
params.Set("nonce", fmt.Sprintf("%v", c.nonce))
|
||
|
params.Set("source", fmt.Sprintf("%v", c.source))
|
||
|
params.Set("volumeId", fmt.Sprintf("%v", c.volumeId))
|
||
|
if v, ok := c.opt_["licenseTypes"]; ok {
|
||
|
params.Set("licenseTypes", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if v, ok := c.opt_["locale"]; ok {
|
||
|
params.Set("locale", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if v, ok := c.opt_["fields"]; ok {
|
||
|
params.Set("fields", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
urls := googleapi.ResolveRelative(c.s.BasePath, "myconfig/requestAccess")
|
||
|
urls += "?" + params.Encode()
|
||
|
req, _ := http.NewRequest("POST", urls, body)
|
||
|
googleapi.SetOpaque(req.URL)
|
||
|
req.Header.Set("User-Agent", c.s.userAgent())
|
||
|
if c.ctx_ != nil {
|
||
|
return ctxhttp.Do(c.ctx_, c.s.client, req)
|
||
|
}
|
||
|
return c.s.client.Do(req)
|
||
|
}
|
||
|
|
||
|
// Do executes the "books.myconfig.requestAccess" call.
|
||
|
// Exactly one of *RequestAccess or error will be non-nil. Any non-2xx
|
||
|
// status code is an error. Response headers are in either
|
||
|
// *RequestAccess.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 *MyconfigRequestAccessCall) Do() (*RequestAccess, error) {
|
||
|
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 := &RequestAccess{
|
||
|
ServerResponse: googleapi.ServerResponse{
|
||
|
Header: res.Header,
|
||
|
HTTPStatusCode: res.StatusCode,
|
||
|
},
|
||
|
}
|
||
|
if err := json.NewDecoder(res.Body).Decode(&ret); err != nil {
|
||
|
return nil, err
|
||
|
}
|
||
|
return ret, nil
|
||
|
// {
|
||
|
// "description": "Request concurrent and download access restrictions.",
|
||
|
// "httpMethod": "POST",
|
||
|
// "id": "books.myconfig.requestAccess",
|
||
|
// "parameterOrder": [
|
||
|
// "source",
|
||
|
// "volumeId",
|
||
|
// "nonce",
|
||
|
// "cpksver"
|
||
|
// ],
|
||
|
// "parameters": {
|
||
|
// "cpksver": {
|
||
|
// "description": "The device/version ID from which to request the restrictions.",
|
||
|
// "location": "query",
|
||
|
// "required": true,
|
||
|
// "type": "string"
|
||
|
// },
|
||
|
// "licenseTypes": {
|
||
|
// "description": "The type of access license to request. If not specified, the default is BOTH.",
|
||
|
// "enum": [
|
||
|
// "BOTH",
|
||
|
// "CONCURRENT",
|
||
|
// "DOWNLOAD"
|
||
|
// ],
|
||
|
// "enumDescriptions": [
|
||
|
// "Both concurrent and download licenses.",
|
||
|
// "Concurrent access license.",
|
||
|
// "Offline download access license."
|
||
|
// ],
|
||
|
// "location": "query",
|
||
|
// "type": "string"
|
||
|
// },
|
||
|
// "locale": {
|
||
|
// "description": "ISO-639-1, ISO-3166-1 codes for message localization, i.e. en_US.",
|
||
|
// "location": "query",
|
||
|
// "type": "string"
|
||
|
// },
|
||
|
// "nonce": {
|
||
|
// "description": "The client nonce value.",
|
||
|
// "location": "query",
|
||
|
// "required": true,
|
||
|
// "type": "string"
|
||
|
// },
|
||
|
// "source": {
|
||
|
// "description": "String to identify the originator of this request.",
|
||
|
// "location": "query",
|
||
|
// "required": true,
|
||
|
// "type": "string"
|
||
|
// },
|
||
|
// "volumeId": {
|
||
|
// "description": "The volume to request concurrent/download restrictions for.",
|
||
|
// "location": "query",
|
||
|
// "required": true,
|
||
|
// "type": "string"
|
||
|
// }
|
||
|
// },
|
||
|
// "path": "myconfig/requestAccess",
|
||
|
// "response": {
|
||
|
// "$ref": "RequestAccess"
|
||
|
// },
|
||
|
// "scopes": [
|
||
|
// "https://www.googleapis.com/auth/books"
|
||
|
// ]
|
||
|
// }
|
||
|
|
||
|
}
|
||
|
|
||
|
// method id "books.myconfig.syncVolumeLicenses":
|
||
|
|
||
|
type MyconfigSyncVolumeLicensesCall struct {
|
||
|
s *Service
|
||
|
source string
|
||
|
nonce string
|
||
|
cpksver string
|
||
|
opt_ map[string]interface{}
|
||
|
ctx_ context.Context
|
||
|
}
|
||
|
|
||
|
// SyncVolumeLicenses: Request downloaded content access for specified
|
||
|
// volumes on the My eBooks shelf.
|
||
|
func (r *MyconfigService) SyncVolumeLicenses(source string, nonce string, cpksver string) *MyconfigSyncVolumeLicensesCall {
|
||
|
c := &MyconfigSyncVolumeLicensesCall{s: r.s, opt_: make(map[string]interface{})}
|
||
|
c.source = source
|
||
|
c.nonce = nonce
|
||
|
c.cpksver = cpksver
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
// Features sets the optional parameter "features": List of features
|
||
|
// supported by the client, i.e., 'RENTALS'
|
||
|
//
|
||
|
// Possible values:
|
||
|
// "RENTALS" - Client supports rentals.
|
||
|
func (c *MyconfigSyncVolumeLicensesCall) Features(features string) *MyconfigSyncVolumeLicensesCall {
|
||
|
c.opt_["features"] = features
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
// Locale sets the optional parameter "locale": ISO-639-1, ISO-3166-1
|
||
|
// codes for message localization, i.e. en_US.
|
||
|
func (c *MyconfigSyncVolumeLicensesCall) Locale(locale string) *MyconfigSyncVolumeLicensesCall {
|
||
|
c.opt_["locale"] = locale
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
// ShowPreorders sets the optional parameter "showPreorders": Set to
|
||
|
// true to show pre-ordered books. Defaults to false.
|
||
|
func (c *MyconfigSyncVolumeLicensesCall) ShowPreorders(showPreorders bool) *MyconfigSyncVolumeLicensesCall {
|
||
|
c.opt_["showPreorders"] = showPreorders
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
// VolumeIds sets the optional parameter "volumeIds": The volume(s) to
|
||
|
// request download restrictions for.
|
||
|
func (c *MyconfigSyncVolumeLicensesCall) VolumeIds(volumeIds string) *MyconfigSyncVolumeLicensesCall {
|
||
|
c.opt_["volumeIds"] = volumeIds
|
||
|
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 *MyconfigSyncVolumeLicensesCall) Fields(s ...googleapi.Field) *MyconfigSyncVolumeLicensesCall {
|
||
|
c.opt_["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 *MyconfigSyncVolumeLicensesCall) Context(ctx context.Context) *MyconfigSyncVolumeLicensesCall {
|
||
|
c.ctx_ = ctx
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
func (c *MyconfigSyncVolumeLicensesCall) doRequest(alt string) (*http.Response, error) {
|
||
|
var body io.Reader = nil
|
||
|
params := make(url.Values)
|
||
|
params.Set("alt", alt)
|
||
|
params.Set("cpksver", fmt.Sprintf("%v", c.cpksver))
|
||
|
params.Set("nonce", fmt.Sprintf("%v", c.nonce))
|
||
|
params.Set("source", fmt.Sprintf("%v", c.source))
|
||
|
if v, ok := c.opt_["features"]; ok {
|
||
|
params.Set("features", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if v, ok := c.opt_["locale"]; ok {
|
||
|
params.Set("locale", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if v, ok := c.opt_["showPreorders"]; ok {
|
||
|
params.Set("showPreorders", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if v, ok := c.opt_["volumeIds"]; ok {
|
||
|
params.Set("volumeIds", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if v, ok := c.opt_["fields"]; ok {
|
||
|
params.Set("fields", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
urls := googleapi.ResolveRelative(c.s.BasePath, "myconfig/syncVolumeLicenses")
|
||
|
urls += "?" + params.Encode()
|
||
|
req, _ := http.NewRequest("POST", urls, body)
|
||
|
googleapi.SetOpaque(req.URL)
|
||
|
req.Header.Set("User-Agent", c.s.userAgent())
|
||
|
if c.ctx_ != nil {
|
||
|
return ctxhttp.Do(c.ctx_, c.s.client, req)
|
||
|
}
|
||
|
return c.s.client.Do(req)
|
||
|
}
|
||
|
|
||
|
// Do executes the "books.myconfig.syncVolumeLicenses" call.
|
||
|
// Exactly one of *Volumes or error will be non-nil. Any non-2xx status
|
||
|
// code is an error. Response headers are in either
|
||
|
// *Volumes.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 *MyconfigSyncVolumeLicensesCall) Do() (*Volumes, error) {
|
||
|
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 := &Volumes{
|
||
|
ServerResponse: googleapi.ServerResponse{
|
||
|
Header: res.Header,
|
||
|
HTTPStatusCode: res.StatusCode,
|
||
|
},
|
||
|
}
|
||
|
if err := json.NewDecoder(res.Body).Decode(&ret); err != nil {
|
||
|
return nil, err
|
||
|
}
|
||
|
return ret, nil
|
||
|
// {
|
||
|
// "description": "Request downloaded content access for specified volumes on the My eBooks shelf.",
|
||
|
// "httpMethod": "POST",
|
||
|
// "id": "books.myconfig.syncVolumeLicenses",
|
||
|
// "parameterOrder": [
|
||
|
// "source",
|
||
|
// "nonce",
|
||
|
// "cpksver"
|
||
|
// ],
|
||
|
// "parameters": {
|
||
|
// "cpksver": {
|
||
|
// "description": "The device/version ID from which to release the restriction.",
|
||
|
// "location": "query",
|
||
|
// "required": true,
|
||
|
// "type": "string"
|
||
|
// },
|
||
|
// "features": {
|
||
|
// "description": "List of features supported by the client, i.e., 'RENTALS'",
|
||
|
// "enum": [
|
||
|
// "RENTALS"
|
||
|
// ],
|
||
|
// "enumDescriptions": [
|
||
|
// "Client supports rentals."
|
||
|
// ],
|
||
|
// "location": "query",
|
||
|
// "repeated": true,
|
||
|
// "type": "string"
|
||
|
// },
|
||
|
// "locale": {
|
||
|
// "description": "ISO-639-1, ISO-3166-1 codes for message localization, i.e. en_US.",
|
||
|
// "location": "query",
|
||
|
// "type": "string"
|
||
|
// },
|
||
|
// "nonce": {
|
||
|
// "description": "The client nonce value.",
|
||
|
// "location": "query",
|
||
|
// "required": true,
|
||
|
// "type": "string"
|
||
|
// },
|
||
|
// "showPreorders": {
|
||
|
// "description": "Set to true to show pre-ordered books. Defaults to false.",
|
||
|
// "location": "query",
|
||
|
// "type": "boolean"
|
||
|
// },
|
||
|
// "source": {
|
||
|
// "description": "String to identify the originator of this request.",
|
||
|
// "location": "query",
|
||
|
// "required": true,
|
||
|
// "type": "string"
|
||
|
// },
|
||
|
// "volumeIds": {
|
||
|
// "description": "The volume(s) to request download restrictions for.",
|
||
|
// "location": "query",
|
||
|
// "repeated": true,
|
||
|
// "type": "string"
|
||
|
// }
|
||
|
// },
|
||
|
// "path": "myconfig/syncVolumeLicenses",
|
||
|
// "response": {
|
||
|
// "$ref": "Volumes"
|
||
|
// },
|
||
|
// "scopes": [
|
||
|
// "https://www.googleapis.com/auth/books"
|
||
|
// ]
|
||
|
// }
|
||
|
|
||
|
}
|
||
|
|
||
|
// method id "books.myconfig.updateUserSettings":
|
||
|
|
||
|
type MyconfigUpdateUserSettingsCall struct {
|
||
|
s *Service
|
||
|
usersettings *Usersettings
|
||
|
opt_ map[string]interface{}
|
||
|
ctx_ context.Context
|
||
|
}
|
||
|
|
||
|
// UpdateUserSettings: Sets the settings for the user. If a sub-object
|
||
|
// is specified, it will overwrite the existing sub-object stored in the
|
||
|
// server. Unspecified sub-objects will retain the existing value.
|
||
|
func (r *MyconfigService) UpdateUserSettings(usersettings *Usersettings) *MyconfigUpdateUserSettingsCall {
|
||
|
c := &MyconfigUpdateUserSettingsCall{s: r.s, opt_: make(map[string]interface{})}
|
||
|
c.usersettings = usersettings
|
||
|
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 *MyconfigUpdateUserSettingsCall) Fields(s ...googleapi.Field) *MyconfigUpdateUserSettingsCall {
|
||
|
c.opt_["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 *MyconfigUpdateUserSettingsCall) Context(ctx context.Context) *MyconfigUpdateUserSettingsCall {
|
||
|
c.ctx_ = ctx
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
func (c *MyconfigUpdateUserSettingsCall) doRequest(alt string) (*http.Response, error) {
|
||
|
var body io.Reader = nil
|
||
|
body, err := googleapi.WithoutDataWrapper.JSONReader(c.usersettings)
|
||
|
if err != nil {
|
||
|
return nil, err
|
||
|
}
|
||
|
ctype := "application/json"
|
||
|
params := make(url.Values)
|
||
|
params.Set("alt", alt)
|
||
|
if v, ok := c.opt_["fields"]; ok {
|
||
|
params.Set("fields", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
urls := googleapi.ResolveRelative(c.s.BasePath, "myconfig/updateUserSettings")
|
||
|
urls += "?" + params.Encode()
|
||
|
req, _ := http.NewRequest("POST", urls, body)
|
||
|
googleapi.SetOpaque(req.URL)
|
||
|
req.Header.Set("Content-Type", ctype)
|
||
|
req.Header.Set("User-Agent", c.s.userAgent())
|
||
|
if c.ctx_ != nil {
|
||
|
return ctxhttp.Do(c.ctx_, c.s.client, req)
|
||
|
}
|
||
|
return c.s.client.Do(req)
|
||
|
}
|
||
|
|
||
|
// Do executes the "books.myconfig.updateUserSettings" call.
|
||
|
// Exactly one of *Usersettings or error will be non-nil. Any non-2xx
|
||
|
// status code is an error. Response headers are in either
|
||
|
// *Usersettings.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 *MyconfigUpdateUserSettingsCall) Do() (*Usersettings, error) {
|
||
|
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 := &Usersettings{
|
||
|
ServerResponse: googleapi.ServerResponse{
|
||
|
Header: res.Header,
|
||
|
HTTPStatusCode: res.StatusCode,
|
||
|
},
|
||
|
}
|
||
|
if err := json.NewDecoder(res.Body).Decode(&ret); err != nil {
|
||
|
return nil, err
|
||
|
}
|
||
|
return ret, nil
|
||
|
// {
|
||
|
// "description": "Sets the settings for the user. If a sub-object is specified, it will overwrite the existing sub-object stored in the server. Unspecified sub-objects will retain the existing value.",
|
||
|
// "httpMethod": "POST",
|
||
|
// "id": "books.myconfig.updateUserSettings",
|
||
|
// "path": "myconfig/updateUserSettings",
|
||
|
// "request": {
|
||
|
// "$ref": "Usersettings"
|
||
|
// },
|
||
|
// "response": {
|
||
|
// "$ref": "Usersettings"
|
||
|
// },
|
||
|
// "scopes": [
|
||
|
// "https://www.googleapis.com/auth/books"
|
||
|
// ]
|
||
|
// }
|
||
|
|
||
|
}
|
||
|
|
||
|
// method id "books.mylibrary.annotations.delete":
|
||
|
|
||
|
type MylibraryAnnotationsDeleteCall struct {
|
||
|
s *Service
|
||
|
annotationId string
|
||
|
opt_ map[string]interface{}
|
||
|
ctx_ context.Context
|
||
|
}
|
||
|
|
||
|
// Delete: Deletes an annotation.
|
||
|
func (r *MylibraryAnnotationsService) Delete(annotationId string) *MylibraryAnnotationsDeleteCall {
|
||
|
c := &MylibraryAnnotationsDeleteCall{s: r.s, opt_: make(map[string]interface{})}
|
||
|
c.annotationId = annotationId
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
// Source sets the optional parameter "source": String to identify the
|
||
|
// originator of this request.
|
||
|
func (c *MylibraryAnnotationsDeleteCall) Source(source string) *MylibraryAnnotationsDeleteCall {
|
||
|
c.opt_["source"] = source
|
||
|
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 *MylibraryAnnotationsDeleteCall) Fields(s ...googleapi.Field) *MylibraryAnnotationsDeleteCall {
|
||
|
c.opt_["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 *MylibraryAnnotationsDeleteCall) Context(ctx context.Context) *MylibraryAnnotationsDeleteCall {
|
||
|
c.ctx_ = ctx
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
func (c *MylibraryAnnotationsDeleteCall) doRequest(alt string) (*http.Response, error) {
|
||
|
var body io.Reader = nil
|
||
|
params := make(url.Values)
|
||
|
params.Set("alt", alt)
|
||
|
if v, ok := c.opt_["source"]; ok {
|
||
|
params.Set("source", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if v, ok := c.opt_["fields"]; ok {
|
||
|
params.Set("fields", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
urls := googleapi.ResolveRelative(c.s.BasePath, "mylibrary/annotations/{annotationId}")
|
||
|
urls += "?" + params.Encode()
|
||
|
req, _ := http.NewRequest("DELETE", urls, body)
|
||
|
googleapi.Expand(req.URL, map[string]string{
|
||
|
"annotationId": c.annotationId,
|
||
|
})
|
||
|
req.Header.Set("User-Agent", c.s.userAgent())
|
||
|
if c.ctx_ != nil {
|
||
|
return ctxhttp.Do(c.ctx_, c.s.client, req)
|
||
|
}
|
||
|
return c.s.client.Do(req)
|
||
|
}
|
||
|
|
||
|
// Do executes the "books.mylibrary.annotations.delete" call.
|
||
|
func (c *MylibraryAnnotationsDeleteCall) Do() error {
|
||
|
res, err := c.doRequest("json")
|
||
|
if err != nil {
|
||
|
return err
|
||
|
}
|
||
|
defer googleapi.CloseBody(res)
|
||
|
if err := googleapi.CheckResponse(res); err != nil {
|
||
|
return err
|
||
|
}
|
||
|
return nil
|
||
|
// {
|
||
|
// "description": "Deletes an annotation.",
|
||
|
// "httpMethod": "DELETE",
|
||
|
// "id": "books.mylibrary.annotations.delete",
|
||
|
// "parameterOrder": [
|
||
|
// "annotationId"
|
||
|
// ],
|
||
|
// "parameters": {
|
||
|
// "annotationId": {
|
||
|
// "description": "The ID for the annotation to delete.",
|
||
|
// "location": "path",
|
||
|
// "required": true,
|
||
|
// "type": "string"
|
||
|
// },
|
||
|
// "source": {
|
||
|
// "description": "String to identify the originator of this request.",
|
||
|
// "location": "query",
|
||
|
// "type": "string"
|
||
|
// }
|
||
|
// },
|
||
|
// "path": "mylibrary/annotations/{annotationId}",
|
||
|
// "scopes": [
|
||
|
// "https://www.googleapis.com/auth/books"
|
||
|
// ]
|
||
|
// }
|
||
|
|
||
|
}
|
||
|
|
||
|
// method id "books.mylibrary.annotations.insert":
|
||
|
|
||
|
type MylibraryAnnotationsInsertCall struct {
|
||
|
s *Service
|
||
|
annotation *Annotation
|
||
|
opt_ map[string]interface{}
|
||
|
ctx_ context.Context
|
||
|
}
|
||
|
|
||
|
// Insert: Inserts a new annotation.
|
||
|
func (r *MylibraryAnnotationsService) Insert(annotation *Annotation) *MylibraryAnnotationsInsertCall {
|
||
|
c := &MylibraryAnnotationsInsertCall{s: r.s, opt_: make(map[string]interface{})}
|
||
|
c.annotation = annotation
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
// Country sets the optional parameter "country": ISO-3166-1 code to
|
||
|
// override the IP-based location.
|
||
|
func (c *MylibraryAnnotationsInsertCall) Country(country string) *MylibraryAnnotationsInsertCall {
|
||
|
c.opt_["country"] = country
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
// ShowOnlySummaryInResponse sets the optional parameter
|
||
|
// "showOnlySummaryInResponse": Requests that only the summary of the
|
||
|
// specified layer be provided in the response.
|
||
|
func (c *MylibraryAnnotationsInsertCall) ShowOnlySummaryInResponse(showOnlySummaryInResponse bool) *MylibraryAnnotationsInsertCall {
|
||
|
c.opt_["showOnlySummaryInResponse"] = showOnlySummaryInResponse
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
// Source sets the optional parameter "source": String to identify the
|
||
|
// originator of this request.
|
||
|
func (c *MylibraryAnnotationsInsertCall) Source(source string) *MylibraryAnnotationsInsertCall {
|
||
|
c.opt_["source"] = source
|
||
|
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 *MylibraryAnnotationsInsertCall) Fields(s ...googleapi.Field) *MylibraryAnnotationsInsertCall {
|
||
|
c.opt_["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 *MylibraryAnnotationsInsertCall) Context(ctx context.Context) *MylibraryAnnotationsInsertCall {
|
||
|
c.ctx_ = ctx
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
func (c *MylibraryAnnotationsInsertCall) doRequest(alt string) (*http.Response, error) {
|
||
|
var body io.Reader = nil
|
||
|
body, err := googleapi.WithoutDataWrapper.JSONReader(c.annotation)
|
||
|
if err != nil {
|
||
|
return nil, err
|
||
|
}
|
||
|
ctype := "application/json"
|
||
|
params := make(url.Values)
|
||
|
params.Set("alt", alt)
|
||
|
if v, ok := c.opt_["country"]; ok {
|
||
|
params.Set("country", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if v, ok := c.opt_["showOnlySummaryInResponse"]; ok {
|
||
|
params.Set("showOnlySummaryInResponse", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if v, ok := c.opt_["source"]; ok {
|
||
|
params.Set("source", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if v, ok := c.opt_["fields"]; ok {
|
||
|
params.Set("fields", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
urls := googleapi.ResolveRelative(c.s.BasePath, "mylibrary/annotations")
|
||
|
urls += "?" + params.Encode()
|
||
|
req, _ := http.NewRequest("POST", urls, body)
|
||
|
googleapi.SetOpaque(req.URL)
|
||
|
req.Header.Set("Content-Type", ctype)
|
||
|
req.Header.Set("User-Agent", c.s.userAgent())
|
||
|
if c.ctx_ != nil {
|
||
|
return ctxhttp.Do(c.ctx_, c.s.client, req)
|
||
|
}
|
||
|
return c.s.client.Do(req)
|
||
|
}
|
||
|
|
||
|
// Do executes the "books.mylibrary.annotations.insert" call.
|
||
|
// Exactly one of *Annotation or error will be non-nil. Any non-2xx
|
||
|
// status code is an error. Response headers are in either
|
||
|
// *Annotation.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 *MylibraryAnnotationsInsertCall) Do() (*Annotation, error) {
|
||
|
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 := &Annotation{
|
||
|
ServerResponse: googleapi.ServerResponse{
|
||
|
Header: res.Header,
|
||
|
HTTPStatusCode: res.StatusCode,
|
||
|
},
|
||
|
}
|
||
|
if err := json.NewDecoder(res.Body).Decode(&ret); err != nil {
|
||
|
return nil, err
|
||
|
}
|
||
|
return ret, nil
|
||
|
// {
|
||
|
// "description": "Inserts a new annotation.",
|
||
|
// "httpMethod": "POST",
|
||
|
// "id": "books.mylibrary.annotations.insert",
|
||
|
// "parameters": {
|
||
|
// "country": {
|
||
|
// "description": "ISO-3166-1 code to override the IP-based location.",
|
||
|
// "location": "query",
|
||
|
// "type": "string"
|
||
|
// },
|
||
|
// "showOnlySummaryInResponse": {
|
||
|
// "description": "Requests that only the summary of the specified layer be provided in the response.",
|
||
|
// "location": "query",
|
||
|
// "type": "boolean"
|
||
|
// },
|
||
|
// "source": {
|
||
|
// "description": "String to identify the originator of this request.",
|
||
|
// "location": "query",
|
||
|
// "type": "string"
|
||
|
// }
|
||
|
// },
|
||
|
// "path": "mylibrary/annotations",
|
||
|
// "request": {
|
||
|
// "$ref": "Annotation"
|
||
|
// },
|
||
|
// "response": {
|
||
|
// "$ref": "Annotation"
|
||
|
// },
|
||
|
// "scopes": [
|
||
|
// "https://www.googleapis.com/auth/books"
|
||
|
// ]
|
||
|
// }
|
||
|
|
||
|
}
|
||
|
|
||
|
// method id "books.mylibrary.annotations.list":
|
||
|
|
||
|
type MylibraryAnnotationsListCall struct {
|
||
|
s *Service
|
||
|
opt_ map[string]interface{}
|
||
|
ctx_ context.Context
|
||
|
}
|
||
|
|
||
|
// List: Retrieves a list of annotations, possibly filtered.
|
||
|
func (r *MylibraryAnnotationsService) List() *MylibraryAnnotationsListCall {
|
||
|
c := &MylibraryAnnotationsListCall{s: r.s, opt_: make(map[string]interface{})}
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
// ContentVersion sets the optional parameter "contentVersion": The
|
||
|
// content version for the requested volume.
|
||
|
func (c *MylibraryAnnotationsListCall) ContentVersion(contentVersion string) *MylibraryAnnotationsListCall {
|
||
|
c.opt_["contentVersion"] = contentVersion
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
// LayerId sets the optional parameter "layerId": The layer ID to limit
|
||
|
// annotation by.
|
||
|
func (c *MylibraryAnnotationsListCall) LayerId(layerId string) *MylibraryAnnotationsListCall {
|
||
|
c.opt_["layerId"] = layerId
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
// LayerIds sets the optional parameter "layerIds": The layer ID(s) to
|
||
|
// limit annotation by.
|
||
|
func (c *MylibraryAnnotationsListCall) LayerIds(layerIds string) *MylibraryAnnotationsListCall {
|
||
|
c.opt_["layerIds"] = layerIds
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
// MaxResults sets the optional parameter "maxResults": Maximum number
|
||
|
// of results to return
|
||
|
func (c *MylibraryAnnotationsListCall) MaxResults(maxResults int64) *MylibraryAnnotationsListCall {
|
||
|
c.opt_["maxResults"] = maxResults
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
// PageToken sets the optional parameter "pageToken": The value of the
|
||
|
// nextToken from the previous page.
|
||
|
func (c *MylibraryAnnotationsListCall) PageToken(pageToken string) *MylibraryAnnotationsListCall {
|
||
|
c.opt_["pageToken"] = pageToken
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
// ShowDeleted sets the optional parameter "showDeleted": Set to true to
|
||
|
// return deleted annotations. updatedMin must be in the request to use
|
||
|
// this. Defaults to false.
|
||
|
func (c *MylibraryAnnotationsListCall) ShowDeleted(showDeleted bool) *MylibraryAnnotationsListCall {
|
||
|
c.opt_["showDeleted"] = showDeleted
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
// Source sets the optional parameter "source": String to identify the
|
||
|
// originator of this request.
|
||
|
func (c *MylibraryAnnotationsListCall) Source(source string) *MylibraryAnnotationsListCall {
|
||
|
c.opt_["source"] = source
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
// UpdatedMax sets the optional parameter "updatedMax": RFC 3339
|
||
|
// timestamp to restrict to items updated prior to this timestamp
|
||
|
// (exclusive).
|
||
|
func (c *MylibraryAnnotationsListCall) UpdatedMax(updatedMax string) *MylibraryAnnotationsListCall {
|
||
|
c.opt_["updatedMax"] = updatedMax
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
// UpdatedMin sets the optional parameter "updatedMin": RFC 3339
|
||
|
// timestamp to restrict to items updated since this timestamp
|
||
|
// (inclusive).
|
||
|
func (c *MylibraryAnnotationsListCall) UpdatedMin(updatedMin string) *MylibraryAnnotationsListCall {
|
||
|
c.opt_["updatedMin"] = updatedMin
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
// VolumeId sets the optional parameter "volumeId": The volume to
|
||
|
// restrict annotations to.
|
||
|
func (c *MylibraryAnnotationsListCall) VolumeId(volumeId string) *MylibraryAnnotationsListCall {
|
||
|
c.opt_["volumeId"] = volumeId
|
||
|
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 *MylibraryAnnotationsListCall) Fields(s ...googleapi.Field) *MylibraryAnnotationsListCall {
|
||
|
c.opt_["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 *MylibraryAnnotationsListCall) IfNoneMatch(entityTag string) *MylibraryAnnotationsListCall {
|
||
|
c.opt_["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 *MylibraryAnnotationsListCall) Context(ctx context.Context) *MylibraryAnnotationsListCall {
|
||
|
c.ctx_ = ctx
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
func (c *MylibraryAnnotationsListCall) doRequest(alt string) (*http.Response, error) {
|
||
|
var body io.Reader = nil
|
||
|
params := make(url.Values)
|
||
|
params.Set("alt", alt)
|
||
|
if v, ok := c.opt_["contentVersion"]; ok {
|
||
|
params.Set("contentVersion", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if v, ok := c.opt_["layerId"]; ok {
|
||
|
params.Set("layerId", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if v, ok := c.opt_["layerIds"]; ok {
|
||
|
params.Set("layerIds", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if v, ok := c.opt_["maxResults"]; ok {
|
||
|
params.Set("maxResults", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if v, ok := c.opt_["pageToken"]; ok {
|
||
|
params.Set("pageToken", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if v, ok := c.opt_["showDeleted"]; ok {
|
||
|
params.Set("showDeleted", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if v, ok := c.opt_["source"]; ok {
|
||
|
params.Set("source", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if v, ok := c.opt_["updatedMax"]; ok {
|
||
|
params.Set("updatedMax", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if v, ok := c.opt_["updatedMin"]; ok {
|
||
|
params.Set("updatedMin", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if v, ok := c.opt_["volumeId"]; ok {
|
||
|
params.Set("volumeId", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if v, ok := c.opt_["fields"]; ok {
|
||
|
params.Set("fields", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
urls := googleapi.ResolveRelative(c.s.BasePath, "mylibrary/annotations")
|
||
|
urls += "?" + params.Encode()
|
||
|
req, _ := http.NewRequest("GET", urls, body)
|
||
|
googleapi.SetOpaque(req.URL)
|
||
|
req.Header.Set("User-Agent", c.s.userAgent())
|
||
|
if v, ok := c.opt_["ifNoneMatch"]; ok {
|
||
|
req.Header.Set("If-None-Match", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if c.ctx_ != nil {
|
||
|
return ctxhttp.Do(c.ctx_, c.s.client, req)
|
||
|
}
|
||
|
return c.s.client.Do(req)
|
||
|
}
|
||
|
|
||
|
// Do executes the "books.mylibrary.annotations.list" call.
|
||
|
// Exactly one of *Annotations or error will be non-nil. Any non-2xx
|
||
|
// status code is an error. Response headers are in either
|
||
|
// *Annotations.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 *MylibraryAnnotationsListCall) Do() (*Annotations, error) {
|
||
|
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 := &Annotations{
|
||
|
ServerResponse: googleapi.ServerResponse{
|
||
|
Header: res.Header,
|
||
|
HTTPStatusCode: res.StatusCode,
|
||
|
},
|
||
|
}
|
||
|
if err := json.NewDecoder(res.Body).Decode(&ret); err != nil {
|
||
|
return nil, err
|
||
|
}
|
||
|
return ret, nil
|
||
|
// {
|
||
|
// "description": "Retrieves a list of annotations, possibly filtered.",
|
||
|
// "httpMethod": "GET",
|
||
|
// "id": "books.mylibrary.annotations.list",
|
||
|
// "parameters": {
|
||
|
// "contentVersion": {
|
||
|
// "description": "The content version for the requested volume.",
|
||
|
// "location": "query",
|
||
|
// "type": "string"
|
||
|
// },
|
||
|
// "layerId": {
|
||
|
// "description": "The layer ID to limit annotation by.",
|
||
|
// "location": "query",
|
||
|
// "type": "string"
|
||
|
// },
|
||
|
// "layerIds": {
|
||
|
// "description": "The layer ID(s) to limit annotation by.",
|
||
|
// "location": "query",
|
||
|
// "repeated": true,
|
||
|
// "type": "string"
|
||
|
// },
|
||
|
// "maxResults": {
|
||
|
// "description": "Maximum number of results to return",
|
||
|
// "format": "uint32",
|
||
|
// "location": "query",
|
||
|
// "maximum": "40",
|
||
|
// "minimum": "0",
|
||
|
// "type": "integer"
|
||
|
// },
|
||
|
// "pageToken": {
|
||
|
// "description": "The value of the nextToken from the previous page.",
|
||
|
// "location": "query",
|
||
|
// "type": "string"
|
||
|
// },
|
||
|
// "showDeleted": {
|
||
|
// "description": "Set to true to return deleted annotations. updatedMin must be in the request to use this. Defaults to false.",
|
||
|
// "location": "query",
|
||
|
// "type": "boolean"
|
||
|
// },
|
||
|
// "source": {
|
||
|
// "description": "String to identify the originator of this request.",
|
||
|
// "location": "query",
|
||
|
// "type": "string"
|
||
|
// },
|
||
|
// "updatedMax": {
|
||
|
// "description": "RFC 3339 timestamp to restrict to items updated prior to this timestamp (exclusive).",
|
||
|
// "location": "query",
|
||
|
// "type": "string"
|
||
|
// },
|
||
|
// "updatedMin": {
|
||
|
// "description": "RFC 3339 timestamp to restrict to items updated since this timestamp (inclusive).",
|
||
|
// "location": "query",
|
||
|
// "type": "string"
|
||
|
// },
|
||
|
// "volumeId": {
|
||
|
// "description": "The volume to restrict annotations to.",
|
||
|
// "location": "query",
|
||
|
// "type": "string"
|
||
|
// }
|
||
|
// },
|
||
|
// "path": "mylibrary/annotations",
|
||
|
// "response": {
|
||
|
// "$ref": "Annotations"
|
||
|
// },
|
||
|
// "scopes": [
|
||
|
// "https://www.googleapis.com/auth/books"
|
||
|
// ]
|
||
|
// }
|
||
|
|
||
|
}
|
||
|
|
||
|
// method id "books.mylibrary.annotations.summary":
|
||
|
|
||
|
type MylibraryAnnotationsSummaryCall struct {
|
||
|
s *Service
|
||
|
layerIds []string
|
||
|
volumeId string
|
||
|
opt_ map[string]interface{}
|
||
|
ctx_ context.Context
|
||
|
}
|
||
|
|
||
|
// Summary: Gets the summary of specified layers.
|
||
|
func (r *MylibraryAnnotationsService) Summary(layerIds []string, volumeId string) *MylibraryAnnotationsSummaryCall {
|
||
|
c := &MylibraryAnnotationsSummaryCall{s: r.s, opt_: make(map[string]interface{})}
|
||
|
c.layerIds = layerIds
|
||
|
c.volumeId = volumeId
|
||
|
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 *MylibraryAnnotationsSummaryCall) Fields(s ...googleapi.Field) *MylibraryAnnotationsSummaryCall {
|
||
|
c.opt_["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 *MylibraryAnnotationsSummaryCall) Context(ctx context.Context) *MylibraryAnnotationsSummaryCall {
|
||
|
c.ctx_ = ctx
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
func (c *MylibraryAnnotationsSummaryCall) doRequest(alt string) (*http.Response, error) {
|
||
|
var body io.Reader = nil
|
||
|
params := make(url.Values)
|
||
|
params.Set("alt", alt)
|
||
|
params.Set("volumeId", fmt.Sprintf("%v", c.volumeId))
|
||
|
for _, v := range c.layerIds {
|
||
|
params.Add("layerIds", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if v, ok := c.opt_["fields"]; ok {
|
||
|
params.Set("fields", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
urls := googleapi.ResolveRelative(c.s.BasePath, "mylibrary/annotations/summary")
|
||
|
urls += "?" + params.Encode()
|
||
|
req, _ := http.NewRequest("POST", urls, body)
|
||
|
googleapi.SetOpaque(req.URL)
|
||
|
req.Header.Set("User-Agent", c.s.userAgent())
|
||
|
if c.ctx_ != nil {
|
||
|
return ctxhttp.Do(c.ctx_, c.s.client, req)
|
||
|
}
|
||
|
return c.s.client.Do(req)
|
||
|
}
|
||
|
|
||
|
// Do executes the "books.mylibrary.annotations.summary" call.
|
||
|
// Exactly one of *AnnotationsSummary or error will be non-nil. Any
|
||
|
// non-2xx status code is an error. Response headers are in either
|
||
|
// *AnnotationsSummary.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 *MylibraryAnnotationsSummaryCall) Do() (*AnnotationsSummary, error) {
|
||
|
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 := &AnnotationsSummary{
|
||
|
ServerResponse: googleapi.ServerResponse{
|
||
|
Header: res.Header,
|
||
|
HTTPStatusCode: res.StatusCode,
|
||
|
},
|
||
|
}
|
||
|
if err := json.NewDecoder(res.Body).Decode(&ret); err != nil {
|
||
|
return nil, err
|
||
|
}
|
||
|
return ret, nil
|
||
|
// {
|
||
|
// "description": "Gets the summary of specified layers.",
|
||
|
// "httpMethod": "POST",
|
||
|
// "id": "books.mylibrary.annotations.summary",
|
||
|
// "parameterOrder": [
|
||
|
// "layerIds",
|
||
|
// "volumeId"
|
||
|
// ],
|
||
|
// "parameters": {
|
||
|
// "layerIds": {
|
||
|
// "description": "Array of layer IDs to get the summary for.",
|
||
|
// "location": "query",
|
||
|
// "repeated": true,
|
||
|
// "required": true,
|
||
|
// "type": "string"
|
||
|
// },
|
||
|
// "volumeId": {
|
||
|
// "description": "Volume id to get the summary for.",
|
||
|
// "location": "query",
|
||
|
// "required": true,
|
||
|
// "type": "string"
|
||
|
// }
|
||
|
// },
|
||
|
// "path": "mylibrary/annotations/summary",
|
||
|
// "response": {
|
||
|
// "$ref": "AnnotationsSummary"
|
||
|
// },
|
||
|
// "scopes": [
|
||
|
// "https://www.googleapis.com/auth/books"
|
||
|
// ]
|
||
|
// }
|
||
|
|
||
|
}
|
||
|
|
||
|
// method id "books.mylibrary.annotations.update":
|
||
|
|
||
|
type MylibraryAnnotationsUpdateCall struct {
|
||
|
s *Service
|
||
|
annotationId string
|
||
|
annotation *Annotation
|
||
|
opt_ map[string]interface{}
|
||
|
ctx_ context.Context
|
||
|
}
|
||
|
|
||
|
// Update: Updates an existing annotation.
|
||
|
func (r *MylibraryAnnotationsService) Update(annotationId string, annotation *Annotation) *MylibraryAnnotationsUpdateCall {
|
||
|
c := &MylibraryAnnotationsUpdateCall{s: r.s, opt_: make(map[string]interface{})}
|
||
|
c.annotationId = annotationId
|
||
|
c.annotation = annotation
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
// Source sets the optional parameter "source": String to identify the
|
||
|
// originator of this request.
|
||
|
func (c *MylibraryAnnotationsUpdateCall) Source(source string) *MylibraryAnnotationsUpdateCall {
|
||
|
c.opt_["source"] = source
|
||
|
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 *MylibraryAnnotationsUpdateCall) Fields(s ...googleapi.Field) *MylibraryAnnotationsUpdateCall {
|
||
|
c.opt_["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 *MylibraryAnnotationsUpdateCall) Context(ctx context.Context) *MylibraryAnnotationsUpdateCall {
|
||
|
c.ctx_ = ctx
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
func (c *MylibraryAnnotationsUpdateCall) doRequest(alt string) (*http.Response, error) {
|
||
|
var body io.Reader = nil
|
||
|
body, err := googleapi.WithoutDataWrapper.JSONReader(c.annotation)
|
||
|
if err != nil {
|
||
|
return nil, err
|
||
|
}
|
||
|
ctype := "application/json"
|
||
|
params := make(url.Values)
|
||
|
params.Set("alt", alt)
|
||
|
if v, ok := c.opt_["source"]; ok {
|
||
|
params.Set("source", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if v, ok := c.opt_["fields"]; ok {
|
||
|
params.Set("fields", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
urls := googleapi.ResolveRelative(c.s.BasePath, "mylibrary/annotations/{annotationId}")
|
||
|
urls += "?" + params.Encode()
|
||
|
req, _ := http.NewRequest("PUT", urls, body)
|
||
|
googleapi.Expand(req.URL, map[string]string{
|
||
|
"annotationId": c.annotationId,
|
||
|
})
|
||
|
req.Header.Set("Content-Type", ctype)
|
||
|
req.Header.Set("User-Agent", c.s.userAgent())
|
||
|
if c.ctx_ != nil {
|
||
|
return ctxhttp.Do(c.ctx_, c.s.client, req)
|
||
|
}
|
||
|
return c.s.client.Do(req)
|
||
|
}
|
||
|
|
||
|
// Do executes the "books.mylibrary.annotations.update" call.
|
||
|
// Exactly one of *Annotation or error will be non-nil. Any non-2xx
|
||
|
// status code is an error. Response headers are in either
|
||
|
// *Annotation.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 *MylibraryAnnotationsUpdateCall) Do() (*Annotation, error) {
|
||
|
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 := &Annotation{
|
||
|
ServerResponse: googleapi.ServerResponse{
|
||
|
Header: res.Header,
|
||
|
HTTPStatusCode: res.StatusCode,
|
||
|
},
|
||
|
}
|
||
|
if err := json.NewDecoder(res.Body).Decode(&ret); err != nil {
|
||
|
return nil, err
|
||
|
}
|
||
|
return ret, nil
|
||
|
// {
|
||
|
// "description": "Updates an existing annotation.",
|
||
|
// "httpMethod": "PUT",
|
||
|
// "id": "books.mylibrary.annotations.update",
|
||
|
// "parameterOrder": [
|
||
|
// "annotationId"
|
||
|
// ],
|
||
|
// "parameters": {
|
||
|
// "annotationId": {
|
||
|
// "description": "The ID for the annotation to update.",
|
||
|
// "location": "path",
|
||
|
// "required": true,
|
||
|
// "type": "string"
|
||
|
// },
|
||
|
// "source": {
|
||
|
// "description": "String to identify the originator of this request.",
|
||
|
// "location": "query",
|
||
|
// "type": "string"
|
||
|
// }
|
||
|
// },
|
||
|
// "path": "mylibrary/annotations/{annotationId}",
|
||
|
// "request": {
|
||
|
// "$ref": "Annotation"
|
||
|
// },
|
||
|
// "response": {
|
||
|
// "$ref": "Annotation"
|
||
|
// },
|
||
|
// "scopes": [
|
||
|
// "https://www.googleapis.com/auth/books"
|
||
|
// ]
|
||
|
// }
|
||
|
|
||
|
}
|
||
|
|
||
|
// method id "books.mylibrary.bookshelves.addVolume":
|
||
|
|
||
|
type MylibraryBookshelvesAddVolumeCall struct {
|
||
|
s *Service
|
||
|
shelf string
|
||
|
volumeId string
|
||
|
opt_ map[string]interface{}
|
||
|
ctx_ context.Context
|
||
|
}
|
||
|
|
||
|
// AddVolume: Adds a volume to a bookshelf.
|
||
|
func (r *MylibraryBookshelvesService) AddVolume(shelf string, volumeId string) *MylibraryBookshelvesAddVolumeCall {
|
||
|
c := &MylibraryBookshelvesAddVolumeCall{s: r.s, opt_: make(map[string]interface{})}
|
||
|
c.shelf = shelf
|
||
|
c.volumeId = volumeId
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
// Reason sets the optional parameter "reason": The reason for which the
|
||
|
// book is added to the library.
|
||
|
//
|
||
|
// Possible values:
|
||
|
// "IOS_PREX" - Volumes added from the PREX flow on iOS.
|
||
|
// "IOS_SEARCH" - Volumes added from the Search flow on iOS.
|
||
|
// "ONBOARDING" - Volumes added from the Onboarding flow.
|
||
|
func (c *MylibraryBookshelvesAddVolumeCall) Reason(reason string) *MylibraryBookshelvesAddVolumeCall {
|
||
|
c.opt_["reason"] = reason
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
// Source sets the optional parameter "source": String to identify the
|
||
|
// originator of this request.
|
||
|
func (c *MylibraryBookshelvesAddVolumeCall) Source(source string) *MylibraryBookshelvesAddVolumeCall {
|
||
|
c.opt_["source"] = source
|
||
|
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 *MylibraryBookshelvesAddVolumeCall) Fields(s ...googleapi.Field) *MylibraryBookshelvesAddVolumeCall {
|
||
|
c.opt_["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 *MylibraryBookshelvesAddVolumeCall) Context(ctx context.Context) *MylibraryBookshelvesAddVolumeCall {
|
||
|
c.ctx_ = ctx
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
func (c *MylibraryBookshelvesAddVolumeCall) doRequest(alt string) (*http.Response, error) {
|
||
|
var body io.Reader = nil
|
||
|
params := make(url.Values)
|
||
|
params.Set("alt", alt)
|
||
|
params.Set("volumeId", fmt.Sprintf("%v", c.volumeId))
|
||
|
if v, ok := c.opt_["reason"]; ok {
|
||
|
params.Set("reason", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if v, ok := c.opt_["source"]; ok {
|
||
|
params.Set("source", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if v, ok := c.opt_["fields"]; ok {
|
||
|
params.Set("fields", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
urls := googleapi.ResolveRelative(c.s.BasePath, "mylibrary/bookshelves/{shelf}/addVolume")
|
||
|
urls += "?" + params.Encode()
|
||
|
req, _ := http.NewRequest("POST", urls, body)
|
||
|
googleapi.Expand(req.URL, map[string]string{
|
||
|
"shelf": c.shelf,
|
||
|
})
|
||
|
req.Header.Set("User-Agent", c.s.userAgent())
|
||
|
if c.ctx_ != nil {
|
||
|
return ctxhttp.Do(c.ctx_, c.s.client, req)
|
||
|
}
|
||
|
return c.s.client.Do(req)
|
||
|
}
|
||
|
|
||
|
// Do executes the "books.mylibrary.bookshelves.addVolume" call.
|
||
|
func (c *MylibraryBookshelvesAddVolumeCall) Do() error {
|
||
|
res, err := c.doRequest("json")
|
||
|
if err != nil {
|
||
|
return err
|
||
|
}
|
||
|
defer googleapi.CloseBody(res)
|
||
|
if err := googleapi.CheckResponse(res); err != nil {
|
||
|
return err
|
||
|
}
|
||
|
return nil
|
||
|
// {
|
||
|
// "description": "Adds a volume to a bookshelf.",
|
||
|
// "httpMethod": "POST",
|
||
|
// "id": "books.mylibrary.bookshelves.addVolume",
|
||
|
// "parameterOrder": [
|
||
|
// "shelf",
|
||
|
// "volumeId"
|
||
|
// ],
|
||
|
// "parameters": {
|
||
|
// "reason": {
|
||
|
// "description": "The reason for which the book is added to the library.",
|
||
|
// "enum": [
|
||
|
// "IOS_PREX",
|
||
|
// "IOS_SEARCH",
|
||
|
// "ONBOARDING"
|
||
|
// ],
|
||
|
// "enumDescriptions": [
|
||
|
// "Volumes added from the PREX flow on iOS.",
|
||
|
// "Volumes added from the Search flow on iOS.",
|
||
|
// "Volumes added from the Onboarding flow."
|
||
|
// ],
|
||
|
// "location": "query",
|
||
|
// "type": "string"
|
||
|
// },
|
||
|
// "shelf": {
|
||
|
// "description": "ID of bookshelf to which to add a volume.",
|
||
|
// "location": "path",
|
||
|
// "required": true,
|
||
|
// "type": "string"
|
||
|
// },
|
||
|
// "source": {
|
||
|
// "description": "String to identify the originator of this request.",
|
||
|
// "location": "query",
|
||
|
// "type": "string"
|
||
|
// },
|
||
|
// "volumeId": {
|
||
|
// "description": "ID of volume to add.",
|
||
|
// "location": "query",
|
||
|
// "required": true,
|
||
|
// "type": "string"
|
||
|
// }
|
||
|
// },
|
||
|
// "path": "mylibrary/bookshelves/{shelf}/addVolume",
|
||
|
// "scopes": [
|
||
|
// "https://www.googleapis.com/auth/books"
|
||
|
// ]
|
||
|
// }
|
||
|
|
||
|
}
|
||
|
|
||
|
// method id "books.mylibrary.bookshelves.clearVolumes":
|
||
|
|
||
|
type MylibraryBookshelvesClearVolumesCall struct {
|
||
|
s *Service
|
||
|
shelf string
|
||
|
opt_ map[string]interface{}
|
||
|
ctx_ context.Context
|
||
|
}
|
||
|
|
||
|
// ClearVolumes: Clears all volumes from a bookshelf.
|
||
|
func (r *MylibraryBookshelvesService) ClearVolumes(shelf string) *MylibraryBookshelvesClearVolumesCall {
|
||
|
c := &MylibraryBookshelvesClearVolumesCall{s: r.s, opt_: make(map[string]interface{})}
|
||
|
c.shelf = shelf
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
// Source sets the optional parameter "source": String to identify the
|
||
|
// originator of this request.
|
||
|
func (c *MylibraryBookshelvesClearVolumesCall) Source(source string) *MylibraryBookshelvesClearVolumesCall {
|
||
|
c.opt_["source"] = source
|
||
|
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 *MylibraryBookshelvesClearVolumesCall) Fields(s ...googleapi.Field) *MylibraryBookshelvesClearVolumesCall {
|
||
|
c.opt_["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 *MylibraryBookshelvesClearVolumesCall) Context(ctx context.Context) *MylibraryBookshelvesClearVolumesCall {
|
||
|
c.ctx_ = ctx
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
func (c *MylibraryBookshelvesClearVolumesCall) doRequest(alt string) (*http.Response, error) {
|
||
|
var body io.Reader = nil
|
||
|
params := make(url.Values)
|
||
|
params.Set("alt", alt)
|
||
|
if v, ok := c.opt_["source"]; ok {
|
||
|
params.Set("source", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if v, ok := c.opt_["fields"]; ok {
|
||
|
params.Set("fields", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
urls := googleapi.ResolveRelative(c.s.BasePath, "mylibrary/bookshelves/{shelf}/clearVolumes")
|
||
|
urls += "?" + params.Encode()
|
||
|
req, _ := http.NewRequest("POST", urls, body)
|
||
|
googleapi.Expand(req.URL, map[string]string{
|
||
|
"shelf": c.shelf,
|
||
|
})
|
||
|
req.Header.Set("User-Agent", c.s.userAgent())
|
||
|
if c.ctx_ != nil {
|
||
|
return ctxhttp.Do(c.ctx_, c.s.client, req)
|
||
|
}
|
||
|
return c.s.client.Do(req)
|
||
|
}
|
||
|
|
||
|
// Do executes the "books.mylibrary.bookshelves.clearVolumes" call.
|
||
|
func (c *MylibraryBookshelvesClearVolumesCall) Do() error {
|
||
|
res, err := c.doRequest("json")
|
||
|
if err != nil {
|
||
|
return err
|
||
|
}
|
||
|
defer googleapi.CloseBody(res)
|
||
|
if err := googleapi.CheckResponse(res); err != nil {
|
||
|
return err
|
||
|
}
|
||
|
return nil
|
||
|
// {
|
||
|
// "description": "Clears all volumes from a bookshelf.",
|
||
|
// "httpMethod": "POST",
|
||
|
// "id": "books.mylibrary.bookshelves.clearVolumes",
|
||
|
// "parameterOrder": [
|
||
|
// "shelf"
|
||
|
// ],
|
||
|
// "parameters": {
|
||
|
// "shelf": {
|
||
|
// "description": "ID of bookshelf from which to remove a volume.",
|
||
|
// "location": "path",
|
||
|
// "required": true,
|
||
|
// "type": "string"
|
||
|
// },
|
||
|
// "source": {
|
||
|
// "description": "String to identify the originator of this request.",
|
||
|
// "location": "query",
|
||
|
// "type": "string"
|
||
|
// }
|
||
|
// },
|
||
|
// "path": "mylibrary/bookshelves/{shelf}/clearVolumes",
|
||
|
// "scopes": [
|
||
|
// "https://www.googleapis.com/auth/books"
|
||
|
// ]
|
||
|
// }
|
||
|
|
||
|
}
|
||
|
|
||
|
// method id "books.mylibrary.bookshelves.get":
|
||
|
|
||
|
type MylibraryBookshelvesGetCall struct {
|
||
|
s *Service
|
||
|
shelf string
|
||
|
opt_ map[string]interface{}
|
||
|
ctx_ context.Context
|
||
|
}
|
||
|
|
||
|
// Get: Retrieves metadata for a specific bookshelf belonging to the
|
||
|
// authenticated user.
|
||
|
func (r *MylibraryBookshelvesService) Get(shelf string) *MylibraryBookshelvesGetCall {
|
||
|
c := &MylibraryBookshelvesGetCall{s: r.s, opt_: make(map[string]interface{})}
|
||
|
c.shelf = shelf
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
// Source sets the optional parameter "source": String to identify the
|
||
|
// originator of this request.
|
||
|
func (c *MylibraryBookshelvesGetCall) Source(source string) *MylibraryBookshelvesGetCall {
|
||
|
c.opt_["source"] = source
|
||
|
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 *MylibraryBookshelvesGetCall) Fields(s ...googleapi.Field) *MylibraryBookshelvesGetCall {
|
||
|
c.opt_["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 *MylibraryBookshelvesGetCall) IfNoneMatch(entityTag string) *MylibraryBookshelvesGetCall {
|
||
|
c.opt_["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 *MylibraryBookshelvesGetCall) Context(ctx context.Context) *MylibraryBookshelvesGetCall {
|
||
|
c.ctx_ = ctx
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
func (c *MylibraryBookshelvesGetCall) doRequest(alt string) (*http.Response, error) {
|
||
|
var body io.Reader = nil
|
||
|
params := make(url.Values)
|
||
|
params.Set("alt", alt)
|
||
|
if v, ok := c.opt_["source"]; ok {
|
||
|
params.Set("source", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if v, ok := c.opt_["fields"]; ok {
|
||
|
params.Set("fields", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
urls := googleapi.ResolveRelative(c.s.BasePath, "mylibrary/bookshelves/{shelf}")
|
||
|
urls += "?" + params.Encode()
|
||
|
req, _ := http.NewRequest("GET", urls, body)
|
||
|
googleapi.Expand(req.URL, map[string]string{
|
||
|
"shelf": c.shelf,
|
||
|
})
|
||
|
req.Header.Set("User-Agent", c.s.userAgent())
|
||
|
if v, ok := c.opt_["ifNoneMatch"]; ok {
|
||
|
req.Header.Set("If-None-Match", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if c.ctx_ != nil {
|
||
|
return ctxhttp.Do(c.ctx_, c.s.client, req)
|
||
|
}
|
||
|
return c.s.client.Do(req)
|
||
|
}
|
||
|
|
||
|
// Do executes the "books.mylibrary.bookshelves.get" call.
|
||
|
// Exactly one of *Bookshelf or error will be non-nil. Any non-2xx
|
||
|
// status code is an error. Response headers are in either
|
||
|
// *Bookshelf.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 *MylibraryBookshelvesGetCall) Do() (*Bookshelf, error) {
|
||
|
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 := &Bookshelf{
|
||
|
ServerResponse: googleapi.ServerResponse{
|
||
|
Header: res.Header,
|
||
|
HTTPStatusCode: res.StatusCode,
|
||
|
},
|
||
|
}
|
||
|
if err := json.NewDecoder(res.Body).Decode(&ret); err != nil {
|
||
|
return nil, err
|
||
|
}
|
||
|
return ret, nil
|
||
|
// {
|
||
|
// "description": "Retrieves metadata for a specific bookshelf belonging to the authenticated user.",
|
||
|
// "httpMethod": "GET",
|
||
|
// "id": "books.mylibrary.bookshelves.get",
|
||
|
// "parameterOrder": [
|
||
|
// "shelf"
|
||
|
// ],
|
||
|
// "parameters": {
|
||
|
// "shelf": {
|
||
|
// "description": "ID of bookshelf to retrieve.",
|
||
|
// "location": "path",
|
||
|
// "required": true,
|
||
|
// "type": "string"
|
||
|
// },
|
||
|
// "source": {
|
||
|
// "description": "String to identify the originator of this request.",
|
||
|
// "location": "query",
|
||
|
// "type": "string"
|
||
|
// }
|
||
|
// },
|
||
|
// "path": "mylibrary/bookshelves/{shelf}",
|
||
|
// "response": {
|
||
|
// "$ref": "Bookshelf"
|
||
|
// },
|
||
|
// "scopes": [
|
||
|
// "https://www.googleapis.com/auth/books"
|
||
|
// ]
|
||
|
// }
|
||
|
|
||
|
}
|
||
|
|
||
|
// method id "books.mylibrary.bookshelves.list":
|
||
|
|
||
|
type MylibraryBookshelvesListCall struct {
|
||
|
s *Service
|
||
|
opt_ map[string]interface{}
|
||
|
ctx_ context.Context
|
||
|
}
|
||
|
|
||
|
// List: Retrieves a list of bookshelves belonging to the authenticated
|
||
|
// user.
|
||
|
func (r *MylibraryBookshelvesService) List() *MylibraryBookshelvesListCall {
|
||
|
c := &MylibraryBookshelvesListCall{s: r.s, opt_: make(map[string]interface{})}
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
// Source sets the optional parameter "source": String to identify the
|
||
|
// originator of this request.
|
||
|
func (c *MylibraryBookshelvesListCall) Source(source string) *MylibraryBookshelvesListCall {
|
||
|
c.opt_["source"] = source
|
||
|
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 *MylibraryBookshelvesListCall) Fields(s ...googleapi.Field) *MylibraryBookshelvesListCall {
|
||
|
c.opt_["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 *MylibraryBookshelvesListCall) IfNoneMatch(entityTag string) *MylibraryBookshelvesListCall {
|
||
|
c.opt_["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 *MylibraryBookshelvesListCall) Context(ctx context.Context) *MylibraryBookshelvesListCall {
|
||
|
c.ctx_ = ctx
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
func (c *MylibraryBookshelvesListCall) doRequest(alt string) (*http.Response, error) {
|
||
|
var body io.Reader = nil
|
||
|
params := make(url.Values)
|
||
|
params.Set("alt", alt)
|
||
|
if v, ok := c.opt_["source"]; ok {
|
||
|
params.Set("source", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if v, ok := c.opt_["fields"]; ok {
|
||
|
params.Set("fields", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
urls := googleapi.ResolveRelative(c.s.BasePath, "mylibrary/bookshelves")
|
||
|
urls += "?" + params.Encode()
|
||
|
req, _ := http.NewRequest("GET", urls, body)
|
||
|
googleapi.SetOpaque(req.URL)
|
||
|
req.Header.Set("User-Agent", c.s.userAgent())
|
||
|
if v, ok := c.opt_["ifNoneMatch"]; ok {
|
||
|
req.Header.Set("If-None-Match", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if c.ctx_ != nil {
|
||
|
return ctxhttp.Do(c.ctx_, c.s.client, req)
|
||
|
}
|
||
|
return c.s.client.Do(req)
|
||
|
}
|
||
|
|
||
|
// Do executes the "books.mylibrary.bookshelves.list" call.
|
||
|
// Exactly one of *Bookshelves or error will be non-nil. Any non-2xx
|
||
|
// status code is an error. Response headers are in either
|
||
|
// *Bookshelves.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 *MylibraryBookshelvesListCall) Do() (*Bookshelves, error) {
|
||
|
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 := &Bookshelves{
|
||
|
ServerResponse: googleapi.ServerResponse{
|
||
|
Header: res.Header,
|
||
|
HTTPStatusCode: res.StatusCode,
|
||
|
},
|
||
|
}
|
||
|
if err := json.NewDecoder(res.Body).Decode(&ret); err != nil {
|
||
|
return nil, err
|
||
|
}
|
||
|
return ret, nil
|
||
|
// {
|
||
|
// "description": "Retrieves a list of bookshelves belonging to the authenticated user.",
|
||
|
// "httpMethod": "GET",
|
||
|
// "id": "books.mylibrary.bookshelves.list",
|
||
|
// "parameters": {
|
||
|
// "source": {
|
||
|
// "description": "String to identify the originator of this request.",
|
||
|
// "location": "query",
|
||
|
// "type": "string"
|
||
|
// }
|
||
|
// },
|
||
|
// "path": "mylibrary/bookshelves",
|
||
|
// "response": {
|
||
|
// "$ref": "Bookshelves"
|
||
|
// },
|
||
|
// "scopes": [
|
||
|
// "https://www.googleapis.com/auth/books"
|
||
|
// ]
|
||
|
// }
|
||
|
|
||
|
}
|
||
|
|
||
|
// method id "books.mylibrary.bookshelves.moveVolume":
|
||
|
|
||
|
type MylibraryBookshelvesMoveVolumeCall struct {
|
||
|
s *Service
|
||
|
shelf string
|
||
|
volumeId string
|
||
|
volumePosition int64
|
||
|
opt_ map[string]interface{}
|
||
|
ctx_ context.Context
|
||
|
}
|
||
|
|
||
|
// MoveVolume: Moves a volume within a bookshelf.
|
||
|
func (r *MylibraryBookshelvesService) MoveVolume(shelf string, volumeId string, volumePosition int64) *MylibraryBookshelvesMoveVolumeCall {
|
||
|
c := &MylibraryBookshelvesMoveVolumeCall{s: r.s, opt_: make(map[string]interface{})}
|
||
|
c.shelf = shelf
|
||
|
c.volumeId = volumeId
|
||
|
c.volumePosition = volumePosition
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
// Source sets the optional parameter "source": String to identify the
|
||
|
// originator of this request.
|
||
|
func (c *MylibraryBookshelvesMoveVolumeCall) Source(source string) *MylibraryBookshelvesMoveVolumeCall {
|
||
|
c.opt_["source"] = source
|
||
|
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 *MylibraryBookshelvesMoveVolumeCall) Fields(s ...googleapi.Field) *MylibraryBookshelvesMoveVolumeCall {
|
||
|
c.opt_["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 *MylibraryBookshelvesMoveVolumeCall) Context(ctx context.Context) *MylibraryBookshelvesMoveVolumeCall {
|
||
|
c.ctx_ = ctx
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
func (c *MylibraryBookshelvesMoveVolumeCall) doRequest(alt string) (*http.Response, error) {
|
||
|
var body io.Reader = nil
|
||
|
params := make(url.Values)
|
||
|
params.Set("alt", alt)
|
||
|
params.Set("volumeId", fmt.Sprintf("%v", c.volumeId))
|
||
|
params.Set("volumePosition", fmt.Sprintf("%v", c.volumePosition))
|
||
|
if v, ok := c.opt_["source"]; ok {
|
||
|
params.Set("source", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if v, ok := c.opt_["fields"]; ok {
|
||
|
params.Set("fields", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
urls := googleapi.ResolveRelative(c.s.BasePath, "mylibrary/bookshelves/{shelf}/moveVolume")
|
||
|
urls += "?" + params.Encode()
|
||
|
req, _ := http.NewRequest("POST", urls, body)
|
||
|
googleapi.Expand(req.URL, map[string]string{
|
||
|
"shelf": c.shelf,
|
||
|
})
|
||
|
req.Header.Set("User-Agent", c.s.userAgent())
|
||
|
if c.ctx_ != nil {
|
||
|
return ctxhttp.Do(c.ctx_, c.s.client, req)
|
||
|
}
|
||
|
return c.s.client.Do(req)
|
||
|
}
|
||
|
|
||
|
// Do executes the "books.mylibrary.bookshelves.moveVolume" call.
|
||
|
func (c *MylibraryBookshelvesMoveVolumeCall) Do() error {
|
||
|
res, err := c.doRequest("json")
|
||
|
if err != nil {
|
||
|
return err
|
||
|
}
|
||
|
defer googleapi.CloseBody(res)
|
||
|
if err := googleapi.CheckResponse(res); err != nil {
|
||
|
return err
|
||
|
}
|
||
|
return nil
|
||
|
// {
|
||
|
// "description": "Moves a volume within a bookshelf.",
|
||
|
// "httpMethod": "POST",
|
||
|
// "id": "books.mylibrary.bookshelves.moveVolume",
|
||
|
// "parameterOrder": [
|
||
|
// "shelf",
|
||
|
// "volumeId",
|
||
|
// "volumePosition"
|
||
|
// ],
|
||
|
// "parameters": {
|
||
|
// "shelf": {
|
||
|
// "description": "ID of bookshelf with the volume.",
|
||
|
// "location": "path",
|
||
|
// "required": true,
|
||
|
// "type": "string"
|
||
|
// },
|
||
|
// "source": {
|
||
|
// "description": "String to identify the originator of this request.",
|
||
|
// "location": "query",
|
||
|
// "type": "string"
|
||
|
// },
|
||
|
// "volumeId": {
|
||
|
// "description": "ID of volume to move.",
|
||
|
// "location": "query",
|
||
|
// "required": true,
|
||
|
// "type": "string"
|
||
|
// },
|
||
|
// "volumePosition": {
|
||
|
// "description": "Position on shelf to move the item (0 puts the item before the current first item, 1 puts it between the first and the second and so on.)",
|
||
|
// "format": "int32",
|
||
|
// "location": "query",
|
||
|
// "required": true,
|
||
|
// "type": "integer"
|
||
|
// }
|
||
|
// },
|
||
|
// "path": "mylibrary/bookshelves/{shelf}/moveVolume",
|
||
|
// "scopes": [
|
||
|
// "https://www.googleapis.com/auth/books"
|
||
|
// ]
|
||
|
// }
|
||
|
|
||
|
}
|
||
|
|
||
|
// method id "books.mylibrary.bookshelves.removeVolume":
|
||
|
|
||
|
type MylibraryBookshelvesRemoveVolumeCall struct {
|
||
|
s *Service
|
||
|
shelf string
|
||
|
volumeId string
|
||
|
opt_ map[string]interface{}
|
||
|
ctx_ context.Context
|
||
|
}
|
||
|
|
||
|
// RemoveVolume: Removes a volume from a bookshelf.
|
||
|
func (r *MylibraryBookshelvesService) RemoveVolume(shelf string, volumeId string) *MylibraryBookshelvesRemoveVolumeCall {
|
||
|
c := &MylibraryBookshelvesRemoveVolumeCall{s: r.s, opt_: make(map[string]interface{})}
|
||
|
c.shelf = shelf
|
||
|
c.volumeId = volumeId
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
// Reason sets the optional parameter "reason": The reason for which the
|
||
|
// book is removed from the library.
|
||
|
//
|
||
|
// Possible values:
|
||
|
// "ONBOARDING" - Samples removed from the Onboarding flow.
|
||
|
func (c *MylibraryBookshelvesRemoveVolumeCall) Reason(reason string) *MylibraryBookshelvesRemoveVolumeCall {
|
||
|
c.opt_["reason"] = reason
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
// Source sets the optional parameter "source": String to identify the
|
||
|
// originator of this request.
|
||
|
func (c *MylibraryBookshelvesRemoveVolumeCall) Source(source string) *MylibraryBookshelvesRemoveVolumeCall {
|
||
|
c.opt_["source"] = source
|
||
|
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 *MylibraryBookshelvesRemoveVolumeCall) Fields(s ...googleapi.Field) *MylibraryBookshelvesRemoveVolumeCall {
|
||
|
c.opt_["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 *MylibraryBookshelvesRemoveVolumeCall) Context(ctx context.Context) *MylibraryBookshelvesRemoveVolumeCall {
|
||
|
c.ctx_ = ctx
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
func (c *MylibraryBookshelvesRemoveVolumeCall) doRequest(alt string) (*http.Response, error) {
|
||
|
var body io.Reader = nil
|
||
|
params := make(url.Values)
|
||
|
params.Set("alt", alt)
|
||
|
params.Set("volumeId", fmt.Sprintf("%v", c.volumeId))
|
||
|
if v, ok := c.opt_["reason"]; ok {
|
||
|
params.Set("reason", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if v, ok := c.opt_["source"]; ok {
|
||
|
params.Set("source", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if v, ok := c.opt_["fields"]; ok {
|
||
|
params.Set("fields", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
urls := googleapi.ResolveRelative(c.s.BasePath, "mylibrary/bookshelves/{shelf}/removeVolume")
|
||
|
urls += "?" + params.Encode()
|
||
|
req, _ := http.NewRequest("POST", urls, body)
|
||
|
googleapi.Expand(req.URL, map[string]string{
|
||
|
"shelf": c.shelf,
|
||
|
})
|
||
|
req.Header.Set("User-Agent", c.s.userAgent())
|
||
|
if c.ctx_ != nil {
|
||
|
return ctxhttp.Do(c.ctx_, c.s.client, req)
|
||
|
}
|
||
|
return c.s.client.Do(req)
|
||
|
}
|
||
|
|
||
|
// Do executes the "books.mylibrary.bookshelves.removeVolume" call.
|
||
|
func (c *MylibraryBookshelvesRemoveVolumeCall) Do() error {
|
||
|
res, err := c.doRequest("json")
|
||
|
if err != nil {
|
||
|
return err
|
||
|
}
|
||
|
defer googleapi.CloseBody(res)
|
||
|
if err := googleapi.CheckResponse(res); err != nil {
|
||
|
return err
|
||
|
}
|
||
|
return nil
|
||
|
// {
|
||
|
// "description": "Removes a volume from a bookshelf.",
|
||
|
// "httpMethod": "POST",
|
||
|
// "id": "books.mylibrary.bookshelves.removeVolume",
|
||
|
// "parameterOrder": [
|
||
|
// "shelf",
|
||
|
// "volumeId"
|
||
|
// ],
|
||
|
// "parameters": {
|
||
|
// "reason": {
|
||
|
// "description": "The reason for which the book is removed from the library.",
|
||
|
// "enum": [
|
||
|
// "ONBOARDING"
|
||
|
// ],
|
||
|
// "enumDescriptions": [
|
||
|
// "Samples removed from the Onboarding flow."
|
||
|
// ],
|
||
|
// "location": "query",
|
||
|
// "type": "string"
|
||
|
// },
|
||
|
// "shelf": {
|
||
|
// "description": "ID of bookshelf from which to remove a volume.",
|
||
|
// "location": "path",
|
||
|
// "required": true,
|
||
|
// "type": "string"
|
||
|
// },
|
||
|
// "source": {
|
||
|
// "description": "String to identify the originator of this request.",
|
||
|
// "location": "query",
|
||
|
// "type": "string"
|
||
|
// },
|
||
|
// "volumeId": {
|
||
|
// "description": "ID of volume to remove.",
|
||
|
// "location": "query",
|
||
|
// "required": true,
|
||
|
// "type": "string"
|
||
|
// }
|
||
|
// },
|
||
|
// "path": "mylibrary/bookshelves/{shelf}/removeVolume",
|
||
|
// "scopes": [
|
||
|
// "https://www.googleapis.com/auth/books"
|
||
|
// ]
|
||
|
// }
|
||
|
|
||
|
}
|
||
|
|
||
|
// method id "books.mylibrary.bookshelves.volumes.list":
|
||
|
|
||
|
type MylibraryBookshelvesVolumesListCall struct {
|
||
|
s *Service
|
||
|
shelf string
|
||
|
opt_ map[string]interface{}
|
||
|
ctx_ context.Context
|
||
|
}
|
||
|
|
||
|
// List: Gets volume information for volumes on a bookshelf.
|
||
|
func (r *MylibraryBookshelvesVolumesService) List(shelf string) *MylibraryBookshelvesVolumesListCall {
|
||
|
c := &MylibraryBookshelvesVolumesListCall{s: r.s, opt_: make(map[string]interface{})}
|
||
|
c.shelf = shelf
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
// Country sets the optional parameter "country": ISO-3166-1 code to
|
||
|
// override the IP-based location.
|
||
|
func (c *MylibraryBookshelvesVolumesListCall) Country(country string) *MylibraryBookshelvesVolumesListCall {
|
||
|
c.opt_["country"] = country
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
// MaxResults sets the optional parameter "maxResults": Maximum number
|
||
|
// of results to return
|
||
|
func (c *MylibraryBookshelvesVolumesListCall) MaxResults(maxResults int64) *MylibraryBookshelvesVolumesListCall {
|
||
|
c.opt_["maxResults"] = maxResults
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
// Projection sets the optional parameter "projection": Restrict
|
||
|
// information returned to a set of selected fields.
|
||
|
//
|
||
|
// Possible values:
|
||
|
// "full" - Includes all volume data.
|
||
|
// "lite" - Includes a subset of fields in volumeInfo and accessInfo.
|
||
|
func (c *MylibraryBookshelvesVolumesListCall) Projection(projection string) *MylibraryBookshelvesVolumesListCall {
|
||
|
c.opt_["projection"] = projection
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
// Q sets the optional parameter "q": Full-text search query string in
|
||
|
// this bookshelf.
|
||
|
func (c *MylibraryBookshelvesVolumesListCall) Q(q string) *MylibraryBookshelvesVolumesListCall {
|
||
|
c.opt_["q"] = q
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
// ShowPreorders sets the optional parameter "showPreorders": Set to
|
||
|
// true to show pre-ordered books. Defaults to false.
|
||
|
func (c *MylibraryBookshelvesVolumesListCall) ShowPreorders(showPreorders bool) *MylibraryBookshelvesVolumesListCall {
|
||
|
c.opt_["showPreorders"] = showPreorders
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
// Source sets the optional parameter "source": String to identify the
|
||
|
// originator of this request.
|
||
|
func (c *MylibraryBookshelvesVolumesListCall) Source(source string) *MylibraryBookshelvesVolumesListCall {
|
||
|
c.opt_["source"] = source
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
// StartIndex sets the optional parameter "startIndex": Index of the
|
||
|
// first element to return (starts at 0)
|
||
|
func (c *MylibraryBookshelvesVolumesListCall) StartIndex(startIndex int64) *MylibraryBookshelvesVolumesListCall {
|
||
|
c.opt_["startIndex"] = startIndex
|
||
|
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 *MylibraryBookshelvesVolumesListCall) Fields(s ...googleapi.Field) *MylibraryBookshelvesVolumesListCall {
|
||
|
c.opt_["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 *MylibraryBookshelvesVolumesListCall) IfNoneMatch(entityTag string) *MylibraryBookshelvesVolumesListCall {
|
||
|
c.opt_["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 *MylibraryBookshelvesVolumesListCall) Context(ctx context.Context) *MylibraryBookshelvesVolumesListCall {
|
||
|
c.ctx_ = ctx
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
func (c *MylibraryBookshelvesVolumesListCall) doRequest(alt string) (*http.Response, error) {
|
||
|
var body io.Reader = nil
|
||
|
params := make(url.Values)
|
||
|
params.Set("alt", alt)
|
||
|
if v, ok := c.opt_["country"]; ok {
|
||
|
params.Set("country", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if v, ok := c.opt_["maxResults"]; ok {
|
||
|
params.Set("maxResults", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if v, ok := c.opt_["projection"]; ok {
|
||
|
params.Set("projection", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if v, ok := c.opt_["q"]; ok {
|
||
|
params.Set("q", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if v, ok := c.opt_["showPreorders"]; ok {
|
||
|
params.Set("showPreorders", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if v, ok := c.opt_["source"]; ok {
|
||
|
params.Set("source", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if v, ok := c.opt_["startIndex"]; ok {
|
||
|
params.Set("startIndex", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if v, ok := c.opt_["fields"]; ok {
|
||
|
params.Set("fields", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
urls := googleapi.ResolveRelative(c.s.BasePath, "mylibrary/bookshelves/{shelf}/volumes")
|
||
|
urls += "?" + params.Encode()
|
||
|
req, _ := http.NewRequest("GET", urls, body)
|
||
|
googleapi.Expand(req.URL, map[string]string{
|
||
|
"shelf": c.shelf,
|
||
|
})
|
||
|
req.Header.Set("User-Agent", c.s.userAgent())
|
||
|
if v, ok := c.opt_["ifNoneMatch"]; ok {
|
||
|
req.Header.Set("If-None-Match", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if c.ctx_ != nil {
|
||
|
return ctxhttp.Do(c.ctx_, c.s.client, req)
|
||
|
}
|
||
|
return c.s.client.Do(req)
|
||
|
}
|
||
|
|
||
|
// Do executes the "books.mylibrary.bookshelves.volumes.list" call.
|
||
|
// Exactly one of *Volumes or error will be non-nil. Any non-2xx status
|
||
|
// code is an error. Response headers are in either
|
||
|
// *Volumes.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 *MylibraryBookshelvesVolumesListCall) Do() (*Volumes, error) {
|
||
|
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 := &Volumes{
|
||
|
ServerResponse: googleapi.ServerResponse{
|
||
|
Header: res.Header,
|
||
|
HTTPStatusCode: res.StatusCode,
|
||
|
},
|
||
|
}
|
||
|
if err := json.NewDecoder(res.Body).Decode(&ret); err != nil {
|
||
|
return nil, err
|
||
|
}
|
||
|
return ret, nil
|
||
|
// {
|
||
|
// "description": "Gets volume information for volumes on a bookshelf.",
|
||
|
// "httpMethod": "GET",
|
||
|
// "id": "books.mylibrary.bookshelves.volumes.list",
|
||
|
// "parameterOrder": [
|
||
|
// "shelf"
|
||
|
// ],
|
||
|
// "parameters": {
|
||
|
// "country": {
|
||
|
// "description": "ISO-3166-1 code to override the IP-based location.",
|
||
|
// "location": "query",
|
||
|
// "type": "string"
|
||
|
// },
|
||
|
// "maxResults": {
|
||
|
// "description": "Maximum number of results to return",
|
||
|
// "format": "uint32",
|
||
|
// "location": "query",
|
||
|
// "minimum": "0",
|
||
|
// "type": "integer"
|
||
|
// },
|
||
|
// "projection": {
|
||
|
// "description": "Restrict information returned to a set of selected fields.",
|
||
|
// "enum": [
|
||
|
// "full",
|
||
|
// "lite"
|
||
|
// ],
|
||
|
// "enumDescriptions": [
|
||
|
// "Includes all volume data.",
|
||
|
// "Includes a subset of fields in volumeInfo and accessInfo."
|
||
|
// ],
|
||
|
// "location": "query",
|
||
|
// "type": "string"
|
||
|
// },
|
||
|
// "q": {
|
||
|
// "description": "Full-text search query string in this bookshelf.",
|
||
|
// "location": "query",
|
||
|
// "type": "string"
|
||
|
// },
|
||
|
// "shelf": {
|
||
|
// "description": "The bookshelf ID or name retrieve volumes for.",
|
||
|
// "location": "path",
|
||
|
// "required": true,
|
||
|
// "type": "string"
|
||
|
// },
|
||
|
// "showPreorders": {
|
||
|
// "description": "Set to true to show pre-ordered books. Defaults to false.",
|
||
|
// "location": "query",
|
||
|
// "type": "boolean"
|
||
|
// },
|
||
|
// "source": {
|
||
|
// "description": "String to identify the originator of this request.",
|
||
|
// "location": "query",
|
||
|
// "type": "string"
|
||
|
// },
|
||
|
// "startIndex": {
|
||
|
// "description": "Index of the first element to return (starts at 0)",
|
||
|
// "format": "uint32",
|
||
|
// "location": "query",
|
||
|
// "minimum": "0",
|
||
|
// "type": "integer"
|
||
|
// }
|
||
|
// },
|
||
|
// "path": "mylibrary/bookshelves/{shelf}/volumes",
|
||
|
// "response": {
|
||
|
// "$ref": "Volumes"
|
||
|
// },
|
||
|
// "scopes": [
|
||
|
// "https://www.googleapis.com/auth/books"
|
||
|
// ]
|
||
|
// }
|
||
|
|
||
|
}
|
||
|
|
||
|
// method id "books.mylibrary.readingpositions.get":
|
||
|
|
||
|
type MylibraryReadingpositionsGetCall struct {
|
||
|
s *Service
|
||
|
volumeId string
|
||
|
opt_ map[string]interface{}
|
||
|
ctx_ context.Context
|
||
|
}
|
||
|
|
||
|
// Get: Retrieves my reading position information for a volume.
|
||
|
func (r *MylibraryReadingpositionsService) Get(volumeId string) *MylibraryReadingpositionsGetCall {
|
||
|
c := &MylibraryReadingpositionsGetCall{s: r.s, opt_: make(map[string]interface{})}
|
||
|
c.volumeId = volumeId
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
// ContentVersion sets the optional parameter "contentVersion": Volume
|
||
|
// content version for which this reading position is requested.
|
||
|
func (c *MylibraryReadingpositionsGetCall) ContentVersion(contentVersion string) *MylibraryReadingpositionsGetCall {
|
||
|
c.opt_["contentVersion"] = contentVersion
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
// Source sets the optional parameter "source": String to identify the
|
||
|
// originator of this request.
|
||
|
func (c *MylibraryReadingpositionsGetCall) Source(source string) *MylibraryReadingpositionsGetCall {
|
||
|
c.opt_["source"] = source
|
||
|
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 *MylibraryReadingpositionsGetCall) Fields(s ...googleapi.Field) *MylibraryReadingpositionsGetCall {
|
||
|
c.opt_["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 *MylibraryReadingpositionsGetCall) IfNoneMatch(entityTag string) *MylibraryReadingpositionsGetCall {
|
||
|
c.opt_["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 *MylibraryReadingpositionsGetCall) Context(ctx context.Context) *MylibraryReadingpositionsGetCall {
|
||
|
c.ctx_ = ctx
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
func (c *MylibraryReadingpositionsGetCall) doRequest(alt string) (*http.Response, error) {
|
||
|
var body io.Reader = nil
|
||
|
params := make(url.Values)
|
||
|
params.Set("alt", alt)
|
||
|
if v, ok := c.opt_["contentVersion"]; ok {
|
||
|
params.Set("contentVersion", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if v, ok := c.opt_["source"]; ok {
|
||
|
params.Set("source", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if v, ok := c.opt_["fields"]; ok {
|
||
|
params.Set("fields", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
urls := googleapi.ResolveRelative(c.s.BasePath, "mylibrary/readingpositions/{volumeId}")
|
||
|
urls += "?" + params.Encode()
|
||
|
req, _ := http.NewRequest("GET", urls, body)
|
||
|
googleapi.Expand(req.URL, map[string]string{
|
||
|
"volumeId": c.volumeId,
|
||
|
})
|
||
|
req.Header.Set("User-Agent", c.s.userAgent())
|
||
|
if v, ok := c.opt_["ifNoneMatch"]; ok {
|
||
|
req.Header.Set("If-None-Match", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if c.ctx_ != nil {
|
||
|
return ctxhttp.Do(c.ctx_, c.s.client, req)
|
||
|
}
|
||
|
return c.s.client.Do(req)
|
||
|
}
|
||
|
|
||
|
// Do executes the "books.mylibrary.readingpositions.get" call.
|
||
|
// Exactly one of *ReadingPosition or error will be non-nil. Any non-2xx
|
||
|
// status code is an error. Response headers are in either
|
||
|
// *ReadingPosition.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 *MylibraryReadingpositionsGetCall) Do() (*ReadingPosition, error) {
|
||
|
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 := &ReadingPosition{
|
||
|
ServerResponse: googleapi.ServerResponse{
|
||
|
Header: res.Header,
|
||
|
HTTPStatusCode: res.StatusCode,
|
||
|
},
|
||
|
}
|
||
|
if err := json.NewDecoder(res.Body).Decode(&ret); err != nil {
|
||
|
return nil, err
|
||
|
}
|
||
|
return ret, nil
|
||
|
// {
|
||
|
// "description": "Retrieves my reading position information for a volume.",
|
||
|
// "httpMethod": "GET",
|
||
|
// "id": "books.mylibrary.readingpositions.get",
|
||
|
// "parameterOrder": [
|
||
|
// "volumeId"
|
||
|
// ],
|
||
|
// "parameters": {
|
||
|
// "contentVersion": {
|
||
|
// "description": "Volume content version for which this reading position is requested.",
|
||
|
// "location": "query",
|
||
|
// "type": "string"
|
||
|
// },
|
||
|
// "source": {
|
||
|
// "description": "String to identify the originator of this request.",
|
||
|
// "location": "query",
|
||
|
// "type": "string"
|
||
|
// },
|
||
|
// "volumeId": {
|
||
|
// "description": "ID of volume for which to retrieve a reading position.",
|
||
|
// "location": "path",
|
||
|
// "required": true,
|
||
|
// "type": "string"
|
||
|
// }
|
||
|
// },
|
||
|
// "path": "mylibrary/readingpositions/{volumeId}",
|
||
|
// "response": {
|
||
|
// "$ref": "ReadingPosition"
|
||
|
// },
|
||
|
// "scopes": [
|
||
|
// "https://www.googleapis.com/auth/books"
|
||
|
// ]
|
||
|
// }
|
||
|
|
||
|
}
|
||
|
|
||
|
// method id "books.mylibrary.readingpositions.setPosition":
|
||
|
|
||
|
type MylibraryReadingpositionsSetPositionCall struct {
|
||
|
s *Service
|
||
|
volumeId string
|
||
|
timestamp string
|
||
|
position string
|
||
|
opt_ map[string]interface{}
|
||
|
ctx_ context.Context
|
||
|
}
|
||
|
|
||
|
// SetPosition: Sets my reading position information for a volume.
|
||
|
func (r *MylibraryReadingpositionsService) SetPosition(volumeId string, timestamp string, position string) *MylibraryReadingpositionsSetPositionCall {
|
||
|
c := &MylibraryReadingpositionsSetPositionCall{s: r.s, opt_: make(map[string]interface{})}
|
||
|
c.volumeId = volumeId
|
||
|
c.timestamp = timestamp
|
||
|
c.position = position
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
// Action sets the optional parameter "action": Action that caused this
|
||
|
// reading position to be set.
|
||
|
//
|
||
|
// Possible values:
|
||
|
// "bookmark" - User chose bookmark within volume.
|
||
|
// "chapter" - User selected chapter from list.
|
||
|
// "next-page" - Next page event.
|
||
|
// "prev-page" - Previous page event.
|
||
|
// "scroll" - User navigated to page.
|
||
|
// "search" - User chose search results within volume.
|
||
|
func (c *MylibraryReadingpositionsSetPositionCall) Action(action string) *MylibraryReadingpositionsSetPositionCall {
|
||
|
c.opt_["action"] = action
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
// ContentVersion sets the optional parameter "contentVersion": Volume
|
||
|
// content version for which this reading position applies.
|
||
|
func (c *MylibraryReadingpositionsSetPositionCall) ContentVersion(contentVersion string) *MylibraryReadingpositionsSetPositionCall {
|
||
|
c.opt_["contentVersion"] = contentVersion
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
// DeviceCookie sets the optional parameter "deviceCookie": Random
|
||
|
// persistent device cookie optional on set position.
|
||
|
func (c *MylibraryReadingpositionsSetPositionCall) DeviceCookie(deviceCookie string) *MylibraryReadingpositionsSetPositionCall {
|
||
|
c.opt_["deviceCookie"] = deviceCookie
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
// Source sets the optional parameter "source": String to identify the
|
||
|
// originator of this request.
|
||
|
func (c *MylibraryReadingpositionsSetPositionCall) Source(source string) *MylibraryReadingpositionsSetPositionCall {
|
||
|
c.opt_["source"] = source
|
||
|
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 *MylibraryReadingpositionsSetPositionCall) Fields(s ...googleapi.Field) *MylibraryReadingpositionsSetPositionCall {
|
||
|
c.opt_["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 *MylibraryReadingpositionsSetPositionCall) Context(ctx context.Context) *MylibraryReadingpositionsSetPositionCall {
|
||
|
c.ctx_ = ctx
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
func (c *MylibraryReadingpositionsSetPositionCall) doRequest(alt string) (*http.Response, error) {
|
||
|
var body io.Reader = nil
|
||
|
params := make(url.Values)
|
||
|
params.Set("alt", alt)
|
||
|
params.Set("position", fmt.Sprintf("%v", c.position))
|
||
|
params.Set("timestamp", fmt.Sprintf("%v", c.timestamp))
|
||
|
if v, ok := c.opt_["action"]; ok {
|
||
|
params.Set("action", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if v, ok := c.opt_["contentVersion"]; ok {
|
||
|
params.Set("contentVersion", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if v, ok := c.opt_["deviceCookie"]; ok {
|
||
|
params.Set("deviceCookie", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if v, ok := c.opt_["source"]; ok {
|
||
|
params.Set("source", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if v, ok := c.opt_["fields"]; ok {
|
||
|
params.Set("fields", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
urls := googleapi.ResolveRelative(c.s.BasePath, "mylibrary/readingpositions/{volumeId}/setPosition")
|
||
|
urls += "?" + params.Encode()
|
||
|
req, _ := http.NewRequest("POST", urls, body)
|
||
|
googleapi.Expand(req.URL, map[string]string{
|
||
|
"volumeId": c.volumeId,
|
||
|
})
|
||
|
req.Header.Set("User-Agent", c.s.userAgent())
|
||
|
if c.ctx_ != nil {
|
||
|
return ctxhttp.Do(c.ctx_, c.s.client, req)
|
||
|
}
|
||
|
return c.s.client.Do(req)
|
||
|
}
|
||
|
|
||
|
// Do executes the "books.mylibrary.readingpositions.setPosition" call.
|
||
|
func (c *MylibraryReadingpositionsSetPositionCall) Do() error {
|
||
|
res, err := c.doRequest("json")
|
||
|
if err != nil {
|
||
|
return err
|
||
|
}
|
||
|
defer googleapi.CloseBody(res)
|
||
|
if err := googleapi.CheckResponse(res); err != nil {
|
||
|
return err
|
||
|
}
|
||
|
return nil
|
||
|
// {
|
||
|
// "description": "Sets my reading position information for a volume.",
|
||
|
// "httpMethod": "POST",
|
||
|
// "id": "books.mylibrary.readingpositions.setPosition",
|
||
|
// "parameterOrder": [
|
||
|
// "volumeId",
|
||
|
// "timestamp",
|
||
|
// "position"
|
||
|
// ],
|
||
|
// "parameters": {
|
||
|
// "action": {
|
||
|
// "description": "Action that caused this reading position to be set.",
|
||
|
// "enum": [
|
||
|
// "bookmark",
|
||
|
// "chapter",
|
||
|
// "next-page",
|
||
|
// "prev-page",
|
||
|
// "scroll",
|
||
|
// "search"
|
||
|
// ],
|
||
|
// "enumDescriptions": [
|
||
|
// "User chose bookmark within volume.",
|
||
|
// "User selected chapter from list.",
|
||
|
// "Next page event.",
|
||
|
// "Previous page event.",
|
||
|
// "User navigated to page.",
|
||
|
// "User chose search results within volume."
|
||
|
// ],
|
||
|
// "location": "query",
|
||
|
// "type": "string"
|
||
|
// },
|
||
|
// "contentVersion": {
|
||
|
// "description": "Volume content version for which this reading position applies.",
|
||
|
// "location": "query",
|
||
|
// "type": "string"
|
||
|
// },
|
||
|
// "deviceCookie": {
|
||
|
// "description": "Random persistent device cookie optional on set position.",
|
||
|
// "location": "query",
|
||
|
// "type": "string"
|
||
|
// },
|
||
|
// "position": {
|
||
|
// "description": "Position string for the new volume reading position.",
|
||
|
// "location": "query",
|
||
|
// "required": true,
|
||
|
// "type": "string"
|
||
|
// },
|
||
|
// "source": {
|
||
|
// "description": "String to identify the originator of this request.",
|
||
|
// "location": "query",
|
||
|
// "type": "string"
|
||
|
// },
|
||
|
// "timestamp": {
|
||
|
// "description": "RFC 3339 UTC format timestamp associated with this reading position.",
|
||
|
// "location": "query",
|
||
|
// "required": true,
|
||
|
// "type": "string"
|
||
|
// },
|
||
|
// "volumeId": {
|
||
|
// "description": "ID of volume for which to update the reading position.",
|
||
|
// "location": "path",
|
||
|
// "required": true,
|
||
|
// "type": "string"
|
||
|
// }
|
||
|
// },
|
||
|
// "path": "mylibrary/readingpositions/{volumeId}/setPosition",
|
||
|
// "scopes": [
|
||
|
// "https://www.googleapis.com/auth/books"
|
||
|
// ]
|
||
|
// }
|
||
|
|
||
|
}
|
||
|
|
||
|
// method id "books.notification.get":
|
||
|
|
||
|
type NotificationGetCall struct {
|
||
|
s *Service
|
||
|
notificationId string
|
||
|
opt_ map[string]interface{}
|
||
|
ctx_ context.Context
|
||
|
}
|
||
|
|
||
|
// Get: Returns notification details for a given notification id.
|
||
|
func (r *NotificationService) Get(notificationId string) *NotificationGetCall {
|
||
|
c := &NotificationGetCall{s: r.s, opt_: make(map[string]interface{})}
|
||
|
c.notificationId = notificationId
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
// Locale sets the optional parameter "locale": ISO-639-1 language and
|
||
|
// ISO-3166-1 country code. Ex: 'en_US'. Used for generating
|
||
|
// notification title and body.
|
||
|
func (c *NotificationGetCall) Locale(locale string) *NotificationGetCall {
|
||
|
c.opt_["locale"] = locale
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
// Source sets the optional parameter "source": String to identify the
|
||
|
// originator of this request.
|
||
|
func (c *NotificationGetCall) Source(source string) *NotificationGetCall {
|
||
|
c.opt_["source"] = source
|
||
|
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 *NotificationGetCall) Fields(s ...googleapi.Field) *NotificationGetCall {
|
||
|
c.opt_["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 *NotificationGetCall) IfNoneMatch(entityTag string) *NotificationGetCall {
|
||
|
c.opt_["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 *NotificationGetCall) Context(ctx context.Context) *NotificationGetCall {
|
||
|
c.ctx_ = ctx
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
func (c *NotificationGetCall) doRequest(alt string) (*http.Response, error) {
|
||
|
var body io.Reader = nil
|
||
|
params := make(url.Values)
|
||
|
params.Set("alt", alt)
|
||
|
params.Set("notification_id", fmt.Sprintf("%v", c.notificationId))
|
||
|
if v, ok := c.opt_["locale"]; ok {
|
||
|
params.Set("locale", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if v, ok := c.opt_["source"]; ok {
|
||
|
params.Set("source", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if v, ok := c.opt_["fields"]; ok {
|
||
|
params.Set("fields", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
urls := googleapi.ResolveRelative(c.s.BasePath, "notification/get")
|
||
|
urls += "?" + params.Encode()
|
||
|
req, _ := http.NewRequest("GET", urls, body)
|
||
|
googleapi.SetOpaque(req.URL)
|
||
|
req.Header.Set("User-Agent", c.s.userAgent())
|
||
|
if v, ok := c.opt_["ifNoneMatch"]; ok {
|
||
|
req.Header.Set("If-None-Match", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if c.ctx_ != nil {
|
||
|
return ctxhttp.Do(c.ctx_, c.s.client, req)
|
||
|
}
|
||
|
return c.s.client.Do(req)
|
||
|
}
|
||
|
|
||
|
// Do executes the "books.notification.get" call.
|
||
|
// Exactly one of *Notification or error will be non-nil. Any non-2xx
|
||
|
// status code is an error. Response headers are in either
|
||
|
// *Notification.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 *NotificationGetCall) Do() (*Notification, error) {
|
||
|
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 := &Notification{
|
||
|
ServerResponse: googleapi.ServerResponse{
|
||
|
Header: res.Header,
|
||
|
HTTPStatusCode: res.StatusCode,
|
||
|
},
|
||
|
}
|
||
|
if err := json.NewDecoder(res.Body).Decode(&ret); err != nil {
|
||
|
return nil, err
|
||
|
}
|
||
|
return ret, nil
|
||
|
// {
|
||
|
// "description": "Returns notification details for a given notification id.",
|
||
|
// "httpMethod": "GET",
|
||
|
// "id": "books.notification.get",
|
||
|
// "parameterOrder": [
|
||
|
// "notification_id"
|
||
|
// ],
|
||
|
// "parameters": {
|
||
|
// "locale": {
|
||
|
// "description": "ISO-639-1 language and ISO-3166-1 country code. Ex: 'en_US'. Used for generating notification title and body.",
|
||
|
// "location": "query",
|
||
|
// "type": "string"
|
||
|
// },
|
||
|
// "notification_id": {
|
||
|
// "description": "String to identify the notification.",
|
||
|
// "location": "query",
|
||
|
// "required": true,
|
||
|
// "type": "string"
|
||
|
// },
|
||
|
// "source": {
|
||
|
// "description": "String to identify the originator of this request.",
|
||
|
// "location": "query",
|
||
|
// "type": "string"
|
||
|
// }
|
||
|
// },
|
||
|
// "path": "notification/get",
|
||
|
// "response": {
|
||
|
// "$ref": "Notification"
|
||
|
// },
|
||
|
// "scopes": [
|
||
|
// "https://www.googleapis.com/auth/books"
|
||
|
// ]
|
||
|
// }
|
||
|
|
||
|
}
|
||
|
|
||
|
// method id "books.onboarding.listCategories":
|
||
|
|
||
|
type OnboardingListCategoriesCall struct {
|
||
|
s *Service
|
||
|
opt_ map[string]interface{}
|
||
|
ctx_ context.Context
|
||
|
}
|
||
|
|
||
|
// ListCategories: List categories for onboarding experience.
|
||
|
func (r *OnboardingService) ListCategories() *OnboardingListCategoriesCall {
|
||
|
c := &OnboardingListCategoriesCall{s: r.s, opt_: make(map[string]interface{})}
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
// Locale sets the optional parameter "locale": ISO-639-1 language and
|
||
|
// ISO-3166-1 country code. Default is en-US if unset.
|
||
|
func (c *OnboardingListCategoriesCall) Locale(locale string) *OnboardingListCategoriesCall {
|
||
|
c.opt_["locale"] = locale
|
||
|
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 *OnboardingListCategoriesCall) Fields(s ...googleapi.Field) *OnboardingListCategoriesCall {
|
||
|
c.opt_["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 *OnboardingListCategoriesCall) IfNoneMatch(entityTag string) *OnboardingListCategoriesCall {
|
||
|
c.opt_["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 *OnboardingListCategoriesCall) Context(ctx context.Context) *OnboardingListCategoriesCall {
|
||
|
c.ctx_ = ctx
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
func (c *OnboardingListCategoriesCall) doRequest(alt string) (*http.Response, error) {
|
||
|
var body io.Reader = nil
|
||
|
params := make(url.Values)
|
||
|
params.Set("alt", alt)
|
||
|
if v, ok := c.opt_["locale"]; ok {
|
||
|
params.Set("locale", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if v, ok := c.opt_["fields"]; ok {
|
||
|
params.Set("fields", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
urls := googleapi.ResolveRelative(c.s.BasePath, "onboarding/listCategories")
|
||
|
urls += "?" + params.Encode()
|
||
|
req, _ := http.NewRequest("GET", urls, body)
|
||
|
googleapi.SetOpaque(req.URL)
|
||
|
req.Header.Set("User-Agent", c.s.userAgent())
|
||
|
if v, ok := c.opt_["ifNoneMatch"]; ok {
|
||
|
req.Header.Set("If-None-Match", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if c.ctx_ != nil {
|
||
|
return ctxhttp.Do(c.ctx_, c.s.client, req)
|
||
|
}
|
||
|
return c.s.client.Do(req)
|
||
|
}
|
||
|
|
||
|
// Do executes the "books.onboarding.listCategories" call.
|
||
|
// Exactly one of *Category or error will be non-nil. Any non-2xx status
|
||
|
// code is an error. Response headers are in either
|
||
|
// *Category.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 *OnboardingListCategoriesCall) Do() (*Category, error) {
|
||
|
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 := &Category{
|
||
|
ServerResponse: googleapi.ServerResponse{
|
||
|
Header: res.Header,
|
||
|
HTTPStatusCode: res.StatusCode,
|
||
|
},
|
||
|
}
|
||
|
if err := json.NewDecoder(res.Body).Decode(&ret); err != nil {
|
||
|
return nil, err
|
||
|
}
|
||
|
return ret, nil
|
||
|
// {
|
||
|
// "description": "List categories for onboarding experience.",
|
||
|
// "httpMethod": "GET",
|
||
|
// "id": "books.onboarding.listCategories",
|
||
|
// "parameters": {
|
||
|
// "locale": {
|
||
|
// "description": "ISO-639-1 language and ISO-3166-1 country code. Default is en-US if unset.",
|
||
|
// "location": "query",
|
||
|
// "type": "string"
|
||
|
// }
|
||
|
// },
|
||
|
// "path": "onboarding/listCategories",
|
||
|
// "response": {
|
||
|
// "$ref": "Category"
|
||
|
// },
|
||
|
// "scopes": [
|
||
|
// "https://www.googleapis.com/auth/books"
|
||
|
// ]
|
||
|
// }
|
||
|
|
||
|
}
|
||
|
|
||
|
// method id "books.onboarding.listCategoryVolumes":
|
||
|
|
||
|
type OnboardingListCategoryVolumesCall struct {
|
||
|
s *Service
|
||
|
opt_ map[string]interface{}
|
||
|
ctx_ context.Context
|
||
|
}
|
||
|
|
||
|
// ListCategoryVolumes: List available volumes under categories for
|
||
|
// onboarding experience.
|
||
|
func (r *OnboardingService) ListCategoryVolumes() *OnboardingListCategoryVolumesCall {
|
||
|
c := &OnboardingListCategoryVolumesCall{s: r.s, opt_: make(map[string]interface{})}
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
// CategoryId sets the optional parameter "categoryId": List of category
|
||
|
// ids requested.
|
||
|
func (c *OnboardingListCategoryVolumesCall) CategoryId(categoryId string) *OnboardingListCategoryVolumesCall {
|
||
|
c.opt_["categoryId"] = categoryId
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
// Locale sets the optional parameter "locale": ISO-639-1 language and
|
||
|
// ISO-3166-1 country code. Default is en-US if unset.
|
||
|
func (c *OnboardingListCategoryVolumesCall) Locale(locale string) *OnboardingListCategoryVolumesCall {
|
||
|
c.opt_["locale"] = locale
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
// MaxAllowedMaturityRating sets the optional parameter
|
||
|
// "maxAllowedMaturityRating": The maximum allowed maturity rating of
|
||
|
// returned volumes. Books with a higher maturity rating are filtered
|
||
|
// out.
|
||
|
//
|
||
|
// Possible values:
|
||
|
// "mature" - Show books which are rated mature or lower.
|
||
|
// "not-mature" - Show books which are rated not mature.
|
||
|
func (c *OnboardingListCategoryVolumesCall) MaxAllowedMaturityRating(maxAllowedMaturityRating string) *OnboardingListCategoryVolumesCall {
|
||
|
c.opt_["maxAllowedMaturityRating"] = maxAllowedMaturityRating
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
// PageSize sets the optional parameter "pageSize": Number of maximum
|
||
|
// results per page to be included in the response.
|
||
|
func (c *OnboardingListCategoryVolumesCall) PageSize(pageSize int64) *OnboardingListCategoryVolumesCall {
|
||
|
c.opt_["pageSize"] = pageSize
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
// PageToken sets the optional parameter "pageToken": The value of the
|
||
|
// nextToken from the previous page.
|
||
|
func (c *OnboardingListCategoryVolumesCall) PageToken(pageToken string) *OnboardingListCategoryVolumesCall {
|
||
|
c.opt_["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 *OnboardingListCategoryVolumesCall) Fields(s ...googleapi.Field) *OnboardingListCategoryVolumesCall {
|
||
|
c.opt_["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 *OnboardingListCategoryVolumesCall) IfNoneMatch(entityTag string) *OnboardingListCategoryVolumesCall {
|
||
|
c.opt_["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 *OnboardingListCategoryVolumesCall) Context(ctx context.Context) *OnboardingListCategoryVolumesCall {
|
||
|
c.ctx_ = ctx
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
func (c *OnboardingListCategoryVolumesCall) doRequest(alt string) (*http.Response, error) {
|
||
|
var body io.Reader = nil
|
||
|
params := make(url.Values)
|
||
|
params.Set("alt", alt)
|
||
|
if v, ok := c.opt_["categoryId"]; ok {
|
||
|
params.Set("categoryId", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if v, ok := c.opt_["locale"]; ok {
|
||
|
params.Set("locale", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if v, ok := c.opt_["maxAllowedMaturityRating"]; ok {
|
||
|
params.Set("maxAllowedMaturityRating", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if v, ok := c.opt_["pageSize"]; ok {
|
||
|
params.Set("pageSize", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if v, ok := c.opt_["pageToken"]; ok {
|
||
|
params.Set("pageToken", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if v, ok := c.opt_["fields"]; ok {
|
||
|
params.Set("fields", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
urls := googleapi.ResolveRelative(c.s.BasePath, "onboarding/listCategoryVolumes")
|
||
|
urls += "?" + params.Encode()
|
||
|
req, _ := http.NewRequest("GET", urls, body)
|
||
|
googleapi.SetOpaque(req.URL)
|
||
|
req.Header.Set("User-Agent", c.s.userAgent())
|
||
|
if v, ok := c.opt_["ifNoneMatch"]; ok {
|
||
|
req.Header.Set("If-None-Match", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if c.ctx_ != nil {
|
||
|
return ctxhttp.Do(c.ctx_, c.s.client, req)
|
||
|
}
|
||
|
return c.s.client.Do(req)
|
||
|
}
|
||
|
|
||
|
// Do executes the "books.onboarding.listCategoryVolumes" call.
|
||
|
// Exactly one of *Volume2 or error will be non-nil. Any non-2xx status
|
||
|
// code is an error. Response headers are in either
|
||
|
// *Volume2.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 *OnboardingListCategoryVolumesCall) Do() (*Volume2, error) {
|
||
|
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 := &Volume2{
|
||
|
ServerResponse: googleapi.ServerResponse{
|
||
|
Header: res.Header,
|
||
|
HTTPStatusCode: res.StatusCode,
|
||
|
},
|
||
|
}
|
||
|
if err := json.NewDecoder(res.Body).Decode(&ret); err != nil {
|
||
|
return nil, err
|
||
|
}
|
||
|
return ret, nil
|
||
|
// {
|
||
|
// "description": "List available volumes under categories for onboarding experience.",
|
||
|
// "httpMethod": "GET",
|
||
|
// "id": "books.onboarding.listCategoryVolumes",
|
||
|
// "parameters": {
|
||
|
// "categoryId": {
|
||
|
// "description": "List of category ids requested.",
|
||
|
// "location": "query",
|
||
|
// "repeated": true,
|
||
|
// "type": "string"
|
||
|
// },
|
||
|
// "locale": {
|
||
|
// "description": "ISO-639-1 language and ISO-3166-1 country code. Default is en-US if unset.",
|
||
|
// "location": "query",
|
||
|
// "type": "string"
|
||
|
// },
|
||
|
// "maxAllowedMaturityRating": {
|
||
|
// "description": "The maximum allowed maturity rating of returned volumes. Books with a higher maturity rating are filtered out.",
|
||
|
// "enum": [
|
||
|
// "mature",
|
||
|
// "not-mature"
|
||
|
// ],
|
||
|
// "enumDescriptions": [
|
||
|
// "Show books which are rated mature or lower.",
|
||
|
// "Show books which are rated not mature."
|
||
|
// ],
|
||
|
// "location": "query",
|
||
|
// "type": "string"
|
||
|
// },
|
||
|
// "pageSize": {
|
||
|
// "description": "Number of maximum results per page to be included in the response.",
|
||
|
// "format": "uint32",
|
||
|
// "location": "query",
|
||
|
// "type": "integer"
|
||
|
// },
|
||
|
// "pageToken": {
|
||
|
// "description": "The value of the nextToken from the previous page.",
|
||
|
// "location": "query",
|
||
|
// "type": "string"
|
||
|
// }
|
||
|
// },
|
||
|
// "path": "onboarding/listCategoryVolumes",
|
||
|
// "response": {
|
||
|
// "$ref": "Volume2"
|
||
|
// },
|
||
|
// "scopes": [
|
||
|
// "https://www.googleapis.com/auth/books"
|
||
|
// ]
|
||
|
// }
|
||
|
|
||
|
}
|
||
|
|
||
|
// method id "books.personalizedstream.get":
|
||
|
|
||
|
type PersonalizedstreamGetCall struct {
|
||
|
s *Service
|
||
|
opt_ map[string]interface{}
|
||
|
ctx_ context.Context
|
||
|
}
|
||
|
|
||
|
// Get: Returns a stream of personalized book clusters
|
||
|
func (r *PersonalizedstreamService) Get() *PersonalizedstreamGetCall {
|
||
|
c := &PersonalizedstreamGetCall{s: r.s, opt_: make(map[string]interface{})}
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
// Locale sets the optional parameter "locale": ISO-639-1 language and
|
||
|
// ISO-3166-1 country code. Ex: 'en_US'. Used for generating
|
||
|
// recommendations.
|
||
|
func (c *PersonalizedstreamGetCall) Locale(locale string) *PersonalizedstreamGetCall {
|
||
|
c.opt_["locale"] = locale
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
// MaxAllowedMaturityRating sets the optional parameter
|
||
|
// "maxAllowedMaturityRating": The maximum allowed maturity rating of
|
||
|
// returned recommendations. Books with a higher maturity rating are
|
||
|
// filtered out.
|
||
|
//
|
||
|
// Possible values:
|
||
|
// "mature" - Show books which are rated mature or lower.
|
||
|
// "not-mature" - Show books which are rated not mature.
|
||
|
func (c *PersonalizedstreamGetCall) MaxAllowedMaturityRating(maxAllowedMaturityRating string) *PersonalizedstreamGetCall {
|
||
|
c.opt_["maxAllowedMaturityRating"] = maxAllowedMaturityRating
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
// Source sets the optional parameter "source": String to identify the
|
||
|
// originator of this request.
|
||
|
func (c *PersonalizedstreamGetCall) Source(source string) *PersonalizedstreamGetCall {
|
||
|
c.opt_["source"] = source
|
||
|
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 *PersonalizedstreamGetCall) Fields(s ...googleapi.Field) *PersonalizedstreamGetCall {
|
||
|
c.opt_["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 *PersonalizedstreamGetCall) IfNoneMatch(entityTag string) *PersonalizedstreamGetCall {
|
||
|
c.opt_["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 *PersonalizedstreamGetCall) Context(ctx context.Context) *PersonalizedstreamGetCall {
|
||
|
c.ctx_ = ctx
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
func (c *PersonalizedstreamGetCall) doRequest(alt string) (*http.Response, error) {
|
||
|
var body io.Reader = nil
|
||
|
params := make(url.Values)
|
||
|
params.Set("alt", alt)
|
||
|
if v, ok := c.opt_["locale"]; ok {
|
||
|
params.Set("locale", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if v, ok := c.opt_["maxAllowedMaturityRating"]; ok {
|
||
|
params.Set("maxAllowedMaturityRating", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if v, ok := c.opt_["source"]; ok {
|
||
|
params.Set("source", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if v, ok := c.opt_["fields"]; ok {
|
||
|
params.Set("fields", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
urls := googleapi.ResolveRelative(c.s.BasePath, "personalizedstream/get")
|
||
|
urls += "?" + params.Encode()
|
||
|
req, _ := http.NewRequest("GET", urls, body)
|
||
|
googleapi.SetOpaque(req.URL)
|
||
|
req.Header.Set("User-Agent", c.s.userAgent())
|
||
|
if v, ok := c.opt_["ifNoneMatch"]; ok {
|
||
|
req.Header.Set("If-None-Match", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if c.ctx_ != nil {
|
||
|
return ctxhttp.Do(c.ctx_, c.s.client, req)
|
||
|
}
|
||
|
return c.s.client.Do(req)
|
||
|
}
|
||
|
|
||
|
// Do executes the "books.personalizedstream.get" call.
|
||
|
// Exactly one of *Discoveryclusters or error will be non-nil. Any
|
||
|
// non-2xx status code is an error. Response headers are in either
|
||
|
// *Discoveryclusters.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 *PersonalizedstreamGetCall) Do() (*Discoveryclusters, error) {
|
||
|
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 := &Discoveryclusters{
|
||
|
ServerResponse: googleapi.ServerResponse{
|
||
|
Header: res.Header,
|
||
|
HTTPStatusCode: res.StatusCode,
|
||
|
},
|
||
|
}
|
||
|
if err := json.NewDecoder(res.Body).Decode(&ret); err != nil {
|
||
|
return nil, err
|
||
|
}
|
||
|
return ret, nil
|
||
|
// {
|
||
|
// "description": "Returns a stream of personalized book clusters",
|
||
|
// "httpMethod": "GET",
|
||
|
// "id": "books.personalizedstream.get",
|
||
|
// "parameters": {
|
||
|
// "locale": {
|
||
|
// "description": "ISO-639-1 language and ISO-3166-1 country code. Ex: 'en_US'. Used for generating recommendations.",
|
||
|
// "location": "query",
|
||
|
// "type": "string"
|
||
|
// },
|
||
|
// "maxAllowedMaturityRating": {
|
||
|
// "description": "The maximum allowed maturity rating of returned recommendations. Books with a higher maturity rating are filtered out.",
|
||
|
// "enum": [
|
||
|
// "mature",
|
||
|
// "not-mature"
|
||
|
// ],
|
||
|
// "enumDescriptions": [
|
||
|
// "Show books which are rated mature or lower.",
|
||
|
// "Show books which are rated not mature."
|
||
|
// ],
|
||
|
// "location": "query",
|
||
|
// "type": "string"
|
||
|
// },
|
||
|
// "source": {
|
||
|
// "description": "String to identify the originator of this request.",
|
||
|
// "location": "query",
|
||
|
// "type": "string"
|
||
|
// }
|
||
|
// },
|
||
|
// "path": "personalizedstream/get",
|
||
|
// "response": {
|
||
|
// "$ref": "Discoveryclusters"
|
||
|
// },
|
||
|
// "scopes": [
|
||
|
// "https://www.googleapis.com/auth/books"
|
||
|
// ]
|
||
|
// }
|
||
|
|
||
|
}
|
||
|
|
||
|
// method id "books.promooffer.accept":
|
||
|
|
||
|
type PromoofferAcceptCall struct {
|
||
|
s *Service
|
||
|
opt_ map[string]interface{}
|
||
|
ctx_ context.Context
|
||
|
}
|
||
|
|
||
|
// Accept:
|
||
|
func (r *PromoofferService) Accept() *PromoofferAcceptCall {
|
||
|
c := &PromoofferAcceptCall{s: r.s, opt_: make(map[string]interface{})}
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
// AndroidId sets the optional parameter "androidId": device android_id
|
||
|
func (c *PromoofferAcceptCall) AndroidId(androidId string) *PromoofferAcceptCall {
|
||
|
c.opt_["androidId"] = androidId
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
// Device sets the optional parameter "device": device device
|
||
|
func (c *PromoofferAcceptCall) Device(device string) *PromoofferAcceptCall {
|
||
|
c.opt_["device"] = device
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
// Manufacturer sets the optional parameter "manufacturer": device
|
||
|
// manufacturer
|
||
|
func (c *PromoofferAcceptCall) Manufacturer(manufacturer string) *PromoofferAcceptCall {
|
||
|
c.opt_["manufacturer"] = manufacturer
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
// Model sets the optional parameter "model": device model
|
||
|
func (c *PromoofferAcceptCall) Model(model string) *PromoofferAcceptCall {
|
||
|
c.opt_["model"] = model
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
// OfferId sets the optional parameter "offerId":
|
||
|
func (c *PromoofferAcceptCall) OfferId(offerId string) *PromoofferAcceptCall {
|
||
|
c.opt_["offerId"] = offerId
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
// Product sets the optional parameter "product": device product
|
||
|
func (c *PromoofferAcceptCall) Product(product string) *PromoofferAcceptCall {
|
||
|
c.opt_["product"] = product
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
// Serial sets the optional parameter "serial": device serial
|
||
|
func (c *PromoofferAcceptCall) Serial(serial string) *PromoofferAcceptCall {
|
||
|
c.opt_["serial"] = serial
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
// VolumeId sets the optional parameter "volumeId": Volume id to
|
||
|
// exercise the offer
|
||
|
func (c *PromoofferAcceptCall) VolumeId(volumeId string) *PromoofferAcceptCall {
|
||
|
c.opt_["volumeId"] = volumeId
|
||
|
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 *PromoofferAcceptCall) Fields(s ...googleapi.Field) *PromoofferAcceptCall {
|
||
|
c.opt_["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 *PromoofferAcceptCall) Context(ctx context.Context) *PromoofferAcceptCall {
|
||
|
c.ctx_ = ctx
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
func (c *PromoofferAcceptCall) doRequest(alt string) (*http.Response, error) {
|
||
|
var body io.Reader = nil
|
||
|
params := make(url.Values)
|
||
|
params.Set("alt", alt)
|
||
|
if v, ok := c.opt_["androidId"]; ok {
|
||
|
params.Set("androidId", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if v, ok := c.opt_["device"]; ok {
|
||
|
params.Set("device", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if v, ok := c.opt_["manufacturer"]; ok {
|
||
|
params.Set("manufacturer", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if v, ok := c.opt_["model"]; ok {
|
||
|
params.Set("model", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if v, ok := c.opt_["offerId"]; ok {
|
||
|
params.Set("offerId", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if v, ok := c.opt_["product"]; ok {
|
||
|
params.Set("product", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if v, ok := c.opt_["serial"]; ok {
|
||
|
params.Set("serial", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if v, ok := c.opt_["volumeId"]; ok {
|
||
|
params.Set("volumeId", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if v, ok := c.opt_["fields"]; ok {
|
||
|
params.Set("fields", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
urls := googleapi.ResolveRelative(c.s.BasePath, "promooffer/accept")
|
||
|
urls += "?" + params.Encode()
|
||
|
req, _ := http.NewRequest("POST", urls, body)
|
||
|
googleapi.SetOpaque(req.URL)
|
||
|
req.Header.Set("User-Agent", c.s.userAgent())
|
||
|
if c.ctx_ != nil {
|
||
|
return ctxhttp.Do(c.ctx_, c.s.client, req)
|
||
|
}
|
||
|
return c.s.client.Do(req)
|
||
|
}
|
||
|
|
||
|
// Do executes the "books.promooffer.accept" call.
|
||
|
func (c *PromoofferAcceptCall) Do() error {
|
||
|
res, err := c.doRequest("json")
|
||
|
if err != nil {
|
||
|
return err
|
||
|
}
|
||
|
defer googleapi.CloseBody(res)
|
||
|
if err := googleapi.CheckResponse(res); err != nil {
|
||
|
return err
|
||
|
}
|
||
|
return nil
|
||
|
// {
|
||
|
// "description": "",
|
||
|
// "httpMethod": "POST",
|
||
|
// "id": "books.promooffer.accept",
|
||
|
// "parameters": {
|
||
|
// "androidId": {
|
||
|
// "description": "device android_id",
|
||
|
// "location": "query",
|
||
|
// "type": "string"
|
||
|
// },
|
||
|
// "device": {
|
||
|
// "description": "device device",
|
||
|
// "location": "query",
|
||
|
// "type": "string"
|
||
|
// },
|
||
|
// "manufacturer": {
|
||
|
// "description": "device manufacturer",
|
||
|
// "location": "query",
|
||
|
// "type": "string"
|
||
|
// },
|
||
|
// "model": {
|
||
|
// "description": "device model",
|
||
|
// "location": "query",
|
||
|
// "type": "string"
|
||
|
// },
|
||
|
// "offerId": {
|
||
|
// "location": "query",
|
||
|
// "type": "string"
|
||
|
// },
|
||
|
// "product": {
|
||
|
// "description": "device product",
|
||
|
// "location": "query",
|
||
|
// "type": "string"
|
||
|
// },
|
||
|
// "serial": {
|
||
|
// "description": "device serial",
|
||
|
// "location": "query",
|
||
|
// "type": "string"
|
||
|
// },
|
||
|
// "volumeId": {
|
||
|
// "description": "Volume id to exercise the offer",
|
||
|
// "location": "query",
|
||
|
// "type": "string"
|
||
|
// }
|
||
|
// },
|
||
|
// "path": "promooffer/accept",
|
||
|
// "scopes": [
|
||
|
// "https://www.googleapis.com/auth/books"
|
||
|
// ]
|
||
|
// }
|
||
|
|
||
|
}
|
||
|
|
||
|
// method id "books.promooffer.dismiss":
|
||
|
|
||
|
type PromoofferDismissCall struct {
|
||
|
s *Service
|
||
|
opt_ map[string]interface{}
|
||
|
ctx_ context.Context
|
||
|
}
|
||
|
|
||
|
// Dismiss:
|
||
|
func (r *PromoofferService) Dismiss() *PromoofferDismissCall {
|
||
|
c := &PromoofferDismissCall{s: r.s, opt_: make(map[string]interface{})}
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
// AndroidId sets the optional parameter "androidId": device android_id
|
||
|
func (c *PromoofferDismissCall) AndroidId(androidId string) *PromoofferDismissCall {
|
||
|
c.opt_["androidId"] = androidId
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
// Device sets the optional parameter "device": device device
|
||
|
func (c *PromoofferDismissCall) Device(device string) *PromoofferDismissCall {
|
||
|
c.opt_["device"] = device
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
// Manufacturer sets the optional parameter "manufacturer": device
|
||
|
// manufacturer
|
||
|
func (c *PromoofferDismissCall) Manufacturer(manufacturer string) *PromoofferDismissCall {
|
||
|
c.opt_["manufacturer"] = manufacturer
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
// Model sets the optional parameter "model": device model
|
||
|
func (c *PromoofferDismissCall) Model(model string) *PromoofferDismissCall {
|
||
|
c.opt_["model"] = model
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
// OfferId sets the optional parameter "offerId": Offer to dimiss
|
||
|
func (c *PromoofferDismissCall) OfferId(offerId string) *PromoofferDismissCall {
|
||
|
c.opt_["offerId"] = offerId
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
// Product sets the optional parameter "product": device product
|
||
|
func (c *PromoofferDismissCall) Product(product string) *PromoofferDismissCall {
|
||
|
c.opt_["product"] = product
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
// Serial sets the optional parameter "serial": device serial
|
||
|
func (c *PromoofferDismissCall) Serial(serial string) *PromoofferDismissCall {
|
||
|
c.opt_["serial"] = serial
|
||
|
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 *PromoofferDismissCall) Fields(s ...googleapi.Field) *PromoofferDismissCall {
|
||
|
c.opt_["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 *PromoofferDismissCall) Context(ctx context.Context) *PromoofferDismissCall {
|
||
|
c.ctx_ = ctx
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
func (c *PromoofferDismissCall) doRequest(alt string) (*http.Response, error) {
|
||
|
var body io.Reader = nil
|
||
|
params := make(url.Values)
|
||
|
params.Set("alt", alt)
|
||
|
if v, ok := c.opt_["androidId"]; ok {
|
||
|
params.Set("androidId", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if v, ok := c.opt_["device"]; ok {
|
||
|
params.Set("device", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if v, ok := c.opt_["manufacturer"]; ok {
|
||
|
params.Set("manufacturer", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if v, ok := c.opt_["model"]; ok {
|
||
|
params.Set("model", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if v, ok := c.opt_["offerId"]; ok {
|
||
|
params.Set("offerId", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if v, ok := c.opt_["product"]; ok {
|
||
|
params.Set("product", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if v, ok := c.opt_["serial"]; ok {
|
||
|
params.Set("serial", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if v, ok := c.opt_["fields"]; ok {
|
||
|
params.Set("fields", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
urls := googleapi.ResolveRelative(c.s.BasePath, "promooffer/dismiss")
|
||
|
urls += "?" + params.Encode()
|
||
|
req, _ := http.NewRequest("POST", urls, body)
|
||
|
googleapi.SetOpaque(req.URL)
|
||
|
req.Header.Set("User-Agent", c.s.userAgent())
|
||
|
if c.ctx_ != nil {
|
||
|
return ctxhttp.Do(c.ctx_, c.s.client, req)
|
||
|
}
|
||
|
return c.s.client.Do(req)
|
||
|
}
|
||
|
|
||
|
// Do executes the "books.promooffer.dismiss" call.
|
||
|
func (c *PromoofferDismissCall) Do() error {
|
||
|
res, err := c.doRequest("json")
|
||
|
if err != nil {
|
||
|
return err
|
||
|
}
|
||
|
defer googleapi.CloseBody(res)
|
||
|
if err := googleapi.CheckResponse(res); err != nil {
|
||
|
return err
|
||
|
}
|
||
|
return nil
|
||
|
// {
|
||
|
// "description": "",
|
||
|
// "httpMethod": "POST",
|
||
|
// "id": "books.promooffer.dismiss",
|
||
|
// "parameters": {
|
||
|
// "androidId": {
|
||
|
// "description": "device android_id",
|
||
|
// "location": "query",
|
||
|
// "type": "string"
|
||
|
// },
|
||
|
// "device": {
|
||
|
// "description": "device device",
|
||
|
// "location": "query",
|
||
|
// "type": "string"
|
||
|
// },
|
||
|
// "manufacturer": {
|
||
|
// "description": "device manufacturer",
|
||
|
// "location": "query",
|
||
|
// "type": "string"
|
||
|
// },
|
||
|
// "model": {
|
||
|
// "description": "device model",
|
||
|
// "location": "query",
|
||
|
// "type": "string"
|
||
|
// },
|
||
|
// "offerId": {
|
||
|
// "description": "Offer to dimiss",
|
||
|
// "location": "query",
|
||
|
// "type": "string"
|
||
|
// },
|
||
|
// "product": {
|
||
|
// "description": "device product",
|
||
|
// "location": "query",
|
||
|
// "type": "string"
|
||
|
// },
|
||
|
// "serial": {
|
||
|
// "description": "device serial",
|
||
|
// "location": "query",
|
||
|
// "type": "string"
|
||
|
// }
|
||
|
// },
|
||
|
// "path": "promooffer/dismiss",
|
||
|
// "scopes": [
|
||
|
// "https://www.googleapis.com/auth/books"
|
||
|
// ]
|
||
|
// }
|
||
|
|
||
|
}
|
||
|
|
||
|
// method id "books.promooffer.get":
|
||
|
|
||
|
type PromoofferGetCall struct {
|
||
|
s *Service
|
||
|
opt_ map[string]interface{}
|
||
|
ctx_ context.Context
|
||
|
}
|
||
|
|
||
|
// Get: Returns a list of promo offers available to the user
|
||
|
func (r *PromoofferService) Get() *PromoofferGetCall {
|
||
|
c := &PromoofferGetCall{s: r.s, opt_: make(map[string]interface{})}
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
// AndroidId sets the optional parameter "androidId": device android_id
|
||
|
func (c *PromoofferGetCall) AndroidId(androidId string) *PromoofferGetCall {
|
||
|
c.opt_["androidId"] = androidId
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
// Device sets the optional parameter "device": device device
|
||
|
func (c *PromoofferGetCall) Device(device string) *PromoofferGetCall {
|
||
|
c.opt_["device"] = device
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
// Manufacturer sets the optional parameter "manufacturer": device
|
||
|
// manufacturer
|
||
|
func (c *PromoofferGetCall) Manufacturer(manufacturer string) *PromoofferGetCall {
|
||
|
c.opt_["manufacturer"] = manufacturer
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
// Model sets the optional parameter "model": device model
|
||
|
func (c *PromoofferGetCall) Model(model string) *PromoofferGetCall {
|
||
|
c.opt_["model"] = model
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
// Product sets the optional parameter "product": device product
|
||
|
func (c *PromoofferGetCall) Product(product string) *PromoofferGetCall {
|
||
|
c.opt_["product"] = product
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
// Serial sets the optional parameter "serial": device serial
|
||
|
func (c *PromoofferGetCall) Serial(serial string) *PromoofferGetCall {
|
||
|
c.opt_["serial"] = serial
|
||
|
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 *PromoofferGetCall) Fields(s ...googleapi.Field) *PromoofferGetCall {
|
||
|
c.opt_["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 *PromoofferGetCall) IfNoneMatch(entityTag string) *PromoofferGetCall {
|
||
|
c.opt_["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 *PromoofferGetCall) Context(ctx context.Context) *PromoofferGetCall {
|
||
|
c.ctx_ = ctx
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
func (c *PromoofferGetCall) doRequest(alt string) (*http.Response, error) {
|
||
|
var body io.Reader = nil
|
||
|
params := make(url.Values)
|
||
|
params.Set("alt", alt)
|
||
|
if v, ok := c.opt_["androidId"]; ok {
|
||
|
params.Set("androidId", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if v, ok := c.opt_["device"]; ok {
|
||
|
params.Set("device", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if v, ok := c.opt_["manufacturer"]; ok {
|
||
|
params.Set("manufacturer", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if v, ok := c.opt_["model"]; ok {
|
||
|
params.Set("model", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if v, ok := c.opt_["product"]; ok {
|
||
|
params.Set("product", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if v, ok := c.opt_["serial"]; ok {
|
||
|
params.Set("serial", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if v, ok := c.opt_["fields"]; ok {
|
||
|
params.Set("fields", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
urls := googleapi.ResolveRelative(c.s.BasePath, "promooffer/get")
|
||
|
urls += "?" + params.Encode()
|
||
|
req, _ := http.NewRequest("GET", urls, body)
|
||
|
googleapi.SetOpaque(req.URL)
|
||
|
req.Header.Set("User-Agent", c.s.userAgent())
|
||
|
if v, ok := c.opt_["ifNoneMatch"]; ok {
|
||
|
req.Header.Set("If-None-Match", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if c.ctx_ != nil {
|
||
|
return ctxhttp.Do(c.ctx_, c.s.client, req)
|
||
|
}
|
||
|
return c.s.client.Do(req)
|
||
|
}
|
||
|
|
||
|
// Do executes the "books.promooffer.get" call.
|
||
|
// Exactly one of *Offers or error will be non-nil. Any non-2xx status
|
||
|
// code is an error. Response headers are in either
|
||
|
// *Offers.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 *PromoofferGetCall) Do() (*Offers, error) {
|
||
|
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 := &Offers{
|
||
|
ServerResponse: googleapi.ServerResponse{
|
||
|
Header: res.Header,
|
||
|
HTTPStatusCode: res.StatusCode,
|
||
|
},
|
||
|
}
|
||
|
if err := json.NewDecoder(res.Body).Decode(&ret); err != nil {
|
||
|
return nil, err
|
||
|
}
|
||
|
return ret, nil
|
||
|
// {
|
||
|
// "description": "Returns a list of promo offers available to the user",
|
||
|
// "httpMethod": "GET",
|
||
|
// "id": "books.promooffer.get",
|
||
|
// "parameters": {
|
||
|
// "androidId": {
|
||
|
// "description": "device android_id",
|
||
|
// "location": "query",
|
||
|
// "type": "string"
|
||
|
// },
|
||
|
// "device": {
|
||
|
// "description": "device device",
|
||
|
// "location": "query",
|
||
|
// "type": "string"
|
||
|
// },
|
||
|
// "manufacturer": {
|
||
|
// "description": "device manufacturer",
|
||
|
// "location": "query",
|
||
|
// "type": "string"
|
||
|
// },
|
||
|
// "model": {
|
||
|
// "description": "device model",
|
||
|
// "location": "query",
|
||
|
// "type": "string"
|
||
|
// },
|
||
|
// "product": {
|
||
|
// "description": "device product",
|
||
|
// "location": "query",
|
||
|
// "type": "string"
|
||
|
// },
|
||
|
// "serial": {
|
||
|
// "description": "device serial",
|
||
|
// "location": "query",
|
||
|
// "type": "string"
|
||
|
// }
|
||
|
// },
|
||
|
// "path": "promooffer/get",
|
||
|
// "response": {
|
||
|
// "$ref": "Offers"
|
||
|
// },
|
||
|
// "scopes": [
|
||
|
// "https://www.googleapis.com/auth/books"
|
||
|
// ]
|
||
|
// }
|
||
|
|
||
|
}
|
||
|
|
||
|
// method id "books.volumes.get":
|
||
|
|
||
|
type VolumesGetCall struct {
|
||
|
s *Service
|
||
|
volumeId string
|
||
|
opt_ map[string]interface{}
|
||
|
ctx_ context.Context
|
||
|
}
|
||
|
|
||
|
// Get: Gets volume information for a single volume.
|
||
|
func (r *VolumesService) Get(volumeId string) *VolumesGetCall {
|
||
|
c := &VolumesGetCall{s: r.s, opt_: make(map[string]interface{})}
|
||
|
c.volumeId = volumeId
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
// Country sets the optional parameter "country": ISO-3166-1 code to
|
||
|
// override the IP-based location.
|
||
|
func (c *VolumesGetCall) Country(country string) *VolumesGetCall {
|
||
|
c.opt_["country"] = country
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
// Partner sets the optional parameter "partner": Brand results for
|
||
|
// partner ID.
|
||
|
func (c *VolumesGetCall) Partner(partner string) *VolumesGetCall {
|
||
|
c.opt_["partner"] = partner
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
// Projection sets the optional parameter "projection": Restrict
|
||
|
// information returned to a set of selected fields.
|
||
|
//
|
||
|
// Possible values:
|
||
|
// "full" - Includes all volume data.
|
||
|
// "lite" - Includes a subset of fields in volumeInfo and accessInfo.
|
||
|
func (c *VolumesGetCall) Projection(projection string) *VolumesGetCall {
|
||
|
c.opt_["projection"] = projection
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
// Source sets the optional parameter "source": String to identify the
|
||
|
// originator of this request.
|
||
|
func (c *VolumesGetCall) Source(source string) *VolumesGetCall {
|
||
|
c.opt_["source"] = source
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
// UserLibraryConsistentRead sets the optional parameter
|
||
|
// "user_library_consistent_read":
|
||
|
func (c *VolumesGetCall) UserLibraryConsistentRead(userLibraryConsistentRead bool) *VolumesGetCall {
|
||
|
c.opt_["user_library_consistent_read"] = userLibraryConsistentRead
|
||
|
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 *VolumesGetCall) Fields(s ...googleapi.Field) *VolumesGetCall {
|
||
|
c.opt_["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 *VolumesGetCall) IfNoneMatch(entityTag string) *VolumesGetCall {
|
||
|
c.opt_["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 *VolumesGetCall) Context(ctx context.Context) *VolumesGetCall {
|
||
|
c.ctx_ = ctx
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
func (c *VolumesGetCall) doRequest(alt string) (*http.Response, error) {
|
||
|
var body io.Reader = nil
|
||
|
params := make(url.Values)
|
||
|
params.Set("alt", alt)
|
||
|
if v, ok := c.opt_["country"]; ok {
|
||
|
params.Set("country", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if v, ok := c.opt_["partner"]; ok {
|
||
|
params.Set("partner", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if v, ok := c.opt_["projection"]; ok {
|
||
|
params.Set("projection", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if v, ok := c.opt_["source"]; ok {
|
||
|
params.Set("source", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if v, ok := c.opt_["user_library_consistent_read"]; ok {
|
||
|
params.Set("user_library_consistent_read", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if v, ok := c.opt_["fields"]; ok {
|
||
|
params.Set("fields", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
urls := googleapi.ResolveRelative(c.s.BasePath, "volumes/{volumeId}")
|
||
|
urls += "?" + params.Encode()
|
||
|
req, _ := http.NewRequest("GET", urls, body)
|
||
|
googleapi.Expand(req.URL, map[string]string{
|
||
|
"volumeId": c.volumeId,
|
||
|
})
|
||
|
req.Header.Set("User-Agent", c.s.userAgent())
|
||
|
if v, ok := c.opt_["ifNoneMatch"]; ok {
|
||
|
req.Header.Set("If-None-Match", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if c.ctx_ != nil {
|
||
|
return ctxhttp.Do(c.ctx_, c.s.client, req)
|
||
|
}
|
||
|
return c.s.client.Do(req)
|
||
|
}
|
||
|
|
||
|
// Do executes the "books.volumes.get" call.
|
||
|
// Exactly one of *Volume or error will be non-nil. Any non-2xx status
|
||
|
// code is an error. Response headers are in either
|
||
|
// *Volume.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 *VolumesGetCall) Do() (*Volume, error) {
|
||
|
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 := &Volume{
|
||
|
ServerResponse: googleapi.ServerResponse{
|
||
|
Header: res.Header,
|
||
|
HTTPStatusCode: res.StatusCode,
|
||
|
},
|
||
|
}
|
||
|
if err := json.NewDecoder(res.Body).Decode(&ret); err != nil {
|
||
|
return nil, err
|
||
|
}
|
||
|
return ret, nil
|
||
|
// {
|
||
|
// "description": "Gets volume information for a single volume.",
|
||
|
// "httpMethod": "GET",
|
||
|
// "id": "books.volumes.get",
|
||
|
// "parameterOrder": [
|
||
|
// "volumeId"
|
||
|
// ],
|
||
|
// "parameters": {
|
||
|
// "country": {
|
||
|
// "description": "ISO-3166-1 code to override the IP-based location.",
|
||
|
// "location": "query",
|
||
|
// "type": "string"
|
||
|
// },
|
||
|
// "partner": {
|
||
|
// "description": "Brand results for partner ID.",
|
||
|
// "location": "query",
|
||
|
// "type": "string"
|
||
|
// },
|
||
|
// "projection": {
|
||
|
// "description": "Restrict information returned to a set of selected fields.",
|
||
|
// "enum": [
|
||
|
// "full",
|
||
|
// "lite"
|
||
|
// ],
|
||
|
// "enumDescriptions": [
|
||
|
// "Includes all volume data.",
|
||
|
// "Includes a subset of fields in volumeInfo and accessInfo."
|
||
|
// ],
|
||
|
// "location": "query",
|
||
|
// "type": "string"
|
||
|
// },
|
||
|
// "source": {
|
||
|
// "description": "String to identify the originator of this request.",
|
||
|
// "location": "query",
|
||
|
// "type": "string"
|
||
|
// },
|
||
|
// "user_library_consistent_read": {
|
||
|
// "location": "query",
|
||
|
// "type": "boolean"
|
||
|
// },
|
||
|
// "volumeId": {
|
||
|
// "description": "ID of volume to retrieve.",
|
||
|
// "location": "path",
|
||
|
// "required": true,
|
||
|
// "type": "string"
|
||
|
// }
|
||
|
// },
|
||
|
// "path": "volumes/{volumeId}",
|
||
|
// "response": {
|
||
|
// "$ref": "Volume"
|
||
|
// },
|
||
|
// "scopes": [
|
||
|
// "https://www.googleapis.com/auth/books"
|
||
|
// ]
|
||
|
// }
|
||
|
|
||
|
}
|
||
|
|
||
|
// method id "books.volumes.list":
|
||
|
|
||
|
type VolumesListCall struct {
|
||
|
s *Service
|
||
|
q string
|
||
|
opt_ map[string]interface{}
|
||
|
ctx_ context.Context
|
||
|
}
|
||
|
|
||
|
// List: Performs a book search.
|
||
|
func (r *VolumesService) List(q string) *VolumesListCall {
|
||
|
c := &VolumesListCall{s: r.s, opt_: make(map[string]interface{})}
|
||
|
c.q = q
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
// Download sets the optional parameter "download": Restrict to volumes
|
||
|
// by download availability.
|
||
|
//
|
||
|
// Possible values:
|
||
|
// "epub" - All volumes with epub.
|
||
|
func (c *VolumesListCall) Download(download string) *VolumesListCall {
|
||
|
c.opt_["download"] = download
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
// Filter sets the optional parameter "filter": Filter search results.
|
||
|
//
|
||
|
// Possible values:
|
||
|
// "ebooks" - All Google eBooks.
|
||
|
// "free-ebooks" - Google eBook with full volume text viewability.
|
||
|
// "full" - Public can view entire volume text.
|
||
|
// "paid-ebooks" - Google eBook with a price.
|
||
|
// "partial" - Public able to see parts of text.
|
||
|
func (c *VolumesListCall) Filter(filter string) *VolumesListCall {
|
||
|
c.opt_["filter"] = filter
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
// LangRestrict sets the optional parameter "langRestrict": Restrict
|
||
|
// results to books with this language code.
|
||
|
func (c *VolumesListCall) LangRestrict(langRestrict string) *VolumesListCall {
|
||
|
c.opt_["langRestrict"] = langRestrict
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
// LibraryRestrict sets the optional parameter "libraryRestrict":
|
||
|
// Restrict search to this user's library.
|
||
|
//
|
||
|
// Possible values:
|
||
|
// "my-library" - Restrict to the user's library, any shelf.
|
||
|
// "no-restrict" - Do not restrict based on user's library.
|
||
|
func (c *VolumesListCall) LibraryRestrict(libraryRestrict string) *VolumesListCall {
|
||
|
c.opt_["libraryRestrict"] = libraryRestrict
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
// MaxResults sets the optional parameter "maxResults": Maximum number
|
||
|
// of results to return.
|
||
|
func (c *VolumesListCall) MaxResults(maxResults int64) *VolumesListCall {
|
||
|
c.opt_["maxResults"] = maxResults
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
// OrderBy sets the optional parameter "orderBy": Sort search results.
|
||
|
//
|
||
|
// Possible values:
|
||
|
// "newest" - Most recently published.
|
||
|
// "relevance" - Relevance to search terms.
|
||
|
func (c *VolumesListCall) OrderBy(orderBy string) *VolumesListCall {
|
||
|
c.opt_["orderBy"] = orderBy
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
// Partner sets the optional parameter "partner": Restrict and brand
|
||
|
// results for partner ID.
|
||
|
func (c *VolumesListCall) Partner(partner string) *VolumesListCall {
|
||
|
c.opt_["partner"] = partner
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
// PrintType sets the optional parameter "printType": Restrict to books
|
||
|
// or magazines.
|
||
|
//
|
||
|
// Possible values:
|
||
|
// "all" - All volume content types.
|
||
|
// "books" - Just books.
|
||
|
// "magazines" - Just magazines.
|
||
|
func (c *VolumesListCall) PrintType(printType string) *VolumesListCall {
|
||
|
c.opt_["printType"] = printType
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
// Projection sets the optional parameter "projection": Restrict
|
||
|
// information returned to a set of selected fields.
|
||
|
//
|
||
|
// Possible values:
|
||
|
// "full" - Includes all volume data.
|
||
|
// "lite" - Includes a subset of fields in volumeInfo and accessInfo.
|
||
|
func (c *VolumesListCall) Projection(projection string) *VolumesListCall {
|
||
|
c.opt_["projection"] = projection
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
// ShowPreorders sets the optional parameter "showPreorders": Set to
|
||
|
// true to show books available for preorder. Defaults to false.
|
||
|
func (c *VolumesListCall) ShowPreorders(showPreorders bool) *VolumesListCall {
|
||
|
c.opt_["showPreorders"] = showPreorders
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
// Source sets the optional parameter "source": String to identify the
|
||
|
// originator of this request.
|
||
|
func (c *VolumesListCall) Source(source string) *VolumesListCall {
|
||
|
c.opt_["source"] = source
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
// StartIndex sets the optional parameter "startIndex": Index of the
|
||
|
// first result to return (starts at 0)
|
||
|
func (c *VolumesListCall) StartIndex(startIndex int64) *VolumesListCall {
|
||
|
c.opt_["startIndex"] = startIndex
|
||
|
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 *VolumesListCall) Fields(s ...googleapi.Field) *VolumesListCall {
|
||
|
c.opt_["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 *VolumesListCall) IfNoneMatch(entityTag string) *VolumesListCall {
|
||
|
c.opt_["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 *VolumesListCall) Context(ctx context.Context) *VolumesListCall {
|
||
|
c.ctx_ = ctx
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
func (c *VolumesListCall) doRequest(alt string) (*http.Response, error) {
|
||
|
var body io.Reader = nil
|
||
|
params := make(url.Values)
|
||
|
params.Set("alt", alt)
|
||
|
params.Set("q", fmt.Sprintf("%v", c.q))
|
||
|
if v, ok := c.opt_["download"]; ok {
|
||
|
params.Set("download", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if v, ok := c.opt_["filter"]; ok {
|
||
|
params.Set("filter", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if v, ok := c.opt_["langRestrict"]; ok {
|
||
|
params.Set("langRestrict", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if v, ok := c.opt_["libraryRestrict"]; ok {
|
||
|
params.Set("libraryRestrict", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if v, ok := c.opt_["maxResults"]; ok {
|
||
|
params.Set("maxResults", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if v, ok := c.opt_["orderBy"]; ok {
|
||
|
params.Set("orderBy", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if v, ok := c.opt_["partner"]; ok {
|
||
|
params.Set("partner", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if v, ok := c.opt_["printType"]; ok {
|
||
|
params.Set("printType", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if v, ok := c.opt_["projection"]; ok {
|
||
|
params.Set("projection", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if v, ok := c.opt_["showPreorders"]; ok {
|
||
|
params.Set("showPreorders", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if v, ok := c.opt_["source"]; ok {
|
||
|
params.Set("source", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if v, ok := c.opt_["startIndex"]; ok {
|
||
|
params.Set("startIndex", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if v, ok := c.opt_["fields"]; ok {
|
||
|
params.Set("fields", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
urls := googleapi.ResolveRelative(c.s.BasePath, "volumes")
|
||
|
urls += "?" + params.Encode()
|
||
|
req, _ := http.NewRequest("GET", urls, body)
|
||
|
googleapi.SetOpaque(req.URL)
|
||
|
req.Header.Set("User-Agent", c.s.userAgent())
|
||
|
if v, ok := c.opt_["ifNoneMatch"]; ok {
|
||
|
req.Header.Set("If-None-Match", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if c.ctx_ != nil {
|
||
|
return ctxhttp.Do(c.ctx_, c.s.client, req)
|
||
|
}
|
||
|
return c.s.client.Do(req)
|
||
|
}
|
||
|
|
||
|
// Do executes the "books.volumes.list" call.
|
||
|
// Exactly one of *Volumes or error will be non-nil. Any non-2xx status
|
||
|
// code is an error. Response headers are in either
|
||
|
// *Volumes.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 *VolumesListCall) Do() (*Volumes, error) {
|
||
|
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 := &Volumes{
|
||
|
ServerResponse: googleapi.ServerResponse{
|
||
|
Header: res.Header,
|
||
|
HTTPStatusCode: res.StatusCode,
|
||
|
},
|
||
|
}
|
||
|
if err := json.NewDecoder(res.Body).Decode(&ret); err != nil {
|
||
|
return nil, err
|
||
|
}
|
||
|
return ret, nil
|
||
|
// {
|
||
|
// "description": "Performs a book search.",
|
||
|
// "httpMethod": "GET",
|
||
|
// "id": "books.volumes.list",
|
||
|
// "parameterOrder": [
|
||
|
// "q"
|
||
|
// ],
|
||
|
// "parameters": {
|
||
|
// "download": {
|
||
|
// "description": "Restrict to volumes by download availability.",
|
||
|
// "enum": [
|
||
|
// "epub"
|
||
|
// ],
|
||
|
// "enumDescriptions": [
|
||
|
// "All volumes with epub."
|
||
|
// ],
|
||
|
// "location": "query",
|
||
|
// "type": "string"
|
||
|
// },
|
||
|
// "filter": {
|
||
|
// "description": "Filter search results.",
|
||
|
// "enum": [
|
||
|
// "ebooks",
|
||
|
// "free-ebooks",
|
||
|
// "full",
|
||
|
// "paid-ebooks",
|
||
|
// "partial"
|
||
|
// ],
|
||
|
// "enumDescriptions": [
|
||
|
// "All Google eBooks.",
|
||
|
// "Google eBook with full volume text viewability.",
|
||
|
// "Public can view entire volume text.",
|
||
|
// "Google eBook with a price.",
|
||
|
// "Public able to see parts of text."
|
||
|
// ],
|
||
|
// "location": "query",
|
||
|
// "type": "string"
|
||
|
// },
|
||
|
// "langRestrict": {
|
||
|
// "description": "Restrict results to books with this language code.",
|
||
|
// "location": "query",
|
||
|
// "type": "string"
|
||
|
// },
|
||
|
// "libraryRestrict": {
|
||
|
// "description": "Restrict search to this user's library.",
|
||
|
// "enum": [
|
||
|
// "my-library",
|
||
|
// "no-restrict"
|
||
|
// ],
|
||
|
// "enumDescriptions": [
|
||
|
// "Restrict to the user's library, any shelf.",
|
||
|
// "Do not restrict based on user's library."
|
||
|
// ],
|
||
|
// "location": "query",
|
||
|
// "type": "string"
|
||
|
// },
|
||
|
// "maxResults": {
|
||
|
// "description": "Maximum number of results to return.",
|
||
|
// "format": "uint32",
|
||
|
// "location": "query",
|
||
|
// "maximum": "40",
|
||
|
// "minimum": "0",
|
||
|
// "type": "integer"
|
||
|
// },
|
||
|
// "orderBy": {
|
||
|
// "description": "Sort search results.",
|
||
|
// "enum": [
|
||
|
// "newest",
|
||
|
// "relevance"
|
||
|
// ],
|
||
|
// "enumDescriptions": [
|
||
|
// "Most recently published.",
|
||
|
// "Relevance to search terms."
|
||
|
// ],
|
||
|
// "location": "query",
|
||
|
// "type": "string"
|
||
|
// },
|
||
|
// "partner": {
|
||
|
// "description": "Restrict and brand results for partner ID.",
|
||
|
// "location": "query",
|
||
|
// "type": "string"
|
||
|
// },
|
||
|
// "printType": {
|
||
|
// "description": "Restrict to books or magazines.",
|
||
|
// "enum": [
|
||
|
// "all",
|
||
|
// "books",
|
||
|
// "magazines"
|
||
|
// ],
|
||
|
// "enumDescriptions": [
|
||
|
// "All volume content types.",
|
||
|
// "Just books.",
|
||
|
// "Just magazines."
|
||
|
// ],
|
||
|
// "location": "query",
|
||
|
// "type": "string"
|
||
|
// },
|
||
|
// "projection": {
|
||
|
// "description": "Restrict information returned to a set of selected fields.",
|
||
|
// "enum": [
|
||
|
// "full",
|
||
|
// "lite"
|
||
|
// ],
|
||
|
// "enumDescriptions": [
|
||
|
// "Includes all volume data.",
|
||
|
// "Includes a subset of fields in volumeInfo and accessInfo."
|
||
|
// ],
|
||
|
// "location": "query",
|
||
|
// "type": "string"
|
||
|
// },
|
||
|
// "q": {
|
||
|
// "description": "Full-text search query string.",
|
||
|
// "location": "query",
|
||
|
// "required": true,
|
||
|
// "type": "string"
|
||
|
// },
|
||
|
// "showPreorders": {
|
||
|
// "description": "Set to true to show books available for preorder. Defaults to false.",
|
||
|
// "location": "query",
|
||
|
// "type": "boolean"
|
||
|
// },
|
||
|
// "source": {
|
||
|
// "description": "String to identify the originator of this request.",
|
||
|
// "location": "query",
|
||
|
// "type": "string"
|
||
|
// },
|
||
|
// "startIndex": {
|
||
|
// "description": "Index of the first result to return (starts at 0)",
|
||
|
// "format": "uint32",
|
||
|
// "location": "query",
|
||
|
// "minimum": "0",
|
||
|
// "type": "integer"
|
||
|
// }
|
||
|
// },
|
||
|
// "path": "volumes",
|
||
|
// "response": {
|
||
|
// "$ref": "Volumes"
|
||
|
// },
|
||
|
// "scopes": [
|
||
|
// "https://www.googleapis.com/auth/books"
|
||
|
// ]
|
||
|
// }
|
||
|
|
||
|
}
|
||
|
|
||
|
// method id "books.volumes.associated.list":
|
||
|
|
||
|
type VolumesAssociatedListCall struct {
|
||
|
s *Service
|
||
|
volumeId string
|
||
|
opt_ map[string]interface{}
|
||
|
ctx_ context.Context
|
||
|
}
|
||
|
|
||
|
// List: Return a list of associated books.
|
||
|
func (r *VolumesAssociatedService) List(volumeId string) *VolumesAssociatedListCall {
|
||
|
c := &VolumesAssociatedListCall{s: r.s, opt_: make(map[string]interface{})}
|
||
|
c.volumeId = volumeId
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
// Association sets the optional parameter "association": Association
|
||
|
// type.
|
||
|
//
|
||
|
// Possible values:
|
||
|
// "end-of-sample" - Recommendations for display end-of-sample.
|
||
|
// "end-of-volume" - Recommendations for display end-of-volume.
|
||
|
// "related-for-play" - Related volumes for Play Store.
|
||
|
func (c *VolumesAssociatedListCall) Association(association string) *VolumesAssociatedListCall {
|
||
|
c.opt_["association"] = association
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
// Locale sets the optional parameter "locale": ISO-639-1 language and
|
||
|
// ISO-3166-1 country code. Ex: 'en_US'. Used for generating
|
||
|
// recommendations.
|
||
|
func (c *VolumesAssociatedListCall) Locale(locale string) *VolumesAssociatedListCall {
|
||
|
c.opt_["locale"] = locale
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
// MaxAllowedMaturityRating sets the optional parameter
|
||
|
// "maxAllowedMaturityRating": The maximum allowed maturity rating of
|
||
|
// returned recommendations. Books with a higher maturity rating are
|
||
|
// filtered out.
|
||
|
//
|
||
|
// Possible values:
|
||
|
// "mature" - Show books which are rated mature or lower.
|
||
|
// "not-mature" - Show books which are rated not mature.
|
||
|
func (c *VolumesAssociatedListCall) MaxAllowedMaturityRating(maxAllowedMaturityRating string) *VolumesAssociatedListCall {
|
||
|
c.opt_["maxAllowedMaturityRating"] = maxAllowedMaturityRating
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
// Source sets the optional parameter "source": String to identify the
|
||
|
// originator of this request.
|
||
|
func (c *VolumesAssociatedListCall) Source(source string) *VolumesAssociatedListCall {
|
||
|
c.opt_["source"] = source
|
||
|
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 *VolumesAssociatedListCall) Fields(s ...googleapi.Field) *VolumesAssociatedListCall {
|
||
|
c.opt_["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 *VolumesAssociatedListCall) IfNoneMatch(entityTag string) *VolumesAssociatedListCall {
|
||
|
c.opt_["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 *VolumesAssociatedListCall) Context(ctx context.Context) *VolumesAssociatedListCall {
|
||
|
c.ctx_ = ctx
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
func (c *VolumesAssociatedListCall) doRequest(alt string) (*http.Response, error) {
|
||
|
var body io.Reader = nil
|
||
|
params := make(url.Values)
|
||
|
params.Set("alt", alt)
|
||
|
if v, ok := c.opt_["association"]; ok {
|
||
|
params.Set("association", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if v, ok := c.opt_["locale"]; ok {
|
||
|
params.Set("locale", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if v, ok := c.opt_["maxAllowedMaturityRating"]; ok {
|
||
|
params.Set("maxAllowedMaturityRating", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if v, ok := c.opt_["source"]; ok {
|
||
|
params.Set("source", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if v, ok := c.opt_["fields"]; ok {
|
||
|
params.Set("fields", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
urls := googleapi.ResolveRelative(c.s.BasePath, "volumes/{volumeId}/associated")
|
||
|
urls += "?" + params.Encode()
|
||
|
req, _ := http.NewRequest("GET", urls, body)
|
||
|
googleapi.Expand(req.URL, map[string]string{
|
||
|
"volumeId": c.volumeId,
|
||
|
})
|
||
|
req.Header.Set("User-Agent", c.s.userAgent())
|
||
|
if v, ok := c.opt_["ifNoneMatch"]; ok {
|
||
|
req.Header.Set("If-None-Match", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if c.ctx_ != nil {
|
||
|
return ctxhttp.Do(c.ctx_, c.s.client, req)
|
||
|
}
|
||
|
return c.s.client.Do(req)
|
||
|
}
|
||
|
|
||
|
// Do executes the "books.volumes.associated.list" call.
|
||
|
// Exactly one of *Volumes or error will be non-nil. Any non-2xx status
|
||
|
// code is an error. Response headers are in either
|
||
|
// *Volumes.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 *VolumesAssociatedListCall) Do() (*Volumes, error) {
|
||
|
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 := &Volumes{
|
||
|
ServerResponse: googleapi.ServerResponse{
|
||
|
Header: res.Header,
|
||
|
HTTPStatusCode: res.StatusCode,
|
||
|
},
|
||
|
}
|
||
|
if err := json.NewDecoder(res.Body).Decode(&ret); err != nil {
|
||
|
return nil, err
|
||
|
}
|
||
|
return ret, nil
|
||
|
// {
|
||
|
// "description": "Return a list of associated books.",
|
||
|
// "httpMethod": "GET",
|
||
|
// "id": "books.volumes.associated.list",
|
||
|
// "parameterOrder": [
|
||
|
// "volumeId"
|
||
|
// ],
|
||
|
// "parameters": {
|
||
|
// "association": {
|
||
|
// "description": "Association type.",
|
||
|
// "enum": [
|
||
|
// "end-of-sample",
|
||
|
// "end-of-volume",
|
||
|
// "related-for-play"
|
||
|
// ],
|
||
|
// "enumDescriptions": [
|
||
|
// "Recommendations for display end-of-sample.",
|
||
|
// "Recommendations for display end-of-volume.",
|
||
|
// "Related volumes for Play Store."
|
||
|
// ],
|
||
|
// "location": "query",
|
||
|
// "type": "string"
|
||
|
// },
|
||
|
// "locale": {
|
||
|
// "description": "ISO-639-1 language and ISO-3166-1 country code. Ex: 'en_US'. Used for generating recommendations.",
|
||
|
// "location": "query",
|
||
|
// "type": "string"
|
||
|
// },
|
||
|
// "maxAllowedMaturityRating": {
|
||
|
// "description": "The maximum allowed maturity rating of returned recommendations. Books with a higher maturity rating are filtered out.",
|
||
|
// "enum": [
|
||
|
// "mature",
|
||
|
// "not-mature"
|
||
|
// ],
|
||
|
// "enumDescriptions": [
|
||
|
// "Show books which are rated mature or lower.",
|
||
|
// "Show books which are rated not mature."
|
||
|
// ],
|
||
|
// "location": "query",
|
||
|
// "type": "string"
|
||
|
// },
|
||
|
// "source": {
|
||
|
// "description": "String to identify the originator of this request.",
|
||
|
// "location": "query",
|
||
|
// "type": "string"
|
||
|
// },
|
||
|
// "volumeId": {
|
||
|
// "description": "ID of the source volume.",
|
||
|
// "location": "path",
|
||
|
// "required": true,
|
||
|
// "type": "string"
|
||
|
// }
|
||
|
// },
|
||
|
// "path": "volumes/{volumeId}/associated",
|
||
|
// "response": {
|
||
|
// "$ref": "Volumes"
|
||
|
// },
|
||
|
// "scopes": [
|
||
|
// "https://www.googleapis.com/auth/books"
|
||
|
// ]
|
||
|
// }
|
||
|
|
||
|
}
|
||
|
|
||
|
// method id "books.volumes.mybooks.list":
|
||
|
|
||
|
type VolumesMybooksListCall struct {
|
||
|
s *Service
|
||
|
opt_ map[string]interface{}
|
||
|
ctx_ context.Context
|
||
|
}
|
||
|
|
||
|
// List: Return a list of books in My Library.
|
||
|
func (r *VolumesMybooksService) List() *VolumesMybooksListCall {
|
||
|
c := &VolumesMybooksListCall{s: r.s, opt_: make(map[string]interface{})}
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
// AcquireMethod sets the optional parameter "acquireMethod": How the
|
||
|
// book was aquired
|
||
|
//
|
||
|
// Possible values:
|
||
|
// "PREORDERED" - Preordered books (not yet available)
|
||
|
// "PREVIOUSLY_RENTED" - User-rented books past their expiration time
|
||
|
// "PUBLIC_DOMAIN" - Public domain books
|
||
|
// "PURCHASED" - Purchased books
|
||
|
// "RENTED" - User-rented books
|
||
|
// "SAMPLE" - Sample books
|
||
|
// "UPLOADED" - User uploaded books
|
||
|
func (c *VolumesMybooksListCall) AcquireMethod(acquireMethod string) *VolumesMybooksListCall {
|
||
|
c.opt_["acquireMethod"] = acquireMethod
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
// Locale sets the optional parameter "locale": ISO-639-1 language and
|
||
|
// ISO-3166-1 country code. Ex:'en_US'. Used for generating
|
||
|
// recommendations.
|
||
|
func (c *VolumesMybooksListCall) Locale(locale string) *VolumesMybooksListCall {
|
||
|
c.opt_["locale"] = locale
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
// MaxResults sets the optional parameter "maxResults": Maximum number
|
||
|
// of results to return.
|
||
|
func (c *VolumesMybooksListCall) MaxResults(maxResults int64) *VolumesMybooksListCall {
|
||
|
c.opt_["maxResults"] = maxResults
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
// ProcessingState sets the optional parameter "processingState": The
|
||
|
// processing state of the user uploaded volumes to be returned.
|
||
|
// Applicable only if the UPLOADED is specified in the acquireMethod.
|
||
|
//
|
||
|
// Possible values:
|
||
|
// "COMPLETED_FAILED" - The volume processing hase failed.
|
||
|
// "COMPLETED_SUCCESS" - The volume processing was completed.
|
||
|
// "RUNNING" - The volume processing is not completed.
|
||
|
func (c *VolumesMybooksListCall) ProcessingState(processingState string) *VolumesMybooksListCall {
|
||
|
c.opt_["processingState"] = processingState
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
// Source sets the optional parameter "source": String to identify the
|
||
|
// originator of this request.
|
||
|
func (c *VolumesMybooksListCall) Source(source string) *VolumesMybooksListCall {
|
||
|
c.opt_["source"] = source
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
// StartIndex sets the optional parameter "startIndex": Index of the
|
||
|
// first result to return (starts at 0)
|
||
|
func (c *VolumesMybooksListCall) StartIndex(startIndex int64) *VolumesMybooksListCall {
|
||
|
c.opt_["startIndex"] = startIndex
|
||
|
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 *VolumesMybooksListCall) Fields(s ...googleapi.Field) *VolumesMybooksListCall {
|
||
|
c.opt_["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 *VolumesMybooksListCall) IfNoneMatch(entityTag string) *VolumesMybooksListCall {
|
||
|
c.opt_["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 *VolumesMybooksListCall) Context(ctx context.Context) *VolumesMybooksListCall {
|
||
|
c.ctx_ = ctx
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
func (c *VolumesMybooksListCall) doRequest(alt string) (*http.Response, error) {
|
||
|
var body io.Reader = nil
|
||
|
params := make(url.Values)
|
||
|
params.Set("alt", alt)
|
||
|
if v, ok := c.opt_["acquireMethod"]; ok {
|
||
|
params.Set("acquireMethod", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if v, ok := c.opt_["locale"]; ok {
|
||
|
params.Set("locale", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if v, ok := c.opt_["maxResults"]; ok {
|
||
|
params.Set("maxResults", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if v, ok := c.opt_["processingState"]; ok {
|
||
|
params.Set("processingState", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if v, ok := c.opt_["source"]; ok {
|
||
|
params.Set("source", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if v, ok := c.opt_["startIndex"]; ok {
|
||
|
params.Set("startIndex", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if v, ok := c.opt_["fields"]; ok {
|
||
|
params.Set("fields", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
urls := googleapi.ResolveRelative(c.s.BasePath, "volumes/mybooks")
|
||
|
urls += "?" + params.Encode()
|
||
|
req, _ := http.NewRequest("GET", urls, body)
|
||
|
googleapi.SetOpaque(req.URL)
|
||
|
req.Header.Set("User-Agent", c.s.userAgent())
|
||
|
if v, ok := c.opt_["ifNoneMatch"]; ok {
|
||
|
req.Header.Set("If-None-Match", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if c.ctx_ != nil {
|
||
|
return ctxhttp.Do(c.ctx_, c.s.client, req)
|
||
|
}
|
||
|
return c.s.client.Do(req)
|
||
|
}
|
||
|
|
||
|
// Do executes the "books.volumes.mybooks.list" call.
|
||
|
// Exactly one of *Volumes or error will be non-nil. Any non-2xx status
|
||
|
// code is an error. Response headers are in either
|
||
|
// *Volumes.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 *VolumesMybooksListCall) Do() (*Volumes, error) {
|
||
|
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 := &Volumes{
|
||
|
ServerResponse: googleapi.ServerResponse{
|
||
|
Header: res.Header,
|
||
|
HTTPStatusCode: res.StatusCode,
|
||
|
},
|
||
|
}
|
||
|
if err := json.NewDecoder(res.Body).Decode(&ret); err != nil {
|
||
|
return nil, err
|
||
|
}
|
||
|
return ret, nil
|
||
|
// {
|
||
|
// "description": "Return a list of books in My Library.",
|
||
|
// "httpMethod": "GET",
|
||
|
// "id": "books.volumes.mybooks.list",
|
||
|
// "parameters": {
|
||
|
// "acquireMethod": {
|
||
|
// "description": "How the book was aquired",
|
||
|
// "enum": [
|
||
|
// "PREORDERED",
|
||
|
// "PREVIOUSLY_RENTED",
|
||
|
// "PUBLIC_DOMAIN",
|
||
|
// "PURCHASED",
|
||
|
// "RENTED",
|
||
|
// "SAMPLE",
|
||
|
// "UPLOADED"
|
||
|
// ],
|
||
|
// "enumDescriptions": [
|
||
|
// "Preordered books (not yet available)",
|
||
|
// "User-rented books past their expiration time",
|
||
|
// "Public domain books",
|
||
|
// "Purchased books",
|
||
|
// "User-rented books",
|
||
|
// "Sample books",
|
||
|
// "User uploaded books"
|
||
|
// ],
|
||
|
// "location": "query",
|
||
|
// "repeated": true,
|
||
|
// "type": "string"
|
||
|
// },
|
||
|
// "locale": {
|
||
|
// "description": "ISO-639-1 language and ISO-3166-1 country code. Ex:'en_US'. Used for generating recommendations.",
|
||
|
// "location": "query",
|
||
|
// "type": "string"
|
||
|
// },
|
||
|
// "maxResults": {
|
||
|
// "description": "Maximum number of results to return.",
|
||
|
// "format": "uint32",
|
||
|
// "location": "query",
|
||
|
// "maximum": "100",
|
||
|
// "minimum": "0",
|
||
|
// "type": "integer"
|
||
|
// },
|
||
|
// "processingState": {
|
||
|
// "description": "The processing state of the user uploaded volumes to be returned. Applicable only if the UPLOADED is specified in the acquireMethod.",
|
||
|
// "enum": [
|
||
|
// "COMPLETED_FAILED",
|
||
|
// "COMPLETED_SUCCESS",
|
||
|
// "RUNNING"
|
||
|
// ],
|
||
|
// "enumDescriptions": [
|
||
|
// "The volume processing hase failed.",
|
||
|
// "The volume processing was completed.",
|
||
|
// "The volume processing is not completed."
|
||
|
// ],
|
||
|
// "location": "query",
|
||
|
// "repeated": true,
|
||
|
// "type": "string"
|
||
|
// },
|
||
|
// "source": {
|
||
|
// "description": "String to identify the originator of this request.",
|
||
|
// "location": "query",
|
||
|
// "type": "string"
|
||
|
// },
|
||
|
// "startIndex": {
|
||
|
// "description": "Index of the first result to return (starts at 0)",
|
||
|
// "format": "uint32",
|
||
|
// "location": "query",
|
||
|
// "minimum": "0",
|
||
|
// "type": "integer"
|
||
|
// }
|
||
|
// },
|
||
|
// "path": "volumes/mybooks",
|
||
|
// "response": {
|
||
|
// "$ref": "Volumes"
|
||
|
// },
|
||
|
// "scopes": [
|
||
|
// "https://www.googleapis.com/auth/books"
|
||
|
// ]
|
||
|
// }
|
||
|
|
||
|
}
|
||
|
|
||
|
// method id "books.volumes.recommended.list":
|
||
|
|
||
|
type VolumesRecommendedListCall struct {
|
||
|
s *Service
|
||
|
opt_ map[string]interface{}
|
||
|
ctx_ context.Context
|
||
|
}
|
||
|
|
||
|
// List: Return a list of recommended books for the current user.
|
||
|
func (r *VolumesRecommendedService) List() *VolumesRecommendedListCall {
|
||
|
c := &VolumesRecommendedListCall{s: r.s, opt_: make(map[string]interface{})}
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
// Locale sets the optional parameter "locale": ISO-639-1 language and
|
||
|
// ISO-3166-1 country code. Ex: 'en_US'. Used for generating
|
||
|
// recommendations.
|
||
|
func (c *VolumesRecommendedListCall) Locale(locale string) *VolumesRecommendedListCall {
|
||
|
c.opt_["locale"] = locale
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
// MaxAllowedMaturityRating sets the optional parameter
|
||
|
// "maxAllowedMaturityRating": The maximum allowed maturity rating of
|
||
|
// returned recommendations. Books with a higher maturity rating are
|
||
|
// filtered out.
|
||
|
//
|
||
|
// Possible values:
|
||
|
// "mature" - Show books which are rated mature or lower.
|
||
|
// "not-mature" - Show books which are rated not mature.
|
||
|
func (c *VolumesRecommendedListCall) MaxAllowedMaturityRating(maxAllowedMaturityRating string) *VolumesRecommendedListCall {
|
||
|
c.opt_["maxAllowedMaturityRating"] = maxAllowedMaturityRating
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
// Source sets the optional parameter "source": String to identify the
|
||
|
// originator of this request.
|
||
|
func (c *VolumesRecommendedListCall) Source(source string) *VolumesRecommendedListCall {
|
||
|
c.opt_["source"] = source
|
||
|
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 *VolumesRecommendedListCall) Fields(s ...googleapi.Field) *VolumesRecommendedListCall {
|
||
|
c.opt_["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 *VolumesRecommendedListCall) IfNoneMatch(entityTag string) *VolumesRecommendedListCall {
|
||
|
c.opt_["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 *VolumesRecommendedListCall) Context(ctx context.Context) *VolumesRecommendedListCall {
|
||
|
c.ctx_ = ctx
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
func (c *VolumesRecommendedListCall) doRequest(alt string) (*http.Response, error) {
|
||
|
var body io.Reader = nil
|
||
|
params := make(url.Values)
|
||
|
params.Set("alt", alt)
|
||
|
if v, ok := c.opt_["locale"]; ok {
|
||
|
params.Set("locale", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if v, ok := c.opt_["maxAllowedMaturityRating"]; ok {
|
||
|
params.Set("maxAllowedMaturityRating", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if v, ok := c.opt_["source"]; ok {
|
||
|
params.Set("source", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if v, ok := c.opt_["fields"]; ok {
|
||
|
params.Set("fields", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
urls := googleapi.ResolveRelative(c.s.BasePath, "volumes/recommended")
|
||
|
urls += "?" + params.Encode()
|
||
|
req, _ := http.NewRequest("GET", urls, body)
|
||
|
googleapi.SetOpaque(req.URL)
|
||
|
req.Header.Set("User-Agent", c.s.userAgent())
|
||
|
if v, ok := c.opt_["ifNoneMatch"]; ok {
|
||
|
req.Header.Set("If-None-Match", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if c.ctx_ != nil {
|
||
|
return ctxhttp.Do(c.ctx_, c.s.client, req)
|
||
|
}
|
||
|
return c.s.client.Do(req)
|
||
|
}
|
||
|
|
||
|
// Do executes the "books.volumes.recommended.list" call.
|
||
|
// Exactly one of *Volumes or error will be non-nil. Any non-2xx status
|
||
|
// code is an error. Response headers are in either
|
||
|
// *Volumes.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 *VolumesRecommendedListCall) Do() (*Volumes, error) {
|
||
|
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 := &Volumes{
|
||
|
ServerResponse: googleapi.ServerResponse{
|
||
|
Header: res.Header,
|
||
|
HTTPStatusCode: res.StatusCode,
|
||
|
},
|
||
|
}
|
||
|
if err := json.NewDecoder(res.Body).Decode(&ret); err != nil {
|
||
|
return nil, err
|
||
|
}
|
||
|
return ret, nil
|
||
|
// {
|
||
|
// "description": "Return a list of recommended books for the current user.",
|
||
|
// "httpMethod": "GET",
|
||
|
// "id": "books.volumes.recommended.list",
|
||
|
// "parameters": {
|
||
|
// "locale": {
|
||
|
// "description": "ISO-639-1 language and ISO-3166-1 country code. Ex: 'en_US'. Used for generating recommendations.",
|
||
|
// "location": "query",
|
||
|
// "type": "string"
|
||
|
// },
|
||
|
// "maxAllowedMaturityRating": {
|
||
|
// "description": "The maximum allowed maturity rating of returned recommendations. Books with a higher maturity rating are filtered out.",
|
||
|
// "enum": [
|
||
|
// "mature",
|
||
|
// "not-mature"
|
||
|
// ],
|
||
|
// "enumDescriptions": [
|
||
|
// "Show books which are rated mature or lower.",
|
||
|
// "Show books which are rated not mature."
|
||
|
// ],
|
||
|
// "location": "query",
|
||
|
// "type": "string"
|
||
|
// },
|
||
|
// "source": {
|
||
|
// "description": "String to identify the originator of this request.",
|
||
|
// "location": "query",
|
||
|
// "type": "string"
|
||
|
// }
|
||
|
// },
|
||
|
// "path": "volumes/recommended",
|
||
|
// "response": {
|
||
|
// "$ref": "Volumes"
|
||
|
// },
|
||
|
// "scopes": [
|
||
|
// "https://www.googleapis.com/auth/books"
|
||
|
// ]
|
||
|
// }
|
||
|
|
||
|
}
|
||
|
|
||
|
// method id "books.volumes.recommended.rate":
|
||
|
|
||
|
type VolumesRecommendedRateCall struct {
|
||
|
s *Service
|
||
|
rating string
|
||
|
volumeId string
|
||
|
opt_ map[string]interface{}
|
||
|
ctx_ context.Context
|
||
|
}
|
||
|
|
||
|
// Rate: Rate a recommended book for the current user.
|
||
|
func (r *VolumesRecommendedService) Rate(rating string, volumeId string) *VolumesRecommendedRateCall {
|
||
|
c := &VolumesRecommendedRateCall{s: r.s, opt_: make(map[string]interface{})}
|
||
|
c.rating = rating
|
||
|
c.volumeId = volumeId
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
// Locale sets the optional parameter "locale": ISO-639-1 language and
|
||
|
// ISO-3166-1 country code. Ex: 'en_US'. Used for generating
|
||
|
// recommendations.
|
||
|
func (c *VolumesRecommendedRateCall) Locale(locale string) *VolumesRecommendedRateCall {
|
||
|
c.opt_["locale"] = locale
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
// Source sets the optional parameter "source": String to identify the
|
||
|
// originator of this request.
|
||
|
func (c *VolumesRecommendedRateCall) Source(source string) *VolumesRecommendedRateCall {
|
||
|
c.opt_["source"] = source
|
||
|
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 *VolumesRecommendedRateCall) Fields(s ...googleapi.Field) *VolumesRecommendedRateCall {
|
||
|
c.opt_["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 *VolumesRecommendedRateCall) Context(ctx context.Context) *VolumesRecommendedRateCall {
|
||
|
c.ctx_ = ctx
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
func (c *VolumesRecommendedRateCall) doRequest(alt string) (*http.Response, error) {
|
||
|
var body io.Reader = nil
|
||
|
params := make(url.Values)
|
||
|
params.Set("alt", alt)
|
||
|
params.Set("rating", fmt.Sprintf("%v", c.rating))
|
||
|
params.Set("volumeId", fmt.Sprintf("%v", c.volumeId))
|
||
|
if v, ok := c.opt_["locale"]; ok {
|
||
|
params.Set("locale", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if v, ok := c.opt_["source"]; ok {
|
||
|
params.Set("source", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if v, ok := c.opt_["fields"]; ok {
|
||
|
params.Set("fields", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
urls := googleapi.ResolveRelative(c.s.BasePath, "volumes/recommended/rate")
|
||
|
urls += "?" + params.Encode()
|
||
|
req, _ := http.NewRequest("POST", urls, body)
|
||
|
googleapi.SetOpaque(req.URL)
|
||
|
req.Header.Set("User-Agent", c.s.userAgent())
|
||
|
if c.ctx_ != nil {
|
||
|
return ctxhttp.Do(c.ctx_, c.s.client, req)
|
||
|
}
|
||
|
return c.s.client.Do(req)
|
||
|
}
|
||
|
|
||
|
// Do executes the "books.volumes.recommended.rate" call.
|
||
|
// Exactly one of *BooksVolumesRecommendedRateResponse or error will be
|
||
|
// non-nil. Any non-2xx status code is an error. Response headers are in
|
||
|
// either *BooksVolumesRecommendedRateResponse.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 *VolumesRecommendedRateCall) Do() (*BooksVolumesRecommendedRateResponse, error) {
|
||
|
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 := &BooksVolumesRecommendedRateResponse{
|
||
|
ServerResponse: googleapi.ServerResponse{
|
||
|
Header: res.Header,
|
||
|
HTTPStatusCode: res.StatusCode,
|
||
|
},
|
||
|
}
|
||
|
if err := json.NewDecoder(res.Body).Decode(&ret); err != nil {
|
||
|
return nil, err
|
||
|
}
|
||
|
return ret, nil
|
||
|
// {
|
||
|
// "description": "Rate a recommended book for the current user.",
|
||
|
// "httpMethod": "POST",
|
||
|
// "id": "books.volumes.recommended.rate",
|
||
|
// "parameterOrder": [
|
||
|
// "rating",
|
||
|
// "volumeId"
|
||
|
// ],
|
||
|
// "parameters": {
|
||
|
// "locale": {
|
||
|
// "description": "ISO-639-1 language and ISO-3166-1 country code. Ex: 'en_US'. Used for generating recommendations.",
|
||
|
// "location": "query",
|
||
|
// "type": "string"
|
||
|
// },
|
||
|
// "rating": {
|
||
|
// "description": "Rating to be given to the volume.",
|
||
|
// "enum": [
|
||
|
// "HAVE_IT",
|
||
|
// "NOT_INTERESTED"
|
||
|
// ],
|
||
|
// "enumDescriptions": [
|
||
|
// "Rating indicating a dismissal due to ownership.",
|
||
|
// "Rating indicating a negative dismissal of a volume."
|
||
|
// ],
|
||
|
// "location": "query",
|
||
|
// "required": true,
|
||
|
// "type": "string"
|
||
|
// },
|
||
|
// "source": {
|
||
|
// "description": "String to identify the originator of this request.",
|
||
|
// "location": "query",
|
||
|
// "type": "string"
|
||
|
// },
|
||
|
// "volumeId": {
|
||
|
// "description": "ID of the source volume.",
|
||
|
// "location": "query",
|
||
|
// "required": true,
|
||
|
// "type": "string"
|
||
|
// }
|
||
|
// },
|
||
|
// "path": "volumes/recommended/rate",
|
||
|
// "response": {
|
||
|
// "$ref": "BooksVolumesRecommendedRateResponse"
|
||
|
// },
|
||
|
// "scopes": [
|
||
|
// "https://www.googleapis.com/auth/books"
|
||
|
// ]
|
||
|
// }
|
||
|
|
||
|
}
|
||
|
|
||
|
// method id "books.volumes.useruploaded.list":
|
||
|
|
||
|
type VolumesUseruploadedListCall struct {
|
||
|
s *Service
|
||
|
opt_ map[string]interface{}
|
||
|
ctx_ context.Context
|
||
|
}
|
||
|
|
||
|
// List: Return a list of books uploaded by the current user.
|
||
|
func (r *VolumesUseruploadedService) List() *VolumesUseruploadedListCall {
|
||
|
c := &VolumesUseruploadedListCall{s: r.s, opt_: make(map[string]interface{})}
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
// Locale sets the optional parameter "locale": ISO-639-1 language and
|
||
|
// ISO-3166-1 country code. Ex: 'en_US'. Used for generating
|
||
|
// recommendations.
|
||
|
func (c *VolumesUseruploadedListCall) Locale(locale string) *VolumesUseruploadedListCall {
|
||
|
c.opt_["locale"] = locale
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
// MaxResults sets the optional parameter "maxResults": Maximum number
|
||
|
// of results to return.
|
||
|
func (c *VolumesUseruploadedListCall) MaxResults(maxResults int64) *VolumesUseruploadedListCall {
|
||
|
c.opt_["maxResults"] = maxResults
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
// ProcessingState sets the optional parameter "processingState": The
|
||
|
// processing state of the user uploaded volumes to be returned.
|
||
|
//
|
||
|
// Possible values:
|
||
|
// "COMPLETED_FAILED" - The volume processing hase failed.
|
||
|
// "COMPLETED_SUCCESS" - The volume processing was completed.
|
||
|
// "RUNNING" - The volume processing is not completed.
|
||
|
func (c *VolumesUseruploadedListCall) ProcessingState(processingState string) *VolumesUseruploadedListCall {
|
||
|
c.opt_["processingState"] = processingState
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
// Source sets the optional parameter "source": String to identify the
|
||
|
// originator of this request.
|
||
|
func (c *VolumesUseruploadedListCall) Source(source string) *VolumesUseruploadedListCall {
|
||
|
c.opt_["source"] = source
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
// StartIndex sets the optional parameter "startIndex": Index of the
|
||
|
// first result to return (starts at 0)
|
||
|
func (c *VolumesUseruploadedListCall) StartIndex(startIndex int64) *VolumesUseruploadedListCall {
|
||
|
c.opt_["startIndex"] = startIndex
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
// VolumeId sets the optional parameter "volumeId": The ids of the
|
||
|
// volumes to be returned. If not specified all that match the
|
||
|
// processingState are returned.
|
||
|
func (c *VolumesUseruploadedListCall) VolumeId(volumeId string) *VolumesUseruploadedListCall {
|
||
|
c.opt_["volumeId"] = volumeId
|
||
|
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 *VolumesUseruploadedListCall) Fields(s ...googleapi.Field) *VolumesUseruploadedListCall {
|
||
|
c.opt_["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 *VolumesUseruploadedListCall) IfNoneMatch(entityTag string) *VolumesUseruploadedListCall {
|
||
|
c.opt_["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 *VolumesUseruploadedListCall) Context(ctx context.Context) *VolumesUseruploadedListCall {
|
||
|
c.ctx_ = ctx
|
||
|
return c
|
||
|
}
|
||
|
|
||
|
func (c *VolumesUseruploadedListCall) doRequest(alt string) (*http.Response, error) {
|
||
|
var body io.Reader = nil
|
||
|
params := make(url.Values)
|
||
|
params.Set("alt", alt)
|
||
|
if v, ok := c.opt_["locale"]; ok {
|
||
|
params.Set("locale", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if v, ok := c.opt_["maxResults"]; ok {
|
||
|
params.Set("maxResults", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if v, ok := c.opt_["processingState"]; ok {
|
||
|
params.Set("processingState", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if v, ok := c.opt_["source"]; ok {
|
||
|
params.Set("source", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if v, ok := c.opt_["startIndex"]; ok {
|
||
|
params.Set("startIndex", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if v, ok := c.opt_["volumeId"]; ok {
|
||
|
params.Set("volumeId", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if v, ok := c.opt_["fields"]; ok {
|
||
|
params.Set("fields", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
urls := googleapi.ResolveRelative(c.s.BasePath, "volumes/useruploaded")
|
||
|
urls += "?" + params.Encode()
|
||
|
req, _ := http.NewRequest("GET", urls, body)
|
||
|
googleapi.SetOpaque(req.URL)
|
||
|
req.Header.Set("User-Agent", c.s.userAgent())
|
||
|
if v, ok := c.opt_["ifNoneMatch"]; ok {
|
||
|
req.Header.Set("If-None-Match", fmt.Sprintf("%v", v))
|
||
|
}
|
||
|
if c.ctx_ != nil {
|
||
|
return ctxhttp.Do(c.ctx_, c.s.client, req)
|
||
|
}
|
||
|
return c.s.client.Do(req)
|
||
|
}
|
||
|
|
||
|
// Do executes the "books.volumes.useruploaded.list" call.
|
||
|
// Exactly one of *Volumes or error will be non-nil. Any non-2xx status
|
||
|
// code is an error. Response headers are in either
|
||
|
// *Volumes.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 *VolumesUseruploadedListCall) Do() (*Volumes, error) {
|
||
|
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 := &Volumes{
|
||
|
ServerResponse: googleapi.ServerResponse{
|
||
|
Header: res.Header,
|
||
|
HTTPStatusCode: res.StatusCode,
|
||
|
},
|
||
|
}
|
||
|
if err := json.NewDecoder(res.Body).Decode(&ret); err != nil {
|
||
|
return nil, err
|
||
|
}
|
||
|
return ret, nil
|
||
|
// {
|
||
|
// "description": "Return a list of books uploaded by the current user.",
|
||
|
// "httpMethod": "GET",
|
||
|
// "id": "books.volumes.useruploaded.list",
|
||
|
// "parameters": {
|
||
|
// "locale": {
|
||
|
// "description": "ISO-639-1 language and ISO-3166-1 country code. Ex: 'en_US'. Used for generating recommendations.",
|
||
|
// "location": "query",
|
||
|
// "type": "string"
|
||
|
// },
|
||
|
// "maxResults": {
|
||
|
// "description": "Maximum number of results to return.",
|
||
|
// "format": "uint32",
|
||
|
// "location": "query",
|
||
|
// "maximum": "40",
|
||
|
// "minimum": "0",
|
||
|
// "type": "integer"
|
||
|
// },
|
||
|
// "processingState": {
|
||
|
// "description": "The processing state of the user uploaded volumes to be returned.",
|
||
|
// "enum": [
|
||
|
// "COMPLETED_FAILED",
|
||
|
// "COMPLETED_SUCCESS",
|
||
|
// "RUNNING"
|
||
|
// ],
|
||
|
// "enumDescriptions": [
|
||
|
// "The volume processing hase failed.",
|
||
|
// "The volume processing was completed.",
|
||
|
// "The volume processing is not completed."
|
||
|
// ],
|
||
|
// "location": "query",
|
||
|
// "repeated": true,
|
||
|
// "type": "string"
|
||
|
// },
|
||
|
// "source": {
|
||
|
// "description": "String to identify the originator of this request.",
|
||
|
// "location": "query",
|
||
|
// "type": "string"
|
||
|
// },
|
||
|
// "startIndex": {
|
||
|
// "description": "Index of the first result to return (starts at 0)",
|
||
|
// "format": "uint32",
|
||
|
// "location": "query",
|
||
|
// "minimum": "0",
|
||
|
// "type": "integer"
|
||
|
// },
|
||
|
// "volumeId": {
|
||
|
// "description": "The ids of the volumes to be returned. If not specified all that match the processingState are returned.",
|
||
|
// "location": "query",
|
||
|
// "repeated": true,
|
||
|
// "type": "string"
|
||
|
// }
|
||
|
// },
|
||
|
// "path": "volumes/useruploaded",
|
||
|
// "response": {
|
||
|
// "$ref": "Volumes"
|
||
|
// },
|
||
|
// "scopes": [
|
||
|
// "https://www.googleapis.com/auth/books"
|
||
|
// ]
|
||
|
// }
|
||
|
|
||
|
}
|