2330 lines
		
	
	
		
			92 KiB
		
	
	
	
		
			Ruby
		
	
	
	
			
		
		
	
	
			2330 lines
		
	
	
		
			92 KiB
		
	
	
	
		
			Ruby
		
	
	
	
| # 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 DatastoreV1
 | |
|       
 | |
|       # The request for Datastore.AllocateIds.
 | |
|       class AllocateIdsRequest
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # A list of keys with incomplete key paths for which to allocate IDs.
 | |
|         # No key may be reserved/read-only.
 | |
|         # Corresponds to the JSON property `keys`
 | |
|         # @return [Array<Google::Apis::DatastoreV1::Key>]
 | |
|         attr_accessor :keys
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @keys = args[:keys] if args.key?(:keys)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # The response for Datastore.AllocateIds.
 | |
|       class AllocateIdsResponse
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # The keys specified in the request (in the same order), each with
 | |
|         # its key path completed with a newly allocated ID.
 | |
|         # Corresponds to the JSON property `keys`
 | |
|         # @return [Array<Google::Apis::DatastoreV1::Key>]
 | |
|         attr_accessor :keys
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @keys = args[:keys] if args.key?(:keys)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # An array value.
 | |
|       class ArrayValue
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # Values in the array.
 | |
|         # The order of values in an array is preserved as long as all values have
 | |
|         # identical settings for 'exclude_from_indexes'.
 | |
|         # Corresponds to the JSON property `values`
 | |
|         # @return [Array<Google::Apis::DatastoreV1::Value>]
 | |
|         attr_accessor :values
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @values = args[:values] if args.key?(:values)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # The request for Datastore.BeginTransaction.
 | |
|       class BeginTransactionRequest
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # Options for beginning a new transaction.
 | |
|         # Transactions can be created explicitly with calls to
 | |
|         # Datastore.BeginTransaction or implicitly by setting
 | |
|         # ReadOptions.new_transaction in read requests.
 | |
|         # Corresponds to the JSON property `transactionOptions`
 | |
|         # @return [Google::Apis::DatastoreV1::TransactionOptions]
 | |
|         attr_accessor :transaction_options
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @transaction_options = args[:transaction_options] if args.key?(:transaction_options)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # The response for Datastore.BeginTransaction.
 | |
|       class BeginTransactionResponse
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # The transaction identifier (always present).
 | |
|         # Corresponds to the JSON property `transaction`
 | |
|         # NOTE: Values are automatically base64 encoded/decoded in the client library.
 | |
|         # @return [String]
 | |
|         attr_accessor :transaction
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @transaction = args[:transaction] if args.key?(:transaction)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # The request for Datastore.Commit.
 | |
|       class CommitRequest
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # The type of commit to perform. Defaults to `TRANSACTIONAL`.
 | |
|         # Corresponds to the JSON property `mode`
 | |
|         # @return [String]
 | |
|         attr_accessor :mode
 | |
|       
 | |
|         # The mutations to perform.
 | |
|         # When mode is `TRANSACTIONAL`, mutations affecting a single entity are
 | |
|         # applied in order. The following sequences of mutations affecting a single
 | |
|         # entity are not permitted in a single `Commit` request:
 | |
|         # - `insert` followed by `insert`
 | |
|         # - `update` followed by `insert`
 | |
|         # - `upsert` followed by `insert`
 | |
|         # - `delete` followed by `update`
 | |
|         # When mode is `NON_TRANSACTIONAL`, no two mutations may affect a single
 | |
|         # entity.
 | |
|         # Corresponds to the JSON property `mutations`
 | |
|         # @return [Array<Google::Apis::DatastoreV1::Mutation>]
 | |
|         attr_accessor :mutations
 | |
|       
 | |
|         # The identifier of the transaction associated with the commit. A
 | |
|         # transaction identifier is returned by a call to
 | |
|         # Datastore.BeginTransaction.
 | |
|         # Corresponds to the JSON property `transaction`
 | |
|         # NOTE: Values are automatically base64 encoded/decoded in the client library.
 | |
|         # @return [String]
 | |
|         attr_accessor :transaction
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @mode = args[:mode] if args.key?(:mode)
 | |
|           @mutations = args[:mutations] if args.key?(:mutations)
 | |
|           @transaction = args[:transaction] if args.key?(:transaction)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # The response for Datastore.Commit.
 | |
|       class CommitResponse
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # The number of index entries updated during the commit, or zero if none were
 | |
|         # updated.
 | |
|         # Corresponds to the JSON property `indexUpdates`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :index_updates
 | |
|       
 | |
|         # The result of performing the mutations.
 | |
|         # The i-th mutation result corresponds to the i-th mutation in the request.
 | |
|         # Corresponds to the JSON property `mutationResults`
 | |
|         # @return [Array<Google::Apis::DatastoreV1::MutationResult>]
 | |
|         attr_accessor :mutation_results
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @index_updates = args[:index_updates] if args.key?(:index_updates)
 | |
|           @mutation_results = args[:mutation_results] if args.key?(:mutation_results)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # A filter that merges multiple other filters using the given operator.
 | |
|       class CompositeFilter
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # The list of filters to combine.
 | |
|         # Must contain at least one filter.
 | |
|         # Corresponds to the JSON property `filters`
 | |
|         # @return [Array<Google::Apis::DatastoreV1::Filter>]
 | |
|         attr_accessor :filters
 | |
|       
 | |
|         # The operator for combining multiple filters.
 | |
|         # Corresponds to the JSON property `op`
 | |
|         # @return [String]
 | |
|         attr_accessor :op
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @filters = args[:filters] if args.key?(:filters)
 | |
|           @op = args[:op] if args.key?(:op)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # A generic empty message that you can re-use to avoid defining duplicated
 | |
|       # empty messages in your APIs. A typical example is to use it as the request
 | |
|       # or the response type of an API method. For instance:
 | |
|       # service Foo `
 | |
|       # rpc Bar(google.protobuf.Empty) returns (google.protobuf.Empty);
 | |
|       # `
 | |
|       # The JSON representation for `Empty` is empty JSON object ````.
 | |
|       class Empty
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # A Datastore data object.
 | |
|       # An entity is limited to 1 megabyte when stored. That _roughly_
 | |
|       # corresponds to a limit of 1 megabyte for the serialized form of this
 | |
|       # message.
 | |
|       class Entity
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # A unique identifier for an entity.
 | |
|         # If a key's partition ID or any of its path kinds or names are
 | |
|         # reserved/read-only, the key is reserved/read-only.
 | |
|         # A reserved/read-only key is forbidden in certain documented contexts.
 | |
|         # Corresponds to the JSON property `key`
 | |
|         # @return [Google::Apis::DatastoreV1::Key]
 | |
|         attr_accessor :key
 | |
|       
 | |
|         # The entity's properties.
 | |
|         # The map's keys are property names.
 | |
|         # A property name matching regex `__.*__` is reserved.
 | |
|         # A reserved property name is forbidden in certain documented contexts.
 | |
|         # The name must not contain more than 500 characters.
 | |
|         # The name cannot be `""`.
 | |
|         # Corresponds to the JSON property `properties`
 | |
|         # @return [Hash<String,Google::Apis::DatastoreV1::Value>]
 | |
|         attr_accessor :properties
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @key = args[:key] if args.key?(:key)
 | |
|           @properties = args[:properties] if args.key?(:properties)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # The result of fetching an entity from Datastore.
 | |
|       class EntityResult
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # A cursor that points to the position after the result entity.
 | |
|         # Set only when the `EntityResult` is part of a `QueryResultBatch` message.
 | |
|         # Corresponds to the JSON property `cursor`
 | |
|         # NOTE: Values are automatically base64 encoded/decoded in the client library.
 | |
|         # @return [String]
 | |
|         attr_accessor :cursor
 | |
|       
 | |
|         # A Datastore data object.
 | |
|         # An entity is limited to 1 megabyte when stored. That _roughly_
 | |
|         # corresponds to a limit of 1 megabyte for the serialized form of this
 | |
|         # message.
 | |
|         # Corresponds to the JSON property `entity`
 | |
|         # @return [Google::Apis::DatastoreV1::Entity]
 | |
|         attr_accessor :entity
 | |
|       
 | |
|         # The version of the entity, a strictly positive number that monotonically
 | |
|         # increases with changes to the entity.
 | |
|         # This field is set for `FULL` entity
 | |
|         # results.
 | |
|         # For missing entities in `LookupResponse`, this
 | |
|         # is the version of the snapshot that was used to look up the entity, and it
 | |
|         # is always set except for eventually consistent reads.
 | |
|         # Corresponds to the JSON property `version`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :version
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @cursor = args[:cursor] if args.key?(:cursor)
 | |
|           @entity = args[:entity] if args.key?(:entity)
 | |
|           @version = args[:version] if args.key?(:version)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # A holder for any type of filter.
 | |
|       class Filter
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # A filter that merges multiple other filters using the given operator.
 | |
|         # Corresponds to the JSON property `compositeFilter`
 | |
|         # @return [Google::Apis::DatastoreV1::CompositeFilter]
 | |
|         attr_accessor :composite_filter
 | |
|       
 | |
|         # A filter on a specific property.
 | |
|         # Corresponds to the JSON property `propertyFilter`
 | |
|         # @return [Google::Apis::DatastoreV1::PropertyFilter]
 | |
|         attr_accessor :property_filter
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @composite_filter = args[:composite_filter] if args.key?(:composite_filter)
 | |
|           @property_filter = args[:property_filter] if args.key?(:property_filter)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # Metadata common to all Datastore Admin operations.
 | |
|       class GoogleDatastoreAdminV1CommonMetadata
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # The time the operation ended, either successfully or otherwise.
 | |
|         # Corresponds to the JSON property `endTime`
 | |
|         # @return [String]
 | |
|         attr_accessor :end_time
 | |
|       
 | |
|         # The client-assigned labels which were provided when the operation was
 | |
|         # created. May also include additional labels.
 | |
|         # Corresponds to the JSON property `labels`
 | |
|         # @return [Hash<String,String>]
 | |
|         attr_accessor :labels
 | |
|       
 | |
|         # The type of the operation. Can be used as a filter in
 | |
|         # ListOperationsRequest.
 | |
|         # Corresponds to the JSON property `operationType`
 | |
|         # @return [String]
 | |
|         attr_accessor :operation_type
 | |
|       
 | |
|         # The time that work began on the operation.
 | |
|         # Corresponds to the JSON property `startTime`
 | |
|         # @return [String]
 | |
|         attr_accessor :start_time
 | |
|       
 | |
|         # The current state of the Operation.
 | |
|         # Corresponds to the JSON property `state`
 | |
|         # @return [String]
 | |
