# Generated by the protocol buffer compiler.  DO NOT EDIT!
# sources: google/api/annotations.proto, google/api/field_behavior.proto, google/api/http.proto, google/api/visibility.proto
# plugin: python-betterproto
from dataclasses import dataclass
from typing import List

import betterproto


class FieldBehavior(betterproto.Enum):
    """
    An indicator of the behavior of a given field (for example, that a field is
    required in requests, or given as output but ignored as input). This **does
    not** change the behavior in protocol buffers itself; it only denotes the
    behavior and may affect how API tooling handles the field. Note: This enum
    **may** receive new values in the future.
    """

    FIELD_BEHAVIOR_UNSPECIFIED = 0
    """Conventional default for enums. Do not use this."""

    OPTIONAL = 1
    """
    Specifically denotes a field as optional. While all fields in protocol
    buffers are optional, this may be specified for emphasis if appropriate.
    """

    REQUIRED = 2
    """
    Denotes a field as required. This indicates that the field **must** be
    provided as part of the request, and failure to do so will cause an error
    (usually `INVALID_ARGUMENT`).
    """

    OUTPUT_ONLY = 3
    """
    Denotes a field as output only. This indicates that the field is provided
    in responses, but including the field in a request does nothing (the server
    *must* ignore it and *must not* throw an error as a result of the field's
    presence).
    """

    INPUT_ONLY = 4
    """
    Denotes a field as input only. This indicates that the field is provided in
    requests, and the corresponding field is not included in output.
    """

    IMMUTABLE = 5
    """
    Denotes a field as immutable. This indicates that the field may be set once
    in a request to create a resource, but may not be changed thereafter.
    """

    UNORDERED_LIST = 6
    """
    Denotes that a (repeated) field is an unordered list. This indicates that
    the service may provide the elements of the list in any arbitrary  order,
    rather than the order the user originally provided. Additionally, the
    list's order may or may not be stable.
    """

    NON_EMPTY_DEFAULT = 7
    """
    Denotes that this field returns a non-empty default value if not set. This
    indicates that if the user provides the empty value in a request, a non-
    empty value will be returned. The user will not be aware of what non-empty
    value to expect.
    """

    IDENTIFIER = 8
    """
    Denotes that the field in a resource (a message annotated with
    google.api.resource) is used in the resource name to uniquely identify the
    resource. For AIP-compliant APIs, this should only be applied to the `name`
    field on the resource. This behavior should not be applied to references to
    other resources within the message. The identifier field of resources often
    have different field behavior depending on the request it is embedded in
    (e.g. for Create methods name is optional and unused, while for Update
    methods it is required). Instead of method-specific annotations, only
    `IDENTIFIER` is required.
    """


@dataclass(eq=False, repr=False)
class Http(betterproto.Message):
    """
    Defines the HTTP configuration for an API service. It contains a list of
    [HttpRule][google.api.HttpRule], each specifying the mapping of an RPC
    method to one or more HTTP REST API methods.
    """

    rules: List["HttpRule"] = betterproto.message_field(1)
    """
    A list of HTTP configuration rules that apply to individual API methods.
    **NOTE:** All service configuration rules follow "last one wins" order.
    """

    fully_decode_reserved_expansion: bool = betterproto.bool_field(2)
    """
    When set to true, URL path parameters will be fully URI-decoded except in
    cases of single segment matches in reserved expansion, where "%2F" will be
    left encoded. The default behavior is to not decode RFC 6570 reserved
    characters in multi segment matches.
    """


