google-api-ruby-client/generated/google/apis/pubsub_v1beta1a/classes.rb

606 lines
22 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 PubsubV1beta1a
# Request for the Acknowledge method.
class AcknowledgeRequest
include Google::Apis::Core::Hashable
# The acknowledgment ID for the message being acknowledged. This was
# returned by the Pub/Sub system in the Pull response.
# Corresponds to the JSON property `ackId`
# @return [Array<String>]
attr_accessor :ack_id
# The subscription whose message is being acknowledged.
# Corresponds to the JSON property `subscription`
# @return [String]
attr_accessor :subscription
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
@ack_id = args[:ack_id] if args.key?(:ack_id)
@subscription = args[:subscription] if args.key?(:subscription)
end
end
# An empty message that you can re-use to avoid defining duplicated empty
# messages in your project. A typical example is to use it as argument or the
# return value of a service API. For instance:
# service Foo `
# rpc Bar (proto2.Empty) returns (proto2.Empty) ` `;
# `;
# BEGIN GOOGLE-INTERNAL
# The difference between this one and net/rpc/empty-message.proto is that
# 1) The generated message here is in proto2 C++ API.
# 2) The proto2.Empty has minimum dependencies
# (no message_set or net/rpc dependencies)
# END GOOGLE-INTERNAL
class Empty
include Google::Apis::Core::Hashable
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
end
end
# A key-value pair applied to a given object.
class Label
include Google::Apis::Core::Hashable
# The key of a label is a syntactically valid URL (as per RFC 1738) with
# the "scheme" and initial slashes omitted and with the additional
# restrictions noted below. Each key should be globally unique. The
# "host" portion is called the "namespace" and is not necessarily
# resolvable to a network endpoint. Instead, the namespace indicates what
# system or entity defines the semantics of the label. Namespaces do not
# restrict the set of objects to which a label may be associated.
# Keys are defined by the following grammar:
# key = hostname "/" kpath
# kpath = ksegment *[ "/" ksegment ]
# ksegment = alphadigit | *[ alphadigit | "-" | "_" | "." ]
# where "hostname" and "alphadigit" are defined as in RFC 1738.
# Example key:
# spanner.google.com/universe
# Corresponds to the JSON property `key`
# @return [String]
attr_accessor :key
# An integer value.
# Corresponds to the JSON property `numValue`
# @return [Fixnum]
attr_accessor :num_value
# A string value.
# Corresponds to the JSON property `strValue`
# @return [String]
attr_accessor :str_value
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
@key = args[:key] if args.key?(:key)
@num_value = args[:num_value] if args.key?(:num_value)
@str_value = args[:str_value] if args.key?(:str_value)
end
end
# Response for the ListSubscriptions method.
class ListSubscriptionsResponse
include Google::Apis::Core::Hashable
# If not empty, indicates that there are more subscriptions that match the
# request and this value should be passed to the next
# <code>ListSubscriptionsRequest</code> to continue.
# Corresponds to the JSON property `nextPageToken`
# @return [String]
attr_accessor :next_page_token
# The subscriptions that match the request.
# Corresponds to the JSON property `subscription`
# @return [Array<Google::Apis::PubsubV1beta1a::Subscription>]
attr_accessor :subscription
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)
@subscription = args[:subscription] if args.key?(:subscription)
end
end
# Response for the ListTopics method.
class ListTopicsResponse
include Google::Apis::Core::Hashable
# If not empty, indicates that there are more topics that match the request,
# and this value should be passed to the next <code>ListTopicsRequest</code>
# to continue.
# Corresponds to the JSON property `nextPageToken`
# @return [String]
attr_accessor :next_page_token
# The resulting topics.
# Corresponds to the JSON property `topic`
# @return [Array<Google::Apis::PubsubV1beta1a::Topic>]
attr_accessor :topic
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)
@topic = args[:topic] if args.key?(:topic)
end
end
# Request for the ModifyAckDeadline method.
class ModifyAckDeadlineRequest
include Google::Apis::Core::Hashable
# The new ack deadline with respect to the time this request was sent to the
# Pub/Sub system. Must be >= 0. For example, if the value is 10, the new ack
# deadline will expire 10 seconds after the ModifyAckDeadline call was made.
# Specifying zero may immediately make the message available for another pull
# request.
# Corresponds to the JSON property `ackDeadlineSeconds`
# @return [Fixnum]
attr_accessor :ack_deadline_seconds
# The acknowledgment ID. Either this or ack_ids must be populated,
# not both.
# Corresponds to the JSON property `ackId`
# @return [String]
attr_accessor :ack_id
# List of acknowledgment IDs. Either this field or ack_id
# should be populated, not both.
# Corresponds to the JSON property `ackIds`
# @return [Array<String>]
attr_accessor :ack_ids
# Next Index: 5
# The name of the subscription from which messages are being pulled.
# Corresponds to the JSON property `subscription`
# @return [String]
attr_accessor :subscription
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
@ack_deadline_seconds = args[:ack_deadline_seconds] if args.key?(:ack_deadline_seconds)
@ack_id = args[:ack_id] if args.key?(:ack_id)
@ack_ids = args[:ack_ids] if args.key?(:ack_ids)
@subscription = args[:subscription] if args.key?(:subscription)
end
end
# Request for the ModifyPushConfig method.
class ModifyPushConfigRequest
include Google::Apis::Core::Hashable
# Configuration for a push delivery endpoint.
# Corresponds to the JSON property `pushConfig`
# @return [Google::Apis::PubsubV1beta1a::PushConfig]
attr_accessor :push_config
# The name of the subscription.
# Corresponds to the JSON property `subscription`
# @return [String]
attr_accessor :subscription
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
@push_config = args[:push_config] if args.key?(:push_config)
@subscription = args[:subscription] if args.key?(:subscription)
end
end
# Request for the PublishBatch method.
class PublishBatchRequest
include Google::Apis::Core::Hashable
# The messages to publish.
# Corresponds to the JSON property `messages`
# @return [Array<Google::Apis::PubsubV1beta1a::PubsubMessage>]
attr_accessor :messages
# The messages in the request will be published on this topic.
# Corresponds to the JSON property `topic`
# @return [String]
attr_accessor :topic
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
@messages = args[:messages] if args.key?(:messages)
@topic = args[:topic] if args.key?(:topic)
end
end
# Response for the PublishBatch method.
class PublishBatchResponse
include Google::Apis::Core::Hashable
# The server-assigned ID of each published message, in the same order as
# the messages in the request. IDs are guaranteed to be unique within
# the topic.
# Corresponds to the JSON property `messageIds`
# @return [Array<String>]
attr_accessor :message_ids
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
@message_ids = args[:message_ids] if args.key?(:message_ids)
end
end
# Request for the Publish method.
class PublishRequest
include Google::Apis::Core::Hashable
# A message data and its labels.
# Corresponds to the JSON property `message`
# @return [Google::Apis::PubsubV1beta1a::PubsubMessage]
attr_accessor :message
# The message in the request will be published on this topic.
# Corresponds to the JSON property `topic`
# @return [String]
attr_accessor :topic
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
@message = args[:message] if args.key?(:message)
@topic = args[:topic] if args.key?(:topic)
end
end
# An event indicating a received message or truncation event.
class PubsubEvent
include Google::Apis::Core::Hashable
# Indicates that this subscription has been deleted. (Note that pull
# subscribers will always receive NOT_FOUND in response in their pull
# request on the subscription, rather than seeing this boolean.)
# Corresponds to the JSON property `deleted`
# @return [Boolean]
attr_accessor :deleted
alias_method :deleted?, :deleted
# A message data and its labels.
# Corresponds to the JSON property `message`
# @return [Google::Apis::PubsubV1beta1a::PubsubMessage]
attr_accessor :message
# The subscription that received the event.
# Corresponds to the JSON property `subscription`
# @return [String]
attr_accessor :subscription
# Indicates that this subscription has been truncated.
# Corresponds to the JSON property `truncated`
# @return [Boolean]
attr_accessor :truncated
alias_method :truncated?, :truncated
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
@deleted = args[:deleted] if args.key?(:deleted)
@message = args[:message] if args.key?(:message)
@subscription = args[:subscription] if args.key?(:subscription)
@truncated = args[:truncated] if args.key?(:truncated)
end
end
# A message data and its labels.
class PubsubMessage
include Google::Apis::Core::Hashable
# The message payload.
# Corresponds to the JSON property `data`
# NOTE: Values are automatically base64 encoded/decoded in the client library.
# @return [String]
attr_accessor :data
# Optional list of labels for this message. Keys in this collection must
# be unique.
# Corresponds to the JSON property `label`
# @return [Array<Google::Apis::PubsubV1beta1a::Label>]
attr_accessor :label
# ID of this message assigned by the server at publication time. Guaranteed
# to be unique within the topic. This value may be read by a subscriber
# that receives a PubsubMessage via a Pull call or a push delivery. It must
# not be populated by a publisher in a Publish call.
# Corresponds to the JSON property `messageId`
# @return [String]
attr_accessor :message_id
# The time at which the message was published.
# The time is milliseconds since the UNIX epoch.
# Corresponds to the JSON property `publishTime`
# @return [Fixnum]
attr_accessor :publish_time
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
@data = args[:data] if args.key?(:data)
@label = args[:label] if args.key?(:label)
@message_id = args[:message_id] if args.key?(:message_id)
@publish_time = args[:publish_time] if args.key?(:publish_time)
end
end
# Request for the PullBatch method.
class PullBatchRequest
include Google::Apis::Core::Hashable
# The maximum number of PubsubEvents returned for this request. The Pub/Sub
# system may return fewer than the number of events specified.
# Corresponds to the JSON property `maxEvents`
# @return [Fixnum]
attr_accessor :max_events
# If this is specified as true the system will respond immediately even if
# it is not able to return a message in the Pull response. Otherwise the
# system is allowed to wait until at least one message is available rather
# than returning no messages. The client may cancel the request if it does
# not wish to wait any longer for the response.
# Corresponds to the JSON property `returnImmediately`
# @return [Boolean]
attr_accessor :return_immediately
alias_method :return_immediately?, :return_immediately
# The subscription from which messages should be pulled.
# Corresponds to the JSON property `subscription`
# @return [String]
attr_accessor :subscription
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
@max_events = args[:max_events] if args.key?(:max_events)
@return_immediately = args[:return_immediately] if args.key?(:return_immediately)
@subscription = args[:subscription] if args.key?(:subscription)
end
end
# Response for the PullBatch method.
class PullBatchResponse
include Google::Apis::Core::Hashable
# Received Pub/Sub messages or status events. The Pub/Sub system will return
# zero messages if there are no more messages available in the backlog. The
# Pub/Sub system may return fewer than the max_events requested even if
# there are more messages available in the backlog.
# Corresponds to the JSON property `pullResponses`
# @return [Array<Google::Apis::PubsubV1beta1a::PullResponse>]
attr_accessor :pull_responses
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
@pull_responses = args[:pull_responses] if args.key?(:pull_responses)
end
end
# Request for the Pull method.
class PullRequest
include Google::Apis::Core::Hashable
# If this is specified as true the system will respond immediately even if
# it is not able to return a message in the Pull response. Otherwise the
# system is allowed to wait until at least one message is available rather
# than returning FAILED_PRECONDITION. The client may cancel the request if
# it does not wish to wait any longer for the response.
# Corresponds to the JSON property `returnImmediately`
# @return [Boolean]
attr_accessor :return_immediately
alias_method :return_immediately?, :return_immediately
# The subscription from which a message should be pulled.
# Corresponds to the JSON property `subscription`
# @return [String]
attr_accessor :subscription
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
@return_immediately = args[:return_immediately] if args.key?(:return_immediately)
@subscription = args[:subscription] if args.key?(:subscription)
end
end
# Either a <code>PubsubMessage</code> or a truncation event. One of these two
# must be populated.
class PullResponse
include Google::Apis::Core::Hashable
# This ID must be used to acknowledge the received event or message.
# Corresponds to the JSON property `ackId`
# @return [String]
attr_accessor :ack_id
# An event indicating a received message or truncation event.
# Corresponds to the JSON property `pubsubEvent`
# @return [Google::Apis::PubsubV1beta1a::PubsubEvent]
attr_accessor :pubsub_event
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
@ack_id = args[:ack_id] if args.key?(:ack_id)
@pubsub_event = args[:pubsub_event] if args.key?(:pubsub_event)
end
end
# Configuration for a push delivery endpoint.
class PushConfig
include Google::Apis::Core::Hashable
# A URL locating the endpoint to which messages should be pushed.
# For example, a Webhook endpoint might use "https://example.com/push".
# Corresponds to the JSON property `pushEndpoint`
# @return [String]
attr_accessor :push_endpoint
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
@push_endpoint = args[:push_endpoint] if args.key?(:push_endpoint)
end
end
# A subscription resource.
class Subscription
include Google::Apis::Core::Hashable
# For either push or pull delivery, the value is the maximum time after a
# subscriber receives a message before the subscriber should acknowledge or
# Nack the message. If the Ack deadline for a message passes without an
# Ack or a Nack, the Pub/Sub system will eventually redeliver the message.
# If a subscriber acknowledges after the deadline, the Pub/Sub system may
# accept the Ack, but it is possible that the message has been already
# delivered again. Multiple Acks to the message are allowed and will
# succeed.
# For push delivery, this value is used to set the request timeout for
# the call to the push endpoint.
# For pull delivery, this value is used as the initial value for the Ack
# deadline. It may be overridden for each message using its corresponding
# ack_id with <code>ModifyAckDeadline</code>.
# While a message is outstanding (i.e. it has been delivered to a pull
# subscriber and the subscriber has not yet Acked or Nacked), the Pub/Sub
# system will not deliver that message to another pull subscriber
# (on a best-effort basis).
# Corresponds to the JSON property `ackDeadlineSeconds`
# @return [Fixnum]
attr_accessor :ack_deadline_seconds
# Name of the subscription.
# Corresponds to the JSON property `name`
# @return [String]
attr_accessor :name
# Configuration for a push delivery endpoint.
# Corresponds to the JSON property `pushConfig`
# @return [Google::Apis::PubsubV1beta1a::PushConfig]
attr_accessor :push_config
# The name of the topic from which this subscription is receiving messages.
# Corresponds to the JSON property `topic`
# @return [String]
attr_accessor :topic
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
@ack_deadline_seconds = args[:ack_deadline_seconds] if args.key?(:ack_deadline_seconds)
@name = args[:name] if args.key?(:name)
@push_config = args[:push_config] if args.key?(:push_config)
@topic = args[:topic] if args.key?(:topic)
end
end
# A topic resource.
class Topic
include Google::Apis::Core::Hashable
# Name of the topic.
# 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
end
end
end