|         attr_accessor :state
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @end_time = args[:end_time] if args.key?(:end_time)
 | |
|           @labels = args[:labels] if args.key?(:labels)
 | |
|           @operation_type = args[:operation_type] if args.key?(:operation_type)
 | |
|           @start_time = args[:start_time] if args.key?(:start_time)
 | |
|           @state = args[:state] if args.key?(:state)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # Identifies a subset of entities in a project. This is specified as
 | |
|       # combinations of kinds and namespaces (either or both of which may be all, as
 | |
|       # described in the following examples).
 | |
|       # Example usage:
 | |
|       # Entire project:
 | |
|       # kinds=[], namespace_ids=[]
 | |
|       # Kinds Foo and Bar in all namespaces:
 | |
|       # kinds=['Foo', 'Bar'], namespace_ids=[]
 | |
|       # Kinds Foo and Bar only in the default namespace:
 | |
|       # kinds=['Foo', 'Bar'], namespace_ids=['']
 | |
|       # Kinds Foo and Bar in both the default and Baz namespaces:
 | |
|       # kinds=['Foo', 'Bar'], namespace_ids=['', 'Baz']
 | |
|       # The entire Baz namespace:
 | |
|       # kinds=[], namespace_ids=['Baz']
 | |
|       class GoogleDatastoreAdminV1EntityFilter
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # If empty, then this represents all kinds.
 | |
|         # Corresponds to the JSON property `kinds`
 | |
|         # @return [Array<String>]
 | |
|         attr_accessor :kinds
 | |
|       
 | |
|         # An empty list represents all namespaces. This is the preferred
 | |
|         # usage for projects that don't use namespaces.
 | |
|         # An empty string element represents the default namespace. This should be
 | |
|         # used if the project has data in non-default namespaces, but doesn't want to
 | |
|         # include them.
 | |
|         # Each namespace in this list must be unique.
 | |
|         # Corresponds to the JSON property `namespaceIds`
 | |
|         # @return [Array<String>]
 | |
|         attr_accessor :namespace_ids
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @kinds = args[:kinds] if args.key?(:kinds)
 | |
|           @namespace_ids = args[:namespace_ids] if args.key?(:namespace_ids)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # Metadata for ExportEntities operations.
 | |
|       class GoogleDatastoreAdminV1ExportEntitiesMetadata
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # Metadata common to all Datastore Admin operations.
 | |
|         # Corresponds to the JSON property `common`
 | |
|         # @return [Google::Apis::DatastoreV1::GoogleDatastoreAdminV1CommonMetadata]
 | |
|         attr_accessor :common
 | |
|       
 | |
|         # Identifies a subset of entities in a project. This is specified as
 | |
|         # combinations of kinds and namespaces (either or both of which may be all, as
 | |
|         # described in the following examples).
 | |
|         # Example usage:
 | |
|         # Entire project:
 | |
|         # kinds=[], namespace_ids=[]
 | |
|         # Kinds Foo and Bar in all namespaces:
 | |
|         # kinds=['Foo', 'Bar'], namespace_ids=[]
 | |
|         # Kinds Foo and Bar only in the default namespace:
 | |
|         # kinds=['Foo', 'Bar'], namespace_ids=['']
 | |
|         # Kinds Foo and Bar in both the default and Baz namespaces:
 | |
|         # kinds=['Foo', 'Bar'], namespace_ids=['', 'Baz']
 | |
|         # The entire Baz namespace:
 | |
|         # kinds=[], namespace_ids=['Baz']
 | |
|         # Corresponds to the JSON property `entityFilter`
 | |
|         # @return [Google::Apis::DatastoreV1::GoogleDatastoreAdminV1EntityFilter]
 | |
|         attr_accessor :entity_filter
 | |
|       
 | |
|         # Location for the export metadata and data files. This will be the same
 | |
|         # value as the
 | |
|         # google.datastore.admin.v1.ExportEntitiesRequest.output_url_prefix
 | |
|         # field. The final output location is provided in
 | |
|         # google.datastore.admin.v1.ExportEntitiesResponse.output_url.
 | |
|         # Corresponds to the JSON property `outputUrlPrefix`
 | |
|         # @return [String]
 | |
|         attr_accessor :output_url_prefix
 | |
|       
 | |
|         # Measures the progress of a particular metric.
 | |
|         # Corresponds to the JSON property `progressBytes`
 | |
|         # @return [Google::Apis::DatastoreV1::GoogleDatastoreAdminV1Progress]
 | |
|         attr_accessor :progress_bytes
 | |
|       
 | |
|         # Measures the progress of a particular metric.
 | |
|         # Corresponds to the JSON property `progressEntities`
 | |
|         # @return [Google::Apis::DatastoreV1::GoogleDatastoreAdminV1Progress]
 | |
|         attr_accessor :progress_entities
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @common = args[:common] if args.key?(:common)
 | |
|           @entity_filter = args[:entity_filter] if args.key?(:entity_filter)
 | |
|           @output_url_prefix = args[:output_url_prefix] if args.key?(:output_url_prefix)
 | |
|           @progress_bytes = args[:progress_bytes] if args.key?(:progress_bytes)
 | |
|           @progress_entities = args[:progress_entities] if args.key?(:progress_entities)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # The request for
 | |
|       # google.datastore.admin.v1.DatastoreAdmin.ExportEntities.
 | |
|       class GoogleDatastoreAdminV1ExportEntitiesRequest
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # Identifies a subset of entities in a project. This is specified as
 | |
|         # combinations of kinds and namespaces (either or both of which may be all, as
 | |
|         # described in the following examples).
 | |
|         # Example usage:
 | |
|         # Entire project:
 | |
|         # kinds=[], namespace_ids=[]
 | |
|         # Kinds Foo and Bar in all namespaces:
 | |
|         # kinds=['Foo', 'Bar'], namespace_ids=[]
 | |
|         # Kinds Foo and Bar only in the default namespace:
 | |
|         # kinds=['Foo', 'Bar'], namespace_ids=['']
 | |
|         # Kinds Foo and Bar in both the default and Baz namespaces:
 | |
|         # kinds=['Foo', 'Bar'], namespace_ids=['', 'Baz']
 | |
|         # The entire Baz namespace:
 | |
|         # kinds=[], namespace_ids=['Baz']
 | |
|         # Corresponds to the JSON property `entityFilter`
 | |
|         # @return [Google::Apis::DatastoreV1::GoogleDatastoreAdminV1EntityFilter]
 | |
|         attr_accessor :entity_filter
 | |
|       
 | |
|         # Client-assigned labels.
 | |
|         # Corresponds to the JSON property `labels`
 | |
|         # @return [Hash<String,String>]
 | |
|         attr_accessor :labels
 | |
|       
 | |
|         # Location for the export metadata and data files.
 | |
|         # The full resource URL of the external storage location. Currently, only
 | |
|         # Google Cloud Storage is supported. So output_url_prefix should be of the
 | |
|         # form: `gs://BUCKET_NAME[/NAMESPACE_PATH]`, where `BUCKET_NAME` is the
 | |
|         # name of the Cloud Storage bucket and `NAMESPACE_PATH` is an optional Cloud
 | |
|         # Storage namespace path (this is not a Cloud Datastore namespace). For more
 | |
|         # information about Cloud Storage namespace paths, see
 | |
|         # [Object name
 | |
|         # considerations](https://cloud.google.com/storage/docs/naming#object-
 | |
|         # considerations).
 | |
|         # The resulting files will be nested deeper than the specified URL prefix.
 | |
|         # The final output URL will be provided in the
 | |
|         # google.datastore.admin.v1.ExportEntitiesResponse.output_url field. That
 | |
|         # value should be used for subsequent ImportEntities operations.
 | |
|         # By nesting the data files deeper, the same Cloud Storage bucket can be used
 | |
|         # in multiple ExportEntities operations without conflict.
 | |
|         # Corresponds to the JSON property `outputUrlPrefix`
 | |
|         # @return [String]
 | |
|         attr_accessor :output_url_prefix
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @entity_filter = args[:entity_filter] if args.key?(:entity_filter)
 | |
|           @labels = args[:labels] if args.key?(:labels)
 | |
|           @output_url_prefix = args[:output_url_prefix] if args.key?(:output_url_prefix)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # The response for
 | |
|       # google.datastore.admin.v1.DatastoreAdmin.ExportEntities.
 | |
|       class GoogleDatastoreAdminV1ExportEntitiesResponse
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # Location of the output metadata file. This can be used to begin an import
 | |
|         # into Cloud Datastore (this project or another project). See
 | |
|         # google.datastore.admin.v1.ImportEntitiesRequest.input_url.
 | |
|         # Only present if the operation completed successfully.
 | |
|         # Corresponds to the JSON property `outputUrl`
 | |
|         # @return [String]
 | |
|         attr_accessor :output_url
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @output_url = args[:output_url] if args.key?(:output_url)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # Metadata for ImportEntities operations.
 | |
|       class GoogleDatastoreAdminV1ImportEntitiesMetadata
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # Metadata common to all Datastore Admin operations.
 | |
|         # Corresponds to the JSON property `common`
 | |
|         # @return [Google::Apis::DatastoreV1::GoogleDatastoreAdminV1CommonMetadata]
 | |
|         attr_accessor :common
 | |
|       
 | |
|         # Identifies a subset of entities in a project. This is specified as
 | |
|         # combinations of kinds and namespaces (either or both of which may be all, as
 | |
|         # described in the following examples).
 | |
|         # Example usage:
 | |
|         # Entire project:
 | |
|         # kinds=[], namespace_ids=[]
 | |
|         # Kinds Foo and Bar in all namespaces:
 | |
|         # kinds=['Foo', 'Bar'], namespace_ids=[]
 | |
|         # Kinds Foo and Bar only in the default namespace:
 | |
|         # kinds=['Foo', 'Bar'], namespace_ids=['']
 | |
|         # Kinds Foo and Bar in both the default and Baz namespaces:
 | |
|         # kinds=['Foo', 'Bar'], namespace_ids=['', 'Baz']
 | |
|         # The entire Baz namespace:
 | |
|         # kinds=[], namespace_ids=['Baz']
 | |
|         # Corresponds to the JSON property `entityFilter`
 | |
|         # @return [Google::Apis::DatastoreV1::GoogleDatastoreAdminV1EntityFilter]
 | |
|         attr_accessor :entity_filter
 | |
|       
 | |
|         # The location of the import metadata file. This will be the same value as
 | |
|         # the google.datastore.admin.v1.ExportEntitiesResponse.output_url field.
 | |
|         # Corresponds to the JSON property `inputUrl`
 | |
|         # @return [String]
 | |
|         attr_accessor :input_url
 | |
|       
 | |
