googleapis/google/cloud/pubsublite/v1/common.proto

189 lines
6.6 KiB
Protocol Buffer

// Copyright 2020 Google LLC
//
// 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.
syntax = "proto3";
package google.cloud.pubsublite.v1;
import "google/api/resource.proto";
import "google/protobuf/duration.proto";
import "google/protobuf/timestamp.proto";
option cc_enable_arenas = true;
option csharp_namespace = "Google.Cloud.PubSubLite.V1";
option go_package = "google.golang.org/genproto/googleapis/cloud/pubsublite/v1;pubsublite";
option java_multiple_files = true;
option java_outer_classname = "CommonProto";
option java_package = "com.google.cloud.pubsublite.proto";
option php_namespace = "Google\\Cloud\\PubSubLite\\V1";
option ruby_package = "Google::Cloud::PubSubLite::V1";
// The values associated with a key of an attribute.
message AttributeValues {
// The list of values associated with a key.
repeated bytes values = 1;
}
// A message that is published by publishers and delivered to subscribers.
message PubSubMessage {
// The key used for routing messages to partitions or for compaction (e.g.,
// keep the last N messages per key). If the key is empty, the message is
// routed to an arbitrary partition.
bytes key = 1;
// The payload of the message.
bytes data = 2;
// Optional attributes that can be used for message metadata/headers.
map<string, AttributeValues> attributes = 3;
// An optional, user-specified event time.
google.protobuf.Timestamp event_time = 4;
}
// A cursor that describes the position of a message within a topic partition.
message Cursor {
// The offset of a message within a topic partition. Must be greater than or
// equal 0.
int64 offset = 1;
}
// A message that has been stored and sequenced by the Pub/Sub Lite system.
message SequencedMessage {
// The position of a message within the partition where it is stored.
Cursor cursor = 1;
// The time when the message was received by the server when it was first
// published.
google.protobuf.Timestamp publish_time = 2;
// The user message.
PubSubMessage message = 3;
// The size in bytes of this message for flow control and quota purposes.
int64 size_bytes = 4;
}
// Metadata about a topic resource.
message Topic {
option (google.api.resource) = {
type: "pubsublite.googleapis.com/Topic"
pattern: "projects/{project}/locations/{location}/topics/{topic}"
};
// The settings for a topic's partitions.
message PartitionConfig {
// The throughput capacity configuration for each partition.
message Capacity {
// Publish throughput capacity per partition in MiB/s.
// Must be >= 4 and <= 16.
int32 publish_mib_per_sec = 1;
// Subscribe throughput capacity per partition in MiB/s.
// Must be >= 4 and <= 32.
int32 subscribe_mib_per_sec = 2;
}
// The number of partitions in the topic. Must be at least 1.
int64 count = 1;
// The throughput dimension of this topic.
oneof dimension {
// DEPRECATED: Use capacity instead which can express a superset of
// configurations.
//
// Every partition in the topic is allocated throughput equivalent to
// `scale` times the standard partition throughput (4 MiB/s). This is also
// reflected in the cost of this topic; a topic with `scale` of 2 and
// count of 10 is charged for 20 partitions. This value must be in the
// range [1,4].
int32 scale = 2 [deprecated = true];
// The capacity configuration.
Capacity capacity = 3;
}
}
// The settings for a topic's message retention.
message RetentionConfig {
// The provisioned storage, in bytes, per partition. If the number of bytes
// stored in any of the topic's partitions grows beyond this value, older
// messages will be dropped to make room for newer ones, regardless of the
// value of `period`.
int64 per_partition_bytes = 1;
// How long a published message is retained. If unset, messages will be
// retained as long as the bytes retained for each partition is below
// `per_partition_bytes`.
google.protobuf.Duration period = 2;
}
// The name of the topic.
// Structured like:
// projects/{project_number}/locations/{location}/topics/{topic_id}
string name = 1;
// The settings for this topic's partitions.
PartitionConfig partition_config = 2;
// The settings for this topic's message retention.
RetentionConfig retention_config = 3;
}
// Metadata about a subscription resource.
message Subscription {
option (google.api.resource) = {
type: "pubsublite.googleapis.com/Subscription"
pattern: "projects/{project}/locations/{location}/subscriptions/{subscription}"
};
// The settings for a subscription's message delivery.
message DeliveryConfig {
// When this subscription should send messages to subscribers relative to
// messages persistence in storage. For details, see [Creating Lite
// subscriptions](https://cloud.google.com/pubsub/lite/docs/subscriptions#creating_lite_subscriptions).
enum DeliveryRequirement {
// Default value. This value is unused.
DELIVERY_REQUIREMENT_UNSPECIFIED = 0;
// The server does not wait for a published message to be successfully
// written to storage before delivering it to subscribers.
DELIVER_IMMEDIATELY = 1;
// The server will not deliver a published message to subscribers until
// the message has been successfully written to storage. This will result
// in higher end-to-end latency, but consistent delivery.
DELIVER_AFTER_STORED = 2;
}
// The DeliveryRequirement for this subscription.
DeliveryRequirement delivery_requirement = 3;
}
// The name of the subscription.
// Structured like:
// projects/{project_number}/locations/{location}/subscriptions/{subscription_id}
string name = 1;
// The name of the topic this subscription is attached to.
// Structured like:
// projects/{project_number}/locations/{location}/topics/{topic_id}
string topic = 2 [(google.api.resource_reference) = {
type: "pubsublite.googleapis.com/Topic"
}];
// The settings for this subscription's message delivery.
DeliveryConfig delivery_config = 3;
}