@dataclass(eq=False, repr=False)
class HttpRule(betterproto.Message):
    """
    gRPC Transcoding gRPC Transcoding is a feature for mapping between a gRPC
    method and one or more HTTP REST endpoints. It allows developers to build a
    single API service that supports both gRPC APIs and REST APIs. Many
    systems, including [Google APIs](https://github.com/googleapis/googleapis),
    [Cloud Endpoints](https://cloud.google.com/endpoints), [gRPC
    Gateway](https://github.com/grpc-ecosystem/grpc-gateway), and
    [Envoy](https://github.com/envoyproxy/envoy) proxy support this feature and
    use it for large scale production services. `HttpRule` defines the schema
    of the gRPC/REST mapping. The mapping specifies how different portions of
    the gRPC request message are mapped to the URL path, URL query parameters,
    and HTTP request body. It also controls how the gRPC response message is
    mapped to the HTTP response body. `HttpRule` is typically specified as an
    `google.api.http` annotation on the gRPC method. Each mapping specifies a
    URL path template and an HTTP method. The path template may refer to one or
    more fields in the gRPC request message, as long as each field is a non-
    repeated field with a primitive (non-message) type. The path template
    controls how fields of the request message are mapped to the URL path.
    Example:     service Messaging {       rpc GetMessage(GetMessageRequest)
    returns (Message) {         option (google.api.http) = {             get:
    "/v1/{name=messages/*}"         };       }     }     message
    GetMessageRequest {       string name = 1; // Mapped to URL path.     }
    message Message {       string text = 1; // The resource content.     }
    This enables an HTTP REST to gRPC mapping as below: - HTTP: `GET
    /v1/messages/123456` - gRPC: `GetMessage(name: "messages/123456")` Any
    fields in the request message which are not bound by the path template
    automatically become HTTP query parameters if there is no HTTP request
    body. For example:     service Messaging {       rpc
    GetMessage(GetMessageRequest) returns (Message) {         option
    (google.api.http) = {             get:"/v1/messages/{message_id}"
    };       }     }     message GetMessageRequest {       message SubMessage {
    string subfield = 1;       }       string message_id = 1; // Mapped to URL
    path.       int64 revision = 2;    // Mapped to URL query parameter
    `revision`.       SubMessage sub = 3;    // Mapped to URL query parameter
    `sub.subfield`.     } This enables a HTTP JSON to RPC mapping as below: -
    HTTP: `GET /v1/messages/123456?revision=2&sub.subfield=foo` - gRPC:
    `GetMessage(message_id: "123456" revision: 2 sub: SubMessage(subfield:
    "foo"))` Note that fields which are mapped to URL query parameters must
    have a primitive type or a repeated primitive type or a non-repeated
    message type. In the case of a repeated type, the parameter can be repeated
    in the URL as `...?param=A&param=B`. In the case of a message type, each
    field of the message is mapped to a separate parameter, such as
    `...?foo.a=A&foo.b=B&foo.c=C`. For HTTP methods that allow a request body,
    the `body` field specifies the mapping. Consider a REST update method on
    the message resource collection:     service Messaging {       rpc
    UpdateMessage(UpdateMessageRequest) returns (Message) {         option
    (google.api.http) = {           patch: "/v1/messages/{message_id}"
    body: "message"         };       }     }     message UpdateMessageRequest {
    string message_id = 1; // mapped to the URL       Message message = 2;   //
    mapped to the body     } The following HTTP JSON to RPC mapping is enabled,
    where the representation of the JSON in the request body is determined by
    protos JSON encoding: - HTTP: `PATCH /v1/messages/123456 { "text": "Hi!" }`
    - gRPC: `UpdateMessage(message_id: "123456" message { text: "Hi!" })` The
    special name `*` can be used in the body mapping to define that every field
    not bound by the path template should be mapped to the request body.  This
    enables the following alternative definition of the update method:
    service Messaging {       rpc UpdateMessage(Message) returns (Message) {
    option (google.api.http) = {           patch: "/v1/messages/{message_id}"
    body: "*"         };       }     }     message Message {       string
    message_id = 1;       string text = 2;     } The following HTTP JSON to RPC
    mapping is enabled: - HTTP: `PATCH /v1/messages/123456 { "text": "Hi!" }` -
    gRPC: `UpdateMessage(message_id: "123456" text: "Hi!")` Note that when
    using `*` in the body mapping, it is not possible to have HTTP parameters,
    as all fields not bound by the path end in the body. This makes this option
    more rarely used in practice when defining REST APIs. The common usage of
    `*` is in custom methods which don't use the URL at all for transferring
    data. It is possible to define multiple HTTP methods for one RPC by using
    the `additional_bindings` option. Example:     service Messaging {
    rpc GetMessage(GetMessageRequest) returns (Message) {         option
    (google.api.http) = {           get: "/v1/messages/{message_id}"
    additional_bindings {             get:
    "/v1/users/{user_id}/messages/{message_id}"           }         };       }
    }     message GetMessageRequest {       string message_id = 1;       string
    user_id = 2;     } This enables the following two alternative HTTP JSON to
    RPC mappings: - HTTP: `GET /v1/messages/123456` - gRPC:
    `GetMessage(message_id: "123456")` - HTTP: `GET
    /v1/users/me/messages/123456` - gRPC: `GetMessage(user_id: "me" message_id:
    "123456")` Rules for HTTP mapping 1. Leaf request fields (recursive
    expansion nested messages in the request    message) are classified into
    three categories:    - Fields referred by the path template. They are
    passed via the URL path.    - Fields referred by the
    [HttpRule.body][google.api.HttpRule.body]. They    are passed via the HTTP
    request body.    - All other fields are passed via the URL query
    parameters, and the      parameter name is the field path in the request
    message. A repeated      field can be represented as multiple query
    parameters under the same      name.  2. If
    [HttpRule.body][google.api.HttpRule.body] is "*", there is no URL  query
    parameter, all fields     are passed via URL path and HTTP request body.
    3. If [HttpRule.body][google.api.HttpRule.body] is omitted, there is no
    HTTP  request body, all     fields are passed via URL path and URL query
    parameters. Path template syntax     Template = "/" Segments [ Verb ] ;
    Segments = Segment { "/" Segment } ;     Segment  = "*" | "**" | LITERAL |
    Variable ;     Variable = "{" FieldPath [ "=" Segments ] "}" ;
    FieldPath = IDENT { "." IDENT } ;     Verb     = ":" LITERAL ; The syntax
    `*` matches a single URL path segment. The syntax `**` matches zero or more
    URL path segments, which must be the last part of the URL path except the
    `Verb`. The syntax `Variable` matches part of the URL path as specified by
    its template. A variable template must not contain other variables. If a
    variable matches a single path segment, its template may be omitted, e.g.
    `{var}` is equivalent to `{var=*}`. The syntax `LITERAL` matches literal
    text in the URL path. If the `LITERAL` contains any reserved character,
    such characters should be percent-encoded before the matching. If a
    variable contains exactly one path segment, such as `"{var}"` or
    `"{var=*}"`, when such a variable is expanded into a URL path on the client
    side, all characters except `[-_.~0-9a-zA-Z]` are percent-encoded. The
    server side does the reverse decoding. Such variables show up in the
    [Discovery
    Document](https://developers.google.com/discovery/v1/reference/apis) as
    `{var}`. If a variable contains multiple path segments, such as
    `"{var=foo/*}"` or `"{var=**}"`, when such a variable is expanded into a
    URL path on the client side, all characters except `[-_.~/0-9a-zA-Z]` are
    percent-encoded. The server side does the reverse decoding, except "%2F"
    and "%2f" are left unchanged. Such variables show up in the [Discovery
    Document](https://developers.google.com/discovery/v1/reference/apis) as
    `{+var}`. Using gRPC API Service Configuration gRPC API Service
    Configuration (service config) is a configuration language for configuring
    a gRPC service to become a user-facing product. The service config is
    simply the YAML representation of the `google.api.Service` proto message.
    As an alternative to annotating your proto file, you can configure gRPC
    transcoding in your service config YAML files. You do this by specifying a
    `HttpRule` that maps the gRPC method to a REST endpoint, achieving the same
    effect as the proto annotation. This can be particularly useful if you have
    a proto that is reused in multiple services. Note that any transcoding
    specified in the service config will override any matching transcoding
    configuration in the proto. The following example selects a gRPC method and
    applies an `HttpRule` to it:     http:       rules:         - selector:
    example.v1.Messaging.GetMessage           get:
    /v1/messages/{message_id}/{sub.subfield} Special notes When gRPC
    Transcoding is used to map a gRPC to JSON REST endpoints, the proto to JSON
    conversion must follow the [proto3
    specification](https://developers.google.com/protocol-
    buffers/docs/proto3#json). While the single segment variable follows the
    semantics of [RFC 6570](https://tools.ietf.org/html/rfc6570) Section 3.2.2
    Simple String Expansion, the multi segment variable **does not** follow RFC
    6570 Section 3.2.3 Reserved Expansion. The reason is that the Reserved
    Expansion does not expand special characters like `?` and `#`, which would
    lead to invalid URLs. As the result, gRPC Transcoding uses a custom
    encoding for multi segment variables. The path variables **must not** refer
    to any repeated or mapped field, because client libraries are not capable
    of handling such variable expansion. The path variables **must not**
    capture the leading "/" character. The reason is that the most common use
    case "{var}" does not capture the leading "/" character. For consistency,
    all path variables must share the same behavior. Repeated message fields
    must not be mapped to URL query parameters, because no client library can
    support such complicated mapping. If an API needs to use a JSON array for
    request or response body, it can map the request or response body to a
    repeated field. However, some gRPC Transcoding implementations may not
    support this feature.
    """

    selector: str = betterproto.string_field(1)
    """
    Selects a method to which this rule applies. Refer to
    [selector][google.api.DocumentationRule.selector] for syntax details.
    """

    get: str = betterproto.string_field(2, group="pattern")
    """
    Maps to HTTP GET. Used for listing and getting information about resources.
    """

    put: str = betterproto.string_field(3, group="pattern")
    """Maps to HTTP PUT. Used for replacing a resource."""

    post: str = betterproto.string_field(4, group="pattern")
    """
    Maps to HTTP POST. Used for creating a resource or performing an action.
    """

    delete: str = betterproto.string_field(5, group="pattern")
    """Maps to HTTP DELETE. Used for deleting a resource."""

    patch: str = betterproto.string_field(6, group="pattern")
    """Maps to HTTP PATCH. Used for updating a resource."""

    custom: "CustomHttpPattern" = betterproto.message_field(8, group="pattern")
    """
    The custom pattern is used for specifying an HTTP method that is not
    included in the `pattern` field, such as HEAD, or "*" to leave the HTTP
    method unspecified for this rule. The wild-card rule is useful for services
    that provide content to Web (HTML) clients.
    """

    body: str = betterproto.string_field(7)
    """
    The name of the request field whose value is mapped to the HTTP request
    body, or `*` for mapping all request fields not captured by the path
    pattern to the HTTP body, or omitted for not having any HTTP request body.
    NOTE: the referred field must be present at the top-level of the request
    message type.
    """

    response_body: str = betterproto.string_field(12)
    """
    Optional. The name of the response field whose value is mapped to the HTTP
    response body. When omitted, the entire response message will be used as
    the HTTP response body. NOTE: The referred field must be present at the
    top-level of the response message type.
    """

    additional_bindings: List["HttpRule"] = betterproto.message_field(11)
    """
    Additional HTTP bindings for the selector. Nested bindings must not contain
    an `additional_bindings` field themselves (that is, the nesting may only be
    one level deep).
    """