|         # Measures the progress of a particular metric.
 | |
|         # Corresponds to the JSON property `progressBytes`
 | |
|         # @return [Google::Apis::DatastoreV1::GoogleDatastoreAdminV1Progress]
 | |
|         attr_accessor :progress_bytes
 | |
|       
 | |
|         # Measures the progress of a particular metric.
 | |
|         # Corresponds to the JSON property `progressEntities`
 | |
|         # @return [Google::Apis::DatastoreV1::GoogleDatastoreAdminV1Progress]
 | |
|         attr_accessor :progress_entities
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @common = args[:common] if args.key?(:common)
 | |
|           @entity_filter = args[:entity_filter] if args.key?(:entity_filter)
 | |
|           @input_url = args[:input_url] if args.key?(:input_url)
 | |
|           @progress_bytes = args[:progress_bytes] if args.key?(:progress_bytes)
 | |
|           @progress_entities = args[:progress_entities] if args.key?(:progress_entities)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # The request for
 | |
|       # google.datastore.admin.v1.DatastoreAdmin.ImportEntities.
 | |
|       class GoogleDatastoreAdminV1ImportEntitiesRequest
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # Identifies a subset of entities in a project. This is specified as
 | |
|         # combinations of kinds and namespaces (either or both of which may be all, as
 | |
|         # described in the following examples).
 | |
|         # Example usage:
 | |
|         # Entire project:
 | |
|         # kinds=[], namespace_ids=[]
 | |
|         # Kinds Foo and Bar in all namespaces:
 | |
|         # kinds=['Foo', 'Bar'], namespace_ids=[]
 | |
|         # Kinds Foo and Bar only in the default namespace:
 | |
|         # kinds=['Foo', 'Bar'], namespace_ids=['']
 | |
|         # Kinds Foo and Bar in both the default and Baz namespaces:
 | |
|         # kinds=['Foo', 'Bar'], namespace_ids=['', 'Baz']
 | |
|         # The entire Baz namespace:
 | |
|         # kinds=[], namespace_ids=['Baz']
 | |
|         # Corresponds to the JSON property `entityFilter`
 | |
|         # @return [Google::Apis::DatastoreV1::GoogleDatastoreAdminV1EntityFilter]
 | |
|         attr_accessor :entity_filter
 | |
|       
 | |
|         # The full resource URL of the external storage location. Currently, only
 | |
|         # Google Cloud Storage is supported. So input_url should be of the form:
 | |
|         # `gs://BUCKET_NAME[/NAMESPACE_PATH]/OVERALL_EXPORT_METADATA_FILE`, where
 | |
|         # `BUCKET_NAME` is the name of the Cloud Storage bucket, `NAMESPACE_PATH` is
 | |
|         # an optional Cloud Storage namespace path (this is not a Cloud Datastore
 | |
|         # namespace), and `OVERALL_EXPORT_METADATA_FILE` is the metadata file written
 | |
|         # by the ExportEntities operation. For more information about Cloud Storage
 | |
|         # namespace paths, see
 | |
|         # [Object name
 | |
|         # considerations](https://cloud.google.com/storage/docs/naming#object-
 | |
|         # considerations).
 | |
|         # For more information, see
 | |
|         # google.datastore.admin.v1.ExportEntitiesResponse.output_url.
 | |
|         # Corresponds to the JSON property `inputUrl`
 | |
|         # @return [String]
 | |
|         attr_accessor :input_url
 | |
|       
 | |
|         # Client-assigned labels.
 | |
|         # Corresponds to the JSON property `labels`
 | |
|         # @return [Hash<String,String>]
 | |
|         attr_accessor :labels
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @entity_filter = args[:entity_filter] if args.key?(:entity_filter)
 | |
|           @input_url = args[:input_url] if args.key?(:input_url)
 | |
|           @labels = args[:labels] if args.key?(:labels)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # A minimal index definition.
 | |
|       class GoogleDatastoreAdminV1Index
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # The index's ancestor mode.  Must not be ANCESTOR_MODE_UNSPECIFIED.
 | |
|         # Required.
 | |
|         # Corresponds to the JSON property `ancestor`
 | |
|         # @return [String]
 | |
|         attr_accessor :ancestor
 | |
|       
 | |
|         # The resource ID of the index.
 | |
|         # Output only.
 | |
|         # Corresponds to the JSON property `indexId`
 | |
|         # @return [String]
 | |
|         attr_accessor :index_id
 | |
|       
 | |
|         # The entity kind to which this index applies.
 | |
|         # Required.
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         # Project ID.
 | |
|         # Output only.
 | |
|         # Corresponds to the JSON property `projectId`
 | |
|         # @return [String]
 | |
|         attr_accessor :project_id
 | |
|       
 | |
|         # An ordered sequence of property names and their index attributes.
 | |
|         # Required.
 | |
|         # Corresponds to the JSON property `properties`
 | |
|         # @return [Array<Google::Apis::DatastoreV1::GoogleDatastoreAdminV1IndexedProperty>]
 | |
|         attr_accessor :properties
 | |
|       
 | |
|         # The state of the index.
 | |
|         # Output only.
 | |
|         # Corresponds to the JSON property `state`
 | |
|         # @return [String]
 | |
|         attr_accessor :state
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @ancestor = args[:ancestor] if args.key?(:ancestor)
 | |
|           @index_id = args[:index_id] if args.key?(:index_id)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|           @project_id = args[:project_id] if args.key?(:project_id)
 | |
|           @properties = args[:properties] if args.key?(:properties)
 | |
|           @state = args[:state] if args.key?(:state)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # Metadata for Index operations.
 | |
|       class GoogleDatastoreAdminV1IndexOperationMetadata
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # Metadata common to all Datastore Admin operations.
 | |
|         # Corresponds to the JSON property `common`
 | |
|         # @return [Google::Apis::DatastoreV1::GoogleDatastoreAdminV1CommonMetadata]
 | |
|         attr_accessor :common
 | |
|       
 | |
|         # The index resource ID that this operation is acting on.
 | |
|         # Corresponds to the JSON property `indexId`
 | |
|         # @return [String]
 | |
|         attr_accessor :index_id
 | |
|       
 | |
|         # Measures the progress of a particular metric.
 | |
|         # Corresponds to the JSON property `progressEntities`
 | |
|         # @return [Google::Apis::DatastoreV1::GoogleDatastoreAdminV1Progress]
 | |
|         attr_accessor :progress_entities
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @common = args[:common] if args.key?(:common)
 | |
|           @index_id = args[:index_id] if args.key?(:index_id)
 | |
|           @progress_entities = args[:progress_entities] if args.key?(:progress_entities)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # A property of an index.
 | |
|       class GoogleDatastoreAdminV1IndexedProperty
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # The indexed property's direction.  Must not be DIRECTION_UNSPECIFIED.
 | |
|         # Required.
 | |
|         # Corresponds to the JSON property `direction`
 | |
|         # @return [String]
 | |
|         attr_accessor :direction
 | |
|       
 | |
|         # The property name to index.
 | |
|         # Required.
 | |
|         # Corresponds to the JSON property `name`
 | |
|         # @return [String]
 | |
|         attr_accessor :name
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @direction = args[:direction] if args.key?(:direction)
 | |
|           @name = args[:name] if args.key?(:name)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # The response for
 | |
|       # google.datastore.admin.v1.DatastoreAdmin.ListIndexes.
 | |
|       class GoogleDatastoreAdminV1ListIndexesResponse
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # The indexes.
 | |
|         # Corresponds to the JSON property `indexes`
 | |
|         # @return [Array<Google::Apis::DatastoreV1::GoogleDatastoreAdminV1Index>]
 | |
|         attr_accessor :indexes
 | |
|       
 | |
|         # The standard List next-page token.
 | |
|         # Corresponds to the JSON property `nextPageToken`
 | |
|         # @return [String]
 | |
|         attr_accessor :next_page_token
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @indexes = args[:indexes] if args.key?(:indexes)
 | |
|           @next_page_token = args[:next_page_token] if args.key?(:next_page_token)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # Measures the progress of a particular metric.
 | |
|       class GoogleDatastoreAdminV1Progress
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # The amount of work that has been completed. Note that this may be greater
 | |
|         # than work_estimated.
 | |
|         # Corresponds to the JSON property `workCompleted`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :work_completed
 | |
|       
 | |
|         # An estimate of how much work needs to be performed. May be zero if the
 | |
|         # work estimate is unavailable.
 | |
|         # Corresponds to the JSON property `workEstimated`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :work_estimated
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @work_completed = args[:work_completed] if args.key?(:work_completed)
 | |
|           @work_estimated = args[:work_estimated] if args.key?(:work_estimated)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # Metadata common to all Datastore Admin operations.
 | |
|       class GoogleDatastoreAdminV1beta1CommonMetadata
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # The time the operation ended, either successfully or otherwise.
 | |
|         # Corresponds to the JSON property `endTime`
 | |
|         # @return [String]
 | |
|         attr_accessor :end_time
 | |
|       
 | |
|         # The client-assigned labels which were provided when the operation was
 | |
|         # created. May also include additional labels.
 | |
|         # Corresponds to the JSON property `labels`
 | |
|         # @return [Hash<String,String>]
 | |
|         attr_accessor :labels
 | |
|       
 | |
|         # The type of the operation. Can be used as a filter in
 | |
|         # ListOperationsRequest.
 | |
|         # Corresponds to the JSON property `operationType`
 | |
|         # @return [String]
 | |
|         attr_accessor :operation_type
 | |
|       
 | |
|         # The time that work began on the operation.
 | |
|         # Corresponds to the JSON property `startTime`
 | |
|         # @return [String]
 | |
|         attr_accessor :start_time
 | |
|       
 | |
|         # The current state of the Operation.
 | |
|         # Corresponds to the JSON property `state`
 | |
|         # @return [String]
 | |
|         attr_accessor :state
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @end_time = args[:end_time] if args.key?(:end_time)
 | |
|           @labels = args[:labels] if args.key?(:labels)
 | |
|           @operation_type = args[:operation_type] if args.key?(:operation_type)
 | |
|           @start_time = args[:start_time] if args.key?(:start_time)
 | |
|           @state = args[:state] if args.key?(:state)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # Identifies a subset of entities in a project. This is specified as
 | |
|       # combinations of kinds and namespaces (either or both of which may be all, as
 | |
|       # described in the following examples).
 | |
|       # Example usage:
 | |
|       # Entire project:
 | |
|       # kinds=[], namespace_ids=[]
 | |
|       # Kinds Foo and Bar in all namespaces:
 | |
|       # kinds=['Foo', 'Bar'], namespace_ids=[]
 | |
|       # Kinds Foo and Bar only in the default namespace:
 | |
