# Copyright 2015 Google Inc. # # Licensed under the Apache License, Version 2.0 (the "License"); # you may not use this file except in compliance with the License. # You may obtain a copy of the License at # # http://www.apache.org/licenses/LICENSE-2.0 # # Unless required by applicable law or agreed to in writing, software # distributed under the License is distributed on an "AS IS" BASIS, # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. # See the License for the specific language governing permissions and # limitations under the License. require 'date' require 'google/apis/core/base_service' require 'google/apis/core/json_representation' require 'google/apis/core/hashable' require 'google/apis/errors' module Google module Apis module BooksV1 # class Annotation include Google::Apis::Core::Hashable # 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. # Corresponds to the JSON property `afterSelectedText` # @return [String] attr_accessor :after_selected_text # 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. # Corresponds to the JSON property `beforeSelectedText` # @return [String] attr_accessor :before_selected_text # Selection ranges sent from the client. # Corresponds to the JSON property `clientVersionRanges` # @return [Google::Apis::BooksV1::Annotation::ClientVersionRanges] attr_accessor :client_version_ranges # Timestamp for the created time of this annotation. # Corresponds to the JSON property `created` # @return [DateTime] attr_accessor :created # Selection ranges for the most recent content version. # Corresponds to the JSON property `currentVersionRanges` # @return [Google::Apis::BooksV1::Annotation::CurrentVersionRanges] attr_accessor :current_version_ranges # User-created data for this annotation. # Corresponds to the JSON property `data` # @return [String] attr_accessor :data # Indicates that this annotation is deleted. # Corresponds to the JSON property `deleted` # @return [Boolean] attr_accessor :deleted alias_method :deleted?, :deleted # The highlight style for this annotation. # Corresponds to the JSON property `highlightStyle` # @return [String] attr_accessor :highlight_style # Id of this annotation, in the form of a GUID. # Corresponds to the JSON property `id` # @return [String] attr_accessor :id # Resource type. # Corresponds to the JSON property `kind` # @return [String] attr_accessor :kind # The layer this annotation is for. # Corresponds to the JSON property `layerId` # @return [String] attr_accessor :layer_id # # Corresponds to the JSON property `layerSummary` # @return [Google::Apis::BooksV1::Annotation::LayerSummary] attr_accessor :layer_summary # Pages that this annotation spans. # Corresponds to the JSON property `pageIds` # @return [Array] attr_accessor :page_ids # Excerpt from the volume. # Corresponds to the JSON property `selectedText` # @return [String] attr_accessor :selected_text # URL to this resource. # Corresponds to the JSON property `selfLink` # @return [String] attr_accessor :self_link # Timestamp for the last time this annotation was modified. # Corresponds to the JSON property `updated` # @return [DateTime] attr_accessor :updated # The volume that this annotation belongs to. # Corresponds to the JSON property `volumeId` # @return [String] attr_accessor :volume_id def initialize(**args) update!(**args) end # Update properties of this object def update!(**args) @after_selected_text = args[:after_selected_text] unless args[:after_selected_text].nil? @before_selected_text = args[:before_selected_text] unless args[:before_selected_text].nil? @client_version_ranges = args[:client_version_ranges] unless args[:client_version_ranges].nil? @created = args[:created] unless args[:created].nil? @current_version_ranges = args[:current_version_ranges] unless args[:current_version_ranges].nil? @data = args[:data] unless args[:data].nil? @deleted = args[:deleted] unless args[:deleted].nil? @highlight_style = args[:highlight_style] unless args[:highlight_style].nil? @id = args[:id] unless args[:id].nil? @kind = args[:kind] unless args[:kind].nil? @layer_id = args[:layer_id] unless args[:layer_id].nil? @layer_summary = args[:layer_summary] unless args[:layer_summary].nil? @page_ids = args[:page_ids] unless args[:page_ids].nil? @selected_text = args[:selected_text] unless args[:selected_text].nil? @self_link = args[:self_link] unless args[:self_link].nil? @updated = args[:updated] unless args[:updated].nil? @volume_id = args[:volume_id] unless args[:volume_id].nil? end # Selection ranges sent from the client. class ClientVersionRanges include Google::Apis::Core::Hashable # Range in CFI format for this annotation sent by client. # Corresponds to the JSON property `cfiRange` # @return [Google::Apis::BooksV1::AnnotatinsRange] attr_accessor :cfi_range # Content version the client sent in. # Corresponds to the JSON property `contentVersion` # @return [String] attr_accessor :content_version # Range in GB image format for this annotation sent by client. # Corresponds to the JSON property `gbImageRange` # @return [Google::Apis::BooksV1::AnnotatinsRange] attr_accessor :gb_image_range # Range in GB text format for this annotation sent by client. # Corresponds to the JSON property `gbTextRange` # @return [Google::Apis::BooksV1::AnnotatinsRange] attr_accessor :gb_text_range # Range in image CFI format for this annotation sent by client. # Corresponds to the JSON property `imageCfiRange` # @return [Google::Apis::BooksV1::AnnotatinsRange] attr_accessor :image_cfi_range def initialize(**args) update!(**args) end # Update properties of this object def update!(**args) @cfi_range = args[:cfi_range] unless args[:cfi_range].nil? @content_version = args[:content_version] unless args[:content_version].nil? @gb_image_range = args[:gb_image_range] unless args[:gb_image_range].nil? @gb_text_range = args[:gb_text_range] unless args[:gb_text_range].nil? @image_cfi_range = args[:image_cfi_range] unless args[:image_cfi_range].nil? end end # Selection ranges for the most recent content version. class CurrentVersionRanges include Google::Apis::Core::Hashable # Range in CFI format for this annotation for version above. # Corresponds to the JSON property `cfiRange` # @return [Google::Apis::BooksV1::AnnotatinsRange] attr_accessor :cfi_range # Content version applicable to ranges below. # Corresponds to the JSON property `contentVersion` # @return [String] attr_accessor :content_version # Range in GB image format for this annotation for version above. # Corresponds to the JSON property `gbImageRange` # @return [Google::Apis::BooksV1::AnnotatinsRange] attr_accessor :gb_image_range # Range in GB text format for this annotation for version above. # Corresponds to the JSON property `gbTextRange` # @return [Google::Apis::BooksV1::AnnotatinsRange] attr_accessor :gb_text_range # Range in image CFI format for this annotation for version above. # Corresponds to the JSON property `imageCfiRange` # @return [Google::Apis::BooksV1::AnnotatinsRange] attr_accessor :image_cfi_range def initialize(**args) update!(**args) end # Update properties of this object def update!(**args) @cfi_range = args[:cfi_range] unless args[:cfi_range].nil? @content_version = args[:content_version] unless args[:content_version].nil? @gb_image_range = args[:gb_image_range] unless args[:gb_image_range].nil? @gb_text_range = args[:gb_text_range] unless args[:gb_text_range].nil? @image_cfi_range = args[:image_cfi_range] unless args[:image_cfi_range].nil? end end # class LayerSummary include Google::Apis::Core::Hashable # Maximum allowed characters on this layer, especially for the "copy" layer. # Corresponds to the JSON property `allowedCharacterCount` # @return [Fixnum] attr_accessor :allowed_character_count # Type of limitation on this layer. "limited" or "unlimited" for the "copy" # layer. # Corresponds to the JSON property `limitType` # @return [String] attr_accessor :limit_type # Remaining allowed characters on this layer, especially for the "copy" layer. # Corresponds to the JSON property `remainingCharacterCount` # @return [Fixnum] attr_accessor :remaining_character_count def initialize(**args) update!(**args) end # Update properties of this object def update!(**args) @allowed_character_count = args[:allowed_character_count] unless args[:allowed_character_count].nil? @limit_type = args[:limit_type] unless args[:limit_type].nil? @remaining_character_count = args[:remaining_character_count] unless args[:remaining_character_count].nil? end end end # class AnnotationData include Google::Apis::Core::Hashable # The type of annotation this data is for. # Corresponds to the JSON property `annotationType` # @return [String] attr_accessor :annotation_type # # Corresponds to the JSON property `data` # @return [Object] attr_accessor :data # Base64 encoded data for this annotation data. # Corresponds to the JSON property `encoded_data` # @return [String] attr_accessor :encoded_data # Unique id for this annotation data. # Corresponds to the JSON property `id` # @return [String] attr_accessor :id # Resource Type # Corresponds to the JSON property `kind` # @return [String] attr_accessor :kind # The Layer id for this data. * # Corresponds to the JSON property `layerId` # @return [String] attr_accessor :layer_id # URL for this resource. * # Corresponds to the JSON property `selfLink` # @return [String] attr_accessor :self_link # Timestamp for the last time this data was updated. (RFC 3339 UTC date-time # format). # Corresponds to the JSON property `updated` # @return [DateTime] attr_accessor :updated # The volume id for this data. * # Corresponds to the JSON property `volumeId` # @return [String] attr_accessor :volume_id def initialize(**args) update!(**args) end # Update properties of this object def update!(**args) @annotation_type = args[:annotation_type] unless args[:annotation_type].nil? @data = args[:data] unless args[:data].nil? @encoded_data = args[:encoded_data] unless args[:encoded_data].nil? @id = args[:id] unless args[:id].nil? @kind = args[:kind] unless args[:kind].nil? @layer_id = args[:layer_id] unless args[:layer_id].nil? @self_link = args[:self_link] unless args[:self_link].nil? @updated = args[:updated] unless args[:updated].nil? @volume_id = args[:volume_id] unless args[:volume_id].nil? end end # class Annotations include Google::Apis::Core::Hashable # A list of annotations. # Corresponds to the JSON property `items` # @return [Array] attr_accessor :items # Resource type. # Corresponds to the JSON property `kind` # @return [String] attr_accessor :kind # Token to pass in for pagination for the next page. This will not be present if # this request does not have more results. # Corresponds to the JSON property `nextPageToken` # @return [String] attr_accessor :next_page_token # Total number of annotations found. This may be greater than the number of # notes returned in this response if results have been paginated. # Corresponds to the JSON property `totalItems` # @return [Fixnum] attr_accessor :total_items def initialize(**args) update!(**args) end # Update properties of this object def update!(**args) @items = args[:items] unless args[:items].nil? @kind = args[:kind] unless args[:kind].nil? @next_page_token = args[:next_page_token] unless args[:next_page_token].nil? @total_items = args[:total_items] unless args[:total_items].nil? end end # class AnnotationsSummary include Google::Apis::Core::Hashable # # Corresponds to the JSON property `kind` # @return [String] attr_accessor :kind # # Corresponds to the JSON property `layers` # @return [Array] attr_accessor :layers def initialize(**args) update!(**args) end # Update properties of this object def update!(**args) @kind = args[:kind] unless args[:kind].nil? @layers = args[:layers] unless args[:layers].nil? end # class Layer include Google::Apis::Core::Hashable # # Corresponds to the JSON property `allowedCharacterCount` # @return [Fixnum] attr_accessor :allowed_character_count # # Corresponds to the JSON property `layerId` # @return [String] attr_accessor :layer_id # # Corresponds to the JSON property `limitType` # @return [String] attr_accessor :limit_type # # Corresponds to the JSON property `remainingCharacterCount` # @return [Fixnum] attr_accessor :remaining_character_count # # Corresponds to the JSON property `updated` # @return [DateTime] attr_accessor :updated def initialize(**args) update!(**args) end # Update properties of this object def update!(**args) @allowed_character_count = args[:allowed_character_count] unless args[:allowed_character_count].nil? @layer_id = args[:layer_id] unless args[:layer_id].nil? @limit_type = args[:limit_type] unless args[:limit_type].nil? @remaining_character_count = args[:remaining_character_count] unless args[:remaining_character_count].nil? @updated = args[:updated] unless args[:updated].nil? end end end # class AnnotationsData include Google::Apis::Core::Hashable # A list of Annotation Data. # Corresponds to the JSON property `items` # @return [Array] attr_accessor :items # Resource type # Corresponds to the JSON property `kind` # @return [String] attr_accessor :kind # Token to pass in for pagination for the next page. This will not be present if # this request does not have more results. # Corresponds to the JSON property `nextPageToken` # @return [String] attr_accessor :next_page_token # The total number of volume annotations found. # Corresponds to the JSON property `totalItems` # @return [Fixnum] attr_accessor :total_items def initialize(**args) update!(**args) end # Update properties of this object def update!(**args) @items = args[:items] unless args[:items].nil? @kind = args[:kind] unless args[:kind].nil? @next_page_token = args[:next_page_token] unless args[:next_page_token].nil? @total_items = args[:total_items] unless args[:total_items].nil? end end # class AnnotatinsRange include Google::Apis::Core::Hashable # The offset from the ending position. # Corresponds to the JSON property `endOffset` # @return [String] attr_accessor :end_offset # The ending position for the range. # Corresponds to the JSON property `endPosition` # @return [String] attr_accessor :end_position # The offset from the starting position. # Corresponds to the JSON property `startOffset` # @return [String] attr_accessor :start_offset # The starting position for the range. # Corresponds to the JSON property `startPosition` # @return [String] attr_accessor :start_position def initialize(**args) update!(**args) end # Update properties of this object def update!(**args) @end_offset = args[:end_offset] unless args[:end_offset].nil? @end_position = args[:end_position] unless args[:end_position].nil? @start_offset = args[:start_offset] unless args[:start_offset].nil? @start_position = args[:start_position] unless args[:start_position].nil? end end # class LoadingResource include Google::Apis::Core::Hashable # # Corresponds to the JSON property `author` # @return [String] attr_accessor :author # # Corresponds to the JSON property `processingState` # @return [String] attr_accessor :processing_state # # Corresponds to the JSON property `title` # @return [String] attr_accessor :title # # Corresponds to the JSON property `volumeId` # @return [String] attr_accessor :volume_id def initialize(**args) update!(**args) end # Update properties of this object def update!(**args) @author = args[:author] unless args[:author].nil? @processing_state = args[:processing_state] unless args[:processing_state].nil? @title = args[:title] unless args[:title].nil? @volume_id = args[:volume_id] unless args[:volume_id].nil? end end # class RateRecommendedVolumeResponse include Google::Apis::Core::Hashable # # Corresponds to the JSON property `consistency_token` # @return [String] attr_accessor :consistency_token def initialize(**args) update!(**args) end # Update properties of this object def update!(**args) @consistency_token = args[:consistency_token] unless args[:consistency_token].nil? end end # class Bookshelf include Google::Apis::Core::Hashable # Whether this bookshelf is PUBLIC or PRIVATE. # Corresponds to the JSON property `access` # @return [String] attr_accessor :access # Created time for this bookshelf (formatted UTC timestamp with millisecond # resolution). # Corresponds to the JSON property `created` # @return [DateTime] attr_accessor :created # Description of this bookshelf. # Corresponds to the JSON property `description` # @return [String] attr_accessor :description # Id of this bookshelf, only unique by user. # Corresponds to the JSON property `id` # @return [Fixnum] attr_accessor :id # Resource type for bookshelf metadata. # Corresponds to the JSON property `kind` # @return [String] attr_accessor :kind # URL to this resource. # Corresponds to the JSON property `selfLink` # @return [String] attr_accessor :self_link # Title of this bookshelf. # Corresponds to the JSON property `title` # @return [String] attr_accessor :title # Last modified time of this bookshelf (formatted UTC timestamp with millisecond # resolution). # Corresponds to the JSON property `updated` # @return [DateTime] attr_accessor :updated # Number of volumes in this bookshelf. # Corresponds to the JSON property `volumeCount` # @return [Fixnum] attr_accessor :volume_count # Last time a volume was added or removed from this bookshelf (formatted UTC # timestamp with millisecond resolution). # Corresponds to the JSON property `volumesLastUpdated` # @return [DateTime] attr_accessor :volumes_last_updated def initialize(**args) update!(**args) end # Update properties of this object def update!(**args) @access = args[:access] unless args[:access].nil? @created = args[:created] unless args[:created].nil? @description = args[:description] unless args[:description].nil? @id = args[:id] unless args[:id].nil? @kind = args[:kind] unless args[:kind].nil? @self_link = args[:self_link] unless args[:self_link].nil? @title = args[:title] unless args[:title].nil? @updated = args[:updated] unless args[:updated].nil? @volume_count = args[:volume_count] unless args[:volume_count].nil? @volumes_last_updated = args[:volumes_last_updated] unless args[:volumes_last_updated].nil? end end # class Bookshelves include Google::Apis::Core::Hashable # A list of bookshelves. # Corresponds to the JSON property `items` # @return [Array] attr_accessor :items # Resource type. # Corresponds to the JSON property `kind` # @return [String] attr_accessor :kind def initialize(**args) update!(**args) end # Update properties of this object def update!(**args) @items = args[:items] unless args[:items].nil? @kind = args[:kind] unless args[:kind].nil? end end # class Category include Google::Apis::Core::Hashable # A list of onboarding categories. # Corresponds to the JSON property `items` # @return [Array] attr_accessor :items # Resource type. # Corresponds to the JSON property `kind` # @return [String] attr_accessor :kind def initialize(**args) update!(**args) end # Update properties of this object def update!(**args) @items = args[:items] unless args[:items].nil? @kind = args[:kind] unless args[:kind].nil? end # class Item include Google::Apis::Core::Hashable # # Corresponds to the JSON property `badgeUrl` # @return [String] attr_accessor :badge_url # # Corresponds to the JSON property `categoryId` # @return [String] attr_accessor :category_id # # Corresponds to the JSON property `name` # @return [String] attr_accessor :name def initialize(**args) update!(**args) end # Update properties of this object def update!(**args) @badge_url = args[:badge_url] unless args[:badge_url].nil? @category_id = args[:category_id] unless args[:category_id].nil? @name = args[:name] unless args[:name].nil? end end end # class ConcurrentAccessRestriction include Google::Apis::Core::Hashable # Whether access is granted for this (user, device, volume). # Corresponds to the JSON property `deviceAllowed` # @return [Boolean] attr_accessor :device_allowed alias_method :device_allowed?, :device_allowed # Resource type. # Corresponds to the JSON property `kind` # @return [String] attr_accessor :kind # The maximum number of concurrent access licenses for this volume. # Corresponds to the JSON property `maxConcurrentDevices` # @return [Fixnum] attr_accessor :max_concurrent_devices # Error/warning message. # Corresponds to the JSON property `message` # @return [String] attr_accessor :message # Client nonce for verification. Download access and client-validation only. # Corresponds to the JSON property `nonce` # @return [String] attr_accessor :nonce # Error/warning reason code. # Corresponds to the JSON property `reasonCode` # @return [String] attr_accessor :reason_code # Whether this volume has any concurrent access restrictions. # Corresponds to the JSON property `restricted` # @return [Boolean] attr_accessor :restricted alias_method :restricted?, :restricted # Response signature. # Corresponds to the JSON property `signature` # @return [String] attr_accessor :signature # Client app identifier for verification. Download access and client-validation # only. # Corresponds to the JSON property `source` # @return [String] attr_accessor :source # Time in seconds for license auto-expiration. # Corresponds to the JSON property `timeWindowSeconds` # @return [Fixnum] attr_accessor :time_window_seconds # Identifies the volume for which this entry applies. # Corresponds to the JSON property `volumeId` # @return [String] attr_accessor :volume_id def initialize(**args) update!(**args) end # Update properties of this object def update!(**args) @device_allowed = args[:device_allowed] unless args[:device_allowed].nil? @kind = args[:kind] unless args[:kind].nil? @max_concurrent_devices = args[:max_concurrent_devices] unless args[:max_concurrent_devices].nil? @message = args[:message] unless args[:message].nil? @nonce = args[:nonce] unless args[:nonce].nil? @reason_code = args[:reason_code] unless args[:reason_code].nil? @restricted = args[:restricted] unless args[:restricted].nil? @signature = args[:signature] unless args[:signature].nil? @source = args[:source] unless args[:source].nil? @time_window_seconds = args[:time_window_seconds] unless args[:time_window_seconds].nil? @volume_id = args[:volume_id] unless args[:volume_id].nil? end end # class DictLayerData include Google::Apis::Core::Hashable # # Corresponds to the JSON property `common` # @return [Google::Apis::BooksV1::DictLayerData::Common] attr_accessor :common # # Corresponds to the JSON property `dict` # @return [Google::Apis::BooksV1::DictLayerData::Dict] attr_accessor :dict # # Corresponds to the JSON property `kind` # @return [String] attr_accessor :kind def initialize(**args) update!(**args) end # Update properties of this object def update!(**args) @common = args[:common] unless args[:common].nil? @dict = args[:dict] unless args[:dict].nil? @kind = args[:kind] unless args[:kind].nil? end # class Common include Google::Apis::Core::Hashable # The display title and localized canonical name to use when searching for this # entity on Google search. # Corresponds to the JSON property `title` # @return [String] attr_accessor :title def initialize(**args) update!(**args) end # Update properties of this object def update!(**args) @title = args[:title] unless args[:title].nil? end end # class Dict include Google::Apis::Core::Hashable # The source, url and attribution for this dictionary data. # Corresponds to the JSON property `source` # @return [Google::Apis::BooksV1::DictLayerData::Dict::Source] attr_accessor :source # # Corresponds to the JSON property `words` # @return [Array] attr_accessor :words def initialize(**args) update!(**args) end # Update properties of this object def update!(**args) @source = args[:source] unless args[:source].nil? @words = args[:words] unless args[:words].nil? end # The source, url and attribution for this dictionary data. class Source include Google::Apis::Core::Hashable # # Corresponds to the JSON property `attribution` # @return [String] attr_accessor :attribution # # Corresponds to the JSON property `url` # @return [String] attr_accessor :url def initialize(**args) update!(**args) end # Update properties of this object def update!(**args) @attribution = args[:attribution] unless args[:attribution].nil? @url = args[:url] unless args[:url].nil? end end # class Word include Google::Apis::Core::Hashable # # Corresponds to the JSON property `derivatives` # @return [Array] attr_accessor :derivatives # # Corresponds to the JSON property `examples` # @return [Array] attr_accessor :examples # # Corresponds to the JSON property `senses` # @return [Array] attr_accessor :senses # The words with different meanings but not related words, e.g. "go" (game) and " # go" (verb). # Corresponds to the JSON property `source` # @return [Google::Apis::BooksV1::DictLayerData::Dict::Word::Source] attr_accessor :source def initialize(**args) update!(**args) end # Update properties of this object def update!(**args) @derivatives = args[:derivatives] unless args[:derivatives].nil? @examples = args[:examples] unless args[:examples].nil? @senses = args[:senses] unless args[:senses].nil? @source = args[:source] unless args[:source].nil? end # class Derivative include Google::Apis::Core::Hashable # # Corresponds to the JSON property `source` # @return [Google::Apis::BooksV1::DictLayerData::Dict::Word::Derivative::Source] attr_accessor :source # # Corresponds to the JSON property `text` # @return [String] attr_accessor :text def initialize(**args) update!(**args) end # Update properties of this object def update!(**args) @source = args[:source] unless args[:source].nil? @text = args[:text] unless args[:text].nil? end # class Source include Google::Apis::Core::Hashable # # Corresponds to the JSON property `attribution` # @return [String] attr_accessor :attribution # # Corresponds to the JSON property `url` # @return [String] attr_accessor :url def initialize(**args) update!(**args) end # Update properties of this object def update!(**args) @attribution = args[:attribution] unless args[:attribution].nil? @url = args[:url] unless args[:url].nil? end end end # class Example include Google::Apis::Core::Hashable # # Corresponds to the JSON property `source` # @return [Google::Apis::BooksV1::DictLayerData::Dict::Word::Example::Source] attr_accessor :source # # Corresponds to the JSON property `text` # @return [String] attr_accessor :text def initialize(**args) update!(**args) end # Update properties of this object def update!(**args) @source = args[:source] unless args[:source].nil? @text = args[:text] unless args[:text].nil? end # class Source include Google::Apis::Core::Hashable # # Corresponds to the JSON property `attribution` # @return [String] attr_accessor :attribution # # Corresponds to the JSON property `url` # @return [String] attr_accessor :url def initialize(**args) update!(**args) end # Update properties of this object def update!(**args) @attribution = args[:attribution] unless args[:attribution].nil? @url = args[:url] unless args[:url].nil? end end end # class Sense include Google::Apis::Core::Hashable # # Corresponds to the JSON property `conjugations` # @return [Array] attr_accessor :conjugations # # Corresponds to the JSON property `definitions` # @return [Array] attr_accessor :definitions # # Corresponds to the JSON property `partOfSpeech` # @return [String] attr_accessor :part_of_speech # # Corresponds to the JSON property `pronunciation` # @return [String] attr_accessor :pronunciation # # Corresponds to the JSON property `pronunciationUrl` # @return [String] attr_accessor :pronunciation_url # # Corresponds to the JSON property `source` # @return [Google::Apis::BooksV1::DictLayerData::Dict::Word::Sense::Source] attr_accessor :source # # Corresponds to the JSON property `syllabification` # @return [String] attr_accessor :syllabification # # Corresponds to the JSON property `synonyms` # @return [Array] attr_accessor :synonyms def initialize(**args) update!(**args) end # Update properties of this object def update!(**args) @conjugations = args[:conjugations] unless args[:conjugations].nil? @definitions = args[:definitions] unless args[:definitions].nil? @part_of_speech = args[:part_of_speech] unless args[:part_of_speech].nil? @pronunciation = args[:pronunciation] unless args[:pronunciation].nil? @pronunciation_url = args[:pronunciation_url] unless args[:pronunciation_url].nil? @source = args[:source] unless args[:source].nil? @syllabification = args[:syllabification] unless args[:syllabification].nil? @synonyms = args[:synonyms] unless args[:synonyms].nil? end # class Conjugation include Google::Apis::Core::Hashable # # Corresponds to the JSON property `type` # @return [String] attr_accessor :type # # Corresponds to the JSON property `value` # @return [String] attr_accessor :value def initialize(**args) update!(**args) end # Update properties of this object def update!(**args) @type = args[:type] unless args[:type].nil? @value = args[:value] unless args[:value].nil? end end # class Definition include Google::Apis::Core::Hashable # # Corresponds to the JSON property `definition` # @return [String] attr_accessor :definition # # Corresponds to the JSON property `examples` # @return [Array] attr_accessor :examples def initialize(**args) update!(**args) end # Update properties of this object def update!(**args) @definition = args[:definition] unless args[:definition].nil? @examples = args[:examples] unless args[:examples].nil? end # class Example include Google::Apis::Core::Hashable # # Corresponds to the JSON property `source` # @return [Google::Apis::BooksV1::DictLayerData::Dict::Word::Sense::Definition::Example::Source] attr_accessor :source # # Corresponds to the JSON property `text` # @return [String] attr_accessor :text def initialize(**args) update!(**args) end # Update properties of this object def update!(**args) @source = args[:source] unless args[:source].nil? @text = args[:text] unless args[:text].nil? end # class Source include Google::Apis::Core::Hashable # # Corresponds to the JSON property `attribution` # @return [String] attr_accessor :attribution # # Corresponds to the JSON property `url` # @return [String] attr_accessor :url def initialize(**args) update!(**args) end # Update properties of this object def update!(**args) @attribution = args[:attribution] unless args[:attribution].nil? @url = args[:url] unless args[:url].nil? end end end end # class Source include Google::Apis::Core::Hashable # # Corresponds to the JSON property `attribution` # @return [String] attr_accessor :attribution # # Corresponds to the JSON property `url` # @return [String] attr_accessor :url def initialize(**args) update!(**args) end # Update properties of this object def update!(**args) @attribution = args[:attribution] unless args[:attribution].nil? @url = args[:url] unless args[:url].nil? end end # class Synonym include Google::Apis::Core::Hashable # # Corresponds to the JSON property `source` # @return [Google::Apis::BooksV1::DictLayerData::Dict::Word::Sense::Synonym::Source] attr_accessor :source # # Corresponds to the JSON property `text` # @return [String] attr_accessor :text def initialize(**args) update!(**args) end # Update properties of this object def update!(**args) @source = args[:source] unless args[:source].nil? @text = args[:text] unless args[:text].nil? end # class Source include Google::Apis::Core::Hashable # # Corresponds to the JSON property `attribution` # @return [String] attr_accessor :attribution # # Corresponds to the JSON property `url` # @return [String] attr_accessor :url def initialize(**args) update!(**args) end # Update properties of this object def update!(**args) @attribution = args[:attribution] unless args[:attribution].nil? @url = args[:url] unless args[:url].nil? end end end end # The words with different meanings but not related words, e.g. "go" (game) and " # go" (verb). class Source include Google::Apis::Core::Hashable # # Corresponds to the JSON property `attribution` # @return [String] attr_accessor :attribution # # Corresponds to the JSON property `url` # @return [String] attr_accessor :url def initialize(**args) update!(**args) end # Update properties of this object def update!(**args) @attribution = args[:attribution] unless args[:attribution].nil? @url = args[:url] unless args[:url].nil? end end end end end # class DownloadAccessRestriction include Google::Apis::Core::Hashable # If restricted, whether access is granted for this (user, device, volume). # Corresponds to the JSON property `deviceAllowed` # @return [Boolean] attr_accessor :device_allowed alias_method :device_allowed?, :device_allowed # If restricted, the number of content download licenses already acquired ( # including the requesting client, if licensed). # Corresponds to the JSON property `downloadsAcquired` # @return [Fixnum] attr_accessor :downloads_acquired # If deviceAllowed, whether access was just acquired with this request. # Corresponds to the JSON property `justAcquired` # @return [Boolean] attr_accessor :just_acquired alias_method :just_acquired?, :just_acquired # Resource type. # Corresponds to the JSON property `kind` # @return [String] attr_accessor :kind # If restricted, the maximum number of content download licenses for this volume. # Corresponds to the JSON property `maxDownloadDevices` # @return [Fixnum] attr_accessor :max_download_devices # Error/warning message. # Corresponds to the JSON property `message` # @return [String] attr_accessor :message # Client nonce for verification. Download access and client-validation only. # Corresponds to the JSON property `nonce` # @return [String] attr_accessor :nonce # 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 # Corresponds to the JSON property `reasonCode` # @return [String] attr_accessor :reason_code # Whether this volume has any download access restrictions. # Corresponds to the JSON property `restricted` # @return [Boolean] attr_accessor :restricted alias_method :restricted?, :restricted # Response signature. # Corresponds to the JSON property `signature` # @return [String] attr_accessor :signature # Client app identifier for verification. Download access and client-validation # only. # Corresponds to the JSON property `source` # @return [String] attr_accessor :source # Identifies the volume for which this entry applies. # Corresponds to the JSON property `volumeId` # @return [String] attr_accessor :volume_id def initialize(**args) update!(**args) end # Update properties of this object def update!(**args) @device_allowed = args[:device_allowed] unless args[:device_allowed].nil? @downloads_acquired = args[:downloads_acquired] unless args[:downloads_acquired].nil? @just_acquired = args[:just_acquired] unless args[:just_acquired].nil? @kind = args[:kind] unless args[:kind].nil? @max_download_devices = args[:max_download_devices] unless args[:max_download_devices].nil? @message = args[:message] unless args[:message].nil? @nonce = args[:nonce] unless args[:nonce].nil? @reason_code = args[:reason_code] unless args[:reason_code].nil? @restricted = args[:restricted] unless args[:restricted].nil? @signature = args[:signature] unless args[:signature].nil? @source = args[:source] unless args[:source].nil? @volume_id = args[:volume_id] unless args[:volume_id].nil? end end # class DownloadAccesses include Google::Apis::Core::Hashable # A list of download access responses. # Corresponds to the JSON property `downloadAccessList` # @return [Array] attr_accessor :download_access_list # Resource type. # Corresponds to the JSON property `kind` # @return [String] attr_accessor :kind def initialize(**args) update!(**args) end # Update properties of this object def update!(**args) @download_access_list = args[:download_access_list] unless args[:download_access_list].nil? @kind = args[:kind] unless args[:kind].nil? end end # class GeoLayerData include Google::Apis::Core::Hashable # # Corresponds to the JSON property `common` # @return [Google::Apis::BooksV1::GeoLayerData::Common] attr_accessor :common # # Corresponds to the JSON property `geo` # @return [Google::Apis::BooksV1::GeoLayerData::Geo] attr_accessor :geo # # Corresponds to the JSON property `kind` # @return [String] attr_accessor :kind def initialize(**args) update!(**args) end # Update properties of this object def update!(**args) @common = args[:common] unless args[:common].nil? @geo = args[:geo] unless args[:geo].nil? @kind = args[:kind] unless args[:kind].nil? end # class Common include Google::Apis::Core::Hashable # The language of the information url and description. # Corresponds to the JSON property `lang` # @return [String] attr_accessor :lang # The URL for the preview image information. # Corresponds to the JSON property `previewImageUrl` # @return [String] attr_accessor :preview_image_url # The description for this location. # Corresponds to the JSON property `snippet` # @return [String] attr_accessor :snippet # The URL for information for this location. Ex: wikipedia link. # Corresponds to the JSON property `snippetUrl` # @return [String] attr_accessor :snippet_url # The display title and localized canonical name to use when searching for this # entity on Google search. # Corresponds to the JSON property `title` # @return [String] attr_accessor :title def initialize(**args) update!(**args) end # Update properties of this object def update!(**args) @lang = args[:lang] unless args[:lang].nil? @preview_image_url = args[:preview_image_url] unless args[:preview_image_url].nil? @snippet = args[:snippet] unless args[:snippet].nil? @snippet_url = args[:snippet_url] unless args[:snippet_url].nil? @title = args[:title] unless args[:title].nil? end end # class Geo include Google::Apis::Core::Hashable # The boundary of the location as a set of loops containing pairs of latitude, # longitude coordinates. # Corresponds to the JSON property `boundary` # @return [Array>] attr_accessor :boundary # The cache policy active for this data. EX: UNRESTRICTED, RESTRICTED, NEVER # Corresponds to the JSON property `cachePolicy` # @return [String] attr_accessor :cache_policy # The country code of the location. # Corresponds to the JSON property `countryCode` # @return [String] attr_accessor :country_code # The latitude of the location. # Corresponds to the JSON property `latitude` # @return [Float] attr_accessor :latitude # The longitude of the location. # Corresponds to the JSON property `longitude` # @return [Float] attr_accessor :longitude # The type of map that should be used for this location. EX: HYBRID, ROADMAP, # SATELLITE, TERRAIN # Corresponds to the JSON property `mapType` # @return [String] attr_accessor :map_type # The viewport for showing this location. This is a latitude, longitude # rectangle. # Corresponds to the JSON property `viewport` # @return [Google::Apis::BooksV1::GeoLayerData::Geo::Viewport] attr_accessor :viewport # 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 # Corresponds to the JSON property `zoom` # @return [Fixnum] attr_accessor :zoom def initialize(**args) update!(**args) end # Update properties of this object def update!(**args) @boundary = args[:boundary] unless args[:boundary].nil? @cache_policy = args[:cache_policy] unless args[:cache_policy].nil? @country_code = args[:country_code] unless args[:country_code].nil? @latitude = args[:latitude] unless args[:latitude].nil? @longitude = args[:longitude] unless args[:longitude].nil? @map_type = args[:map_type] unless args[:map_type].nil? @viewport = args[:viewport] unless args[:viewport].nil? @zoom = args[:zoom] unless args[:zoom].nil? end # class Boundary include Google::Apis::Core::Hashable # # Corresponds to the JSON property `latitude` # @return [Fixnum] attr_accessor :latitude # # Corresponds to the JSON property `longitude` # @return [Fixnum] attr_accessor :longitude def initialize(**args) update!(**args) end # Update properties of this object def update!(**args) @latitude = args[:latitude] unless args[:latitude].nil? @longitude = args[:longitude] unless args[:longitude].nil? end end # The viewport for showing this location. This is a latitude, longitude # rectangle. class Viewport include Google::Apis::Core::Hashable # # Corresponds to the JSON property `hi` # @return [Google::Apis::BooksV1::GeoLayerData::Geo::Viewport::Hi] attr_accessor :hi # # Corresponds to the JSON property `lo` # @return [Google::Apis::BooksV1::GeoLayerData::Geo::Viewport::Lo] attr_accessor :lo def initialize(**args) update!(**args) end # Update properties of this object def update!(**args) @hi = args[:hi] unless args[:hi].nil? @lo = args[:lo] unless args[:lo].nil? end # class Hi include Google::Apis::Core::Hashable # # Corresponds to the JSON property `latitude` # @return [Float] attr_accessor :latitude # # Corresponds to the JSON property `longitude` # @return [Float] attr_accessor :longitude def initialize(**args) update!(**args) end # Update properties of this object def update!(**args) @latitude = args[:latitude] unless args[:latitude].nil? @longitude = args[:longitude] unless args[:longitude].nil? end end # class Lo include Google::Apis::Core::Hashable # # Corresponds to the JSON property `latitude` # @return [Float] attr_accessor :latitude # # Corresponds to the JSON property `longitude` # @return [Float] attr_accessor :longitude def initialize(**args) update!(**args) end # Update properties of this object def update!(**args) @latitude = args[:latitude] unless args[:latitude].nil? @longitude = args[:longitude] unless args[:longitude].nil? end end end end end # class LayerSummaries include Google::Apis::Core::Hashable # A list of layer summary items. # Corresponds to the JSON property `items` # @return [Array] attr_accessor :items # Resource type. # Corresponds to the JSON property `kind` # @return [String] attr_accessor :kind # The total number of layer summaries found. # Corresponds to the JSON property `totalItems` # @return [Fixnum] attr_accessor :total_items def initialize(**args) update!(**args) end # Update properties of this object def update!(**args) @items = args[:items] unless args[:items].nil? @kind = args[:kind] unless args[:kind].nil? @total_items = args[:total_items] unless args[:total_items].nil? end end # class LayerSummary include Google::Apis::Core::Hashable # The number of annotations for this layer. # Corresponds to the JSON property `annotationCount` # @return [Fixnum] attr_accessor :annotation_count # The list of annotation types contained for this layer. # Corresponds to the JSON property `annotationTypes` # @return [Array] attr_accessor :annotation_types # Link to get data for this annotation. # Corresponds to the JSON property `annotationsDataLink` # @return [String] attr_accessor :annotations_data_link # The link to get the annotations for this layer. # Corresponds to the JSON property `annotationsLink` # @return [String] attr_accessor :annotations_link # The content version this resource is for. # Corresponds to the JSON property `contentVersion` # @return [String] attr_accessor :content_version # The number of data items for this layer. # Corresponds to the JSON property `dataCount` # @return [Fixnum] attr_accessor :data_count # Unique id of this layer summary. # Corresponds to the JSON property `id` # @return [String] attr_accessor :id # Resource Type # Corresponds to the JSON property `kind` # @return [String] attr_accessor :kind # The layer id for this summary. # Corresponds to the JSON property `layerId` # @return [String] attr_accessor :layer_id # URL to this resource. # Corresponds to the JSON property `selfLink` # @return [String] attr_accessor :self_link # Timestamp for the last time an item in this layer was updated. (RFC 3339 UTC # date-time format). # Corresponds to the JSON property `updated` # @return [DateTime] attr_accessor :updated # 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. # Corresponds to the JSON property `volumeAnnotationsVersion` # @return [String] attr_accessor :volume_annotations_version # The volume id this resource is for. # Corresponds to the JSON property `volumeId` # @return [String] attr_accessor :volume_id def initialize(**args) update!(**args) end # Update properties of this object def update!(**args) @annotation_count = args[:annotation_count] unless args[:annotation_count].nil? @annotation_types = args[:annotation_types] unless args[:annotation_types].nil? @annotations_data_link = args[:annotations_data_link] unless args[:annotations_data_link].nil? @annotations_link = args[:annotations_link] unless args[:annotations_link].nil? @content_version = args[:content_version] unless args[:content_version].nil? @data_count = args[:data_count] unless args[:data_count].nil? @id = args[:id] unless args[:id].nil? @kind = args[:kind] unless args[:kind].nil? @layer_id = args[:layer_id] unless args[:layer_id].nil? @self_link = args[:self_link] unless args[:self_link].nil? @updated = args[:updated] unless args[:updated].nil? @volume_annotations_version = args[:volume_annotations_version] unless args[:volume_annotations_version].nil? @volume_id = args[:volume_id] unless args[:volume_id].nil? end end # class Metadata include Google::Apis::Core::Hashable # A list of offline dictionary metadata. # Corresponds to the JSON property `items` # @return [Array] attr_accessor :items # Resource type. # Corresponds to the JSON property `kind` # @return [String] attr_accessor :kind def initialize(**args) update!(**args) end # Update properties of this object def update!(**args) @items = args[:items] unless args[:items].nil? @kind = args[:kind] unless args[:kind].nil? end # class Item include Google::Apis::Core::Hashable # # Corresponds to the JSON property `download_url` # @return [String] attr_accessor :download_url # # Corresponds to the JSON property `encrypted_key` # @return [String] attr_accessor :encrypted_key # # Corresponds to the JSON property `language` # @return [String] attr_accessor :language # # Corresponds to the JSON property `size` # @return [String] attr_accessor :size # # Corresponds to the JSON property `version` # @return [String] attr_accessor :version def initialize(**args) update!(**args) end # Update properties of this object def update!(**args) @download_url = args[:download_url] unless args[:download_url].nil? @encrypted_key = args[:encrypted_key] unless args[:encrypted_key].nil? @language = args[:language] unless args[:language].nil? @size = args[:size] unless args[:size].nil? @version = args[:version] unless args[:version].nil? end end end # class Offers include Google::Apis::Core::Hashable # A list of offers. # Corresponds to the JSON property `items` # @return [Array] attr_accessor :items # Resource type. # Corresponds to the JSON property `kind` # @return [String] attr_accessor :kind def initialize(**args) update!(**args) end # Update properties of this object def update!(**args) @items = args[:items] unless args[:items].nil? @kind = args[:kind] unless args[:kind].nil? end # class Item include Google::Apis::Core::Hashable # # Corresponds to the JSON property `artUrl` # @return [String] attr_accessor :art_url # # Corresponds to the JSON property `gservicesKey` # @return [String] attr_accessor :gservices_key # # Corresponds to the JSON property `id` # @return [String] attr_accessor :id # # Corresponds to the JSON property `items` # @return [Array] attr_accessor :items def initialize(**args) update!(**args) end # Update properties of this object def update!(**args) @art_url = args[:art_url] unless args[:art_url].nil? @gservices_key = args[:gservices_key] unless args[:gservices_key].nil? @id = args[:id] unless args[:id].nil? @items = args[:items] unless args[:items].nil? end # class Item include Google::Apis::Core::Hashable # # Corresponds to the JSON property `author` # @return [String] attr_accessor :author # # Corresponds to the JSON property `canonicalVolumeLink` # @return [String] attr_accessor :canonical_volume_link # # Corresponds to the JSON property `coverUrl` # @return [String] attr_accessor :cover_url # # Corresponds to the JSON property `description` # @return [String] attr_accessor :description # # Corresponds to the JSON property `title` # @return [String] attr_accessor :title # # Corresponds to the JSON property `volumeId` # @return [String] attr_accessor :volume_id def initialize(**args) update!(**args) end # Update properties of this object def update!(**args) @author = args[:author] unless args[:author].nil? @canonical_volume_link = args[:canonical_volume_link] unless args[:canonical_volume_link].nil? @cover_url = args[:cover_url] unless args[:cover_url].nil? @description = args[:description] unless args[:description].nil? @title = args[:title] unless args[:title].nil? @volume_id = args[:volume_id] unless args[:volume_id].nil? end end end end # class ReadingPosition include Google::Apis::Core::Hashable # Position in an EPUB as a CFI. # Corresponds to the JSON property `epubCfiPosition` # @return [String] attr_accessor :epub_cfi_position # Position in a volume for image-based content. # Corresponds to the JSON property `gbImagePosition` # @return [String] attr_accessor :gb_image_position # Position in a volume for text-based content. # Corresponds to the JSON property `gbTextPosition` # @return [String] attr_accessor :gb_text_position # Resource type for a reading position. # Corresponds to the JSON property `kind` # @return [String] attr_accessor :kind # Position in a PDF file. # Corresponds to the JSON property `pdfPosition` # @return [String] attr_accessor :pdf_position # Timestamp when this reading position was last updated (formatted UTC timestamp # with millisecond resolution). # Corresponds to the JSON property `updated` # @return [DateTime] attr_accessor :updated # Volume id associated with this reading position. # Corresponds to the JSON property `volumeId` # @return [String] attr_accessor :volume_id def initialize(**args) update!(**args) end # Update properties of this object def update!(**args) @epub_cfi_position = args[:epub_cfi_position] unless args[:epub_cfi_position].nil? @gb_image_position = args[:gb_image_position] unless args[:gb_image_position].nil? @gb_text_position = args[:gb_text_position] unless args[:gb_text_position].nil? @kind = args[:kind] unless args[:kind].nil? @pdf_position = args[:pdf_position] unless args[:pdf_position].nil? @updated = args[:updated] unless args[:updated].nil? @volume_id = args[:volume_id] unless args[:volume_id].nil? end end # class RequestAccess include Google::Apis::Core::Hashable # A concurrent access response. # Corresponds to the JSON property `concurrentAccess` # @return [Google::Apis::BooksV1::ConcurrentAccessRestriction] attr_accessor :concurrent_access # A download access response. # Corresponds to the JSON property `downloadAccess` # @return [Google::Apis::BooksV1::DownloadAccessRestriction] attr_accessor :download_access # Resource type. # Corresponds to the JSON property `kind` # @return [String] attr_accessor :kind def initialize(**args) update!(**args) end # Update properties of this object def update!(**args) @concurrent_access = args[:concurrent_access] unless args[:concurrent_access].nil? @download_access = args[:download_access] unless args[:download_access].nil? @kind = args[:kind] unless args[:kind].nil? end end # class Review include Google::Apis::Core::Hashable # Author of this review. # Corresponds to the JSON property `author` # @return [Google::Apis::BooksV1::Review::Author] attr_accessor :author # Review text. # Corresponds to the JSON property `content` # @return [String] attr_accessor :content # Date of this review. # Corresponds to the JSON property `date` # @return [String] attr_accessor :date # URL for the full review text, for reviews gathered from the web. # Corresponds to the JSON property `fullTextUrl` # @return [String] attr_accessor :full_text_url # Resource type for a review. # Corresponds to the JSON property `kind` # @return [String] attr_accessor :kind # Star rating for this review. Possible values are ONE, TWO, THREE, FOUR, FIVE # or NOT_RATED. # Corresponds to the JSON property `rating` # @return [String] attr_accessor :rating # Information regarding the source of this review, when the review is not from a # Google Books user. # Corresponds to the JSON property `source` # @return [Google::Apis::BooksV1::Review::Source] attr_accessor :source # Title for this review. # Corresponds to the JSON property `title` # @return [String] attr_accessor :title # Source type for this review. Possible values are EDITORIAL, WEB_USER or # GOOGLE_USER. # Corresponds to the JSON property `type` # @return [String] attr_accessor :type # Volume that this review is for. # Corresponds to the JSON property `volumeId` # @return [String] attr_accessor :volume_id def initialize(**args) update!(**args) end # Update properties of this object def update!(**args) @author = args[:author] unless args[:author].nil? @content = args[:content] unless args[:content].nil? @date = args[:date] unless args[:date].nil? @full_text_url = args[:full_text_url] unless args[:full_text_url].nil? @kind = args[:kind] unless args[:kind].nil? @rating = args[:rating] unless args[:rating].nil? @source = args[:source] unless args[:source].nil? @title = args[:title] unless args[:title].nil? @type = args[:type] unless args[:type].nil? @volume_id = args[:volume_id] unless args[:volume_id].nil? end # Author of this review. class Author include Google::Apis::Core::Hashable # Name of this person. # Corresponds to the JSON property `displayName` # @return [String] attr_accessor :display_name def initialize(**args) update!(**args) end # Update properties of this object def update!(**args) @display_name = args[:display_name] unless args[:display_name].nil? end end # Information regarding the source of this review, when the review is not from a # Google Books user. class Source include Google::Apis::Core::Hashable # Name of the source. # Corresponds to the JSON property `description` # @return [String] attr_accessor :description # Extra text about the source of the review. # Corresponds to the JSON property `extraDescription` # @return [String] attr_accessor :extra_description # URL of the source of the review. # Corresponds to the JSON property `url` # @return [String] attr_accessor :url def initialize(**args) update!(**args) end # Update properties of this object def update!(**args) @description = args[:description] unless args[:description].nil? @extra_description = args[:extra_description] unless args[:extra_description].nil? @url = args[:url] unless args[:url].nil? end end end # class UserSettings include Google::Apis::Core::Hashable # Resource type. # Corresponds to the JSON property `kind` # @return [String] attr_accessor :kind # User settings in sub-objects, each for different purposes. # Corresponds to the JSON property `notesExport` # @return [Google::Apis::BooksV1::UserSettings::NotesExport] attr_accessor :notes_export def initialize(**args) update!(**args) end # Update properties of this object def update!(**args) @kind = args[:kind] unless args[:kind].nil? @notes_export = args[:notes_export] unless args[:notes_export].nil? end # User settings in sub-objects, each for different purposes. class NotesExport include Google::Apis::Core::Hashable # # Corresponds to the JSON property `folderName` # @return [String] attr_accessor :folder_name # # Corresponds to the JSON property `isEnabled` # @return [Boolean] attr_accessor :is_enabled alias_method :is_enabled?, :is_enabled def initialize(**args) update!(**args) end # Update properties of this object def update!(**args) @folder_name = args[:folder_name] unless args[:folder_name].nil? @is_enabled = args[:is_enabled] unless args[:is_enabled].nil? end end end # class Volume include Google::Apis::Core::Hashable # 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.). # Corresponds to the JSON property `accessInfo` # @return [Google::Apis::BooksV1::Volume::AccessInfo] attr_accessor :access_info # Opaque identifier for a specific version of a volume resource. (In LITE # projection) # Corresponds to the JSON property `etag` # @return [String] attr_accessor :etag # Unique identifier for a volume. (In LITE projection.) # Corresponds to the JSON property `id` # @return [String] attr_accessor :id # Resource type for a volume. (In LITE projection.) # Corresponds to the JSON property `kind` # @return [String] attr_accessor :kind # What layers exist in this volume and high level information about them. # Corresponds to the JSON property `layerInfo` # @return [Google::Apis::BooksV1::Volume::LayerInfo] attr_accessor :layer_info # Recommendation related information for this volume. # Corresponds to the JSON property `recommendedInfo` # @return [Google::Apis::BooksV1::Volume::RecommendedInfo] attr_accessor :recommended_info # 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). # Corresponds to the JSON property `saleInfo` # @return [Google::Apis::BooksV1::Volume::SaleInfo] attr_accessor :sale_info # Search result information related to this volume. # Corresponds to the JSON property `searchInfo` # @return [Google::Apis::BooksV1::Volume::SearchInfo] attr_accessor :search_info # URL to this resource. (In LITE projection.) # Corresponds to the JSON property `selfLink` # @return [String] attr_accessor :self_link # User specific information related to this volume. (e.g. page this user last # read or whether they purchased this book) # Corresponds to the JSON property `userInfo` # @return [Google::Apis::BooksV1::Volume::UserInfo] attr_accessor :user_info # General volume information. # Corresponds to the JSON property `volumeInfo` # @return [Google::Apis::BooksV1::Volume::VolumeInfo] attr_accessor :volume_info def initialize(**args) update!(**args) end # Update properties of this object def update!(**args) @access_info = args[:access_info] unless args[:access_info].nil? @etag = args[:etag] unless args[:etag].nil? @id = args[:id] unless args[:id].nil? @kind = args[:kind] unless args[:kind].nil? @layer_info = args[:layer_info] unless args[:layer_info].nil? @recommended_info = args[:recommended_info] unless args[:recommended_info].nil? @sale_info = args[:sale_info] unless args[:sale_info].nil? @search_info = args[:search_info] unless args[:search_info].nil? @self_link = args[:self_link] unless args[:self_link].nil? @user_info = args[:user_info] unless args[:user_info].nil? @volume_info = args[:volume_info] unless args[:volume_info].nil? end # 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.). class AccessInfo include Google::Apis::Core::Hashable # 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.) # Corresponds to the JSON property `accessViewStatus` # @return [String] attr_accessor :access_view_status # The two-letter ISO_3166-1 country code for which this access information is # valid. (In LITE projection.) # Corresponds to the JSON property `country` # @return [String] attr_accessor :country # Information about a volume's download license access restrictions. # Corresponds to the JSON property `downloadAccess` # @return [Google::Apis::BooksV1::DownloadAccessRestriction] attr_accessor :download_access # URL to the Google Drive viewer if this volume is uploaded by the user by # selecting the file from Google Drive. # Corresponds to the JSON property `driveImportedContentLink` # @return [String] attr_accessor :drive_imported_content_link # Whether this volume can be embedded in a viewport using the Embedded Viewer # API. # Corresponds to the JSON property `embeddable` # @return [Boolean] attr_accessor :embeddable alias_method :embeddable?, :embeddable # Information about epub content. (In LITE projection.) # Corresponds to the JSON property `epub` # @return [Google::Apis::BooksV1::Volume::AccessInfo::Epub] attr_accessor :epub # 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. # Corresponds to the JSON property `explicitOfflineLicenseManagement` # @return [Boolean] attr_accessor :explicit_offline_license_management alias_method :explicit_offline_license_management?, :explicit_offline_license_management # Information about pdf content. (In LITE projection.) # Corresponds to the JSON property `pdf` # @return [Google::Apis::BooksV1::Volume::AccessInfo::Pdf] attr_accessor :pdf # Whether or not this book is public domain in the country listed above. # Corresponds to the JSON property `publicDomain` # @return [Boolean] attr_accessor :public_domain alias_method :public_domain?, :public_domain # Whether quote sharing is allowed for this volume. # Corresponds to the JSON property `quoteSharingAllowed` # @return [Boolean] attr_accessor :quote_sharing_allowed alias_method :quote_sharing_allowed?, :quote_sharing_allowed # Whether text-to-speech is permitted for this volume. Values can be ALLOWED, # ALLOWED_FOR_ACCESSIBILITY, or NOT_ALLOWED. # Corresponds to the JSON property `textToSpeechPermission` # @return [String] attr_accessor :text_to_speech_permission # For ordered but not yet processed orders, we give a URL that can be used to go # to the appropriate Google Wallet page. # Corresponds to the JSON property `viewOrderUrl` # @return [String] attr_accessor :view_order_url # 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. # Corresponds to the JSON property `viewability` # @return [String] attr_accessor :viewability # URL to read this volume on the Google Books site. Link will not allow users to # read non-viewable volumes. # Corresponds to the JSON property `webReaderLink` # @return [String] attr_accessor :web_reader_link def initialize(**args) update!(**args) end # Update properties of this object def update!(**args) @access_view_status = args[:access_view_status] unless args[:access_view_status].nil? @country = args[:country] unless args[:country].nil? @download_access = args[:download_access] unless args[:download_access].nil? @drive_imported_content_link = args[:drive_imported_content_link] unless args[:drive_imported_content_link].nil? @embeddable = args[:embeddable] unless args[:embeddable].nil? @epub = args[:epub] unless args[:epub].nil? @explicit_offline_license_management = args[:explicit_offline_license_management] unless args[:explicit_offline_license_management].nil? @pdf = args[:pdf] unless args[:pdf].nil? @public_domain = args[:public_domain] unless args[:public_domain].nil? @quote_sharing_allowed = args[:quote_sharing_allowed] unless args[:quote_sharing_allowed].nil? @text_to_speech_permission = args[:text_to_speech_permission] unless args[:text_to_speech_permission].nil? @view_order_url = args[:view_order_url] unless args[:view_order_url].nil? @viewability = args[:viewability] unless args[:viewability].nil? @web_reader_link = args[:web_reader_link] unless args[:web_reader_link].nil? end # Information about epub content. (In LITE projection.) class Epub include Google::Apis::Core::Hashable # URL to retrieve ACS token for epub download. (In LITE projection.) # Corresponds to the JSON property `acsTokenLink` # @return [String] attr_accessor :acs_token_link # URL to download epub. (In LITE projection.) # Corresponds to the JSON property `downloadLink` # @return [String] attr_accessor :download_link # Is a flowing text epub available either as public domain or for purchase. (In # LITE projection.) # Corresponds to the JSON property `isAvailable` # @return [Boolean] attr_accessor :is_available alias_method :is_available?, :is_available def initialize(**args) update!(**args) end # Update properties of this object def update!(**args) @acs_token_link = args[:acs_token_link] unless args[:acs_token_link].nil? @download_link = args[:download_link] unless args[:download_link].nil? @is_available = args[:is_available] unless args[:is_available].nil? end end # Information about pdf content. (In LITE projection.) class Pdf include Google::Apis::Core::Hashable # URL to retrieve ACS token for pdf download. (In LITE projection.) # Corresponds to the JSON property `acsTokenLink` # @return [String] attr_accessor :acs_token_link # URL to download pdf. (In LITE projection.) # Corresponds to the JSON property `downloadLink` # @return [String] attr_accessor :download_link # Is a scanned image pdf available either as public domain or for purchase. (In # LITE projection.) # Corresponds to the JSON property `isAvailable` # @return [Boolean] attr_accessor :is_available alias_method :is_available?, :is_available def initialize(**args) update!(**args) end # Update properties of this object def update!(**args) @acs_token_link = args[:acs_token_link] unless args[:acs_token_link].nil? @download_link = args[:download_link] unless args[:download_link].nil? @is_available = args[:is_available] unless args[:is_available].nil? end end end # What layers exist in this volume and high level information about them. class LayerInfo include Google::Apis::Core::Hashable # A layer should appear here if and only if the layer exists for this book. # Corresponds to the JSON property `layers` # @return [Array] attr_accessor :layers def initialize(**args) update!(**args) end # Update properties of this object def update!(**args) @layers = args[:layers] unless args[:layers].nil? end # class Layer include Google::Apis::Core::Hashable # The layer id of this layer (e.g. "geo"). # Corresponds to the JSON property `layerId` # @return [String] attr_accessor :layer_id # 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. # Corresponds to the JSON property `volumeAnnotationsVersion` # @return [String] attr_accessor :volume_annotations_version def initialize(**args) update!(**args) end # Update properties of this object def update!(**args) @layer_id = args[:layer_id] unless args[:layer_id].nil? @volume_annotations_version = args[:volume_annotations_version] unless args[:volume_annotations_version].nil? end end end # Recommendation related information for this volume. class RecommendedInfo include Google::Apis::Core::Hashable # A text explaining why this volume is recommended. # Corresponds to the JSON property `explanation` # @return [String] attr_accessor :explanation def initialize(**args) update!(**args) end # Update properties of this object def update!(**args) @explanation = args[:explanation] unless args[:explanation].nil? end end # 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). class SaleInfo include Google::Apis::Core::Hashable # URL to purchase this volume on the Google Books site. (In LITE projection) # Corresponds to the JSON property `buyLink` # @return [String] attr_accessor :buy_link # The two-letter ISO_3166-1 country code for which this sale information is # valid. (In LITE projection.) # Corresponds to the JSON property `country` # @return [String] attr_accessor :country # Whether or not this volume is an eBook (can be added to the My eBooks shelf). # Corresponds to the JSON property `isEbook` # @return [Boolean] attr_accessor :is_ebook alias_method :is_ebook?, :is_ebook # Suggested retail price. (In LITE projection.) # Corresponds to the JSON property `listPrice` # @return [Google::Apis::BooksV1::Volume::SaleInfo::ListPrice] attr_accessor :list_price # Offers available for this volume (sales and rentals). # Corresponds to the JSON property `offers` # @return [Array] attr_accessor :offers # The date on which this book is available for sale. # Corresponds to the JSON property `onSaleDate` # @return [DateTime] attr_accessor :on_sale_date # 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.) # Corresponds to the JSON property `retailPrice` # @return [Google::Apis::BooksV1::Volume::SaleInfo::RetailPrice] attr_accessor :retail_price # 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. # Corresponds to the JSON property `saleability` # @return [String] attr_accessor :saleability def initialize(**args) update!(**args) end # Update properties of this object def update!(**args) @buy_link = args[:buy_link] unless args[:buy_link].nil? @country = args[:country] unless args[:country].nil? @is_ebook = args[:is_ebook] unless args[:is_ebook].nil? @list_price = args[:list_price] unless args[:list_price].nil? @offers = args[:offers] unless args[:offers].nil? @on_sale_date = args[:on_sale_date] unless args[:on_sale_date].nil? @retail_price = args[:retail_price] unless args[:retail_price].nil? @saleability = args[:saleability] unless args[:saleability].nil? end # Suggested retail price. (In LITE projection.) class ListPrice include Google::Apis::Core::Hashable # Amount in the currency listed below. (In LITE projection.) # Corresponds to the JSON property `amount` # @return [Float] attr_accessor :amount # An ISO 4217, three-letter currency code. (In LITE projection.) # Corresponds to the JSON property `currencyCode` # @return [String] attr_accessor :currency_code def initialize(**args) update!(**args) end # Update properties of this object def update!(**args) @amount = args[:amount] unless args[:amount].nil? @currency_code = args[:currency_code] unless args[:currency_code].nil? end end # class Offer include Google::Apis::Core::Hashable # The finsky offer type (e.g., PURCHASE=0 RENTAL=3) # Corresponds to the JSON property `finskyOfferType` # @return [Fixnum] attr_accessor :finsky_offer_type # Offer list (=undiscounted) price in Micros. # Corresponds to the JSON property `listPrice` # @return [Google::Apis::BooksV1::Volume::SaleInfo::Offer::ListPrice] attr_accessor :list_price # The rental duration (for rental offers only). # Corresponds to the JSON property `rentalDuration` # @return [Google::Apis::BooksV1::Volume::SaleInfo::Offer::RentalDuration] attr_accessor :rental_duration # Offer retail (=discounted) price in Micros # Corresponds to the JSON property `retailPrice` # @return [Google::Apis::BooksV1::Volume::SaleInfo::Offer::RetailPrice] attr_accessor :retail_price def initialize(**args) update!(**args) end # Update properties of this object def update!(**args) @finsky_offer_type = args[:finsky_offer_type] unless args[:finsky_offer_type].nil? @list_price = args[:list_price] unless args[:list_price].nil? @rental_duration = args[:rental_duration] unless args[:rental_duration].nil? @retail_price = args[:retail_price] unless args[:retail_price].nil? end # Offer list (=undiscounted) price in Micros. class ListPrice include Google::Apis::Core::Hashable # # Corresponds to the JSON property `amountInMicros` # @return [Float] attr_accessor :amount_in_micros # # Corresponds to the JSON property `currencyCode` # @return [String] attr_accessor :currency_code def initialize(**args) update!(**args) end # Update properties of this object def update!(**args) @amount_in_micros = args[:amount_in_micros] unless args[:amount_in_micros].nil? @currency_code = args[:currency_code] unless args[:currency_code].nil? end end # The rental duration (for rental offers only). class RentalDuration include Google::Apis::Core::Hashable # # Corresponds to the JSON property `count` # @return [Float] attr_accessor :count # # Corresponds to the JSON property `unit` # @return [String] attr_accessor :unit def initialize(**args) update!(**args) end # Update properties of this object def update!(**args) @count = args[:count] unless args[:count].nil? @unit = args[:unit] unless args[:unit].nil? end end # Offer retail (=discounted) price in Micros class RetailPrice include Google::Apis::Core::Hashable # # Corresponds to the JSON property `amountInMicros` # @return [Float] attr_accessor :amount_in_micros # # Corresponds to the JSON property `currencyCode` # @return [String] attr_accessor :currency_code def initialize(**args) update!(**args) end # Update properties of this object def update!(**args) @amount_in_micros = args[:amount_in_micros] unless args[:amount_in_micros].nil? @currency_code = args[:currency_code] unless args[:currency_code].nil? end end end # 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.) class RetailPrice include Google::Apis::Core::Hashable # Amount in the currency listed below. (In LITE projection.) # Corresponds to the JSON property `amount` # @return [Float] attr_accessor :amount # An ISO 4217, three-letter currency code. (In LITE projection.) # Corresponds to the JSON property `currencyCode` # @return [String] attr_accessor :currency_code def initialize(**args) update!(**args) end # Update properties of this object def update!(**args) @amount = args[:amount] unless args[:amount].nil? @currency_code = args[:currency_code] unless args[:currency_code].nil? end end end # Search result information related to this volume. class SearchInfo include Google::Apis::Core::Hashable # A text snippet containing the search query. # Corresponds to the JSON property `textSnippet` # @return [String] attr_accessor :text_snippet def initialize(**args) update!(**args) end # Update properties of this object def update!(**args) @text_snippet = args[:text_snippet] unless args[:text_snippet].nil? end end # User specific information related to this volume. (e.g. page this user last # read or whether they purchased this book) class UserInfo include Google::Apis::Core::Hashable # Copy/Paste accounting information. # Corresponds to the JSON property `copy` # @return [Google::Apis::BooksV1::Volume::UserInfo::Copy] attr_accessor :copy # Whether or not this volume is currently in "my books." # Corresponds to the JSON property `isInMyBooks` # @return [Boolean] attr_accessor :is_in_my_books alias_method :is_in_my_books?, :is_in_my_books # Whether or not this volume was pre-ordered by the authenticated user making # the request. (In LITE projection.) # Corresponds to the JSON property `isPreordered` # @return [Boolean] attr_accessor :is_preordered alias_method :is_preordered?, :is_preordered # Whether or not this volume was purchased by the authenticated user making the # request. (In LITE projection.) # Corresponds to the JSON property `isPurchased` # @return [Boolean] attr_accessor :is_purchased alias_method :is_purchased?, :is_purchased # Whether or not this volume was user uploaded. # Corresponds to the JSON property `isUploaded` # @return [Boolean] attr_accessor :is_uploaded alias_method :is_uploaded?, :is_uploaded # The user's current reading position in the volume, if one is available. (In # LITE projection.) # Corresponds to the JSON property `readingPosition` # @return [Google::Apis::BooksV1::ReadingPosition] attr_accessor :reading_position # Period during this book is/was a valid rental. # Corresponds to the JSON property `rentalPeriod` # @return [Google::Apis::BooksV1::Volume::UserInfo::RentalPeriod] attr_accessor :rental_period # Whether this book is an active or an expired rental. # Corresponds to the JSON property `rentalState` # @return [String] attr_accessor :rental_state # This user's review of this volume, if one exists. # Corresponds to the JSON property `review` # @return [Google::Apis::BooksV1::Review] attr_accessor :review # 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). # Corresponds to the JSON property `updated` # @return [DateTime] attr_accessor :updated # # Corresponds to the JSON property `userUploadedVolumeInfo` # @return [Google::Apis::BooksV1::Volume::UserInfo::UserUploadedVolumeInfo] attr_accessor :user_uploaded_volume_info def initialize(**args) update!(**args) end # Update properties of this object def update!(**args) @copy = args[:copy] unless args[:copy].nil? @is_in_my_books = args[:is_in_my_books] unless args[:is_in_my_books].nil? @is_preordered = args[:is_preordered] unless args[:is_preordered].nil? @is_purchased = args[:is_purchased] unless args[:is_purchased].nil? @is_uploaded = args[:is_uploaded] unless args[:is_uploaded].nil? @reading_position = args[:reading_position] unless args[:reading_position].nil? @rental_period = args[:rental_period] unless args[:rental_period].nil? @rental_state = args[:rental_state] unless args[:rental_state].nil? @review = args[:review] unless args[:review].nil? @updated = args[:updated] unless args[:updated].nil? @user_uploaded_volume_info = args[:user_uploaded_volume_info] unless args[:user_uploaded_volume_info].nil? end # Copy/Paste accounting information. class Copy include Google::Apis::Core::Hashable # # Corresponds to the JSON property `allowedCharacterCount` # @return [Fixnum] attr_accessor :allowed_character_count # # Corresponds to the JSON property `limitType` # @return [String] attr_accessor :limit_type # # Corresponds to the JSON property `remainingCharacterCount` # @return [Fixnum] attr_accessor :remaining_character_count # # Corresponds to the JSON property `updated` # @return [DateTime] attr_accessor :updated def initialize(**args) update!(**args) end # Update properties of this object def update!(**args) @allowed_character_count = args[:allowed_character_count] unless args[:allowed_character_count].nil? @limit_type = args[:limit_type] unless args[:limit_type].nil? @remaining_character_count = args[:remaining_character_count] unless args[:remaining_character_count].nil? @updated = args[:updated] unless args[:updated].nil? end end # Period during this book is/was a valid rental. class RentalPeriod include Google::Apis::Core::Hashable # # Corresponds to the JSON property `endUtcSec` # @return [String] attr_accessor :end_utc_sec # # Corresponds to the JSON property `startUtcSec` # @return [String] attr_accessor :start_utc_sec def initialize(**args) update!(**args) end # Update properties of this object def update!(**args) @end_utc_sec = args[:end_utc_sec] unless args[:end_utc_sec].nil? @start_utc_sec = args[:start_utc_sec] unless args[:start_utc_sec].nil? end end # class UserUploadedVolumeInfo include Google::Apis::Core::Hashable # # Corresponds to the JSON property `processingState` # @return [String] attr_accessor :processing_state def initialize(**args) update!(**args) end # Update properties of this object def update!(**args) @processing_state = args[:processing_state] unless args[:processing_state].nil? end end end # General volume information. class VolumeInfo include Google::Apis::Core::Hashable # Whether anonymous logging should be allowed. # Corresponds to the JSON property `allowAnonLogging` # @return [Boolean] attr_accessor :allow_anon_logging alias_method :allow_anon_logging?, :allow_anon_logging # The names of the authors and/or editors for this volume. (In LITE projection) # Corresponds to the JSON property `authors` # @return [Array] attr_accessor :authors # The mean review rating for this volume. (min = 1.0, max = 5.0) # Corresponds to the JSON property `averageRating` # @return [Float] attr_accessor :average_rating # Canonical URL for a volume. (In LITE projection.) # Corresponds to the JSON property `canonicalVolumeLink` # @return [String] attr_accessor :canonical_volume_link # A list of subject categories, such as "Fiction", "Suspense", etc. # Corresponds to the JSON property `categories` # @return [Array] attr_accessor :categories # An identifier for the version of the volume content (text & images). (In LITE # projection) # Corresponds to the JSON property `contentVersion` # @return [String] attr_accessor :content_version # 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.) # Corresponds to the JSON property `description` # @return [String] attr_accessor :description # Physical dimensions of this volume. # Corresponds to the JSON property `dimensions` # @return [Google::Apis::BooksV1::Volume::VolumeInfo::Dimensions] attr_accessor :dimensions # A list of image links for all the sizes that are available. (In LITE # projection.) # Corresponds to the JSON property `imageLinks` # @return [Google::Apis::BooksV1::Volume::VolumeInfo::ImageLinks] attr_accessor :image_links # Industry standard identifiers for this volume. # Corresponds to the JSON property `industryIdentifiers` # @return [Array] attr_accessor :industry_identifiers # URL to view information about this volume on the Google Books site. (In LITE # projection) # Corresponds to the JSON property `infoLink` # @return [String] attr_accessor :info_link # Best language for this volume (based on content). It is the two-letter ISO 639- # 1 code such as 'fr', 'en', etc. # Corresponds to the JSON property `language` # @return [String] attr_accessor :language # The main category to which this volume belongs. It will be the category from # the categories list returned below that has the highest weight. # Corresponds to the JSON property `mainCategory` # @return [String] attr_accessor :main_category # # Corresponds to the JSON property `maturityRating` # @return [String] attr_accessor :maturity_rating # Total number of pages as per publisher metadata. # Corresponds to the JSON property `pageCount` # @return [Fixnum] attr_accessor :page_count # URL to preview this volume on the Google Books site. # Corresponds to the JSON property `previewLink` # @return [String] attr_accessor :preview_link # Type of publication of this volume. Possible values are BOOK or MAGAZINE. # Corresponds to the JSON property `printType` # @return [String] attr_accessor :print_type # Total number of printed pages in generated pdf representation. # Corresponds to the JSON property `printedPageCount` # @return [Fixnum] attr_accessor :printed_page_count # Date of publication. (In LITE projection.) # Corresponds to the JSON property `publishedDate` # @return [String] attr_accessor :published_date # Publisher of this volume. (In LITE projection.) # Corresponds to the JSON property `publisher` # @return [String] attr_accessor :publisher # The number of review ratings for this volume. # Corresponds to the JSON property `ratingsCount` # @return [Fixnum] attr_accessor :ratings_count # The reading modes available for this volume. # Corresponds to the JSON property `readingModes` # @return [Object] attr_accessor :reading_modes # Total number of sample pages as per publisher metadata. # Corresponds to the JSON property `samplePageCount` # @return [Fixnum] attr_accessor :sample_page_count # Volume subtitle. (In LITE projection.) # Corresponds to the JSON property `subtitle` # @return [String] attr_accessor :subtitle # Volume title. (In LITE projection.) # Corresponds to the JSON property `title` # @return [String] attr_accessor :title def initialize(**args) update!(**args) end # Update properties of this object def update!(**args) @allow_anon_logging = args[:allow_anon_logging] unless args[:allow_anon_logging].nil? @authors = args[:authors] unless args[:authors].nil? @average_rating = args[:average_rating] unless args[:average_rating].nil? @canonical_volume_link = args[:canonical_volume_link] unless args[:canonical_volume_link].nil? @categories = args[:categories] unless args[:categories].nil? @content_version = args[:content_version] unless args[:content_version].nil? @description = args[:description] unless args[:description].nil? @dimensions = args[:dimensions] unless args[:dimensions].nil? @image_links = args[:image_links] unless args[:image_links].nil? @industry_identifiers = args[:industry_identifiers] unless args[:industry_identifiers].nil? @info_link = args[:info_link] unless args[:info_link].nil? @language = args[:language] unless args[:language].nil? @main_category = args[:main_category] unless args[:main_category].nil? @maturity_rating = args[:maturity_rating] unless args[:maturity_rating].nil? @page_count = args[:page_count] unless args[:page_count].nil? @preview_link = args[:preview_link] unless args[:preview_link].nil? @print_type = args[:print_type] unless args[:print_type].nil? @printed_page_count = args[:printed_page_count] unless args[:printed_page_count].nil? @published_date = args[:published_date] unless args[:published_date].nil? @publisher = args[:publisher] unless args[:publisher].nil? @ratings_count = args[:ratings_count] unless args[:ratings_count].nil? @reading_modes = args[:reading_modes] unless args[:reading_modes].nil? @sample_page_count = args[:sample_page_count] unless args[:sample_page_count].nil? @subtitle = args[:subtitle] unless args[:subtitle].nil? @title = args[:title] unless args[:title].nil? end # Physical dimensions of this volume. class Dimensions include Google::Apis::Core::Hashable # Height or length of this volume (in cm). # Corresponds to the JSON property `height` # @return [String] attr_accessor :height # Thickness of this volume (in cm). # Corresponds to the JSON property `thickness` # @return [String] attr_accessor :thickness # Width of this volume (in cm). # Corresponds to the JSON property `width` # @return [String] attr_accessor :width def initialize(**args) update!(**args) end # Update properties of this object def update!(**args) @height = args[:height] unless args[:height].nil? @thickness = args[:thickness] unless args[:thickness].nil? @width = args[:width] unless args[:width].nil? end end # A list of image links for all the sizes that are available. (In LITE # projection.) class ImageLinks include Google::Apis::Core::Hashable # Image link for extra large size (width of ~1280 pixels). (In LITE projection) # Corresponds to the JSON property `extraLarge` # @return [String] attr_accessor :extra_large # Image link for large size (width of ~800 pixels). (In LITE projection) # Corresponds to the JSON property `large` # @return [String] attr_accessor :large # Image link for medium size (width of ~575 pixels). (In LITE projection) # Corresponds to the JSON property `medium` # @return [String] attr_accessor :medium # Image link for small size (width of ~300 pixels). (In LITE projection) # Corresponds to the JSON property `small` # @return [String] attr_accessor :small # Image link for small thumbnail size (width of ~80 pixels). (In LITE projection) # Corresponds to the JSON property `smallThumbnail` # @return [String] attr_accessor :small_thumbnail # Image link for thumbnail size (width of ~128 pixels). (In LITE projection) # Corresponds to the JSON property `thumbnail` # @return [String] attr_accessor :thumbnail def initialize(**args) update!(**args) end # Update properties of this object def update!(**args) @extra_large = args[:extra_large] unless args[:extra_large].nil? @large = args[:large] unless args[:large].nil? @medium = args[:medium] unless args[:medium].nil? @small = args[:small] unless args[:small].nil? @small_thumbnail = args[:small_thumbnail] unless args[:small_thumbnail].nil? @thumbnail = args[:thumbnail] unless args[:thumbnail].nil? end end # class IndustryIdentifier include Google::Apis::Core::Hashable # Industry specific volume identifier. # Corresponds to the JSON property `identifier` # @return [String] attr_accessor :identifier # Identifier type. Possible values are ISBN_10, ISBN_13, ISSN and OTHER. # Corresponds to the JSON property `type` # @return [String] attr_accessor :type def initialize(**args) update!(**args) end # Update properties of this object def update!(**args) @identifier = args[:identifier] unless args[:identifier].nil? @type = args[:type] unless args[:type].nil? end end end end # class Volume2 include Google::Apis::Core::Hashable # A list of volumes. # Corresponds to the JSON property `items` # @return [Array] attr_accessor :items # Resource type. # Corresponds to the JSON property `kind` # @return [String] attr_accessor :kind # # Corresponds to the JSON property `nextPageToken` # @return [String] attr_accessor :next_page_token def initialize(**args) update!(**args) end # Update properties of this object def update!(**args) @items = args[:items] unless args[:items].nil? @kind = args[:kind] unless args[:kind].nil? @next_page_token = args[:next_page_token] unless args[:next_page_token].nil? end end # class VolumeAnnotation include Google::Apis::Core::Hashable # The annotation data id for this volume annotation. # Corresponds to the JSON property `annotationDataId` # @return [String] attr_accessor :annotation_data_id # Link to get data for this annotation. # Corresponds to the JSON property `annotationDataLink` # @return [String] attr_accessor :annotation_data_link # The type of annotation this is. # Corresponds to the JSON property `annotationType` # @return [String] attr_accessor :annotation_type # The content ranges to identify the selected text. # Corresponds to the JSON property `contentRanges` # @return [Google::Apis::BooksV1::VolumeAnnotation::ContentRanges] attr_accessor :content_ranges # Data for this annotation. # Corresponds to the JSON property `data` # @return [String] attr_accessor :data # Indicates that this annotation is deleted. # Corresponds to the JSON property `deleted` # @return [Boolean] attr_accessor :deleted alias_method :deleted?, :deleted # Unique id of this volume annotation. # Corresponds to the JSON property `id` # @return [String] attr_accessor :id # Resource Type # Corresponds to the JSON property `kind` # @return [String] attr_accessor :kind # The Layer this annotation is for. # Corresponds to the JSON property `layerId` # @return [String] attr_accessor :layer_id # Pages the annotation spans. # Corresponds to the JSON property `pageIds` # @return [Array] attr_accessor :page_ids # Excerpt from the volume. # Corresponds to the JSON property `selectedText` # @return [String] attr_accessor :selected_text # URL to this resource. # Corresponds to the JSON property `selfLink` # @return [String] attr_accessor :self_link # Timestamp for the last time this anntoation was updated. (RFC 3339 UTC date- # time format). # Corresponds to the JSON property `updated` # @return [DateTime] attr_accessor :updated # The Volume this annotation is for. # Corresponds to the JSON property `volumeId` # @return [String] attr_accessor :volume_id def initialize(**args) update!(**args) end # Update properties of this object def update!(**args) @annotation_data_id = args[:annotation_data_id] unless args[:annotation_data_id].nil? @annotation_data_link = args[:annotation_data_link] unless args[:annotation_data_link].nil? @annotation_type = args[:annotation_type] unless args[:annotation_type].nil? @content_ranges = args[:content_ranges] unless args[:content_ranges].nil? @data = args[:data] unless args[:data].nil? @deleted = args[:deleted] unless args[:deleted].nil? @id = args[:id] unless args[:id].nil? @kind = args[:kind] unless args[:kind].nil? @layer_id = args[:layer_id] unless args[:layer_id].nil? @page_ids = args[:page_ids] unless args[:page_ids].nil? @selected_text = args[:selected_text] unless args[:selected_text].nil? @self_link = args[:self_link] unless args[:self_link].nil? @updated = args[:updated] unless args[:updated].nil? @volume_id = args[:volume_id] unless args[:volume_id].nil? end # The content ranges to identify the selected text. class ContentRanges include Google::Apis::Core::Hashable # Range in CFI format for this annotation for version above. # Corresponds to the JSON property `cfiRange` # @return [Google::Apis::BooksV1::AnnotatinsRange] attr_accessor :cfi_range # Content version applicable to ranges below. # Corresponds to the JSON property `contentVersion` # @return [String] attr_accessor :content_version # Range in GB image format for this annotation for version above. # Corresponds to the JSON property `gbImageRange` # @return [Google::Apis::BooksV1::AnnotatinsRange] attr_accessor :gb_image_range # Range in GB text format for this annotation for version above. # Corresponds to the JSON property `gbTextRange` # @return [Google::Apis::BooksV1::AnnotatinsRange] attr_accessor :gb_text_range def initialize(**args) update!(**args) end # Update properties of this object def update!(**args) @cfi_range = args[:cfi_range] unless args[:cfi_range].nil? @content_version = args[:content_version] unless args[:content_version].nil? @gb_image_range = args[:gb_image_range] unless args[:gb_image_range].nil? @gb_text_range = args[:gb_text_range] unless args[:gb_text_range].nil? end end end # class Volumeannotations include Google::Apis::Core::Hashable # A list of volume annotations. # Corresponds to the JSON property `items` # @return [Array] attr_accessor :items # Resource type # Corresponds to the JSON property `kind` # @return [String] attr_accessor :kind # Token to pass in for pagination for the next page. This will not be present if # this request does not have more results. # Corresponds to the JSON property `nextPageToken` # @return [String] attr_accessor :next_page_token # The total number of volume annotations found. # Corresponds to the JSON property `totalItems` # @return [Fixnum] attr_accessor :total_items # 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). # Corresponds to the JSON property `version` # @return [String] attr_accessor :version def initialize(**args) update!(**args) end # Update properties of this object def update!(**args) @items = args[:items] unless args[:items].nil? @kind = args[:kind] unless args[:kind].nil? @next_page_token = args[:next_page_token] unless args[:next_page_token].nil? @total_items = args[:total_items] unless args[:total_items].nil? @version = args[:version] unless args[:version].nil? end end # class Volumes include Google::Apis::Core::Hashable # A list of volumes. # Corresponds to the JSON property `items` # @return [Array] attr_accessor :items # Resource type. # Corresponds to the JSON property `kind` # @return [String] attr_accessor :kind # Total number of volumes found. This might be greater than the number of # volumes returned in this response if results have been paginated. # Corresponds to the JSON property `totalItems` # @return [Fixnum] attr_accessor :total_items def initialize(**args) update!(**args) end # Update properties of this object def update!(**args) @items = args[:items] unless args[:items].nil? @kind = args[:kind] unless args[:kind].nil? @total_items = args[:total_items] unless args[:total_items].nil? end end end end end