@dataclass(eq=False, repr=False)
class CustomHttpPattern(betterproto.Message):
    """A custom pattern is used for defining custom HTTP verb."""

    kind: str = betterproto.string_field(1)
    """The name of this custom HTTP verb."""

    path: str = betterproto.string_field(2)
    """The path matched by this custom verb."""


@dataclass(eq=False, repr=False)
class Visibility(betterproto.Message):
    """
    `Visibility` restricts service consumer's access to service elements, such
    as whether an application can call a visibility-restricted method. The
    restriction is expressed by applying visibility labels on service elements.
    The visibility labels are elsewhere linked to service consumers. A service
    can define multiple visibility labels, but a service consumer should be
    granted at most one visibility label. Multiple visibility labels for a
    single service consumer are not supported. If an element and all its
    parents have no visibility label, its visibility is unconditionally
    granted. Example:     visibility:       rules:       - selector:
    google.calendar.Calendar.EnhancedSearch         restriction: PREVIEW
    - selector: google.calendar.Calendar.Delegate         restriction: INTERNAL
    Here, all methods are publicly visible except for the restricted methods
    EnhancedSearch and Delegate.
    """

    rules: List["VisibilityRule"] = betterproto.message_field(1)
    """
    A list of visibility rules that apply to individual API elements. **NOTE:**
    All service configuration rules follow "last one wins" order.
    """


@dataclass(eq=False, repr=False)
class VisibilityRule(betterproto.Message):
    """
    A visibility rule provides visibility configuration for an individual API
    element.
    """

    selector: str = betterproto.string_field(1)
    """
    Selects methods, messages, fields, enums, etc. to which this rule applies.
    Refer to [selector][google.api.DocumentationRule.selector] for syntax
    details.
    """

    restriction: str = betterproto.string_field(2)
    """
    A comma-separated list of visibility labels that apply to the `selector`.
    Any of the listed labels can be used to grant the visibility. If a rule has
    multiple labels, removing one of the labels but not all of them can break
    clients. Example:     visibility:       rules:       - selector:
    google.calendar.Calendar.EnhancedSearch         restriction: INTERNAL,
    PREVIEW Removing INTERNAL from this restriction will break clients that
    rely on this method and only had access to it through INTERNAL.
    """