|       # kinds=['Foo', 'Bar'], namespace_ids=['']
 | |
|       # Kinds Foo and Bar in both the default and Baz namespaces:
 | |
|       # kinds=['Foo', 'Bar'], namespace_ids=['', 'Baz']
 | |
|       # The entire Baz namespace:
 | |
|       # kinds=[], namespace_ids=['Baz']
 | |
|       class GoogleDatastoreAdminV1beta1EntityFilter
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # If empty, then this represents all kinds.
 | |
|         # Corresponds to the JSON property `kinds`
 | |
|         # @return [Array<String>]
 | |
|         attr_accessor :kinds
 | |
|       
 | |
|         # An empty list represents all namespaces. This is the preferred
 | |
|         # usage for projects that don't use namespaces.
 | |
|         # An empty string element represents the default namespace. This should be
 | |
|         # used if the project has data in non-default namespaces, but doesn't want to
 | |
|         # include them.
 | |
|         # Each namespace in this list must be unique.
 | |
|         # Corresponds to the JSON property `namespaceIds`
 | |
|         # @return [Array<String>]
 | |
|         attr_accessor :namespace_ids
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @kinds = args[:kinds] if args.key?(:kinds)
 | |
|           @namespace_ids = args[:namespace_ids] if args.key?(:namespace_ids)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # Metadata for ExportEntities operations.
 | |
|       class GoogleDatastoreAdminV1beta1ExportEntitiesMetadata
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # Metadata common to all Datastore Admin operations.
 | |
|         # Corresponds to the JSON property `common`
 | |
|         # @return [Google::Apis::DatastoreV1::GoogleDatastoreAdminV1beta1CommonMetadata]
 | |
|         attr_accessor :common
 | |
|       
 | |
|         # Identifies a subset of entities in a project. This is specified as
 | |
|         # combinations of kinds and namespaces (either or both of which may be all, as
 | |
|         # described in the following examples).
 | |
|         # Example usage:
 | |
|         # Entire project:
 | |
|         # kinds=[], namespace_ids=[]
 | |
|         # Kinds Foo and Bar in all namespaces:
 | |
|         # kinds=['Foo', 'Bar'], namespace_ids=[]
 | |
|         # Kinds Foo and Bar only in the default namespace:
 | |
|         # kinds=['Foo', 'Bar'], namespace_ids=['']
 | |
|         # Kinds Foo and Bar in both the default and Baz namespaces:
 | |
|         # kinds=['Foo', 'Bar'], namespace_ids=['', 'Baz']
 | |
|         # The entire Baz namespace:
 | |
|         # kinds=[], namespace_ids=['Baz']
 | |
|         # Corresponds to the JSON property `entityFilter`
 | |
|         # @return [Google::Apis::DatastoreV1::GoogleDatastoreAdminV1beta1EntityFilter]
 | |
|         attr_accessor :entity_filter
 | |
|       
 | |
|         # Location for the export metadata and data files. This will be the same
 | |
|         # value as the
 | |
|         # google.datastore.admin.v1beta1.ExportEntitiesRequest.output_url_prefix
 | |
|         # field. The final output location is provided in
 | |
|         # google.datastore.admin.v1beta1.ExportEntitiesResponse.output_url.
 | |
|         # Corresponds to the JSON property `outputUrlPrefix`
 | |
|         # @return [String]
 | |
|         attr_accessor :output_url_prefix
 | |
|       
 | |
|         # Measures the progress of a particular metric.
 | |
|         # Corresponds to the JSON property `progressBytes`
 | |
|         # @return [Google::Apis::DatastoreV1::GoogleDatastoreAdminV1beta1Progress]
 | |
|         attr_accessor :progress_bytes
 | |
|       
 | |
|         # Measures the progress of a particular metric.
 | |
|         # Corresponds to the JSON property `progressEntities`
 | |
|         # @return [Google::Apis::DatastoreV1::GoogleDatastoreAdminV1beta1Progress]
 | |
|         attr_accessor :progress_entities
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @common = args[:common] if args.key?(:common)
 | |
|           @entity_filter = args[:entity_filter] if args.key?(:entity_filter)
 | |
|           @output_url_prefix = args[:output_url_prefix] if args.key?(:output_url_prefix)
 | |
|           @progress_bytes = args[:progress_bytes] if args.key?(:progress_bytes)
 | |
|           @progress_entities = args[:progress_entities] if args.key?(:progress_entities)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # The response for
 | |
|       # google.datastore.admin.v1beta1.DatastoreAdmin.ExportEntities.
 | |
|       class GoogleDatastoreAdminV1beta1ExportEntitiesResponse
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # Location of the output metadata file. This can be used to begin an import
 | |
|         # into Cloud Datastore (this project or another project). See
 | |
|         # google.datastore.admin.v1beta1.ImportEntitiesRequest.input_url.
 | |
|         # Only present if the operation completed successfully.
 | |
|         # Corresponds to the JSON property `outputUrl`
 | |
|         # @return [String]
 | |
|         attr_accessor :output_url
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @output_url = args[:output_url] if args.key?(:output_url)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # Metadata for ImportEntities operations.
 | |
|       class GoogleDatastoreAdminV1beta1ImportEntitiesMetadata
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # Metadata common to all Datastore Admin operations.
 | |
|         # Corresponds to the JSON property `common`
 | |
|         # @return [Google::Apis::DatastoreV1::GoogleDatastoreAdminV1beta1CommonMetadata]
 | |
|         attr_accessor :common
 | |
|       
 | |
|         # Identifies a subset of entities in a project. This is specified as
 | |
|         # combinations of kinds and namespaces (either or both of which may be all, as
 | |
|         # described in the following examples).
 | |
|         # Example usage:
 | |
|         # Entire project:
 | |
|         # kinds=[], namespace_ids=[]
 | |
|         # Kinds Foo and Bar in all namespaces:
 | |
|         # kinds=['Foo', 'Bar'], namespace_ids=[]
 | |
|         # Kinds Foo and Bar only in the default namespace:
 | |
|         # kinds=['Foo', 'Bar'], namespace_ids=['']
 | |
|         # Kinds Foo and Bar in both the default and Baz namespaces:
 | |
|         # kinds=['Foo', 'Bar'], namespace_ids=['', 'Baz']
 | |
|         # The entire Baz namespace:
 | |
|         # kinds=[], namespace_ids=['Baz']
 | |
|         # Corresponds to the JSON property `entityFilter`
 | |
|         # @return [Google::Apis::DatastoreV1::GoogleDatastoreAdminV1beta1EntityFilter]
 | |
|         attr_accessor :entity_filter
 | |
|       
 | |
|         # The location of the import metadata file. This will be the same value as
 | |
|         # the google.datastore.admin.v1beta1.ExportEntitiesResponse.output_url
 | |
|         # field.
 | |
|         # Corresponds to the JSON property `inputUrl`
 | |
|         # @return [String]
 | |
|         attr_accessor :input_url
 | |
|       
 | |
|         # Measures the progress of a particular metric.
 | |
|         # Corresponds to the JSON property `progressBytes`
 | |
|         # @return [Google::Apis::DatastoreV1::GoogleDatastoreAdminV1beta1Progress]
 | |
|         attr_accessor :progress_bytes
 | |
|       
 | |
|         # Measures the progress of a particular metric.
 | |
|         # Corresponds to the JSON property `progressEntities`
 | |
|         # @return [Google::Apis::DatastoreV1::GoogleDatastoreAdminV1beta1Progress]
 | |
|         attr_accessor :progress_entities
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @common = args[:common] if args.key?(:common)
 | |
|           @entity_filter = args[:entity_filter] if args.key?(:entity_filter)
 | |
|           @input_url = args[:input_url] if args.key?(:input_url)
 | |
|           @progress_bytes = args[:progress_bytes] if args.key?(:progress_bytes)
 | |
|           @progress_entities = args[:progress_entities] if args.key?(:progress_entities)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # Measures the progress of a particular metric.
 | |
|       class GoogleDatastoreAdminV1beta1Progress
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # The amount of work that has been completed. Note that this may be greater
 | |
|         # than work_estimated.
 | |
|         # Corresponds to the JSON property `workCompleted`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :work_completed
 | |
|       
 | |
|         # An estimate of how much work needs to be performed. May be zero if the
 | |
|         # work estimate is unavailable.
 | |
|         # Corresponds to the JSON property `workEstimated`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :work_estimated
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @work_completed = args[:work_completed] if args.key?(:work_completed)
 | |
|           @work_estimated = args[:work_estimated] if args.key?(:work_estimated)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # The response message for Operations.ListOperations.
 | |
|       class GoogleLongrunningListOperationsResponse
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # The standard List next-page token.
 | |
|         # Corresponds to the JSON property `nextPageToken`
 | |
|         # @return [String]
 | |
|         attr_accessor :next_page_token
 | |
|       
 | |
|         # A list of operations that matches the specified filter in the request.
 | |
|         # Corresponds to the JSON property `operations`
 | |
|         # @return [Array<Google::Apis::DatastoreV1::GoogleLongrunningOperation>]
 | |
|         attr_accessor :operations
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @next_page_token = args[:next_page_token] if args.key?(:next_page_token)
 | |
|           @operations = args[:operations] if args.key?(:operations)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # This resource represents a long-running operation that is the result of a
 | |
|       # network API call.
 | |
|       class GoogleLongrunningOperation
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # If the value is `false`, it means the operation is still in progress.
 | |
|         # If `true`, the operation is completed, and either `error` or `response` is
 | |
|         # available.
 | |
|         # Corresponds to the JSON property `done`
 | |
|         # @return [Boolean]
 | |
|         attr_accessor :done
 | |
|         alias_method :done?, :done
 | |
|       
 | |
|         # The `Status` type defines a logical error model that is suitable for
 | |
|         # different programming environments, including REST APIs and RPC APIs. It is
 | |
|         # used by [gRPC](https://github.com/grpc). The error model is designed to be:
 | |
|         # - Simple to use and understand for most users
 | |
|         # - Flexible enough to meet unexpected needs
 | |
|         # # Overview
 | |
|         # The `Status` message contains three pieces of data: error code, error
 | |
|         # message, and error details. The error code should be an enum value of
 | |
|         # google.rpc.Code, but it may accept additional error codes if needed.  The
 | |
|         # error message should be a developer-facing English message that helps
 | |
|         # developers *understand* and *resolve* the error. If a localized user-facing
 | |
|         # error message is needed, put the localized message in the error details or
 | |
|         # localize it in the client. The optional error details may contain arbitrary
 | |
|         # information about the error. There is a predefined set of error detail types
 | |
|         # in the package `google.rpc` that can be used for common error conditions.
 | |
|         # # Language mapping
 | |
