2015-06-23 23:05:46 +00:00
|
|
|
# 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 DriveV2
|
|
|
|
|
|
|
|
# An item with user information and settings.
|
|
|
|
class About
|
|
|
|
include Google::Apis::Core::Hashable
|
|
|
|
|
|
|
|
# Information about supported additional roles per file type. The most specific
|
|
|
|
# type takes precedence.
|
|
|
|
# Corresponds to the JSON property `additionalRoleInfo`
|
|
|
|
# @return [Array<Google::Apis::DriveV2::About::AdditionalRoleInfo>]
|
|
|
|
attr_accessor :additional_role_info
|
|
|
|
|
|
|
|
# The domain sharing policy for the current user. Possible values are:
|
|
|
|
# - ALLOWED
|
|
|
|
# - ALLOWED_WITH_WARNING
|
|
|
|
# - INCOMING_ONLY
|
|
|
|
# - DISALLOWED
|
|
|
|
# Corresponds to the JSON property `domainSharingPolicy`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :domain_sharing_policy
|
|
|
|
|
|
|
|
# The ETag of the item.
|
|
|
|
# Corresponds to the JSON property `etag`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :etag
|
|
|
|
|
|
|
|
# The allowable export formats.
|
|
|
|
# Corresponds to the JSON property `exportFormats`
|
|
|
|
# @return [Array<Google::Apis::DriveV2::About::ExportFormat>]
|
|
|
|
attr_accessor :export_formats
|
|
|
|
|
|
|
|
# List of additional features enabled on this account.
|
|
|
|
# Corresponds to the JSON property `features`
|
|
|
|
# @return [Array<Google::Apis::DriveV2::About::Feature>]
|
|
|
|
attr_accessor :features
|
|
|
|
|
|
|
|
# The palette of allowable folder colors as RGB hex strings.
|
|
|
|
# Corresponds to the JSON property `folderColorPalette`
|
|
|
|
# @return [Array<String>]
|
|
|
|
attr_accessor :folder_color_palette
|
|
|
|
|
|
|
|
# The allowable import formats.
|
|
|
|
# Corresponds to the JSON property `importFormats`
|
|
|
|
# @return [Array<Google::Apis::DriveV2::About::ImportFormat>]
|
|
|
|
attr_accessor :import_formats
|
|
|
|
|
|
|
|
# A boolean indicating whether the authenticated app is installed by the
|
|
|
|
# authenticated user.
|
|
|
|
# Corresponds to the JSON property `isCurrentAppInstalled`
|
|
|
|
# @return [Boolean]
|
|
|
|
attr_accessor :is_current_app_installed
|
|
|
|
alias_method :is_current_app_installed?, :is_current_app_installed
|
|
|
|
|
|
|
|
# This is always drive#about.
|
|
|
|
# Corresponds to the JSON property `kind`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :kind
|
|
|
|
|
|
|
|
# The user's language or locale code, as defined by BCP 47, with some extensions
|
|
|
|
# from Unicode's LDML format (http://www.unicode.org/reports/tr35/).
|
|
|
|
# Corresponds to the JSON property `languageCode`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :language_code
|
|
|
|
|
|
|
|
# The largest change id.
|
|
|
|
# Corresponds to the JSON property `largestChangeId`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :largest_change_id
|
|
|
|
|
|
|
|
# List of max upload sizes for each file type. The most specific type takes
|
|
|
|
# precedence.
|
|
|
|
# Corresponds to the JSON property `maxUploadSizes`
|
|
|
|
# @return [Array<Google::Apis::DriveV2::About::MaxUploadSize>]
|
|
|
|
attr_accessor :max_upload_sizes
|
|
|
|
|
|
|
|
# The name of the current user.
|
|
|
|
# Corresponds to the JSON property `name`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :name
|
|
|
|
|
|
|
|
# The current user's ID as visible in the permissions collection.
|
|
|
|
# Corresponds to the JSON property `permissionId`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :permission_id
|
|
|
|
|
|
|
|
# The amount of storage quota used by different Google services.
|
|
|
|
# Corresponds to the JSON property `quotaBytesByService`
|
|
|
|
# @return [Array<Google::Apis::DriveV2::About::QuotaBytesByService>]
|
|
|
|
attr_accessor :quota_bytes_by_service
|
|
|
|
|
|
|
|
# The total number of quota bytes.
|
|
|
|
# Corresponds to the JSON property `quotaBytesTotal`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :quota_bytes_total
|
|
|
|
|
|
|
|
# The number of quota bytes used by Google Drive.
|
|
|
|
# Corresponds to the JSON property `quotaBytesUsed`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :quota_bytes_used
|
|
|
|
|
|
|
|
# The number of quota bytes used by all Google apps (Drive, Picasa, etc.).
|
|
|
|
# Corresponds to the JSON property `quotaBytesUsedAggregate`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :quota_bytes_used_aggregate
|
|
|
|
|
|
|
|
# The number of quota bytes used by trashed items.
|
|
|
|
# Corresponds to the JSON property `quotaBytesUsedInTrash`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :quota_bytes_used_in_trash
|
|
|
|
|
|
|
|
# The type of the user's storage quota. Possible values are:
|
|
|
|
# - LIMITED
|
|
|
|
# - UNLIMITED
|
|
|
|
# Corresponds to the JSON property `quotaType`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :quota_type
|
|
|
|
|
|
|
|
# The number of remaining change ids.
|
|
|
|
# Corresponds to the JSON property `remainingChangeIds`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :remaining_change_ids
|
|
|
|
|
|
|
|
# The id of the root folder.
|
|
|
|
# Corresponds to the JSON property `rootFolderId`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :root_folder_id
|
|
|
|
|
|
|
|
# A link back to this item.
|
|
|
|
# Corresponds to the JSON property `selfLink`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :self_link
|
|
|
|
|
|
|
|
# The JSON template for a user.
|
|
|
|
# Corresponds to the JSON property `user`
|
|
|
|
# @return [Google::Apis::DriveV2::User]
|
|
|
|
attr_accessor :user
|
|
|
|
|
|
|
|
def initialize(**args)
|
|
|
|
update!(**args)
|
|
|
|
end
|
|
|
|
|
|
|
|
# Update properties of this object
|
|
|
|
def update!(**args)
|
|
|
|
@additional_role_info = args[:additional_role_info] unless args[:additional_role_info].nil?
|
|
|
|
@domain_sharing_policy = args[:domain_sharing_policy] unless args[:domain_sharing_policy].nil?
|
|
|
|
@etag = args[:etag] unless args[:etag].nil?
|
|
|
|
@export_formats = args[:export_formats] unless args[:export_formats].nil?
|
|
|
|
@features = args[:features] unless args[:features].nil?
|
|
|
|
@folder_color_palette = args[:folder_color_palette] unless args[:folder_color_palette].nil?
|
|
|
|
@import_formats = args[:import_formats] unless args[:import_formats].nil?
|
|
|
|
@is_current_app_installed = args[:is_current_app_installed] unless args[:is_current_app_installed].nil?
|
|
|
|
@kind = args[:kind] unless args[:kind].nil?
|
|
|
|
@language_code = args[:language_code] unless args[:language_code].nil?
|
|
|
|
@largest_change_id = args[:largest_change_id] unless args[:largest_change_id].nil?
|
|
|
|
@max_upload_sizes = args[:max_upload_sizes] unless args[:max_upload_sizes].nil?
|
|
|
|
@name = args[:name] unless args[:name].nil?
|
|
|
|
@permission_id = args[:permission_id] unless args[:permission_id].nil?
|
|
|
|
@quota_bytes_by_service = args[:quota_bytes_by_service] unless args[:quota_bytes_by_service].nil?
|
|
|
|
@quota_bytes_total = args[:quota_bytes_total] unless args[:quota_bytes_total].nil?
|
|
|
|
@quota_bytes_used = args[:quota_bytes_used] unless args[:quota_bytes_used].nil?
|
|
|
|
@quota_bytes_used_aggregate = args[:quota_bytes_used_aggregate] unless args[:quota_bytes_used_aggregate].nil?
|
|
|
|
@quota_bytes_used_in_trash = args[:quota_bytes_used_in_trash] unless args[:quota_bytes_used_in_trash].nil?
|
|
|
|
@quota_type = args[:quota_type] unless args[:quota_type].nil?
|
|
|
|
@remaining_change_ids = args[:remaining_change_ids] unless args[:remaining_change_ids].nil?
|
|
|
|
@root_folder_id = args[:root_folder_id] unless args[:root_folder_id].nil?
|
|
|
|
@self_link = args[:self_link] unless args[:self_link].nil?
|
|
|
|
@user = args[:user] unless args[:user].nil?
|
|
|
|
end
|
|
|
|
|
|
|
|
#
|
|
|
|
class AdditionalRoleInfo
|
|
|
|
include Google::Apis::Core::Hashable
|
|
|
|
|
|
|
|
# The supported additional roles per primary role.
|
|
|
|
# Corresponds to the JSON property `roleSets`
|
|
|
|
# @return [Array<Google::Apis::DriveV2::About::AdditionalRoleInfo::RoleSet>]
|
|
|
|
attr_accessor :role_sets
|
|
|
|
|
|
|
|
# The content type that this additional role info applies to.
|
|
|
|
# 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)
|
|
|
|
@role_sets = args[:role_sets] unless args[:role_sets].nil?
|
|
|
|
@type = args[:type] unless args[:type].nil?
|
|
|
|
end
|
|
|
|
|
|
|
|
#
|
|
|
|
class RoleSet
|
|
|
|
include Google::Apis::Core::Hashable
|
|
|
|
|
|
|
|
# The supported additional roles with the primary role.
|
|
|
|
# Corresponds to the JSON property `additionalRoles`
|
|
|
|
# @return [Array<String>]
|
|
|
|
attr_accessor :additional_roles
|
|
|
|
|
|
|
|
# A primary permission role.
|
|
|
|
# Corresponds to the JSON property `primaryRole`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :primary_role
|
|
|
|
|
|
|
|
def initialize(**args)
|
|
|
|
update!(**args)
|
|
|
|
end
|
|
|
|
|
|
|
|
# Update properties of this object
|
|
|
|
def update!(**args)
|
|
|
|
@additional_roles = args[:additional_roles] unless args[:additional_roles].nil?
|
|
|
|
@primary_role = args[:primary_role] unless args[:primary_role].nil?
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
#
|
|
|
|
class ExportFormat
|
|
|
|
include Google::Apis::Core::Hashable
|
|
|
|
|
|
|
|
# The content type to convert from.
|
|
|
|
# Corresponds to the JSON property `source`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :source
|
|
|
|
|
|
|
|
# The possible content types to convert to.
|
|
|
|
# Corresponds to the JSON property `targets`
|
|
|
|
# @return [Array<String>]
|
|
|
|
attr_accessor :targets
|
|
|
|
|
|
|
|
def initialize(**args)
|
|
|
|
update!(**args)
|
|
|
|
end
|
|
|
|
|
|
|
|
# Update properties of this object
|
|
|
|
def update!(**args)
|
|
|
|
@source = args[:source] unless args[:source].nil?
|
|
|
|
@targets = args[:targets] unless args[:targets].nil?
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
#
|
|
|
|
class Feature
|
|
|
|
include Google::Apis::Core::Hashable
|
|
|
|
|
|
|
|
# The name of the feature.
|
|
|
|
# Corresponds to the JSON property `featureName`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :feature_name
|
|
|
|
|
|
|
|
# The request limit rate for this feature, in queries per second.
|
|
|
|
# Corresponds to the JSON property `featureRate`
|
|
|
|
# @return [Float]
|
|
|
|
attr_accessor :feature_rate
|
|
|
|
|
|
|
|
def initialize(**args)
|
|
|
|
update!(**args)
|
|
|
|
end
|
|
|
|
|
|
|
|
# Update properties of this object
|
|
|
|
def update!(**args)
|
|
|
|
@feature_name = args[:feature_name] unless args[:feature_name].nil?
|
|
|
|
@feature_rate = args[:feature_rate] unless args[:feature_rate].nil?
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
#
|
|
|
|
class ImportFormat
|
|
|
|
include Google::Apis::Core::Hashable
|
|
|
|
|
|
|
|
# The imported file's content type to convert from.
|
|
|
|
# Corresponds to the JSON property `source`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :source
|
|
|
|
|
|
|
|
# The possible content types to convert to.
|
|
|
|
# Corresponds to the JSON property `targets`
|
|
|
|
# @return [Array<String>]
|
|
|
|
attr_accessor :targets
|
|
|
|
|
|
|
|
def initialize(**args)
|
|
|
|
update!(**args)
|
|
|
|
end
|
|
|
|
|
|
|
|
# Update properties of this object
|
|
|
|
def update!(**args)
|
|
|
|
@source = args[:source] unless args[:source].nil?
|
|
|
|
@targets = args[:targets] unless args[:targets].nil?
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
#
|
|
|
|
class MaxUploadSize
|
|
|
|
include Google::Apis::Core::Hashable
|
|
|
|
|
|
|
|
# The max upload size for this type.
|
|
|
|
# Corresponds to the JSON property `size`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :size
|
|
|
|
|
|
|
|
# The file type.
|
|
|
|
# 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)
|
|
|
|
@size = args[:size] unless args[:size].nil?
|
|
|
|
@type = args[:type] unless args[:type].nil?
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
#
|
|
|
|
class QuotaBytesByService
|
|
|
|
include Google::Apis::Core::Hashable
|
|
|
|
|
|
|
|
# The storage quota bytes used by the service.
|
|
|
|
# Corresponds to the JSON property `bytesUsed`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :bytes_used
|
|
|
|
|
|
|
|
# The service's name, e.g. DRIVE, GMAIL, or PHOTOS.
|
|
|
|
# Corresponds to the JSON property `serviceName`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :service_name
|
|
|
|
|
|
|
|
def initialize(**args)
|
|
|
|
update!(**args)
|
|
|
|
end
|
|
|
|
|
|
|
|
# Update properties of this object
|
|
|
|
def update!(**args)
|
|
|
|
@bytes_used = args[:bytes_used] unless args[:bytes_used].nil?
|
|
|
|
@service_name = args[:service_name] unless args[:service_name].nil?
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
# The apps resource provides a list of the apps that a user has installed, with
|
|
|
|
# information about each app's supported MIME types, file extensions, and other
|
|
|
|
# details.
|
|
|
|
class App
|
|
|
|
include Google::Apis::Core::Hashable
|
|
|
|
|
|
|
|
# Whether the app is authorized to access data on the user's Drive.
|
|
|
|
# Corresponds to the JSON property `authorized`
|
|
|
|
# @return [Boolean]
|
|
|
|
attr_accessor :authorized
|
|
|
|
alias_method :authorized?, :authorized
|
|
|
|
|
|
|
|
# The template url to create a new file with this app in a given folder. The
|
|
|
|
# template will contain `folderId` to be replaced by the folder to create the
|
|
|
|
# new file in.
|
|
|
|
# Corresponds to the JSON property `createInFolderTemplate`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :create_in_folder_template
|
|
|
|
|
|
|
|
# The url to create a new file with this app.
|
|
|
|
# Corresponds to the JSON property `createUrl`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :create_url
|
|
|
|
|
|
|
|
# Whether the app has drive-wide scope. An app with drive-wide scope can access
|
|
|
|
# all files in the user's drive.
|
|
|
|
# Corresponds to the JSON property `hasDriveWideScope`
|
|
|
|
# @return [Boolean]
|
|
|
|
attr_accessor :has_drive_wide_scope
|
|
|
|
alias_method :has_drive_wide_scope?, :has_drive_wide_scope
|
|
|
|
|
|
|
|
# The various icons for the app.
|
|
|
|
# Corresponds to the JSON property `icons`
|
|
|
|
# @return [Array<Google::Apis::DriveV2::App::Icon>]
|
|
|
|
attr_accessor :icons
|
|
|
|
|
|
|
|
# The ID of the app.
|
|
|
|
# Corresponds to the JSON property `id`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :id
|
|
|
|
|
|
|
|
# Whether the app is installed.
|
|
|
|
# Corresponds to the JSON property `installed`
|
|
|
|
# @return [Boolean]
|
|
|
|
attr_accessor :installed
|
|
|
|
alias_method :installed?, :installed
|
|
|
|
|
|
|
|
# This is always drive#app.
|
|
|
|
# Corresponds to the JSON property `kind`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :kind
|
|
|
|
|
|
|
|
# A long description of the app.
|
|
|
|
# Corresponds to the JSON property `longDescription`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :long_description
|
|
|
|
|
|
|
|
# The name of the app.
|
|
|
|
# Corresponds to the JSON property `name`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :name
|
|
|
|
|
|
|
|
# The type of object this app creates (e.g. Chart). If empty, the app name
|
|
|
|
# should be used instead.
|
|
|
|
# Corresponds to the JSON property `objectType`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :object_type
|
|
|
|
|
|
|
|
# The template url for opening files with this app. The template will contain `
|
|
|
|
# ids` and/or `exportIds` to be replaced by the actual file ids. See Open Files
|
|
|
|
# for the full documentation.
|
|
|
|
# Corresponds to the JSON property `openUrlTemplate`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :open_url_template
|
|
|
|
|
|
|
|
# The list of primary file extensions.
|
|
|
|
# Corresponds to the JSON property `primaryFileExtensions`
|
|
|
|
# @return [Array<String>]
|
|
|
|
attr_accessor :primary_file_extensions
|
|
|
|
|
|
|
|
# The list of primary mime types.
|
|
|
|
# Corresponds to the JSON property `primaryMimeTypes`
|
|
|
|
# @return [Array<String>]
|
|
|
|
attr_accessor :primary_mime_types
|
|
|
|
|
|
|
|
# The ID of the product listing for this app.
|
|
|
|
# Corresponds to the JSON property `productId`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :product_id
|
|
|
|
|
|
|
|
# A link to the product listing for this app.
|
|
|
|
# Corresponds to the JSON property `productUrl`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :product_url
|
|
|
|
|
|
|
|
# The list of secondary file extensions.
|
|
|
|
# Corresponds to the JSON property `secondaryFileExtensions`
|
|
|
|
# @return [Array<String>]
|
|
|
|
attr_accessor :secondary_file_extensions
|
|
|
|
|
|
|
|
# The list of secondary mime types.
|
|
|
|
# Corresponds to the JSON property `secondaryMimeTypes`
|
|
|
|
# @return [Array<String>]
|
|
|
|
attr_accessor :secondary_mime_types
|
|
|
|
|
|
|
|
# A short description of the app.
|
|
|
|
# Corresponds to the JSON property `shortDescription`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :short_description
|
|
|
|
|
|
|
|
# Whether this app supports creating new objects.
|
|
|
|
# Corresponds to the JSON property `supportsCreate`
|
|
|
|
# @return [Boolean]
|
|
|
|
attr_accessor :supports_create
|
|
|
|
alias_method :supports_create?, :supports_create
|
|
|
|
|
|
|
|
# Whether this app supports importing Google Docs.
|
|
|
|
# Corresponds to the JSON property `supportsImport`
|
|
|
|
# @return [Boolean]
|
|
|
|
attr_accessor :supports_import
|
|
|
|
alias_method :supports_import?, :supports_import
|
|
|
|
|
|
|
|
# Whether this app supports opening more than one file.
|
|
|
|
# Corresponds to the JSON property `supportsMultiOpen`
|
|
|
|
# @return [Boolean]
|
|
|
|
attr_accessor :supports_multi_open
|
|
|
|
alias_method :supports_multi_open?, :supports_multi_open
|
|
|
|
|
|
|
|
# Whether this app supports creating new files when offline.
|
|
|
|
# Corresponds to the JSON property `supportsOfflineCreate`
|
|
|
|
# @return [Boolean]
|
|
|
|
attr_accessor :supports_offline_create
|
|
|
|
alias_method :supports_offline_create?, :supports_offline_create
|
|
|
|
|
|
|
|
# Whether the app is selected as the default handler for the types it supports.
|
|
|
|
# Corresponds to the JSON property `useByDefault`
|
|
|
|
# @return [Boolean]
|
|
|
|
attr_accessor :use_by_default
|
|
|
|
alias_method :use_by_default?, :use_by_default
|
|
|
|
|
|
|
|
def initialize(**args)
|
|
|
|
update!(**args)
|
|
|
|
end
|
|
|
|
|
|
|
|
# Update properties of this object
|
|
|
|
def update!(**args)
|
|
|
|
@authorized = args[:authorized] unless args[:authorized].nil?
|
|
|
|
@create_in_folder_template = args[:create_in_folder_template] unless args[:create_in_folder_template].nil?
|
|
|
|
@create_url = args[:create_url] unless args[:create_url].nil?
|
|
|
|
@has_drive_wide_scope = args[:has_drive_wide_scope] unless args[:has_drive_wide_scope].nil?
|
|
|
|
@icons = args[:icons] unless args[:icons].nil?
|
|
|
|
@id = args[:id] unless args[:id].nil?
|
|
|
|
@installed = args[:installed] unless args[:installed].nil?
|
|
|
|
@kind = args[:kind] unless args[:kind].nil?
|
|
|
|
@long_description = args[:long_description] unless args[:long_description].nil?
|
|
|
|
@name = args[:name] unless args[:name].nil?
|
|
|
|
@object_type = args[:object_type] unless args[:object_type].nil?
|
|
|
|
@open_url_template = args[:open_url_template] unless args[:open_url_template].nil?
|
|
|
|
@primary_file_extensions = args[:primary_file_extensions] unless args[:primary_file_extensions].nil?
|
|
|
|
@primary_mime_types = args[:primary_mime_types] unless args[:primary_mime_types].nil?
|
|
|
|
@product_id = args[:product_id] unless args[:product_id].nil?
|
|
|
|
@product_url = args[:product_url] unless args[:product_url].nil?
|
|
|
|
@secondary_file_extensions = args[:secondary_file_extensions] unless args[:secondary_file_extensions].nil?
|
|
|
|
@secondary_mime_types = args[:secondary_mime_types] unless args[:secondary_mime_types].nil?
|
|
|
|
@short_description = args[:short_description] unless args[:short_description].nil?
|
|
|
|
@supports_create = args[:supports_create] unless args[:supports_create].nil?
|
|
|
|
@supports_import = args[:supports_import] unless args[:supports_import].nil?
|
|
|
|
@supports_multi_open = args[:supports_multi_open] unless args[:supports_multi_open].nil?
|
|
|
|
@supports_offline_create = args[:supports_offline_create] unless args[:supports_offline_create].nil?
|
|
|
|
@use_by_default = args[:use_by_default] unless args[:use_by_default].nil?
|
|
|
|
end
|
|
|
|
|
|
|
|
#
|
|
|
|
class Icon
|
|
|
|
include Google::Apis::Core::Hashable
|
|
|
|
|
|
|
|
# Category of the icon. Allowed values are:
|
|
|
|
# - application - icon for the application
|
|
|
|
# - document - icon for a file associated with the app
|
|
|
|
# - documentShared - icon for a shared file associated with the app
|
|
|
|
# Corresponds to the JSON property `category`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :category
|
|
|
|
|
|
|
|
# URL for the icon.
|
|
|
|
# Corresponds to the JSON property `iconUrl`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :icon_url
|
|
|
|
|
|
|
|
# Size of the icon. Represented as the maximum of the width and height.
|
|
|
|
# Corresponds to the JSON property `size`
|
|
|
|
# @return [Fixnum]
|
|
|
|
attr_accessor :size
|
|
|
|
|
|
|
|
def initialize(**args)
|
|
|
|
update!(**args)
|
|
|
|
end
|
|
|
|
|
|
|
|
# Update properties of this object
|
|
|
|
def update!(**args)
|
|
|
|
@category = args[:category] unless args[:category].nil?
|
|
|
|
@icon_url = args[:icon_url] unless args[:icon_url].nil?
|
|
|
|
@size = args[:size] unless args[:size].nil?
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
# A list of third-party applications which the user has installed or given
|
|
|
|
# access to Google Drive.
|
|
|
|
class AppList
|
|
|
|
include Google::Apis::Core::Hashable
|
|
|
|
|
|
|
|
# List of app IDs that the user has specified to use by default. The list is in
|
|
|
|
# reverse-priority order (lowest to highest).
|
|
|
|
# Corresponds to the JSON property `defaultAppIds`
|
|
|
|
# @return [Array<String>]
|
|
|
|
attr_accessor :default_app_ids
|
|
|
|
|
|
|
|
# The ETag of the list.
|
|
|
|
# Corresponds to the JSON property `etag`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :etag
|
|
|
|
|
|
|
|
# The actual list of apps.
|
|
|
|
# Corresponds to the JSON property `items`
|
|
|
|
# @return [Array<Google::Apis::DriveV2::App>]
|
|
|
|
attr_accessor :items
|
|
|
|
|
|
|
|
# This is always drive#appList.
|
|
|
|
# Corresponds to the JSON property `kind`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :kind
|
|
|
|
|
|
|
|
# A link back to this list.
|
|
|
|
# Corresponds to the JSON property `selfLink`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :self_link
|
|
|
|
|
|
|
|
def initialize(**args)
|
|
|
|
update!(**args)
|
|
|
|
end
|
|
|
|
|
|
|
|
# Update properties of this object
|
|
|
|
def update!(**args)
|
|
|
|
@default_app_ids = args[:default_app_ids] unless args[:default_app_ids].nil?
|
|
|
|
@etag = args[:etag] unless args[:etag].nil?
|
|
|
|
@items = args[:items] unless args[:items].nil?
|
|
|
|
@kind = args[:kind] unless args[:kind].nil?
|
|
|
|
@self_link = args[:self_link] unless args[:self_link].nil?
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
# Representation of a change to a file.
|
|
|
|
class Change
|
|
|
|
include Google::Apis::Core::Hashable
|
|
|
|
|
|
|
|
# Whether the file has been deleted.
|
|
|
|
# Corresponds to the JSON property `deleted`
|
|
|
|
# @return [Boolean]
|
|
|
|
attr_accessor :deleted
|
|
|
|
alias_method :deleted?, :deleted
|
|
|
|
|
|
|
|
# The metadata for a file.
|
|
|
|
# Corresponds to the JSON property `file`
|
|
|
|
# @return [Google::Apis::DriveV2::File]
|
|
|
|
attr_accessor :file
|
|
|
|
|
|
|
|
# The ID of the file associated with this change.
|
|
|
|
# Corresponds to the JSON property `fileId`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :file_id
|
|
|
|
|
|
|
|
# The ID of the change.
|
|
|
|
# Corresponds to the JSON property `id`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :id
|
|
|
|
|
|
|
|
# This is always drive#change.
|
|
|
|
# Corresponds to the JSON property `kind`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :kind
|
|
|
|
|
|
|
|
# The time of this modification.
|
|
|
|
# Corresponds to the JSON property `modificationDate`
|
|
|
|
# @return [DateTime]
|
|
|
|
attr_accessor :modification_date
|
|
|
|
|
|
|
|
# A link back to this change.
|
|
|
|
# Corresponds to the JSON property `selfLink`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :self_link
|
|
|
|
|
|
|
|
def initialize(**args)
|
|
|
|
update!(**args)
|
|
|
|
end
|
|
|
|
|
|
|
|
# Update properties of this object
|
|
|
|
def update!(**args)
|
|
|
|
@deleted = args[:deleted] unless args[:deleted].nil?
|
|
|
|
@file = args[:file] unless args[:file].nil?
|
|
|
|
@file_id = args[:file_id] unless args[:file_id].nil?
|
|
|
|
@id = args[:id] unless args[:id].nil?
|
|
|
|
@kind = args[:kind] unless args[:kind].nil?
|
|
|
|
@modification_date = args[:modification_date] unless args[:modification_date].nil?
|
|
|
|
@self_link = args[:self_link] unless args[:self_link].nil?
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
# A list of changes for a user.
|
|
|
|
class ChangeList
|
|
|
|
include Google::Apis::Core::Hashable
|
|
|
|
|
|
|
|
# The ETag of the list.
|
|
|
|
# Corresponds to the JSON property `etag`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :etag
|
|
|
|
|
|
|
|
# The actual list of changes.
|
|
|
|
# Corresponds to the JSON property `items`
|
|
|
|
# @return [Array<Google::Apis::DriveV2::Change>]
|
|
|
|
attr_accessor :items
|
|
|
|
|
|
|
|
# This is always drive#changeList.
|
|
|
|
# Corresponds to the JSON property `kind`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :kind
|
|
|
|
|
|
|
|
# The current largest change ID.
|
|
|
|
# Corresponds to the JSON property `largestChangeId`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :largest_change_id
|
|
|
|
|
|
|
|
# A link to the next page of changes.
|
|
|
|
# Corresponds to the JSON property `nextLink`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :next_link
|
|
|
|
|
|
|
|
# The page token for the next page of changes.
|
|
|
|
# Corresponds to the JSON property `nextPageToken`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :next_page_token
|
|
|
|
|
|
|
|
# A link back to this list.
|
|
|
|
# Corresponds to the JSON property `selfLink`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :self_link
|
|
|
|
|
|
|
|
def initialize(**args)
|
|
|
|
update!(**args)
|
|
|
|
end
|
|
|
|
|
|
|
|
# Update properties of this object
|
|
|
|
def update!(**args)
|
|
|
|
@etag = args[:etag] unless args[:etag].nil?
|
|
|
|
@items = args[:items] unless args[:items].nil?
|
|
|
|
@kind = args[:kind] unless args[:kind].nil?
|
|
|
|
@largest_change_id = args[:largest_change_id] unless args[:largest_change_id].nil?
|
|
|
|
@next_link = args[:next_link] unless args[:next_link].nil?
|
|
|
|
@next_page_token = args[:next_page_token] unless args[:next_page_token].nil?
|
|
|
|
@self_link = args[:self_link] unless args[:self_link].nil?
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
# An notification channel used to watch for resource changes.
|
|
|
|
class Channel
|
|
|
|
include Google::Apis::Core::Hashable
|
|
|
|
|
|
|
|
# The address where notifications are delivered for this channel.
|
|
|
|
# Corresponds to the JSON property `address`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :address
|
|
|
|
|
|
|
|
# Date and time of notification channel expiration, expressed as a Unix
|
|
|
|
# timestamp, in milliseconds. Optional.
|
|
|
|
# Corresponds to the JSON property `expiration`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :expiration
|
|
|
|
|
|
|
|
# A UUID or similar unique string that identifies this channel.
|
|
|
|
# Corresponds to the JSON property `id`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :id
|
|
|
|
|
|
|
|
# Identifies this as a notification channel used to watch for changes to a
|
|
|
|
# resource. Value: the fixed string "api#channel".
|
|
|
|
# Corresponds to the JSON property `kind`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :kind
|
|
|
|
|
|
|
|
# Additional parameters controlling delivery channel behavior. Optional.
|
|
|
|
# Corresponds to the JSON property `params`
|
|
|
|
# @return [Hash<String,String>]
|
|
|
|
attr_accessor :params
|
|
|
|
|
|
|
|
# A Boolean value to indicate whether payload is wanted. Optional.
|
|
|
|
# Corresponds to the JSON property `payload`
|
|
|
|
# @return [Boolean]
|
|
|
|
attr_accessor :payload
|
|
|
|
alias_method :payload?, :payload
|
|
|
|
|
|
|
|
# An opaque ID that identifies the resource being watched on this channel.
|
|
|
|
# Stable across different API versions.
|
|
|
|
# Corresponds to the JSON property `resourceId`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :resource_id
|
|
|
|
|
|
|
|
# A version-specific identifier for the watched resource.
|
|
|
|
# Corresponds to the JSON property `resourceUri`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :resource_uri
|
|
|
|
|
|
|
|
# An arbitrary string delivered to the target address with each notification
|
|
|
|
# delivered over this channel. Optional.
|
|
|
|
# Corresponds to the JSON property `token`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :token
|
|
|
|
|
|
|
|
# The type of delivery mechanism used for this channel.
|
|
|
|
# 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)
|
|
|
|
@address = args[:address] unless args[:address].nil?
|
|
|
|
@expiration = args[:expiration] unless args[:expiration].nil?
|
|
|
|
@id = args[:id] unless args[:id].nil?
|
|
|
|
@kind = args[:kind] unless args[:kind].nil?
|
|
|
|
@params = args[:params] unless args[:params].nil?
|
|
|
|
@payload = args[:payload] unless args[:payload].nil?
|
|
|
|
@resource_id = args[:resource_id] unless args[:resource_id].nil?
|
|
|
|
@resource_uri = args[:resource_uri] unless args[:resource_uri].nil?
|
|
|
|
@token = args[:token] unless args[:token].nil?
|
|
|
|
@type = args[:type] unless args[:type].nil?
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
# A list of children of a file.
|
|
|
|
class ChildList
|
|
|
|
include Google::Apis::Core::Hashable
|
|
|
|
|
|
|
|
# The ETag of the list.
|
|
|
|
# Corresponds to the JSON property `etag`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :etag
|
|
|
|
|
|
|
|
# The actual list of children.
|
|
|
|
# Corresponds to the JSON property `items`
|
|
|
|
# @return [Array<Google::Apis::DriveV2::ChildReference>]
|
|
|
|
attr_accessor :items
|
|
|
|
|
|
|
|
# This is always drive#childList.
|
|
|
|
# Corresponds to the JSON property `kind`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :kind
|
|
|
|
|
|
|
|
# A link to the next page of children.
|
|
|
|
# Corresponds to the JSON property `nextLink`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :next_link
|
|
|
|
|
|
|
|
# The page token for the next page of children.
|
|
|
|
# Corresponds to the JSON property `nextPageToken`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :next_page_token
|
|
|
|
|
|
|
|
# A link back to this list.
|
|
|
|
# Corresponds to the JSON property `selfLink`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :self_link
|
|
|
|
|
|
|
|
def initialize(**args)
|
|
|
|
update!(**args)
|
|
|
|
end
|
|
|
|
|
|
|
|
# Update properties of this object
|
|
|
|
def update!(**args)
|
|
|
|
@etag = args[:etag] unless args[:etag].nil?
|
|
|
|
@items = args[:items] unless args[:items].nil?
|
|
|
|
@kind = args[:kind] unless args[:kind].nil?
|
|
|
|
@next_link = args[:next_link] unless args[:next_link].nil?
|
|
|
|
@next_page_token = args[:next_page_token] unless args[:next_page_token].nil?
|
|
|
|
@self_link = args[:self_link] unless args[:self_link].nil?
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
# A reference to a folder's child.
|
|
|
|
class ChildReference
|
|
|
|
include Google::Apis::Core::Hashable
|
|
|
|
|
|
|
|
# A link to the child.
|
|
|
|
# Corresponds to the JSON property `childLink`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :child_link
|
|
|
|
|
|
|
|
# The ID of the child.
|
|
|
|
# Corresponds to the JSON property `id`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :id
|
|
|
|
|
|
|
|
# This is always drive#childReference.
|
|
|
|
# Corresponds to the JSON property `kind`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :kind
|
|
|
|
|
|
|
|
# A link back to this reference.
|
|
|
|
# Corresponds to the JSON property `selfLink`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :self_link
|
|
|
|
|
|
|
|
def initialize(**args)
|
|
|
|
update!(**args)
|
|
|
|
end
|
|
|
|
|
|
|
|
# Update properties of this object
|
|
|
|
def update!(**args)
|
|
|
|
@child_link = args[:child_link] unless args[:child_link].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?
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
# A JSON representation of a comment on a file in Google Drive.
|
|
|
|
class Comment
|
|
|
|
include Google::Apis::Core::Hashable
|
|
|
|
|
|
|
|
# A region of the document represented as a JSON string. See anchor
|
|
|
|
# documentation for details on how to define and interpret anchor properties.
|
|
|
|
# Corresponds to the JSON property `anchor`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :anchor
|
|
|
|
|
|
|
|
# The JSON template for a user.
|
|
|
|
# Corresponds to the JSON property `author`
|
|
|
|
# @return [Google::Apis::DriveV2::User]
|
|
|
|
attr_accessor :author
|
|
|
|
|
|
|
|
# The ID of the comment.
|
|
|
|
# Corresponds to the JSON property `commentId`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :comment_id
|
|
|
|
|
|
|
|
# The plain text content used to create this comment. This is not HTML safe and
|
|
|
|
# should only be used as a starting point to make edits to a comment's content.
|
|
|
|
# Corresponds to the JSON property `content`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :content
|
|
|
|
|
|
|
|
# The context of the file which is being commented on.
|
|
|
|
# Corresponds to the JSON property `context`
|
|
|
|
# @return [Google::Apis::DriveV2::Comment::Context]
|
|
|
|
attr_accessor :context
|
|
|
|
|
|
|
|
# The date when this comment was first created.
|
|
|
|
# Corresponds to the JSON property `createdDate`
|
|
|
|
# @return [DateTime]
|
|
|
|
attr_accessor :created_date
|
|
|
|
|
|
|
|
# Whether this comment has been deleted. If a comment has been deleted the
|
|
|
|
# content will be cleared and this will only represent a comment that once
|
|
|
|
# existed.
|
|
|
|
# Corresponds to the JSON property `deleted`
|
|
|
|
# @return [Boolean]
|
|
|
|
attr_accessor :deleted
|
|
|
|
alias_method :deleted?, :deleted
|
|
|
|
|
|
|
|
# The file which this comment is addressing.
|
|
|
|
# Corresponds to the JSON property `fileId`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :file_id
|
|
|
|
|
|
|
|
# The title of the file which this comment is addressing.
|
|
|
|
# Corresponds to the JSON property `fileTitle`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :file_title
|
|
|
|
|
|
|
|
# HTML formatted content for this comment.
|
|
|
|
# Corresponds to the JSON property `htmlContent`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :html_content
|
|
|
|
|
|
|
|
# This is always drive#comment.
|
|
|
|
# Corresponds to the JSON property `kind`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :kind
|
|
|
|
|
|
|
|
# The date when this comment or any of its replies were last modified.
|
|
|
|
# Corresponds to the JSON property `modifiedDate`
|
|
|
|
# @return [DateTime]
|
|
|
|
attr_accessor :modified_date
|
|
|
|
|
|
|
|
# Replies to this post.
|
|
|
|
# Corresponds to the JSON property `replies`
|
|
|
|
# @return [Array<Google::Apis::DriveV2::CommentReply>]
|
|
|
|
attr_accessor :replies
|
|
|
|
|
|
|
|
# A link back to this comment.
|
|
|
|
# Corresponds to the JSON property `selfLink`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :self_link
|
|
|
|
|
|
|
|
# The status of this comment. Status can be changed by posting a reply to a
|
|
|
|
# comment with the desired status.
|
|
|
|
# - "open" - The comment is still open.
|
|
|
|
# - "resolved" - The comment has been resolved by one of its replies.
|
|
|
|
# Corresponds to the JSON property `status`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :status
|
|
|
|
|
|
|
|
def initialize(**args)
|
|
|
|
update!(**args)
|
|
|
|
end
|
|
|
|
|
|
|
|
# Update properties of this object
|
|
|
|
def update!(**args)
|
|
|
|
@anchor = args[:anchor] unless args[:anchor].nil?
|
|
|
|
@author = args[:author] unless args[:author].nil?
|
|
|
|
@comment_id = args[:comment_id] unless args[:comment_id].nil?
|
|
|
|
@content = args[:content] unless args[:content].nil?
|
|
|
|
@context = args[:context] unless args[:context].nil?
|
|
|
|
@created_date = args[:created_date] unless args[:created_date].nil?
|
|
|
|
@deleted = args[:deleted] unless args[:deleted].nil?
|
|
|
|
@file_id = args[:file_id] unless args[:file_id].nil?
|
|
|
|
@file_title = args[:file_title] unless args[:file_title].nil?
|
|
|
|
@html_content = args[:html_content] unless args[:html_content].nil?
|
|
|
|
@kind = args[:kind] unless args[:kind].nil?
|
|
|
|
@modified_date = args[:modified_date] unless args[:modified_date].nil?
|
|
|
|
@replies = args[:replies] unless args[:replies].nil?
|
|
|
|
@self_link = args[:self_link] unless args[:self_link].nil?
|
|
|
|
@status = args[:status] unless args[:status].nil?
|
|
|
|
end
|
|
|
|
|
|
|
|
# The context of the file which is being commented on.
|
|
|
|
class Context
|
|
|
|
include Google::Apis::Core::Hashable
|
|
|
|
|
|
|
|
# The MIME type of the context snippet.
|
|
|
|
# Corresponds to the JSON property `type`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :type
|
|
|
|
|
|
|
|
# Data representation of the segment of the file being commented on. In the case
|
|
|
|
# of a text file for example, this would be the actual text that the comment is
|
|
|
|
# about.
|
|
|
|
# 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
|
|
|
|
end
|
|
|
|
|
|
|
|
# A JSON representation of a list of comments on a file in Google Drive.
|
|
|
|
class CommentList
|
|
|
|
include Google::Apis::Core::Hashable
|
|
|
|
|
|
|
|
# List of comments.
|
|
|
|
# Corresponds to the JSON property `items`
|
|
|
|
# @return [Array<Google::Apis::DriveV2::Comment>]
|
|
|
|
attr_accessor :items
|
|
|
|
|
|
|
|
# This is always drive#commentList.
|
|
|
|
# Corresponds to the JSON property `kind`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :kind
|
|
|
|
|
|
|
|
# A link to the next page of comments.
|
|
|
|
# Corresponds to the JSON property `nextLink`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :next_link
|
|
|
|
|
|
|
|
# The token to use to request the next page of results.
|
|
|
|
# Corresponds to the JSON property `nextPageToken`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :next_page_token
|
|
|
|
|
|
|
|
# A link back to this list.
|
|
|
|
# Corresponds to the JSON property `selfLink`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :self_link
|
|
|
|
|
|
|
|
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_link = args[:next_link] unless args[:next_link].nil?
|
|
|
|
@next_page_token = args[:next_page_token] unless args[:next_page_token].nil?
|
|
|
|
@self_link = args[:self_link] unless args[:self_link].nil?
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
# A JSON representation of a reply to a comment on a file in Google Drive.
|
|
|
|
class CommentReply
|
|
|
|
include Google::Apis::Core::Hashable
|
|
|
|
|
|
|
|
# The JSON template for a user.
|
|
|
|
# Corresponds to the JSON property `author`
|
|
|
|
# @return [Google::Apis::DriveV2::User]
|
|
|
|
attr_accessor :author
|
|
|
|
|
|
|
|
# The plain text content used to create this reply. This is not HTML safe and
|
|
|
|
# should only be used as a starting point to make edits to a reply's content.
|
|
|
|
# This field is required on inserts if no verb is specified (resolve/reopen).
|
|
|
|
# Corresponds to the JSON property `content`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :content
|
|
|
|
|
|
|
|
# The date when this reply was first created.
|
|
|
|
# Corresponds to the JSON property `createdDate`
|
|
|
|
# @return [DateTime]
|
|
|
|
attr_accessor :created_date
|
|
|
|
|
|
|
|
# Whether this reply has been deleted. If a reply has been deleted the content
|
|
|
|
# will be cleared and this will only represent a reply that once existed.
|
|
|
|
# Corresponds to the JSON property `deleted`
|
|
|
|
# @return [Boolean]
|
|
|
|
attr_accessor :deleted
|
|
|
|
alias_method :deleted?, :deleted
|
|
|
|
|
|
|
|
# HTML formatted content for this reply.
|
|
|
|
# Corresponds to the JSON property `htmlContent`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :html_content
|
|
|
|
|
|
|
|
# This is always drive#commentReply.
|
|
|
|
# Corresponds to the JSON property `kind`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :kind
|
|
|
|
|
|
|
|
# The date when this reply was last modified.
|
|
|
|
# Corresponds to the JSON property `modifiedDate`
|
|
|
|
# @return [DateTime]
|
|
|
|
attr_accessor :modified_date
|
|
|
|
|
|
|
|
# The ID of the reply.
|
|
|
|
# Corresponds to the JSON property `replyId`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :reply_id
|
|
|
|
|
|
|
|
# The action this reply performed to the parent comment. When creating a new
|
|
|
|
# reply this is the action to be perform to the parent comment. Possible values
|
|
|
|
# are:
|
|
|
|
# - "resolve" - To resolve a comment.
|
|
|
|
# - "reopen" - To reopen (un-resolve) a comment.
|
|
|
|
# Corresponds to the JSON property `verb`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :verb
|
|
|
|
|
|
|
|
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?
|
|
|
|
@created_date = args[:created_date] unless args[:created_date].nil?
|
|
|
|
@deleted = args[:deleted] unless args[:deleted].nil?
|
|
|
|
@html_content = args[:html_content] unless args[:html_content].nil?
|
|
|
|
@kind = args[:kind] unless args[:kind].nil?
|
|
|
|
@modified_date = args[:modified_date] unless args[:modified_date].nil?
|
|
|
|
@reply_id = args[:reply_id] unless args[:reply_id].nil?
|
|
|
|
@verb = args[:verb] unless args[:verb].nil?
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
# A JSON representation of a list of replies to a comment on a file in Google
|
|
|
|
# Drive.
|
|
|
|
class CommentReplyList
|
|
|
|
include Google::Apis::Core::Hashable
|
|
|
|
|
|
|
|
# List of reply.
|
|
|
|
# Corresponds to the JSON property `items`
|
|
|
|
# @return [Array<Google::Apis::DriveV2::CommentReply>]
|
|
|
|
attr_accessor :items
|
|
|
|
|
|
|
|
# This is always drive#commentReplyList.
|
|
|
|
# Corresponds to the JSON property `kind`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :kind
|
|
|
|
|
|
|
|
# A link to the next page of replies.
|
|
|
|
# Corresponds to the JSON property `nextLink`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :next_link
|
|
|
|
|
|
|
|
# The token to use to request the next page of results.
|
|
|
|
# Corresponds to the JSON property `nextPageToken`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :next_page_token
|
|
|
|
|
|
|
|
# A link back to this list.
|
|
|
|
# Corresponds to the JSON property `selfLink`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :self_link
|
|
|
|
|
|
|
|
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_link = args[:next_link] unless args[:next_link].nil?
|
|
|
|
@next_page_token = args[:next_page_token] unless args[:next_page_token].nil?
|
|
|
|
@self_link = args[:self_link] unless args[:self_link].nil?
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
# The metadata for a file.
|
|
|
|
class File
|
|
|
|
include Google::Apis::Core::Hashable
|
|
|
|
|
|
|
|
# A link for opening the file in a relevant Google editor or viewer.
|
|
|
|
# Corresponds to the JSON property `alternateLink`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :alternate_link
|
|
|
|
|
|
|
|
# Whether this file is in the Application Data folder.
|
|
|
|
# Corresponds to the JSON property `appDataContents`
|
|
|
|
# @return [Boolean]
|
|
|
|
attr_accessor :app_data_contents
|
|
|
|
alias_method :app_data_contents?, :app_data_contents
|
|
|
|
|
|
|
|
# Whether the current user can comment on the file.
|
|
|
|
# Corresponds to the JSON property `canComment`
|
|
|
|
# @return [Boolean]
|
|
|
|
attr_accessor :can_comment
|
|
|
|
alias_method :can_comment?, :can_comment
|
|
|
|
|
|
|
|
# Whether the file can be copied by the current user.
|
|
|
|
# Corresponds to the JSON property `copyable`
|
|
|
|
# @return [Boolean]
|
|
|
|
attr_accessor :copyable
|
|
|
|
alias_method :copyable?, :copyable
|
|
|
|
|
|
|
|
# Create time for this file (formatted RFC 3339 timestamp).
|
|
|
|
# Corresponds to the JSON property `createdDate`
|
|
|
|
# @return [DateTime]
|
|
|
|
attr_accessor :created_date
|
|
|
|
|
|
|
|
# A link to open this file with the user's default app for this file. Only
|
|
|
|
# populated when the drive.apps.readonly scope is used.
|
|
|
|
# Corresponds to the JSON property `defaultOpenWithLink`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :default_open_with_link
|
|
|
|
|
|
|
|
# A short description of the file.
|
|
|
|
# Corresponds to the JSON property `description`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :description
|
|
|
|
|
2015-06-25 23:12:26 +00:00
|
|
|
#
|
2015-06-23 23:05:46 +00:00
|
|
|
# Corresponds to the JSON property `downloadUrl`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :download_url
|
|
|
|
|
|
|
|
# Whether the file can be edited by the current user.
|
|
|
|
# Corresponds to the JSON property `editable`
|
|
|
|
# @return [Boolean]
|
|
|
|
attr_accessor :editable
|
|
|
|
alias_method :editable?, :editable
|
|
|
|
|
|
|
|
# A link for embedding the file.
|
|
|
|
# Corresponds to the JSON property `embedLink`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :embed_link
|
|
|
|
|
|
|
|
# ETag of the file.
|
|
|
|
# Corresponds to the JSON property `etag`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :etag
|
|
|
|
|
|
|
|
# Whether this file has been explicitly trashed, as opposed to recursively
|
2015-06-25 23:12:26 +00:00
|
|
|
# trashed.
|
2015-06-23 23:05:46 +00:00
|
|
|
# Corresponds to the JSON property `explicitlyTrashed`
|
|
|
|
# @return [Boolean]
|
|
|
|
attr_accessor :explicitly_trashed
|
|
|
|
alias_method :explicitly_trashed?, :explicitly_trashed
|
|
|
|
|
|
|
|
# Links for exporting Google Docs to specific formats.
|
|
|
|
# Corresponds to the JSON property `exportLinks`
|
|
|
|
# @return [Hash<String,String>]
|
|
|
|
attr_accessor :export_links
|
|
|
|
|
|
|
|
# The file extension used when downloading this file. This field is read only.
|
|
|
|
# To set the extension, include it in the title when creating the file. This is
|
|
|
|
# only populated for files with content stored in Drive.
|
|
|
|
# Corresponds to the JSON property `fileExtension`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :file_extension
|
|
|
|
|
|
|
|
# The size of the file in bytes. This is only populated for files with content
|
|
|
|
# stored in Drive.
|
|
|
|
# Corresponds to the JSON property `fileSize`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :file_size
|
|
|
|
|
|
|
|
# Folder color as an RGB hex string if the file is a folder. The list of
|
|
|
|
# supported colors is available in the folderColorPalette field of the About
|
|
|
|
# resource. If an unsupported color is specified, it will be changed to the
|
|
|
|
# closest color in the palette.
|
|
|
|
# Corresponds to the JSON property `folderColorRgb`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :folder_color_rgb
|
|
|
|
|
|
|
|
# The ID of the file's head revision. This will only be populated for files with
|
|
|
|
# content stored in Drive.
|
|
|
|
# Corresponds to the JSON property `headRevisionId`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :head_revision_id
|
|
|
|
|
|
|
|
# A link to the file's icon.
|
|
|
|
# Corresponds to the JSON property `iconLink`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :icon_link
|
|
|
|
|
|
|
|
# The ID of the file.
|
|
|
|
# Corresponds to the JSON property `id`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :id
|
|
|
|
|
|
|
|
# Metadata about image media. This will only be present for image types, and its
|
|
|
|
# contents will depend on what can be parsed from the image content.
|
|
|
|
# Corresponds to the JSON property `imageMediaMetadata`
|
|
|
|
# @return [Google::Apis::DriveV2::File::ImageMediaMetadata]
|
|
|
|
attr_accessor :image_media_metadata
|
|
|
|
|
|
|
|
# Indexable text attributes for the file (can only be written)
|
|
|
|
# Corresponds to the JSON property `indexableText`
|
|
|
|
# @return [Google::Apis::DriveV2::File::IndexableText]
|
|
|
|
attr_accessor :indexable_text
|
|
|
|
|
|
|
|
# The type of file. This is always drive#file.
|
|
|
|
# Corresponds to the JSON property `kind`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :kind
|
|
|
|
|
|
|
|
# A group of labels for the file.
|
|
|
|
# Corresponds to the JSON property `labels`
|
|
|
|
# @return [Google::Apis::DriveV2::File::Labels]
|
|
|
|
attr_accessor :labels
|
|
|
|
|
|
|
|
# The JSON template for a user.
|
|
|
|
# Corresponds to the JSON property `lastModifyingUser`
|
|
|
|
# @return [Google::Apis::DriveV2::User]
|
|
|
|
attr_accessor :last_modifying_user
|
|
|
|
|
|
|
|
# Name of the last user to modify this file.
|
|
|
|
# Corresponds to the JSON property `lastModifyingUserName`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :last_modifying_user_name
|
|
|
|
|
|
|
|
# Last time this file was viewed by the user (formatted RFC 3339 timestamp).
|
|
|
|
# Corresponds to the JSON property `lastViewedByMeDate`
|
|
|
|
# @return [DateTime]
|
|
|
|
attr_accessor :last_viewed_by_me_date
|
|
|
|
|
|
|
|
# Time this file was explicitly marked viewed by the user (formatted RFC 3339
|
|
|
|
# timestamp).
|
|
|
|
# Corresponds to the JSON property `markedViewedByMeDate`
|
|
|
|
# @return [DateTime]
|
|
|
|
attr_accessor :marked_viewed_by_me_date
|
|
|
|
|
|
|
|
# An MD5 checksum for the content of this file. This is populated only for files
|
|
|
|
# with content stored in Drive.
|
|
|
|
# Corresponds to the JSON property `md5Checksum`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :md5_checksum
|
|
|
|
|
|
|
|
# The MIME type of the file. This is only mutable on update when uploading new
|
|
|
|
# content. This field can be left blank, and the mimetype will be determined
|
|
|
|
# from the uploaded content's MIME type.
|
|
|
|
# Corresponds to the JSON property `mimeType`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :mime_type
|
|
|
|
|
|
|
|
# Last time this file was modified by the user (formatted RFC 3339 timestamp).
|
|
|
|
# Note that setting modifiedDate will also update the modifiedByMe date for the
|
|
|
|
# user which set the date.
|
|
|
|
# Corresponds to the JSON property `modifiedByMeDate`
|
|
|
|
# @return [DateTime]
|
|
|
|
attr_accessor :modified_by_me_date
|
|
|
|
|
|
|
|
# Last time this file was modified by anyone (formatted RFC 3339 timestamp).
|
|
|
|
# This is only mutable on update when the setModifiedDate parameter is set.
|
|
|
|
# Corresponds to the JSON property `modifiedDate`
|
|
|
|
# @return [DateTime]
|
|
|
|
attr_accessor :modified_date
|
|
|
|
|
|
|
|
# A map of the id of each of the user's apps to a link to open this file with
|
|
|
|
# that app. Only populated when the drive.apps.readonly scope is used.
|
|
|
|
# Corresponds to the JSON property `openWithLinks`
|
|
|
|
# @return [Hash<String,String>]
|
|
|
|
attr_accessor :open_with_links
|
|
|
|
|
|
|
|
# The original filename if the file was uploaded manually, or the original title
|
|
|
|
# if the file was inserted through the API. Note that renames of the title will
|
|
|
|
# not change the original filename. This will only be populated on files with
|
|
|
|
# content stored in Drive.
|
|
|
|
# Corresponds to the JSON property `originalFilename`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :original_filename
|
|
|
|
|
|
|
|
# Whether the file is owned by the current user.
|
|
|
|
# Corresponds to the JSON property `ownedByMe`
|
|
|
|
# @return [Boolean]
|
|
|
|
attr_accessor :owned_by_me
|
|
|
|
alias_method :owned_by_me?, :owned_by_me
|
|
|
|
|
|
|
|
# Name(s) of the owner(s) of this file.
|
|
|
|
# Corresponds to the JSON property `ownerNames`
|
|
|
|
# @return [Array<String>]
|
|
|
|
attr_accessor :owner_names
|
|
|
|
|
|
|
|
# The owner(s) of this file.
|
|
|
|
# Corresponds to the JSON property `owners`
|
|
|
|
# @return [Array<Google::Apis::DriveV2::User>]
|
|
|
|
attr_accessor :owners
|
|
|
|
|
|
|
|
# Collection of parent folders which contain this file.
|
|
|
|
# Setting this field will put the file in all of the provided folders. On insert,
|
|
|
|
# if no folders are provided, the file will be placed in the default root
|
|
|
|
# folder.
|
|
|
|
# Corresponds to the JSON property `parents`
|
|
|
|
# @return [Array<Google::Apis::DriveV2::ParentReference>]
|
|
|
|
attr_accessor :parents
|
|
|
|
|
|
|
|
# The list of permissions for users with access to this file.
|
|
|
|
# Corresponds to the JSON property `permissions`
|
|
|
|
# @return [Array<Google::Apis::DriveV2::Permission>]
|
|
|
|
attr_accessor :permissions
|
|
|
|
|
|
|
|
# The list of properties.
|
|
|
|
# Corresponds to the JSON property `properties`
|
|
|
|
# @return [Array<Google::Apis::DriveV2::Property>]
|
|
|
|
attr_accessor :properties
|
|
|
|
|
|
|
|
# The number of quota bytes used by this file.
|
|
|
|
# Corresponds to the JSON property `quotaBytesUsed`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :quota_bytes_used
|
|
|
|
|
|
|
|
# A link back to this file.
|
|
|
|
# Corresponds to the JSON property `selfLink`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :self_link
|
|
|
|
|
|
|
|
# Whether the file's sharing settings can be modified by the current user.
|
|
|
|
# Corresponds to the JSON property `shareable`
|
|
|
|
# @return [Boolean]
|
|
|
|
attr_accessor :shareable
|
|
|
|
alias_method :shareable?, :shareable
|
|
|
|
|
|
|
|
# Whether the file has been shared.
|
|
|
|
# Corresponds to the JSON property `shared`
|
|
|
|
# @return [Boolean]
|
|
|
|
attr_accessor :shared
|
|
|
|
alias_method :shared?, :shared
|
|
|
|
|
|
|
|
# Time at which this file was shared with the user (formatted RFC 3339 timestamp)
|
|
|
|
# .
|
|
|
|
# Corresponds to the JSON property `sharedWithMeDate`
|
|
|
|
# @return [DateTime]
|
|
|
|
attr_accessor :shared_with_me_date
|
|
|
|
|
|
|
|
# The JSON template for a user.
|
|
|
|
# Corresponds to the JSON property `sharingUser`
|
|
|
|
# @return [Google::Apis::DriveV2::User]
|
|
|
|
attr_accessor :sharing_user
|
|
|
|
|
2015-07-31 00:05:47 +00:00
|
|
|
# The list of spaces which contain the file. Supported values are 'drive', '
|
|
|
|
# appDataFolder' and 'photos'.
|
2015-06-23 23:05:46 +00:00
|
|
|
# Corresponds to the JSON property `spaces`
|
|
|
|
# @return [Array<String>]
|
|
|
|
attr_accessor :spaces
|
|
|
|
|
|
|
|
# Thumbnail for the file. Only accepted on upload and for files that are not
|
|
|
|
# already thumbnailed by Google.
|
|
|
|
# Corresponds to the JSON property `thumbnail`
|
|
|
|
# @return [Google::Apis::DriveV2::File::Thumbnail]
|
|
|
|
attr_accessor :thumbnail
|
|
|
|
|
|
|
|
# A short-lived link to the file's thumbnail. Typically lasts on the order of
|
|
|
|
# hours.
|
|
|
|
# Corresponds to the JSON property `thumbnailLink`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :thumbnail_link
|
|
|
|
|
|
|
|
# The title of this file.
|
|
|
|
# Corresponds to the JSON property `title`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :title
|
|
|
|
|
|
|
|
# A permission for a file.
|
|
|
|
# Corresponds to the JSON property `userPermission`
|
|
|
|
# @return [Google::Apis::DriveV2::Permission]
|
|
|
|
attr_accessor :user_permission
|
|
|
|
|
|
|
|
# A monotonically increasing version number for the file. This reflects every
|
|
|
|
# change made to the file on the server, even those not visible to the
|
|
|
|
# requesting user.
|
|
|
|
# Corresponds to the JSON property `version`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :version
|
|
|
|
|
|
|
|
# Metadata about video media. This will only be present for video types.
|
|
|
|
# Corresponds to the JSON property `videoMediaMetadata`
|
|
|
|
# @return [Google::Apis::DriveV2::File::VideoMediaMetadata]
|
|
|
|
attr_accessor :video_media_metadata
|
|
|
|
|
|
|
|
# A link for downloading the content of the file in a browser using cookie based
|
|
|
|
# authentication. In cases where the content is shared publicly, the content can
|
|
|
|
# be downloaded without any credentials.
|
|
|
|
# Corresponds to the JSON property `webContentLink`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :web_content_link
|
|
|
|
|
|
|
|
# A link only available on public folders for viewing their static web assets (
|
|
|
|
# HTML, CSS, JS, etc) via Google Drive's Website Hosting.
|
|
|
|
# Corresponds to the JSON property `webViewLink`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :web_view_link
|
|
|
|
|
|
|
|
# Whether writers can share the document with other users.
|
|
|
|
# Corresponds to the JSON property `writersCanShare`
|
|
|
|
# @return [Boolean]
|
|
|
|
attr_accessor :writers_can_share
|
|
|
|
alias_method :writers_can_share?, :writers_can_share
|
|
|
|
|
|
|
|
def initialize(**args)
|
|
|
|
update!(**args)
|
|
|
|
end
|
|
|
|
|
|
|
|
# Update properties of this object
|
|
|
|
def update!(**args)
|
|
|
|
@alternate_link = args[:alternate_link] unless args[:alternate_link].nil?
|
|
|
|
@app_data_contents = args[:app_data_contents] unless args[:app_data_contents].nil?
|
|
|
|
@can_comment = args[:can_comment] unless args[:can_comment].nil?
|
|
|
|
@copyable = args[:copyable] unless args[:copyable].nil?
|
|
|
|
@created_date = args[:created_date] unless args[:created_date].nil?
|
|
|
|
@default_open_with_link = args[:default_open_with_link] unless args[:default_open_with_link].nil?
|
|
|
|
@description = args[:description] unless args[:description].nil?
|
|
|
|
@download_url = args[:download_url] unless args[:download_url].nil?
|
|
|
|
@editable = args[:editable] unless args[:editable].nil?
|
|
|
|
@embed_link = args[:embed_link] unless args[:embed_link].nil?
|
|
|
|
@etag = args[:etag] unless args[:etag].nil?
|
|
|
|
@explicitly_trashed = args[:explicitly_trashed] unless args[:explicitly_trashed].nil?
|
|
|
|
@export_links = args[:export_links] unless args[:export_links].nil?
|
|
|
|
@file_extension = args[:file_extension] unless args[:file_extension].nil?
|
|
|
|
@file_size = args[:file_size] unless args[:file_size].nil?
|
|
|
|
@folder_color_rgb = args[:folder_color_rgb] unless args[:folder_color_rgb].nil?
|
|
|
|
@head_revision_id = args[:head_revision_id] unless args[:head_revision_id].nil?
|
|
|
|
@icon_link = args[:icon_link] unless args[:icon_link].nil?
|
|
|
|
@id = args[:id] unless args[:id].nil?
|
|
|
|
@image_media_metadata = args[:image_media_metadata] unless args[:image_media_metadata].nil?
|
|
|
|
@indexable_text = args[:indexable_text] unless args[:indexable_text].nil?
|
|
|
|
@kind = args[:kind] unless args[:kind].nil?
|
|
|
|
@labels = args[:labels] unless args[:labels].nil?
|
|
|
|
@last_modifying_user = args[:last_modifying_user] unless args[:last_modifying_user].nil?
|
|
|
|
@last_modifying_user_name = args[:last_modifying_user_name] unless args[:last_modifying_user_name].nil?
|
|
|
|
@last_viewed_by_me_date = args[:last_viewed_by_me_date] unless args[:last_viewed_by_me_date].nil?
|
|
|
|
@marked_viewed_by_me_date = args[:marked_viewed_by_me_date] unless args[:marked_viewed_by_me_date].nil?
|
|
|
|
@md5_checksum = args[:md5_checksum] unless args[:md5_checksum].nil?
|
|
|
|
@mime_type = args[:mime_type] unless args[:mime_type].nil?
|
|
|
|
@modified_by_me_date = args[:modified_by_me_date] unless args[:modified_by_me_date].nil?
|
|
|
|
@modified_date = args[:modified_date] unless args[:modified_date].nil?
|
|
|
|
@open_with_links = args[:open_with_links] unless args[:open_with_links].nil?
|
|
|
|
@original_filename = args[:original_filename] unless args[:original_filename].nil?
|
|
|
|
@owned_by_me = args[:owned_by_me] unless args[:owned_by_me].nil?
|
|
|
|
@owner_names = args[:owner_names] unless args[:owner_names].nil?
|
|
|
|
@owners = args[:owners] unless args[:owners].nil?
|
|
|
|
@parents = args[:parents] unless args[:parents].nil?
|
|
|
|
@permissions = args[:permissions] unless args[:permissions].nil?
|
|
|
|
@properties = args[:properties] unless args[:properties].nil?
|
|
|
|
@quota_bytes_used = args[:quota_bytes_used] unless args[:quota_bytes_used].nil?
|
|
|
|
@self_link = args[:self_link] unless args[:self_link].nil?
|
|
|
|
@shareable = args[:shareable] unless args[:shareable].nil?
|
|
|
|
@shared = args[:shared] unless args[:shared].nil?
|
|
|
|
@shared_with_me_date = args[:shared_with_me_date] unless args[:shared_with_me_date].nil?
|
|
|
|
@sharing_user = args[:sharing_user] unless args[:sharing_user].nil?
|
|
|
|
@spaces = args[:spaces] unless args[:spaces].nil?
|
|
|
|
@thumbnail = args[:thumbnail] unless args[:thumbnail].nil?
|
|
|
|
@thumbnail_link = args[:thumbnail_link] unless args[:thumbnail_link].nil?
|
|
|
|
@title = args[:title] unless args[:title].nil?
|
|
|
|
@user_permission = args[:user_permission] unless args[:user_permission].nil?
|
|
|
|
@version = args[:version] unless args[:version].nil?
|
|
|
|
@video_media_metadata = args[:video_media_metadata] unless args[:video_media_metadata].nil?
|
|
|
|
@web_content_link = args[:web_content_link] unless args[:web_content_link].nil?
|
|
|
|
@web_view_link = args[:web_view_link] unless args[:web_view_link].nil?
|
|
|
|
@writers_can_share = args[:writers_can_share] unless args[:writers_can_share].nil?
|
|
|
|
end
|
|
|
|
|
|
|
|
# Metadata about image media. This will only be present for image types, and its
|
|
|
|
# contents will depend on what can be parsed from the image content.
|
|
|
|
class ImageMediaMetadata
|
|
|
|
include Google::Apis::Core::Hashable
|
|
|
|
|
|
|
|
# The aperture used to create the photo (f-number).
|
|
|
|
# Corresponds to the JSON property `aperture`
|
|
|
|
# @return [Float]
|
|
|
|
attr_accessor :aperture
|
|
|
|
|
|
|
|
# The make of the camera used to create the photo.
|
|
|
|
# Corresponds to the JSON property `cameraMake`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :camera_make
|
|
|
|
|
|
|
|
# The model of the camera used to create the photo.
|
|
|
|
# Corresponds to the JSON property `cameraModel`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :camera_model
|
|
|
|
|
|
|
|
# The color space of the photo.
|
|
|
|
# Corresponds to the JSON property `colorSpace`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :color_space
|
|
|
|
|
|
|
|
# The date and time the photo was taken (EXIF format timestamp).
|
|
|
|
# Corresponds to the JSON property `date`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :date
|
|
|
|
|
|
|
|
# The exposure bias of the photo (APEX value).
|
|
|
|
# Corresponds to the JSON property `exposureBias`
|
|
|
|
# @return [Float]
|
|
|
|
attr_accessor :exposure_bias
|
|
|
|
|
|
|
|
# The exposure mode used to create the photo.
|
|
|
|
# Corresponds to the JSON property `exposureMode`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :exposure_mode
|
|
|
|
|
|
|
|
# The length of the exposure, in seconds.
|
|
|
|
# Corresponds to the JSON property `exposureTime`
|
|
|
|
# @return [Float]
|
|
|
|
attr_accessor :exposure_time
|
|
|
|
|
|
|
|
# Whether a flash was used to create the photo.
|
|
|
|
# Corresponds to the JSON property `flashUsed`
|
|
|
|
# @return [Boolean]
|
|
|
|
attr_accessor :flash_used
|
|
|
|
alias_method :flash_used?, :flash_used
|
|
|
|
|
|
|
|
# The focal length used to create the photo, in millimeters.
|
|
|
|
# Corresponds to the JSON property `focalLength`
|
|
|
|
# @return [Float]
|
|
|
|
attr_accessor :focal_length
|
|
|
|
|
|
|
|
# The height of the image in pixels.
|
|
|
|
# Corresponds to the JSON property `height`
|
|
|
|
# @return [Fixnum]
|
|
|
|
attr_accessor :height
|
|
|
|
|
|
|
|
# The ISO speed used to create the photo.
|
|
|
|
# Corresponds to the JSON property `isoSpeed`
|
|
|
|
# @return [Fixnum]
|
|
|
|
attr_accessor :iso_speed
|
|
|
|
|
|
|
|
# The lens used to create the photo.
|
|
|
|
# Corresponds to the JSON property `lens`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :lens
|
|
|
|
|
|
|
|
# Geographic location information stored in the image.
|
|
|
|
# Corresponds to the JSON property `location`
|
|
|
|
# @return [Google::Apis::DriveV2::File::ImageMediaMetadata::Location]
|
|
|
|
attr_accessor :location
|
|
|
|
|
|
|
|
# The smallest f-number of the lens at the focal length used to create the photo
|
|
|
|
# (APEX value).
|
|
|
|
# Corresponds to the JSON property `maxApertureValue`
|
|
|
|
# @return [Float]
|
|
|
|
attr_accessor :max_aperture_value
|
|
|
|
|
|
|
|
# The metering mode used to create the photo.
|
|
|
|
# Corresponds to the JSON property `meteringMode`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :metering_mode
|
|
|
|
|
|
|
|
# The rotation in clockwise degrees from the image's original orientation.
|
|
|
|
# Corresponds to the JSON property `rotation`
|
|
|
|
# @return [Fixnum]
|
|
|
|
attr_accessor :rotation
|
|
|
|
|
|
|
|
# The type of sensor used to create the photo.
|
|
|
|
# Corresponds to the JSON property `sensor`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :sensor
|
|
|
|
|
|
|
|
# The distance to the subject of the photo, in meters.
|
|
|
|
# Corresponds to the JSON property `subjectDistance`
|
|
|
|
# @return [Fixnum]
|
|
|
|
attr_accessor :subject_distance
|
|
|
|
|
|
|
|
# The white balance mode used to create the photo.
|
|
|
|
# Corresponds to the JSON property `whiteBalance`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :white_balance
|
|
|
|
|
|
|
|
# The width of the image in pixels.
|
|
|
|
# Corresponds to the JSON property `width`
|
|
|
|
# @return [Fixnum]
|
|
|
|
attr_accessor :width
|
|
|
|
|
|
|
|
def initialize(**args)
|
|
|
|
update!(**args)
|
|
|
|
end
|
|
|
|
|
|
|
|
# Update properties of this object
|
|
|
|
def update!(**args)
|
|
|
|
@aperture = args[:aperture] unless args[:aperture].nil?
|
|
|
|
@camera_make = args[:camera_make] unless args[:camera_make].nil?
|
|
|
|
@camera_model = args[:camera_model] unless args[:camera_model].nil?
|
|
|
|
@color_space = args[:color_space] unless args[:color_space].nil?
|
|
|
|
@date = args[:date] unless args[:date].nil?
|
|
|
|
@exposure_bias = args[:exposure_bias] unless args[:exposure_bias].nil?
|
|
|
|
@exposure_mode = args[:exposure_mode] unless args[:exposure_mode].nil?
|
|
|
|
@exposure_time = args[:exposure_time] unless args[:exposure_time].nil?
|
|
|
|
@flash_used = args[:flash_used] unless args[:flash_used].nil?
|
|
|
|
@focal_length = args[:focal_length] unless args[:focal_length].nil?
|
|
|
|
@height = args[:height] unless args[:height].nil?
|
|
|
|
@iso_speed = args[:iso_speed] unless args[:iso_speed].nil?
|
|
|
|
@lens = args[:lens] unless args[:lens].nil?
|
|
|
|
@location = args[:location] unless args[:location].nil?
|
|
|
|
@max_aperture_value = args[:max_aperture_value] unless args[:max_aperture_value].nil?
|
|
|
|
@metering_mode = args[:metering_mode] unless args[:metering_mode].nil?
|
|
|
|
@rotation = args[:rotation] unless args[:rotation].nil?
|
|
|
|
@sensor = args[:sensor] unless args[:sensor].nil?
|
|
|
|
@subject_distance = args[:subject_distance] unless args[:subject_distance].nil?
|
|
|
|
@white_balance = args[:white_balance] unless args[:white_balance].nil?
|
|
|
|
@width = args[:width] unless args[:width].nil?
|
|
|
|
end
|
|
|
|
|
|
|
|
# Geographic location information stored in the image.
|
|
|
|
class Location
|
|
|
|
include Google::Apis::Core::Hashable
|
|
|
|
|
|
|
|
# The altitude stored in the image.
|
|
|
|
# Corresponds to the JSON property `altitude`
|
|
|
|
# @return [Float]
|
|
|
|
attr_accessor :altitude
|
|
|
|
|
|
|
|
# The latitude stored in the image.
|
|
|
|
# Corresponds to the JSON property `latitude`
|
|
|
|
# @return [Float]
|
|
|
|
attr_accessor :latitude
|
|
|
|
|
|
|
|
# The longitude stored in the image.
|
|
|
|
# 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)
|
|
|
|
@altitude = args[:altitude] unless args[:altitude].nil?
|
|
|
|
@latitude = args[:latitude] unless args[:latitude].nil?
|
|
|
|
@longitude = args[:longitude] unless args[:longitude].nil?
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
# Indexable text attributes for the file (can only be written)
|
|
|
|
class IndexableText
|
|
|
|
include Google::Apis::Core::Hashable
|
|
|
|
|
|
|
|
# The text to be indexed for this file.
|
|
|
|
# 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)
|
|
|
|
@text = args[:text] unless args[:text].nil?
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
# A group of labels for the file.
|
|
|
|
class Labels
|
|
|
|
include Google::Apis::Core::Hashable
|
|
|
|
|
|
|
|
# Deprecated.
|
|
|
|
# Corresponds to the JSON property `hidden`
|
|
|
|
# @return [Boolean]
|
|
|
|
attr_accessor :hidden
|
|
|
|
alias_method :hidden?, :hidden
|
|
|
|
|
|
|
|
# Whether viewers are prevented from downloading this file.
|
|
|
|
# Corresponds to the JSON property `restricted`
|
|
|
|
# @return [Boolean]
|
|
|
|
attr_accessor :restricted
|
|
|
|
alias_method :restricted?, :restricted
|
|
|
|
|
|
|
|
# Whether this file is starred by the user.
|
|
|
|
# Corresponds to the JSON property `starred`
|
|
|
|
# @return [Boolean]
|
|
|
|
attr_accessor :starred
|
|
|
|
alias_method :starred?, :starred
|
|
|
|
|
|
|
|
# Whether this file has been trashed. This label applies to all users accessing
|
|
|
|
# the file; however, only owners are allowed to see and untrash files.
|
|
|
|
# Corresponds to the JSON property `trashed`
|
|
|
|
# @return [Boolean]
|
|
|
|
attr_accessor :trashed
|
|
|
|
alias_method :trashed?, :trashed
|
|
|
|
|
|
|
|
# Whether this file has been viewed by this user.
|
|
|
|
# Corresponds to the JSON property `viewed`
|
|
|
|
# @return [Boolean]
|
|
|
|
attr_accessor :viewed
|
|
|
|
alias_method :viewed?, :viewed
|
|
|
|
|
|
|
|
def initialize(**args)
|
|
|
|
update!(**args)
|
|
|
|
end
|
|
|
|
|
|
|
|
# Update properties of this object
|
|
|
|
def update!(**args)
|
|
|
|
@hidden = args[:hidden] unless args[:hidden].nil?
|
|
|
|
@restricted = args[:restricted] unless args[:restricted].nil?
|
|
|
|
@starred = args[:starred] unless args[:starred].nil?
|
|
|
|
@trashed = args[:trashed] unless args[:trashed].nil?
|
|
|
|
@viewed = args[:viewed] unless args[:viewed].nil?
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
# Thumbnail for the file. Only accepted on upload and for files that are not
|
|
|
|
# already thumbnailed by Google.
|
|
|
|
class Thumbnail
|
|
|
|
include Google::Apis::Core::Hashable
|
|
|
|
|
|
|
|
# The URL-safe Base64 encoded bytes of the thumbnail image. It should conform to
|
|
|
|
# RFC 4648 section 5.
|
|
|
|
# Corresponds to the JSON property `image`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :image
|
|
|
|
|
|
|
|
# The MIME type of the thumbnail.
|
|
|
|
# Corresponds to the JSON property `mimeType`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :mime_type
|
|
|
|
|
|
|
|
def initialize(**args)
|
|
|
|
update!(**args)
|
|
|
|
end
|
|
|
|
|
|
|
|
# Update properties of this object
|
|
|
|
def update!(**args)
|
|
|
|
@image = args[:image] unless args[:image].nil?
|
|
|
|
@mime_type = args[:mime_type] unless args[:mime_type].nil?
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
# Metadata about video media. This will only be present for video types.
|
|
|
|
class VideoMediaMetadata
|
|
|
|
include Google::Apis::Core::Hashable
|
|
|
|
|
|
|
|
# The duration of the video in milliseconds.
|
|
|
|
# Corresponds to the JSON property `durationMillis`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :duration_millis
|
|
|
|
|
|
|
|
# The height of the video in pixels.
|
|
|
|
# Corresponds to the JSON property `height`
|
|
|
|
# @return [Fixnum]
|
|
|
|
attr_accessor :height
|
|
|
|
|
|
|
|
# The width of the video in pixels.
|
|
|
|
# Corresponds to the JSON property `width`
|
|
|
|
# @return [Fixnum]
|
|
|
|
attr_accessor :width
|
|
|
|
|
|
|
|
def initialize(**args)
|
|
|
|
update!(**args)
|
|
|
|
end
|
|
|
|
|
|
|
|
# Update properties of this object
|
|
|
|
def update!(**args)
|
|
|
|
@duration_millis = args[:duration_millis] unless args[:duration_millis].nil?
|
|
|
|
@height = args[:height] unless args[:height].nil?
|
|
|
|
@width = args[:width] unless args[:width].nil?
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
# A list of files.
|
|
|
|
class FileList
|
|
|
|
include Google::Apis::Core::Hashable
|
|
|
|
|
|
|
|
# The ETag of the list.
|
|
|
|
# Corresponds to the JSON property `etag`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :etag
|
|
|
|
|
|
|
|
# The actual list of files.
|
|
|
|
# Corresponds to the JSON property `items`
|
|
|
|
# @return [Array<Google::Apis::DriveV2::File>]
|
|
|
|
attr_accessor :items
|
|
|
|
|
|
|
|
# This is always drive#fileList.
|
|
|
|
# Corresponds to the JSON property `kind`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :kind
|
|
|
|
|
|
|
|
# A link to the next page of files.
|
|
|
|
# Corresponds to the JSON property `nextLink`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :next_link
|
|
|
|
|
|
|
|
# The page token for the next page of files.
|
|
|
|
# Corresponds to the JSON property `nextPageToken`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :next_page_token
|
|
|
|
|
|
|
|
# A link back to this list.
|
|
|
|
# Corresponds to the JSON property `selfLink`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :self_link
|
|
|
|
|
|
|
|
def initialize(**args)
|
|
|
|
update!(**args)
|
|
|
|
end
|
|
|
|
|
|
|
|
# Update properties of this object
|
|
|
|
def update!(**args)
|
|
|
|
@etag = args[:etag] unless args[:etag].nil?
|
|
|
|
@items = args[:items] unless args[:items].nil?
|
|
|
|
@kind = args[:kind] unless args[:kind].nil?
|
|
|
|
@next_link = args[:next_link] unless args[:next_link].nil?
|
|
|
|
@next_page_token = args[:next_page_token] unless args[:next_page_token].nil?
|
|
|
|
@self_link = args[:self_link] unless args[:self_link].nil?
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
# A list of a file's parents.
|
|
|
|
class ParentList
|
|
|
|
include Google::Apis::Core::Hashable
|
|
|
|
|
|
|
|
# The ETag of the list.
|
|
|
|
# Corresponds to the JSON property `etag`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :etag
|
|
|
|
|
|
|
|
# The actual list of parents.
|
|
|
|
# Corresponds to the JSON property `items`
|
|
|
|
# @return [Array<Google::Apis::DriveV2::ParentReference>]
|
|
|
|
attr_accessor :items
|
|
|
|
|
|
|
|
# This is always drive#parentList.
|
|
|
|
# Corresponds to the JSON property `kind`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :kind
|
|
|
|
|
|
|
|
# A link back to this list.
|
|
|
|
# Corresponds to the JSON property `selfLink`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :self_link
|
|
|
|
|
|
|
|
def initialize(**args)
|
|
|
|
update!(**args)
|
|
|
|
end
|
|
|
|
|
|
|
|
# Update properties of this object
|
|
|
|
def update!(**args)
|
|
|
|
@etag = args[:etag] unless args[:etag].nil?
|
|
|
|
@items = args[:items] unless args[:items].nil?
|
|
|
|
@kind = args[:kind] unless args[:kind].nil?
|
|
|
|
@self_link = args[:self_link] unless args[:self_link].nil?
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
# A reference to a file's parent.
|
|
|
|
class ParentReference
|
|
|
|
include Google::Apis::Core::Hashable
|
|
|
|
|
|
|
|
# The ID of the parent.
|
|
|
|
# Corresponds to the JSON property `id`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :id
|
|
|
|
|
|
|
|
# Whether or not the parent is the root folder.
|
|
|
|
# Corresponds to the JSON property `isRoot`
|
|
|
|
# @return [Boolean]
|
|
|
|
attr_accessor :is_root
|
|
|
|
alias_method :is_root?, :is_root
|
|
|
|
|
|
|
|
# This is always drive#parentReference.
|
|
|
|
# Corresponds to the JSON property `kind`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :kind
|
|
|
|
|
|
|
|
# A link to the parent.
|
|
|
|
# Corresponds to the JSON property `parentLink`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :parent_link
|
|
|
|
|
|
|
|
# A link back to this reference.
|
|
|
|
# Corresponds to the JSON property `selfLink`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :self_link
|
|
|
|
|
|
|
|
def initialize(**args)
|
|
|
|
update!(**args)
|
|
|
|
end
|
|
|
|
|
|
|
|
# Update properties of this object
|
|
|
|
def update!(**args)
|
|
|
|
@id = args[:id] unless args[:id].nil?
|
|
|
|
@is_root = args[:is_root] unless args[:is_root].nil?
|
|
|
|
@kind = args[:kind] unless args[:kind].nil?
|
|
|
|
@parent_link = args[:parent_link] unless args[:parent_link].nil?
|
|
|
|
@self_link = args[:self_link] unless args[:self_link].nil?
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
# A permission for a file.
|
|
|
|
class Permission
|
|
|
|
include Google::Apis::Core::Hashable
|
|
|
|
|
|
|
|
# Additional roles for this user. Only commenter is currently allowed.
|
|
|
|
# Corresponds to the JSON property `additionalRoles`
|
|
|
|
# @return [Array<String>]
|
|
|
|
attr_accessor :additional_roles
|
|
|
|
|
|
|
|
# The authkey parameter required for this permission.
|
|
|
|
# Corresponds to the JSON property `authKey`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :auth_key
|
|
|
|
|
|
|
|
# The domain name of the entity this permission refers to. This is an output-
|
|
|
|
# only field which is present when the permission type is user, group or domain.
|
|
|
|
# Corresponds to the JSON property `domain`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :domain
|
|
|
|
|
|
|
|
# The email address of the user or group this permission refers to. This is an
|
|
|
|
# output-only field which is present when the permission type is user or group.
|
|
|
|
# Corresponds to the JSON property `emailAddress`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :email_address
|
|
|
|
|
|
|
|
# The ETag of the permission.
|
|
|
|
# Corresponds to the JSON property `etag`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :etag
|
|
|
|
|
|
|
|
# The ID of the user this permission refers to, and identical to the
|
|
|
|
# permissionId in the About and Files resources. When making a drive.permissions.
|
|
|
|
# insert request, exactly one of the id or value fields must be specified.
|
|
|
|
# Corresponds to the JSON property `id`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :id
|
|
|
|
|
|
|
|
# This is always drive#permission.
|
|
|
|
# Corresponds to the JSON property `kind`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :kind
|
|
|
|
|
|
|
|
# The name for this permission.
|
|
|
|
# Corresponds to the JSON property `name`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :name
|
|
|
|
|
|
|
|
# A link to the profile photo, if available.
|
|
|
|
# Corresponds to the JSON property `photoLink`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :photo_link
|
|
|
|
|
|
|
|
# The primary role for this user. Allowed values are:
|
|
|
|
# - owner
|
|
|
|
# - reader
|
|
|
|
# - writer
|
|
|
|
# Corresponds to the JSON property `role`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :role
|
|
|
|
|
|
|
|
# A link back to this permission.
|
|
|
|
# Corresponds to the JSON property `selfLink`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :self_link
|
|
|
|
|
|
|
|
# The account type. Allowed values are:
|
|
|
|
# - user
|
|
|
|
# - group
|
|
|
|
# - domain
|
|
|
|
# - anyone
|
|
|
|
# Corresponds to the JSON property `type`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :type
|
|
|
|
|
|
|
|
# The email address or domain name for the entity. This is used during inserts
|
|
|
|
# and is not populated in responses. When making a drive.permissions.insert
|
|
|
|
# request, exactly one of the id or value fields must be specified.
|
|
|
|
# Corresponds to the JSON property `value`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :value
|
|
|
|
|
|
|
|
# Whether the link is required for this permission.
|
|
|
|
# Corresponds to the JSON property `withLink`
|
|
|
|
# @return [Boolean]
|
|
|
|
attr_accessor :with_link
|
|
|
|
alias_method :with_link?, :with_link
|
|
|
|
|
|
|
|
def initialize(**args)
|
|
|
|
update!(**args)
|
|
|
|
end
|
|
|
|
|
|
|
|
# Update properties of this object
|
|
|
|
def update!(**args)
|
|
|
|
@additional_roles = args[:additional_roles] unless args[:additional_roles].nil?
|
|
|
|
@auth_key = args[:auth_key] unless args[:auth_key].nil?
|
|
|
|
@domain = args[:domain] unless args[:domain].nil?
|
|
|
|
@email_address = args[:email_address] unless args[:email_address].nil?
|
|
|
|
@etag = args[:etag] unless args[:etag].nil?
|
|
|
|
@id = args[:id] unless args[:id].nil?
|
|
|
|
@kind = args[:kind] unless args[:kind].nil?
|
|
|
|
@name = args[:name] unless args[:name].nil?
|
|
|
|
@photo_link = args[:photo_link] unless args[:photo_link].nil?
|
|
|
|
@role = args[:role] unless args[:role].nil?
|
|
|
|
@self_link = args[:self_link] unless args[:self_link].nil?
|
|
|
|
@type = args[:type] unless args[:type].nil?
|
|
|
|
@value = args[:value] unless args[:value].nil?
|
|
|
|
@with_link = args[:with_link] unless args[:with_link].nil?
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
# An ID for a user or group as seen in Permission items.
|
|
|
|
class PermissionId
|
|
|
|
include Google::Apis::Core::Hashable
|
|
|
|
|
|
|
|
# The permission ID.
|
|
|
|
# Corresponds to the JSON property `id`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :id
|
|
|
|
|
|
|
|
# This is always drive#permissionId.
|
|
|
|
# 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)
|
|
|
|
@id = args[:id] unless args[:id].nil?
|
|
|
|
@kind = args[:kind] unless args[:kind].nil?
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
# A list of permissions associated with a file.
|
|
|
|
class PermissionList
|
|
|
|
include Google::Apis::Core::Hashable
|
|
|
|
|
|
|
|
# The ETag of the list.
|
|
|
|
# Corresponds to the JSON property `etag`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :etag
|
|
|
|
|
|
|
|
# The actual list of permissions.
|
|
|
|
# Corresponds to the JSON property `items`
|
|
|
|
# @return [Array<Google::Apis::DriveV2::Permission>]
|
|
|
|
attr_accessor :items
|
|
|
|
|
|
|
|
# This is always drive#permissionList.
|
|
|
|
# Corresponds to the JSON property `kind`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :kind
|
|
|
|
|
|
|
|
# A link back to this list.
|
|
|
|
# Corresponds to the JSON property `selfLink`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :self_link
|
|
|
|
|
|
|
|
def initialize(**args)
|
|
|
|
update!(**args)
|
|
|
|
end
|
|
|
|
|
|
|
|
# Update properties of this object
|
|
|
|
def update!(**args)
|
|
|
|
@etag = args[:etag] unless args[:etag].nil?
|
|
|
|
@items = args[:items] unless args[:items].nil?
|
|
|
|
@kind = args[:kind] unless args[:kind].nil?
|
|
|
|
@self_link = args[:self_link] unless args[:self_link].nil?
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
# A key-value pair attached to a file that is either public or private to an
|
|
|
|
# application.
|
|
|
|
# The following limits apply to file properties:
|
|
|
|
# - Maximum of 100 properties total per file
|
|
|
|
# - Maximum of 30 private properties per app
|
|
|
|
# - Maximum of 30 public properties
|
|
|
|
# - Maximum of 124 bytes size limit on (key + value) string in UTF-8 encoding
|
|
|
|
# for a single property.
|
|
|
|
class Property
|
|
|
|
include Google::Apis::Core::Hashable
|
|
|
|
|
|
|
|
# ETag of the property.
|
|
|
|
# Corresponds to the JSON property `etag`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :etag
|
|
|
|
|
|
|
|
# The key of this property.
|
|
|
|
# Corresponds to the JSON property `key`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :key
|
|
|
|
|
|
|
|
# This is always drive#property.
|
|
|
|
# Corresponds to the JSON property `kind`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :kind
|
|
|
|
|
|
|
|
# The link back to this property.
|
|
|
|
# Corresponds to the JSON property `selfLink`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :self_link
|
|
|
|
|
|
|
|
# The value of this property.
|
|
|
|
# Corresponds to the JSON property `value`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :value
|
|
|
|
|
|
|
|
# The visibility of this property.
|
|
|
|
# Corresponds to the JSON property `visibility`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :visibility
|
|
|
|
|
|
|
|
def initialize(**args)
|
|
|
|
update!(**args)
|
|
|
|
end
|
|
|
|
|
|
|
|
# Update properties of this object
|
|
|
|
def update!(**args)
|
|
|
|
@etag = args[:etag] unless args[:etag].nil?
|
|
|
|
@key = args[:key] unless args[:key].nil?
|
|
|
|
@kind = args[:kind] unless args[:kind].nil?
|
|
|
|
@self_link = args[:self_link] unless args[:self_link].nil?
|
|
|
|
@value = args[:value] unless args[:value].nil?
|
|
|
|
@visibility = args[:visibility] unless args[:visibility].nil?
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
# A collection of properties, key-value pairs that are either public or private
|
|
|
|
# to an application.
|
|
|
|
class PropertyList
|
|
|
|
include Google::Apis::Core::Hashable
|
|
|
|
|
|
|
|
# The ETag of the list.
|
|
|
|
# Corresponds to the JSON property `etag`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :etag
|
|
|
|
|
|
|
|
# The list of properties.
|
|
|
|
# Corresponds to the JSON property `items`
|
|
|
|
# @return [Array<Google::Apis::DriveV2::Property>]
|
|
|
|
attr_accessor :items
|
|
|
|
|
|
|
|
# This is always drive#propertyList.
|
|
|
|
# Corresponds to the JSON property `kind`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :kind
|
|
|
|
|
|
|
|
# The link back to this list.
|
|
|
|
# Corresponds to the JSON property `selfLink`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :self_link
|
|
|
|
|
|
|
|
def initialize(**args)
|
|
|
|
update!(**args)
|
|
|
|
end
|
|
|
|
|
|
|
|
# Update properties of this object
|
|
|
|
def update!(**args)
|
|
|
|
@etag = args[:etag] unless args[:etag].nil?
|
|
|
|
@items = args[:items] unless args[:items].nil?
|
|
|
|
@kind = args[:kind] unless args[:kind].nil?
|
|
|
|
@self_link = args[:self_link] unless args[:self_link].nil?
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
# A revision of a file.
|
|
|
|
class Revision
|
|
|
|
include Google::Apis::Core::Hashable
|
|
|
|
|
|
|
|
# Short term download URL for the file. This will only be populated on files
|
|
|
|
# with content stored in Drive.
|
|
|
|
# Corresponds to the JSON property `downloadUrl`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :download_url
|
|
|
|
|
|
|
|
# The ETag of the revision.
|
|
|
|
# Corresponds to the JSON property `etag`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :etag
|
|
|
|
|
|
|
|
# Links for exporting Google Docs to specific formats.
|
|
|
|
# Corresponds to the JSON property `exportLinks`
|
|
|
|
# @return [Hash<String,String>]
|
|
|
|
attr_accessor :export_links
|
|
|
|
|
|
|
|
# The size of the revision in bytes. This will only be populated on files with
|
|
|
|
# content stored in Drive.
|
|
|
|
# Corresponds to the JSON property `fileSize`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :file_size
|
|
|
|
|
|
|
|
# The ID of the revision.
|
|
|
|
# Corresponds to the JSON property `id`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :id
|
|
|
|
|
|
|
|
# This is always drive#revision.
|
|
|
|
# Corresponds to the JSON property `kind`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :kind
|
|
|
|
|
|
|
|
# The JSON template for a user.
|
|
|
|
# Corresponds to the JSON property `lastModifyingUser`
|
|
|
|
# @return [Google::Apis::DriveV2::User]
|
|
|
|
attr_accessor :last_modifying_user
|
|
|
|
|
|
|
|
# Name of the last user to modify this revision.
|
|
|
|
# Corresponds to the JSON property `lastModifyingUserName`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :last_modifying_user_name
|
|
|
|
|
|
|
|
# An MD5 checksum for the content of this revision. This will only be populated
|
|
|
|
# on files with content stored in Drive.
|
|
|
|
# Corresponds to the JSON property `md5Checksum`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :md5_checksum
|
|
|
|
|
|
|
|
# The MIME type of the revision.
|
|
|
|
# Corresponds to the JSON property `mimeType`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :mime_type
|
|
|
|
|
|
|
|
# Last time this revision was modified (formatted RFC 3339 timestamp).
|
|
|
|
# Corresponds to the JSON property `modifiedDate`
|
|
|
|
# @return [DateTime]
|
|
|
|
attr_accessor :modified_date
|
|
|
|
|
|
|
|
# The original filename when this revision was created. This will only be
|
|
|
|
# populated on files with content stored in Drive.
|
|
|
|
# Corresponds to the JSON property `originalFilename`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :original_filename
|
|
|
|
|
|
|
|
# Whether this revision is pinned to prevent automatic purging. This will only
|
|
|
|
# be populated and can only be modified on files with content stored in Drive
|
|
|
|
# which are not Google Docs. Revisions can also be pinned when they are created
|
|
|
|
# through the drive.files.insert/update/copy by using the pinned query parameter.
|
|
|
|
# Corresponds to the JSON property `pinned`
|
|
|
|
# @return [Boolean]
|
|
|
|
attr_accessor :pinned
|
|
|
|
alias_method :pinned?, :pinned
|
|
|
|
|
|
|
|
# Whether subsequent revisions will be automatically republished. This is only
|
|
|
|
# populated and can only be modified for Google Docs.
|
|
|
|
# Corresponds to the JSON property `publishAuto`
|
|
|
|
# @return [Boolean]
|
|
|
|
attr_accessor :publish_auto
|
|
|
|
alias_method :publish_auto?, :publish_auto
|
|
|
|
|
|
|
|
# Whether this revision is published. This is only populated and can only be
|
|
|
|
# modified for Google Docs.
|
|
|
|
# Corresponds to the JSON property `published`
|
|
|
|
# @return [Boolean]
|
|
|
|
attr_accessor :published
|
|
|
|
alias_method :published?, :published
|
|
|
|
|
|
|
|
# A link to the published revision.
|
|
|
|
# Corresponds to the JSON property `publishedLink`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :published_link
|
|
|
|
|
|
|
|
# Whether this revision is published outside the domain. This is only populated
|
|
|
|
# and can only be modified for Google Docs.
|
|
|
|
# Corresponds to the JSON property `publishedOutsideDomain`
|
|
|
|
# @return [Boolean]
|
|
|
|
attr_accessor :published_outside_domain
|
|
|
|
alias_method :published_outside_domain?, :published_outside_domain
|
|
|
|
|
|
|
|
# A link back to this revision.
|
|
|
|
# Corresponds to the JSON property `selfLink`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :self_link
|
|
|
|
|
|
|
|
def initialize(**args)
|
|
|
|
update!(**args)
|
|
|
|
end
|
|
|
|
|
|
|
|
# Update properties of this object
|
|
|
|
def update!(**args)
|
|
|
|
@download_url = args[:download_url] unless args[:download_url].nil?
|
|
|
|
@etag = args[:etag] unless args[:etag].nil?
|
|
|
|
@export_links = args[:export_links] unless args[:export_links].nil?
|
|
|
|
@file_size = args[:file_size] unless args[:file_size].nil?
|
|
|
|
@id = args[:id] unless args[:id].nil?
|
|
|
|
@kind = args[:kind] unless args[:kind].nil?
|
|
|
|
@last_modifying_user = args[:last_modifying_user] unless args[:last_modifying_user].nil?
|
|
|
|
@last_modifying_user_name = args[:last_modifying_user_name] unless args[:last_modifying_user_name].nil?
|
|
|
|
@md5_checksum = args[:md5_checksum] unless args[:md5_checksum].nil?
|
|
|
|
@mime_type = args[:mime_type] unless args[:mime_type].nil?
|
|
|
|
@modified_date = args[:modified_date] unless args[:modified_date].nil?
|
|
|
|
@original_filename = args[:original_filename] unless args[:original_filename].nil?
|
|
|
|
@pinned = args[:pinned] unless args[:pinned].nil?
|
|
|
|
@publish_auto = args[:publish_auto] unless args[:publish_auto].nil?
|
|
|
|
@published = args[:published] unless args[:published].nil?
|
|
|
|
@published_link = args[:published_link] unless args[:published_link].nil?
|
|
|
|
@published_outside_domain = args[:published_outside_domain] unless args[:published_outside_domain].nil?
|
|
|
|
@self_link = args[:self_link] unless args[:self_link].nil?
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
# A list of revisions of a file.
|
|
|
|
class RevisionList
|
|
|
|
include Google::Apis::Core::Hashable
|
|
|
|
|
|
|
|
# The ETag of the list.
|
|
|
|
# Corresponds to the JSON property `etag`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :etag
|
|
|
|
|
|
|
|
# The actual list of revisions.
|
|
|
|
# Corresponds to the JSON property `items`
|
|
|
|
# @return [Array<Google::Apis::DriveV2::Revision>]
|
|
|
|
attr_accessor :items
|
|
|
|
|
|
|
|
# This is always drive#revisionList.
|
|
|
|
# Corresponds to the JSON property `kind`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :kind
|
|
|
|
|
|
|
|
# A link back to this list.
|
|
|
|
# Corresponds to the JSON property `selfLink`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :self_link
|
|
|
|
|
|
|
|
def initialize(**args)
|
|
|
|
update!(**args)
|
|
|
|
end
|
|
|
|
|
|
|
|
# Update properties of this object
|
|
|
|
def update!(**args)
|
|
|
|
@etag = args[:etag] unless args[:etag].nil?
|
|
|
|
@items = args[:items] unless args[:items].nil?
|
|
|
|
@kind = args[:kind] unless args[:kind].nil?
|
|
|
|
@self_link = args[:self_link] unless args[:self_link].nil?
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
# The JSON template for a user.
|
|
|
|
class User
|
|
|
|
include Google::Apis::Core::Hashable
|
|
|
|
|
|
|
|
# A plain text displayable name for this user.
|
|
|
|
# Corresponds to the JSON property `displayName`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :display_name
|
|
|
|
|
|
|
|
# The email address of the user.
|
|
|
|
# Corresponds to the JSON property `emailAddress`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :email_address
|
|
|
|
|
|
|
|
# Whether this user is the same as the authenticated user for whom the request
|
|
|
|
# was made.
|
|
|
|
# Corresponds to the JSON property `isAuthenticatedUser`
|
|
|
|
# @return [Boolean]
|
|
|
|
attr_accessor :is_authenticated_user
|
|
|
|
alias_method :is_authenticated_user?, :is_authenticated_user
|
|
|
|
|
|
|
|
# This is always drive#user.
|
|
|
|
# Corresponds to the JSON property `kind`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :kind
|
|
|
|
|
|
|
|
# The user's ID as visible in the permissions collection.
|
|
|
|
# Corresponds to the JSON property `permissionId`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :permission_id
|
|
|
|
|
|
|
|
# The user's profile picture.
|
|
|
|
# Corresponds to the JSON property `picture`
|
|
|
|
# @return [Google::Apis::DriveV2::User::Picture]
|
|
|
|
attr_accessor :picture
|
|
|
|
|
|
|
|
def initialize(**args)
|
|
|
|
update!(**args)
|
|
|
|
end
|
|
|
|
|
|
|
|
# Update properties of this object
|
|
|
|
def update!(**args)
|
|
|
|
@display_name = args[:display_name] unless args[:display_name].nil?
|
|
|
|
@email_address = args[:email_address] unless args[:email_address].nil?
|
|
|
|
@is_authenticated_user = args[:is_authenticated_user] unless args[:is_authenticated_user].nil?
|
|
|
|
@kind = args[:kind] unless args[:kind].nil?
|
|
|
|
@permission_id = args[:permission_id] unless args[:permission_id].nil?
|
|
|
|
@picture = args[:picture] unless args[:picture].nil?
|
|
|
|
end
|
|
|
|
|
|
|
|
# The user's profile picture.
|
|
|
|
class Picture
|
|
|
|
include Google::Apis::Core::Hashable
|
|
|
|
|
|
|
|
# A URL that points to a profile picture of this user.
|
|
|
|
# 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)
|
|
|
|
@url = args[:url] unless args[:url].nil?
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|