|         # The `Status` message is the logical representation of the error model, but it
 | |
|         # is not necessarily the actual wire format. When the `Status` message is
 | |
|         # exposed in different client libraries and different wire protocols, it can be
 | |
|         # mapped differently. For example, it will likely be mapped to some exceptions
 | |
|         # in Java, but more likely mapped to some error codes in C.
 | |
|         # # Other uses
 | |
|         # The error model and the `Status` message can be used in a variety of
 | |
|         # environments, either with or without APIs, to provide a
 | |
|         # consistent developer experience across different environments.
 | |
|         # Example uses of this error model include:
 | |
|         # - Partial errors. If a service needs to return partial errors to the client,
 | |
|         # it may embed the `Status` in the normal response to indicate the partial
 | |
|         # errors.
 | |
|         # - Workflow errors. A typical workflow has multiple steps. Each step may
 | |
|         # have a `Status` message for error reporting.
 | |
|         # - Batch operations. If a client uses batch request and batch response, the
 | |
|         # `Status` message should be used directly inside batch response, one for
 | |
|         # each error sub-response.
 | |
|         # - Asynchronous operations. If an API call embeds asynchronous operation
 | |
|         # results in its response, the status of those operations should be
 | |
|         # represented directly using the `Status` message.
 | |
|         # - Logging. If some API errors are stored in logs, the message `Status` could
 | |
|         # be used directly after any stripping needed for security/privacy reasons.
 | |
|         # Corresponds to the JSON property `error`
 | |
|         # @return [Google::Apis::DatastoreV1::Status]
 | |
|         attr_accessor :error
 | |
|       
 | |
|         # Service-specific metadata associated with the operation.  It typically
 | |
|         # contains progress information and common metadata such as create time.
 | |
|         # Some services might not provide such metadata.  Any method that returns a
 | |
|         # long-running operation should document the metadata type, if any.
 | |
|         # Corresponds to the JSON property `metadata`
 | |
|         # @return [Hash<String,Object>]
 | |
|         attr_accessor :metadata
 | |
|       
 | |
|         # The server-assigned name, which is only unique within the same service that
 | |
|         # originally returns it. If you use the default HTTP mapping, the
 | |
|         # `name` should have the format of `operations/some/unique/name`.
 | |
|         # Corresponds to the JSON property `name`
 | |
|         # @return [String]
 | |
|         attr_accessor :name
 | |
|       
 | |
|         # The normal response of the operation in case of success.  If the original
 | |
|         # method returns no data on success, such as `Delete`, the response is
 | |
|         # `google.protobuf.Empty`.  If the original method is standard
 | |
|         # `Get`/`Create`/`Update`, the response should be the resource.  For other
 | |
|         # methods, the response should have the type `XxxResponse`, where `Xxx`
 | |
|         # is the original method name.  For example, if the original method name
 | |
|         # is `TakeSnapshot()`, the inferred response type is
 | |
|         # `TakeSnapshotResponse`.
 | |
|         # Corresponds to the JSON property `response`
 | |
|         # @return [Hash<String,Object>]
 | |
|         attr_accessor :response
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @done = args[:done] if args.key?(:done)
 | |
|           @error = args[:error] if args.key?(:error)
 | |
|           @metadata = args[:metadata] if args.key?(:metadata)
 | |
|           @name = args[:name] if args.key?(:name)
 | |
|           @response = args[:response] if args.key?(:response)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # A [GQL
 | |
|       # query](https://cloud.google.com/datastore/docs/apis/gql/gql_reference).
 | |
|       class GqlQuery
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # When false, the query string must not contain any literals and instead must
 | |
|         # bind all values. For example,
 | |
|         # `SELECT * FROM Kind WHERE a = 'string literal'` is not allowed, while
 | |
|         # `SELECT * FROM Kind WHERE a = @value` is.
 | |
|         # Corresponds to the JSON property `allowLiterals`
 | |
|         # @return [Boolean]
 | |
|         attr_accessor :allow_literals
 | |
|         alias_method :allow_literals?, :allow_literals
 | |
|       
 | |
|         # For each non-reserved named binding site in the query string, there must be
 | |
|         # a named parameter with that name, but not necessarily the inverse.
 | |
|         # Key must match regex `A-Za-z_$*`, must not match regex
 | |
|         # `__.*__`, and must not be `""`.
 | |
|         # Corresponds to the JSON property `namedBindings`
 | |
|         # @return [Hash<String,Google::Apis::DatastoreV1::GqlQueryParameter>]
 | |
|         attr_accessor :named_bindings
 | |
|       
 | |
|         # Numbered binding site @1 references the first numbered parameter,
 | |
|         # effectively using 1-based indexing, rather than the usual 0.
 | |
|         # For each binding site numbered i in `query_string`, there must be an i-th
 | |
|         # numbered parameter. The inverse must also be true.
 | |
|         # Corresponds to the JSON property `positionalBindings`
 | |
|         # @return [Array<Google::Apis::DatastoreV1::GqlQueryParameter>]
 | |
|         attr_accessor :positional_bindings
 | |
|       
 | |
|         # A string of the format described
 | |
|         # [here](https://cloud.google.com/datastore/docs/apis/gql/gql_reference).
 | |
|         # Corresponds to the JSON property `queryString`
 | |
|         # @return [String]
 | |
|         attr_accessor :query_string
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @allow_literals = args[:allow_literals] if args.key?(:allow_literals)
 | |
|           @named_bindings = args[:named_bindings] if args.key?(:named_bindings)
 | |
|           @positional_bindings = args[:positional_bindings] if args.key?(:positional_bindings)
 | |
|           @query_string = args[:query_string] if args.key?(:query_string)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # A binding parameter for a GQL query.
 | |
|       class GqlQueryParameter
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # A query cursor. Query cursors are returned in query
 | |
|         # result batches.
 | |
|         # Corresponds to the JSON property `cursor`
 | |
|         # NOTE: Values are automatically base64 encoded/decoded in the client library.
 | |
|         # @return [String]
 | |
|         attr_accessor :cursor
 | |
|       
 | |
|         # A message that can hold any of the supported value types and associated
 | |
|         # metadata.
 | |
|         # Corresponds to the JSON property `value`
 | |
|         # @return [Google::Apis::DatastoreV1::Value]
 | |
|         attr_accessor :value
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @cursor = args[:cursor] if args.key?(:cursor)
 | |
|           @value = args[:value] if args.key?(:value)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # A unique identifier for an entity.
 | |
|       # If a key's partition ID or any of its path kinds or names are
 | |
|       # reserved/read-only, the key is reserved/read-only.
 | |
|       # A reserved/read-only key is forbidden in certain documented contexts.
 | |
|       class Key
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # A partition ID identifies a grouping of entities. The grouping is always
 | |
|         # by project and namespace, however the namespace ID may be empty.
 | |
|         # A partition ID contains several dimensions:
 | |
|         # project ID and namespace ID.
 | |
|         # Partition dimensions:
 | |
|         # - May be `""`.
 | |
|         # - Must be valid UTF-8 bytes.
 | |
|         # - Must have values that match regex `[A-Za-z\d\.\-_]`1,100``
 | |
|         # If the value of any dimension matches regex `__.*__`, the partition is
 | |
|         # reserved/read-only.
 | |
|         # A reserved/read-only partition ID is forbidden in certain documented
 | |
|         # contexts.
 | |
|         # Foreign partition IDs (in which the project ID does
 | |
|         # not match the context project ID ) are discouraged.
 | |
|         # Reads and writes of foreign partition IDs may fail if the project is not in an
 | |
|         # active state.
 | |
|         # Corresponds to the JSON property `partitionId`
 | |
|         # @return [Google::Apis::DatastoreV1::PartitionId]
 | |
|         attr_accessor :partition_id
 | |
|       
 | |
|         # The entity path.
 | |
|         # An entity path consists of one or more elements composed of a kind and a
 | |
|         # string or numerical identifier, which identify entities. The first
 | |
|         # element identifies a _root entity_, the second element identifies
 | |
|         # a _child_ of the root entity, the third element identifies a child of the
 | |
|         # second entity, and so forth. The entities identified by all prefixes of
 | |
|         # the path are called the element's _ancestors_.
 | |
|         # An entity path is always fully complete: *all* of the entity's ancestors
 | |
|         # are required to be in the path along with the entity identifier itself.
 | |
|         # The only exception is that in some documented cases, the identifier in the
 | |
|         # last path element (for the entity) itself may be omitted. For example,
 | |
|         # the last path element of the key of `Mutation.insert` may have no
 | |
|         # identifier.
 | |
|         # A path can never be empty, and a path can have at most 100 elements.
 | |
|         # Corresponds to the JSON property `path`
 | |
|         # @return [Array<Google::Apis::DatastoreV1::PathElement>]
 | |
|         attr_accessor :path
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @partition_id = args[:partition_id] if args.key?(:partition_id)
 | |
|           @path = args[:path] if args.key?(:path)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # A representation of a kind.
 | |
|       class KindExpression
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # The name of the kind.
 | |
|         # Corresponds to the JSON property `name`
 | |
|         # @return [String]
 | |
|         attr_accessor :name
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @name = args[:name] if args.key?(:name)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # An object representing a latitude/longitude pair. This is expressed as a pair
 | |
|       # of doubles representing degrees latitude and degrees longitude. Unless
 | |
|       # specified otherwise, this must conform to the
 | |
|       # <a href="http://www.unoosa.org/pdf/icg/2012/template/WGS_84.pdf">WGS84
 | |
|       # standard</a>. Values must be within normalized ranges.
 | |
|       class LatLng
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # The latitude in degrees. It must be in the range [-90.0, +90.0].
 | |
|         # Corresponds to the JSON property `latitude`
 | |
|         # @return [Float]
 | |
|         attr_accessor :latitude
 | |
|       
 | |
|         # The longitude in degrees. It must be in the range [-180.0, +180.0].
 | |
|         # Corresponds to the JSON property `longitude`
 | |
|         # @return [Float]
 | |
|         attr_accessor :longitude
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @latitude = args[:latitude] if args.key?(:latitude)
 | |
|           @longitude = args[:longitude] if args.key?(:longitude)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # The request for Datastore.Lookup.
 | |
|       class LookupRequest
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # Keys of entities to look up.
 | |
|         # Corresponds to the JSON property `keys`
 | |
|         # @return [Array<Google::Apis::DatastoreV1::Key>]
 | |
|         attr_accessor :keys
 | |
|       
 | |
|         # The options shared by read requests.
 | |
|         # Corresponds to the JSON property `readOptions`
 | |
|         # @return [Google::Apis::DatastoreV1::ReadOptions]
 | |
|         attr_accessor :read_options
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @keys = args[:keys] if args.key?(:keys)
 | |
|           @read_options = args[:read_options] if args.key?(:read_options)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # The response for Datastore.Lookup.
 | |
|       class LookupResponse
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # A list of keys that were not looked up due to resource constraints. The
 | |
|         # order of results in this field is undefined and has no relation to the
 | |
|         # order of the keys in the input.
 | |
|         # Corresponds to the JSON property `deferred`
 | |
|         # @return [Array<Google::Apis::DatastoreV1::Key>]
 | |
|         attr_accessor :deferred
 | |
|       
 | |
|         # Entities found as `ResultType.FULL` entities. The order of results in this
 | |
|         # field is undefined and has no relation to the order of the keys in the
 | |
|         # input.
 | |
|         # Corresponds to the JSON property `found`
 | |
|         # @return [Array<Google::Apis::DatastoreV1::EntityResult>]
 | |
|         attr_accessor :found
 | |
|       
 | |
|         # Entities not found as `ResultType.KEY_ONLY` entities. The order of results
 | |
|         # in this field is undefined and has no relation to the order of the keys
 | |
|         # in the input.
 | |
|         # Corresponds to the JSON property `missing`
 | |
|         # @return [Array<Google::Apis::DatastoreV1::EntityResult>]
 | |
|         attr_accessor :missing
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @deferred = args[:deferred] if args.key?(:deferred)
 | |
|           @found = args[:found] if args.key?(:found)
 | |
|           @missing = args[:missing] if args.key?(:missing)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # A mutation to apply to an entity.
 | |
|       class Mutation
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # The version of the entity that this mutation is being applied to. If this
 | |
|         # does not match the current version on the server, the mutation conflicts.
 | |
|         # Corresponds to the JSON property `baseVersion`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :base_version
 | |
|       
 | |
|         # A unique identifier for an entity.
 | |
|         # If a key's partition ID or any of its path kinds or names are
 | |
|         # reserved/read-only, the key is reserved/read-only.
 | |
|         # A reserved/read-only key is forbidden in certain documented contexts.
 | |
|         # Corresponds to the JSON property `delete`
 | |
|         # @return [Google::Apis::DatastoreV1::Key]
 | |
|         attr_accessor :delete
 | |
|       
 | |
|         # A Datastore data object.
 | |
|         # An entity is limited to 1 megabyte when stored. That _roughly_
 | |
|         # corresponds to a limit of 1 megabyte for the serialized form of this
 | |
|         # message.
 | |
|         # Corresponds to the JSON property `insert`
 | |
|         # @return [Google::Apis::DatastoreV1::Entity]
 | |
|         attr_accessor :insert
 | |
|       
 | |
|         # A Datastore data object.
 | |
|         # An entity is limited to 1 megabyte when stored. That _roughly_
 | |
|         # corresponds to a limit of 1 megabyte for the serialized form of this
 | |
|         # message.
 | |
|         # Corresponds to the JSON property `update`
 | |
|         # @return [Google::Apis::DatastoreV1::Entity]
 | |
|         attr_accessor :update
 | |
|       
 | |
|         # A Datastore data object.
 | |
|         # An entity is limited to 1 megabyte when stored. That _roughly_
 | |
|         # corresponds to a limit of 1 megabyte for the serialized form of this
 | |
|         # message.
 | |
|         # Corresponds to the JSON property `upsert`
 | |
|         # @return [Google::Apis::DatastoreV1::Entity]
 | |
|         attr_accessor :upsert
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @base_version = args[:base_version] if args.key?(:base_version)
 | |
|           @delete = args[:delete] if args.key?(:delete)
 | |
|           @insert = args[:insert] if args.key?(:insert)
 | |
|           @update = args[:update] if args.key?(:update)
 | |
|           @upsert = args[:upsert] if args.key?(:upsert)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # The result of applying a mutation.
 | |
|       class MutationResult
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # Whether a conflict was detected for this mutation. Always false when a
 | |
|         # conflict detection strategy field is not set in the mutation.
 | |
|         # Corresponds to the JSON property `conflictDetected`
 | |
|         # @return [Boolean]
 | |
|         attr_accessor :conflict_detected
 | |
|         alias_method :conflict_detected?, :conflict_detected
 | |
|       
 | |
|         # A unique identifier for an entity.
 | |
|         # If a key's partition ID or any of its path kinds or names are
 | |
|         # reserved/read-only, the key is reserved/read-only.
 | |
|         # A reserved/read-only key is forbidden in certain documented contexts.
 | |
|         # Corresponds to the JSON property `key`
 | |
|         # @return [Google::Apis::DatastoreV1::Key]
 | |
|         attr_accessor :key
 | |
|       
 | |
|         # The version of the entity on the server after processing the mutation. If
 | |
|         # the mutation doesn't change anything on the server, then the version will
 | |
|         # be the version of the current entity or, if no entity is present, a version
 | |
|         # that is strictly greater than the version of any previous entity and less
 | |
|         # than the version of any possible future entity.
 | |
|         # Corresponds to the JSON property `version`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :version
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @conflict_detected = args[:conflict_detected] if args.key?(:conflict_detected)
 | |
|           @key = args[:key] if args.key?(:key)
 | |
|           @version = args[:version] if args.key?(:version)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # A partition ID identifies a grouping of entities. The grouping is always
 | |
|       # by project and namespace, however the namespace ID may be empty.
 | |
|       # A partition ID contains several dimensions:
 | |
|       # project ID and namespace ID.
 | |
|       # Partition dimensions:
 | |
|       # - May be `""`.
 | |
|       # - Must be valid UTF-8 bytes.
 | |
|       # - Must have values that match regex `[A-Za-z\d\.\-_]`1,100``
 | |
|       # If the value of any dimension matches regex `__.*__`, the partition is
 | |
|       # reserved/read-only.
 | |
|       # A reserved/read-only partition ID is forbidden in certain documented
 | |
|       # contexts.
 | |
|       # Foreign partition IDs (in which the project ID does
 | |
|       # not match the context project ID ) are discouraged.
 | |
|       # Reads and writes of foreign partition IDs may fail if the project is not in an
 | |
|       # active state.
 | |
|       class PartitionId
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # If not empty, the ID of the namespace to which the entities belong.
 | |
|         # Corresponds to the JSON property `namespaceId`
 | |
|         # @return [String]
 | |
|         attr_accessor :namespace_id
 | |
|       
 | |
|         # The ID of the project to which the entities belong.
 | |
|         # Corresponds to the JSON property `projectId`
 | |
|         # @return [String]
 | |
|         attr_accessor :project_id
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @namespace_id = args[:namespace_id] if args.key?(:namespace_id)
 | |
|           @project_id = args[:project_id] if args.key?(:project_id)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # A (kind, ID/name) pair used to construct a key path.
 | |
|       # If either name or ID is set, the element is complete.
 | |
|       # If neither is set, the element is incomplete.
 | |
|       class PathElement
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # The auto-allocated ID of the entity.
 | |
|         # Never equal to zero. Values less than zero are discouraged and may not
 | |
|         # be supported in the future.
 | |
|         # Corresponds to the JSON property `id`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :id
 | |
|       
 | |
|         # The kind of the entity.
 | |
|         # A kind matching regex `__.*__` is reserved/read-only.
 | |
|         # A kind must not contain more than 1500 bytes when UTF-8 encoded.
 | |
|         # Cannot be `""`.
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [String]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         # The name of the entity.
 | |
|         # A name matching regex `__.*__` is reserved/read-only.
 | |
|         # A name must not be more than 1500 bytes when UTF-8 encoded.
 | |
|         # Cannot be `""`.
 | |
|         # Corresponds to the JSON property `name`
 | |
|         # @return [String]
 | |
|         attr_accessor :name
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @id = args[:id] if args.key?(:id)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|           @name = args[:name] if args.key?(:name)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # A representation of a property in a projection.
 | |
|       class Projection
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # A reference to a property relative to the kind expressions.
 | |
|         # Corresponds to the JSON property `property`
 | |
|         # @return [Google::Apis::DatastoreV1::PropertyReference]
 | |
|         attr_accessor :property
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @property = args[:property] if args.key?(:property)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # A filter on a specific property.
 | |
|       class PropertyFilter
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # The operator to filter by.
 | |
|         # Corresponds to the JSON property `op`
 | |
|         # @return [String]
 | |
|         attr_accessor :op
 | |
|       
 | |
|         # A reference to a property relative to the kind expressions.
 | |
|         # Corresponds to the JSON property `property`
 | |
|         # @return [Google::Apis::DatastoreV1::PropertyReference]
 | |
|         attr_accessor :property
 | |
|       
 | |
|         # A message that can hold any of the supported value types and associated
 | |
|         # metadata.
 | |
|         # Corresponds to the JSON property `value`
 | |
|         # @return [Google::Apis::DatastoreV1::Value]
 | |
|         attr_accessor :value
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @op = args[:op] if args.key?(:op)
 | |
|           @property = args[:property] if args.key?(:property)
 | |
|           @value = args[:value] if args.key?(:value)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # The desired order for a specific property.
 | |
|       class PropertyOrder
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # The direction to order by. Defaults to `ASCENDING`.
 | |
|         # Corresponds to the JSON property `direction`
 | |
|         # @return [String]
 | |
|         attr_accessor :direction
 | |
|       
 | |
|         # A reference to a property relative to the kind expressions.
 | |
|         # Corresponds to the JSON property `property`
 | |
|         # @return [Google::Apis::DatastoreV1::PropertyReference]
 | |
|         attr_accessor :property
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @direction = args[:direction] if args.key?(:direction)
 | |
|           @property = args[:property] if args.key?(:property)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # A reference to a property relative to the kind expressions.
 | |
|       class PropertyReference
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # The name of the property.
 | |
|         # If name includes "."s, it may be interpreted as a property name path.
 | |
|         # Corresponds to the JSON property `name`
 | |
|         # @return [String]
 | |
|         attr_accessor :name
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @name = args[:name] if args.key?(:name)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # A query for entities.
 | |
|       class Query
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # The properties to make distinct. The query results will contain the first
 | |
|         # result for each distinct combination of values for the given properties
 | |
|         # (if empty, all results are returned).
 | |
|         # Corresponds to the JSON property `distinctOn`
 | |
|         # @return [Array<Google::Apis::DatastoreV1::PropertyReference>]
 | |
|         attr_accessor :distinct_on
 | |
|       
 | |
|         # An ending point for the query results. Query cursors are
 | |
|         # returned in query result batches and
 | |
|         # [can only be used to limit the same
 | |
|         # query](https://cloud.google.com/datastore/docs/concepts/queries#
 | |
|         # cursors_limits_and_offsets).
 | |
|         # Corresponds to the JSON property `endCursor`
 | |
|         # NOTE: Values are automatically base64 encoded/decoded in the client library.
 | |
|         # @return [String]
 | |
|         attr_accessor :end_cursor
 | |
|       
 | |
|         # A holder for any type of filter.
 | |
|         # Corresponds to the JSON property `filter`
 | |
|         # @return [Google::Apis::DatastoreV1::Filter]
 | |
|         attr_accessor :filter
 | |
|       
 | |
|         # The kinds to query (if empty, returns entities of all kinds).
 | |
|         # Currently at most 1 kind may be specified.
 | |
|         # Corresponds to the JSON property `kind`
 | |
|         # @return [Array<Google::Apis::DatastoreV1::KindExpression>]
 | |
|         attr_accessor :kind
 | |
|       
 | |
|         # The maximum number of results to return. Applies after all other
 | |
|         # constraints. Optional.
 | |
|         # Unspecified is interpreted as no limit.
 | |
|         # Must be >= 0 if specified.
 | |
|         # Corresponds to the JSON property `limit`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :limit
 | |
|       
 | |
|         # The number of results to skip. Applies before limit, but after all other
 | |
|         # constraints. Optional. Must be >= 0 if specified.
 | |
|         # Corresponds to the JSON property `offset`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :offset
 | |
|       
 | |
|         # The order to apply to the query results (if empty, order is unspecified).
 | |
|         # Corresponds to the JSON property `order`
 | |
|         # @return [Array<Google::Apis::DatastoreV1::PropertyOrder>]
 | |
|         attr_accessor :order
 | |
|       
 | |
|         # The projection to return. Defaults to returning all properties.
 | |
|         # Corresponds to the JSON property `projection`
 | |
|         # @return [Array<Google::Apis::DatastoreV1::Projection>]
 | |
|         attr_accessor :projection
 | |
|       
 | |
|         # A starting point for the query results. Query cursors are
 | |
|         # returned in query result batches and
 | |
|         # [can only be used to continue the same
 | |
|         # query](https://cloud.google.com/datastore/docs/concepts/queries#
 | |
|         # cursors_limits_and_offsets).
 | |
|         # Corresponds to the JSON property `startCursor`
 | |
|         # NOTE: Values are automatically base64 encoded/decoded in the client library.
 | |
|         # @return [String]
 | |
|         attr_accessor :start_cursor
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @distinct_on = args[:distinct_on] if args.key?(:distinct_on)
 | |
|           @end_cursor = args[:end_cursor] if args.key?(:end_cursor)
 | |
|           @filter = args[:filter] if args.key?(:filter)
 | |
|           @kind = args[:kind] if args.key?(:kind)
 | |
|           @limit = args[:limit] if args.key?(:limit)
 | |
|           @offset = args[:offset] if args.key?(:offset)
 | |
|           @order = args[:order] if args.key?(:order)
 | |
|           @projection = args[:projection] if args.key?(:projection)
 | |
|           @start_cursor = args[:start_cursor] if args.key?(:start_cursor)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # A batch of results produced by a query.
 | |
|       class QueryResultBatch
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # A cursor that points to the position after the last result in the batch.
 | |
|         # Corresponds to the JSON property `endCursor`
 | |
|         # NOTE: Values are automatically base64 encoded/decoded in the client library.
 | |
|         # @return [String]
 | |
|         attr_accessor :end_cursor
 | |
|       
 | |
|         # The result type for every entity in `entity_results`.
 | |
|         # Corresponds to the JSON property `entityResultType`
 | |
|         # @return [String]
 | |
|         attr_accessor :entity_result_type
 | |
|       
 | |
|         # The results for this batch.
 | |
|         # Corresponds to the JSON property `entityResults`
 | |
|         # @return [Array<Google::Apis::DatastoreV1::EntityResult>]
 | |
|         attr_accessor :entity_results
 | |
|       
 | |
|         # The state of the query after the current batch.
 | |
|         # Corresponds to the JSON property `moreResults`
 | |
|         # @return [String]
 | |
|         attr_accessor :more_results
 | |
|       
 | |
|         # A cursor that points to the position after the last skipped result.
 | |
|         # Will be set when `skipped_results` != 0.
 | |
|         # Corresponds to the JSON property `skippedCursor`
 | |
|         # NOTE: Values are automatically base64 encoded/decoded in the client library.
 | |
|         # @return [String]
 | |
|         attr_accessor :skipped_cursor
 | |
|       
 | |
|         # The number of results skipped, typically because of an offset.
 | |
|         # Corresponds to the JSON property `skippedResults`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :skipped_results
 | |
|       
 | |
|         # The version number of the snapshot this batch was returned from.
 | |
|         # This applies to the range of results from the query's `start_cursor` (or
 | |
|         # the beginning of the query if no cursor was given) to this batch's
 | |
|         # `end_cursor` (not the query's `end_cursor`).
 | |
|         # In a single transaction, subsequent query result batches for the same query
 | |
|         # can have a greater snapshot version number. Each batch's snapshot version
 | |
|         # is valid for all preceding batches.
 | |
|         # The value will be zero for eventually consistent queries.
 | |
|         # Corresponds to the JSON property `snapshotVersion`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :snapshot_version
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @end_cursor = args[:end_cursor] if args.key?(:end_cursor)
 | |
|           @entity_result_type = args[:entity_result_type] if args.key?(:entity_result_type)
 | |
|           @entity_results = args[:entity_results] if args.key?(:entity_results)
 | |
|           @more_results = args[:more_results] if args.key?(:more_results)
 | |
|           @skipped_cursor = args[:skipped_cursor] if args.key?(:skipped_cursor)
 | |
|           @skipped_results = args[:skipped_results] if args.key?(:skipped_results)
 | |
|           @snapshot_version = args[:snapshot_version] if args.key?(:snapshot_version)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # Options specific to read-only transactions.
 | |
|       class ReadOnly
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # The options shared by read requests.
 | |
|       class ReadOptions
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # The non-transactional read consistency to use.
 | |
|         # Cannot be set to `STRONG` for global queries.
 | |
|         # Corresponds to the JSON property `readConsistency`
 | |
|         # @return [String]
 | |
|         attr_accessor :read_consistency
 | |
|       
 | |
|         # The identifier of the transaction in which to read. A
 | |
|         # transaction identifier is returned by a call to
 | |
|         # Datastore.BeginTransaction.
 | |
|         # Corresponds to the JSON property `transaction`
 | |
|         # NOTE: Values are automatically base64 encoded/decoded in the client library.
 | |
|         # @return [String]
 | |
|         attr_accessor :transaction
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @read_consistency = args[:read_consistency] if args.key?(:read_consistency)
 | |
|           @transaction = args[:transaction] if args.key?(:transaction)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # Options specific to read / write transactions.
 | |
|       class ReadWrite
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # The transaction identifier of the transaction being retried.
 | |
|         # Corresponds to the JSON property `previousTransaction`
 | |
|         # NOTE: Values are automatically base64 encoded/decoded in the client library.
 | |
|         # @return [String]
 | |
|         attr_accessor :previous_transaction
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @previous_transaction = args[:previous_transaction] if args.key?(:previous_transaction)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # The request for Datastore.ReserveIds.
 | |
|       class ReserveIdsRequest
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # If not empty, the ID of the database against which to make the request.
 | |
|         # Corresponds to the JSON property `databaseId`
 | |
|         # @return [String]
 | |
|         attr_accessor :database_id
 | |
|       
 | |
|         # A list of keys with complete key paths whose numeric IDs should not be
 | |
|         # auto-allocated.
 | |
|         # Corresponds to the JSON property `keys`
 | |
|         # @return [Array<Google::Apis::DatastoreV1::Key>]
 | |
|         attr_accessor :keys
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @database_id = args[:database_id] if args.key?(:database_id)
 | |
|           @keys = args[:keys] if args.key?(:keys)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # The response for Datastore.ReserveIds.
 | |
|       class ReserveIdsResponse
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # The request for Datastore.Rollback.
 | |
|       class RollbackRequest
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # The transaction identifier, returned by a call to
 | |
|         # Datastore.BeginTransaction.
 | |
|         # Corresponds to the JSON property `transaction`
 | |
|         # NOTE: Values are automatically base64 encoded/decoded in the client library.
 | |
|         # @return [String]
 | |
|         attr_accessor :transaction
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @transaction = args[:transaction] if args.key?(:transaction)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # The response for Datastore.Rollback.
 | |
|       # (an empty message).
 | |
|       class RollbackResponse
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # The request for Datastore.RunQuery.
 | |
|       class RunQueryRequest
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # A [GQL
 | |
|         # query](https://cloud.google.com/datastore/docs/apis/gql/gql_reference).
 | |
|         # Corresponds to the JSON property `gqlQuery`
 | |
|         # @return [Google::Apis::DatastoreV1::GqlQuery]
 | |
|         attr_accessor :gql_query
 | |
|       
 | |
|         # A partition ID identifies a grouping of entities. The grouping is always
 | |
|         # by project and namespace, however the namespace ID may be empty.
 | |
|         # A partition ID contains several dimensions:
 | |
|         # project ID and namespace ID.
 | |
|         # Partition dimensions:
 | |
|         # - May be `""`.
 | |
|         # - Must be valid UTF-8 bytes.
 | |
|         # - Must have values that match regex `[A-Za-z\d\.\-_]`1,100``
 | |
|         # If the value of any dimension matches regex `__.*__`, the partition is
 | |
|         # reserved/read-only.
 | |
|         # A reserved/read-only partition ID is forbidden in certain documented
 | |
|         # contexts.
 | |
|         # Foreign partition IDs (in which the project ID does
 | |
|         # not match the context project ID ) are discouraged.
 | |
|         # Reads and writes of foreign partition IDs may fail if the project is not in an
 | |
|         # active state.
 | |
|         # Corresponds to the JSON property `partitionId`
 | |
|         # @return [Google::Apis::DatastoreV1::PartitionId]
 | |
|         attr_accessor :partition_id
 | |
|       
 | |
|         # A query for entities.
 | |
|         # Corresponds to the JSON property `query`
 | |
|         # @return [Google::Apis::DatastoreV1::Query]
 | |
|         attr_accessor :query
 | |
|       
 | |
|         # The options shared by read requests.
 | |
|         # Corresponds to the JSON property `readOptions`
 | |
|         # @return [Google::Apis::DatastoreV1::ReadOptions]
 | |
|         attr_accessor :read_options
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @gql_query = args[:gql_query] if args.key?(:gql_query)
 | |
|           @partition_id = args[:partition_id] if args.key?(:partition_id)
 | |
|           @query = args[:query] if args.key?(:query)
 | |
|           @read_options = args[:read_options] if args.key?(:read_options)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # The response for Datastore.RunQuery.
 | |
|       class RunQueryResponse
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # A batch of results produced by a query.
 | |
|         # Corresponds to the JSON property `batch`
 | |
|         # @return [Google::Apis::DatastoreV1::QueryResultBatch]
 | |
|         attr_accessor :batch
 | |
|       
 | |
|         # A query for entities.
 | |
|         # Corresponds to the JSON property `query`
 | |
|         # @return [Google::Apis::DatastoreV1::Query]
 | |
|         attr_accessor :query
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @batch = args[:batch] if args.key?(:batch)
 | |
|           @query = args[:query] if args.key?(:query)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # The `Status` type defines a logical error model that is suitable for
 | |
|       # different programming environments, including REST APIs and RPC APIs. It is
 | |
|       # used by [gRPC](https://github.com/grpc). The error model is designed to be:
 | |
|       # - Simple to use and understand for most users
 | |
|       # - Flexible enough to meet unexpected needs
 | |
|       # # Overview
 | |
|       # The `Status` message contains three pieces of data: error code, error
 | |
|       # message, and error details. The error code should be an enum value of
 | |
|       # google.rpc.Code, but it may accept additional error codes if needed.  The
 | |
|       # error message should be a developer-facing English message that helps
 | |
|       # developers *understand* and *resolve* the error. If a localized user-facing
 | |
|       # error message is needed, put the localized message in the error details or
 | |
|       # localize it in the client. The optional error details may contain arbitrary
 | |
|       # information about the error. There is a predefined set of error detail types
 | |
|       # in the package `google.rpc` that can be used for common error conditions.
 | |
|       # # Language mapping
 | |
|       # The `Status` message is the logical representation of the error model, but it
 | |
|       # is not necessarily the actual wire format. When the `Status` message is
 | |
|       # exposed in different client libraries and different wire protocols, it can be
 | |
|       # mapped differently. For example, it will likely be mapped to some exceptions
 | |
|       # in Java, but more likely mapped to some error codes in C.
 | |
|       # # Other uses
 | |
|       # The error model and the `Status` message can be used in a variety of
 | |
|       # environments, either with or without APIs, to provide a
 | |
|       # consistent developer experience across different environments.
 | |
|       # Example uses of this error model include:
 | |
|       # - Partial errors. If a service needs to return partial errors to the client,
 | |
|       # it may embed the `Status` in the normal response to indicate the partial
 | |
|       # errors.
 | |
|       # - Workflow errors. A typical workflow has multiple steps. Each step may
 | |
|       # have a `Status` message for error reporting.
 | |
|       # - Batch operations. If a client uses batch request and batch response, the
 | |
|       # `Status` message should be used directly inside batch response, one for
 | |
|       # each error sub-response.
 | |
|       # - Asynchronous operations. If an API call embeds asynchronous operation
 | |
|       # results in its response, the status of those operations should be
 | |
|       # represented directly using the `Status` message.
 | |
|       # - Logging. If some API errors are stored in logs, the message `Status` could
 | |
|       # be used directly after any stripping needed for security/privacy reasons.
 | |
|       class Status
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # The status code, which should be an enum value of google.rpc.Code.
 | |
|         # Corresponds to the JSON property `code`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :code
 | |
|       
 | |
|         # A list of messages that carry the error details.  There is a common set of
 | |
|         # message types for APIs to use.
 | |
|         # Corresponds to the JSON property `details`
 | |
|         # @return [Array<Hash<String,Object>>]
 | |
|         attr_accessor :details
 | |
|       
 | |
|         # A developer-facing error message, which should be in English. Any
 | |
|         # user-facing error message should be localized and sent in the
 | |
|         # google.rpc.Status.details field, or localized by the client.
 | |
|         # Corresponds to the JSON property `message`
 | |
|         # @return [String]
 | |
|         attr_accessor :message
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @code = args[:code] if args.key?(:code)
 | |
|           @details = args[:details] if args.key?(:details)
 | |
|           @message = args[:message] if args.key?(:message)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # Options for beginning a new transaction.
 | |
|       # Transactions can be created explicitly with calls to
 | |
|       # Datastore.BeginTransaction or implicitly by setting
 | |
|       # ReadOptions.new_transaction in read requests.
 | |
|       class TransactionOptions
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # Options specific to read-only transactions.
 | |
|         # Corresponds to the JSON property `readOnly`
 | |
|         # @return [Google::Apis::DatastoreV1::ReadOnly]
 | |
|         attr_accessor :read_only
 | |
|       
 | |
|         # Options specific to read / write transactions.
 | |
|         # Corresponds to the JSON property `readWrite`
 | |
|         # @return [Google::Apis::DatastoreV1::ReadWrite]
 | |
|         attr_accessor :read_write
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @read_only = args[:read_only] if args.key?(:read_only)
 | |
|           @read_write = args[:read_write] if args.key?(:read_write)
 | |
|         end
 | |
|       end
 | |
|       
 | |
|       # A message that can hold any of the supported value types and associated
 | |
|       # metadata.
 | |
|       class Value
 | |
|         include Google::Apis::Core::Hashable
 | |
|       
 | |
|         # An array value.
 | |
|         # Corresponds to the JSON property `arrayValue`
 | |
|         # @return [Google::Apis::DatastoreV1::ArrayValue]
 | |
|         attr_accessor :array_value
 | |
|       
 | |
|         # A blob value.
 | |
|         # May have at most 1,000,000 bytes.
 | |
|         # When `exclude_from_indexes` is false, may have at most 1500 bytes.
 | |
|         # In JSON requests, must be base64-encoded.
 | |
|         # Corresponds to the JSON property `blobValue`
 | |
|         # NOTE: Values are automatically base64 encoded/decoded in the client library.
 | |
|         # @return [String]
 | |
|         attr_accessor :blob_value
 | |
|       
 | |
|         # A boolean value.
 | |
|         # Corresponds to the JSON property `booleanValue`
 | |
|         # @return [Boolean]
 | |
|         attr_accessor :boolean_value
 | |
|         alias_method :boolean_value?, :boolean_value
 | |
|       
 | |
|         # A double value.
 | |
|         # Corresponds to the JSON property `doubleValue`
 | |
|         # @return [Float]
 | |
|         attr_accessor :double_value
 | |
|       
 | |
|         # A Datastore data object.
 | |
|         # An entity is limited to 1 megabyte when stored. That _roughly_
 | |
|         # corresponds to a limit of 1 megabyte for the serialized form of this
 | |
|         # message.
 | |
|         # Corresponds to the JSON property `entityValue`
 | |
|         # @return [Google::Apis::DatastoreV1::Entity]
 | |
|         attr_accessor :entity_value
 | |
|       
 | |
|         # If the value should be excluded from all indexes including those defined
 | |
|         # explicitly.
 | |
|         # Corresponds to the JSON property `excludeFromIndexes`
 | |
|         # @return [Boolean]
 | |
|         attr_accessor :exclude_from_indexes
 | |
|         alias_method :exclude_from_indexes?, :exclude_from_indexes
 | |
|       
 | |
|         # An object representing a latitude/longitude pair. This is expressed as a pair
 | |
|         # of doubles representing degrees latitude and degrees longitude. Unless
 | |
|         # specified otherwise, this must conform to the
 | |
|         # <a href="http://www.unoosa.org/pdf/icg/2012/template/WGS_84.pdf">WGS84
 | |
|         # standard</a>. Values must be within normalized ranges.
 | |
|         # Corresponds to the JSON property `geoPointValue`
 | |
|         # @return [Google::Apis::DatastoreV1::LatLng]
 | |
|         attr_accessor :geo_point_value
 | |
|       
 | |
|         # An integer value.
 | |
|         # Corresponds to the JSON property `integerValue`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :integer_value
 | |
|       
 | |
|         # A unique identifier for an entity.
 | |
|         # If a key's partition ID or any of its path kinds or names are
 | |
|         # reserved/read-only, the key is reserved/read-only.
 | |
|         # A reserved/read-only key is forbidden in certain documented contexts.
 | |
|         # Corresponds to the JSON property `keyValue`
 | |
|         # @return [Google::Apis::DatastoreV1::Key]
 | |
|         attr_accessor :key_value
 | |
|       
 | |
|         # The `meaning` field should only be populated for backwards compatibility.
 | |
|         # Corresponds to the JSON property `meaning`
 | |
|         # @return [Fixnum]
 | |
|         attr_accessor :meaning
 | |
|       
 | |
|         # A null value.
 | |
|         # Corresponds to the JSON property `nullValue`
 | |
|         # @return [String]
 | |
|         attr_accessor :null_value
 | |
|       
 | |
|         # A UTF-8 encoded string value.
 | |
|         # When `exclude_from_indexes` is false (it is indexed) , may have at most 1500
 | |
|         # bytes.
 | |
|         # Otherwise, may be set to at least 1,000,000 bytes.
 | |
|         # Corresponds to the JSON property `stringValue`
 | |
|         # @return [String]
 | |
|         attr_accessor :string_value
 | |
|       
 | |
|         # A timestamp value.
 | |
|         # When stored in the Datastore, precise only to microseconds;
 | |
|         # any additional precision is rounded down.
 | |
|         # Corresponds to the JSON property `timestampValue`
 | |
|         # @return [String]
 | |
|         attr_accessor :timestamp_value
 | |
|       
 | |
|         def initialize(**args)
 | |
|            update!(**args)
 | |
|         end
 | |
|       
 | |
|         # Update properties of this object
 | |
|         def update!(**args)
 | |
|           @array_value = args[:array_value] if args.key?(:array_value)
 | |
|           @blob_value = args[:blob_value] if args.key?(:blob_value)
 | |
|           @boolean_value = args[:boolean_value] if args.key?(:boolean_value)
 | |
|           @double_value = args[:double_value] if args.key?(:double_value)
 | |
|           @entity_value = args[:entity_value] if args.key?(:entity_value)
 | |
|           @exclude_from_indexes = args[:exclude_from_indexes] if args.key?(:exclude_from_indexes)
 | |
|           @geo_point_value = args[:geo_point_value] if args.key?(:geo_point_value)
 | |
|           @integer_value = args[:integer_value] if args.key?(:integer_value)
 | |
|           @key_value = args[:key_value] if args.key?(:key_value)
 | |
|           @meaning = args[:meaning] if args.key?(:meaning)
 | |
|           @null_value = args[:null_value] if args.key?(:null_value)
 | |
|           @string_value = args[:string_value] if args.key?(:string_value)
 | |
|           @timestamp_value = args[:timestamp_value] if args.key?(:timestamp_value)
 | |
|         end
 | |
|       end
 | |
|     end
 | |
|   end
 | |
| end
 |