All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.google.api.services.serviceusage.v1.model.HttpRule Maven / Gradle / Ivy

/*
 * Copyright 2010 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.
 */
/*
 * This code was generated by https://github.com/google/apis-client-generator/
 * (build: 2018-05-04 17:28:03 UTC)
 * on 2018-07-31 at 00:54:18 UTC 
 * Modify at your own risk.
 */

package com.google.api.services.serviceusage.v1.model;

/**
 * `HttpRule` defines the mapping of an RPC method to one or more HTTP REST API methods. The mapping
 * specifies how different portions of the RPC request message are mapped to URL path, URL query
 * parameters, and HTTP request body. The mapping is typically specified as an `google.api.http`
 * annotation on the RPC method, see "google/api/annotations.proto" for details.
 *
 * The mapping consists of a field specifying the path template and method kind.  The path template
 * can refer to fields in the request message, as in the example below which describes a REST GET
 * operation on a resource collection of messages:
 *
 *     service Messaging {       rpc GetMessage(GetMessageRequest) returns (Message) {
 * option (google.api.http).get = "/v1/messages/{message_id}/{sub.subfield}";       }     }
 * message GetMessageRequest {       message SubMessage {         string subfield = 1;       }
 * string message_id = 1; // mapped to the URL       SubMessage sub = 2;    // `sub.subfield` is
 * url-mapped     }     message Message {       string text = 1; // content of the resource     }
 *
 * The same http annotation can alternatively be expressed inside the `GRPC API Configuration` YAML
 * file.
 *
 *     http:       rules:         - selector: .Messaging.GetMessage           get:
 * /v1/messages/{message_id}/{sub.subfield}
 *
 * This definition enables an automatic, bidrectional mapping of HTTP JSON to RPC. Example:
 *
 * HTTP | RPC -----|----- `GET /v1/messages/123456/foo`  | `GetMessage(message_id: "123456" sub:
 * SubMessage(subfield: "foo"))`
 *
 * In general, not only fields but also field paths can be referenced from a path pattern. Fields
 * mapped to the path pattern cannot be repeated and must have a primitive (non-message) type.
 *
 * Any fields in the request message which are not bound by the path pattern automatically become
 * (optional) HTTP query parameters. Assume the following definition of the request message:
 *
 *     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 the URL       int64 revision = 2;    // becomes a parameter
 * SubMessage sub = 3;    // `sub.subfield` becomes a parameter     }
 *
 * This enables a HTTP JSON to RPC mapping as below:
 *
 * HTTP | RPC -----|----- `GET /v1/messages/123456?revision=2=foo` | `GetMessage(message_id:
 * "123456" revision: 2 sub: SubMessage(subfield: "foo"))`
 *
 * Note that fields which are mapped to HTTP parameters must have a primitive type or a repeated
 * primitive type. Message types are not allowed. In the case of a repeated type, the parameter can
 * be repeated in the URL, as in `...?param=A=B`.
 *
 * For HTTP method kinds which 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) = {           put: "/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 | RPC -----|----- `PUT /v1/messages/123456 { "text": "Hi!" }` | `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) = {           put: "/v1/messages/{message_id}"           body: "*"         };
 * }     }     message Message {       string message_id = 1;       string text = 2;     }
 *
 * The following HTTP JSON to RPC mapping is enabled:
 *
 * HTTP | RPC -----|----- `PUT /v1/messages/123456 { "text": "Hi!" }` | `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
 * of 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 | RPC -----|----- `GET /v1/messages/123456` | `GetMessage(message_id: "123456")` `GET
 * /v1/users/me/messages/123456` | `GetMessage(user_id: "me" message_id: "123456")`
 *
 * # Rules for HTTP mapping
 *
 * The rules for mapping HTTP path, query parameters, and body fields to the request message are as
 * follows:
 *
 * 1. The `body` field specifies either `*` or a field path, or is    omitted. If omitted, it
 * indicates there is no HTTP request body. 2. Leaf fields (recursive expansion of nested messages
 * in the    request) can be classified into three types:     (a) Matched in the URL template.
 * (b) Covered by body (if body is `*`, everything except (a) fields;         else everything under
 * the body field)     (c) All other fields. 3. URL query parameters found in the HTTP request are
 * mapped to (c) fields. 4. Any body sent with an HTTP request can contain only (b) fields.
 *
 * The syntax of the path template is as follows:
 *
 *     Template = "/" Segments [ Verb ] ;     Segments = Segment { "/" Segment } ;     Segment  =
 * "*" | "**" | LITERAL | Variable ;     Variable = "{" FieldPath [ "=" Segments ] "}" ;
 * FieldPath = IDENT { "." IDENT } ;     Verb     = ":" LITERAL ;
 *
 * The syntax `*` matches a single path segment. The syntax `**` matches zero or more path segments,
 * which must be the last part of the path except the `Verb`. The syntax `LITERAL` matches literal
 * text in the path.
 *
 * 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=*}`.
 *
 * If a variable contains exactly one path segment, such as `"{var}"` or `"{var=*}"`, when such a
 * variable is expanded into a URL path, all characters except `[-_.~0-9a-zA-Z]` are percent-
 * encoded. Such variables show up in the Discovery Document as `{var}`.
 *
 * If a variable contains one or more path segments, such as `"{var=foo}"` or `"{var=**}"`, when
 * such a variable is expanded into a URL path, all characters except `[-_.~/0-9a-zA-Z]` are
 * percent-encoded. Such variables show up in the Discovery Document as `{+var}`.
 *
 * NOTE: While the single segment variable matches the semantics of [RFC
 * 6570](https://tools.ietf.org/html/rfc6570) Section 3.2.2 Simple String Expansion, the multi
 * segment variable **does not** match RFC 6570 Reserved Expansion. The reason is that the Reserved
 * Expansion does not expand special characters like `?` and `#`, which would lead to invalid URLs.
 *
 * NOTE: the field paths in variables and in the `body` must not refer to repeated fields or map
 * fields.
 *
 * 

This is the Java data model class that specifies how to parse/serialize into the JSON that is * transmitted over HTTP when working with the Service Usage API. For a detailed explanation see: * https://developers.google.com/api-client-library/java/google-http-java-client/json *

* * @author Google, Inc. */ @SuppressWarnings("javadoc") public final class HttpRule extends com.google.api.client.json.GenericJson { /** * 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). * The value may be {@code null}. */ @com.google.api.client.util.Key private java.util.List additionalBindings; /** * Specifies the permission(s) required for an API element for the overall API request to succeed. * It is typically used to mark request message fields that contain the name of the resource and * indicates the permissions that will be checked on that resource. * The value may be {@code null}. */ @com.google.api.client.util.Key private java.util.List authorizations; static { // hack to force ProGuard to consider AuthorizationRule used, since otherwise it would be stripped out // see https://github.com/google/google-api-java-client/issues/543 com.google.api.client.util.Data.nullOf(AuthorizationRule.class); } /** * The name of the request field whose value is mapped to the HTTP body, or `*` for mapping all * fields not captured by the path pattern to the HTTP body. NOTE: the referred field must not be * a repeated field and must be present at the top-level of request message type. * The value may be {@code null}. */ @com.google.api.client.util.Key private java.lang.String body; /** * 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. * The value may be {@code null}. */ @com.google.api.client.util.Key private CustomHttpPattern custom; /** * Used for deleting a resource. * The value may be {@code null}. */ @com.google.api.client.util.Key private java.lang.String delete; /** * Used for listing and getting information about resources. * The value may be {@code null}. */ @com.google.api.client.util.Key private java.lang.String get; /** * Use this only for Scotty Requests. Do not use this for bytestream methods. For media support, * add instead [][google.bytestream.RestByteStream] as an API to your configuration. * The value may be {@code null}. */ @com.google.api.client.util.Key private MediaDownload mediaDownload; /** * Use this only for Scotty Requests. Do not use this for media support using Bytestream, add * instead [][google.bytestream.RestByteStream] as an API to your configuration for Bytestream * methods. * The value may be {@code null}. */ @com.google.api.client.util.Key private MediaUpload mediaUpload; /** * Used for updating a resource. * The value may be {@code null}. */ @com.google.api.client.util.Key private java.lang.String patch; /** * Used for creating a resource. * The value may be {@code null}. */ @com.google.api.client.util.Key private java.lang.String post; /** * Used for updating a resource. * The value may be {@code null}. */ @com.google.api.client.util.Key private java.lang.String put; /** * DO NOT USE. This is an experimental field. * * Optional. The REST collection name is by default derived from the URL pattern. If specified, * this field overrides the default collection name. Example: * * rpc AddressesAggregatedList(AddressesAggregatedListRequest) returns * (AddressesAggregatedListResponse) { option (google.api.http) = { get: * "/v1/projects/{project_id}/aggregated/addresses" rest_collection: "projects.addresses" * }; } * * This method has the automatically derived collection name "projects.aggregated". Because, * semantically, this rpc is actually an operation on the "projects.addresses" collection, the * `rest_collection` field is configured to override the derived collection name. * The value may be {@code null}. */ @com.google.api.client.util.Key private java.lang.String restCollection; /** * DO NOT USE. This is an experimental field. * * Optional. The rest method name is by default derived from the URL pattern. If specified, this * field overrides the default method name. Example: * * rpc CreateResource(CreateResourceRequest) returns (CreateResourceResponse) { * option (google.api.http) = { post: "/v1/resources", body: "resource", * rest_method_name: "insert" }; } * * This method has the automatically derived rest method name "create", but for backwards * compatibility with apiary, it is specified as insert. * The value may be {@code null}. */ @com.google.api.client.util.Key private java.lang.String restMethodName; /** * Selects methods to which this rule applies. * * Refer to selector for syntax details. * The value may be {@code null}. */ @com.google.api.client.util.Key private java.lang.String selector; /** * 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). * @return value or {@code null} for none */ public java.util.List getAdditionalBindings() { return additionalBindings; } /** * 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). * @param additionalBindings additionalBindings or {@code null} for none */ public HttpRule setAdditionalBindings(java.util.List additionalBindings) { this.additionalBindings = additionalBindings; return this; } /** * Specifies the permission(s) required for an API element for the overall API request to succeed. * It is typically used to mark request message fields that contain the name of the resource and * indicates the permissions that will be checked on that resource. * @return value or {@code null} for none */ public java.util.List getAuthorizations() { return authorizations; } /** * Specifies the permission(s) required for an API element for the overall API request to succeed. * It is typically used to mark request message fields that contain the name of the resource and * indicates the permissions that will be checked on that resource. * @param authorizations authorizations or {@code null} for none */ public HttpRule setAuthorizations(java.util.List authorizations) { this.authorizations = authorizations; return this; } /** * The name of the request field whose value is mapped to the HTTP body, or `*` for mapping all * fields not captured by the path pattern to the HTTP body. NOTE: the referred field must not be * a repeated field and must be present at the top-level of request message type. * @return value or {@code null} for none */ public java.lang.String getBody() { return body; } /** * The name of the request field whose value is mapped to the HTTP body, or `*` for mapping all * fields not captured by the path pattern to the HTTP body. NOTE: the referred field must not be * a repeated field and must be present at the top-level of request message type. * @param body body or {@code null} for none */ public HttpRule setBody(java.lang.String body) { this.body = body; return this; } /** * 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. * @return value or {@code null} for none */ public CustomHttpPattern getCustom() { return custom; } /** * 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. * @param custom custom or {@code null} for none */ public HttpRule setCustom(CustomHttpPattern custom) { this.custom = custom; return this; } /** * Used for deleting a resource. * @return value or {@code null} for none */ public java.lang.String getDelete() { return delete; } /** * Used for deleting a resource. * @param delete delete or {@code null} for none */ public HttpRule setDelete(java.lang.String delete) { this.delete = delete; return this; } /** * Used for listing and getting information about resources. * @return value or {@code null} for none */ public java.lang.String getGet() { return get; } /** * Used for listing and getting information about resources. * @param get get or {@code null} for none */ public HttpRule setGet(java.lang.String get) { this.get = get; return this; } /** * Use this only for Scotty Requests. Do not use this for bytestream methods. For media support, * add instead [][google.bytestream.RestByteStream] as an API to your configuration. * @return value or {@code null} for none */ public MediaDownload getMediaDownload() { return mediaDownload; } /** * Use this only for Scotty Requests. Do not use this for bytestream methods. For media support, * add instead [][google.bytestream.RestByteStream] as an API to your configuration. * @param mediaDownload mediaDownload or {@code null} for none */ public HttpRule setMediaDownload(MediaDownload mediaDownload) { this.mediaDownload = mediaDownload; return this; } /** * Use this only for Scotty Requests. Do not use this for media support using Bytestream, add * instead [][google.bytestream.RestByteStream] as an API to your configuration for Bytestream * methods. * @return value or {@code null} for none */ public MediaUpload getMediaUpload() { return mediaUpload; } /** * Use this only for Scotty Requests. Do not use this for media support using Bytestream, add * instead [][google.bytestream.RestByteStream] as an API to your configuration for Bytestream * methods. * @param mediaUpload mediaUpload or {@code null} for none */ public HttpRule setMediaUpload(MediaUpload mediaUpload) { this.mediaUpload = mediaUpload; return this; } /** * Used for updating a resource. * @return value or {@code null} for none */ public java.lang.String getPatch() { return patch; } /** * Used for updating a resource. * @param patch patch or {@code null} for none */ public HttpRule setPatch(java.lang.String patch) { this.patch = patch; return this; } /** * Used for creating a resource. * @return value or {@code null} for none */ public java.lang.String getPost() { return post; } /** * Used for creating a resource. * @param post post or {@code null} for none */ public HttpRule setPost(java.lang.String post) { this.post = post; return this; } /** * Used for updating a resource. * @return value or {@code null} for none */ public java.lang.String getPut() { return put; } /** * Used for updating a resource. * @param put put or {@code null} for none */ public HttpRule setPut(java.lang.String put) { this.put = put; return this; } /** * DO NOT USE. This is an experimental field. * * Optional. The REST collection name is by default derived from the URL pattern. If specified, * this field overrides the default collection name. Example: * * rpc AddressesAggregatedList(AddressesAggregatedListRequest) returns * (AddressesAggregatedListResponse) { option (google.api.http) = { get: * "/v1/projects/{project_id}/aggregated/addresses" rest_collection: "projects.addresses" * }; } * * This method has the automatically derived collection name "projects.aggregated". Because, * semantically, this rpc is actually an operation on the "projects.addresses" collection, the * `rest_collection` field is configured to override the derived collection name. * @return value or {@code null} for none */ public java.lang.String getRestCollection() { return restCollection; } /** * DO NOT USE. This is an experimental field. * * Optional. The REST collection name is by default derived from the URL pattern. If specified, * this field overrides the default collection name. Example: * * rpc AddressesAggregatedList(AddressesAggregatedListRequest) returns * (AddressesAggregatedListResponse) { option (google.api.http) = { get: * "/v1/projects/{project_id}/aggregated/addresses" rest_collection: "projects.addresses" * }; } * * This method has the automatically derived collection name "projects.aggregated". Because, * semantically, this rpc is actually an operation on the "projects.addresses" collection, the * `rest_collection` field is configured to override the derived collection name. * @param restCollection restCollection or {@code null} for none */ public HttpRule setRestCollection(java.lang.String restCollection) { this.restCollection = restCollection; return this; } /** * DO NOT USE. This is an experimental field. * * Optional. The rest method name is by default derived from the URL pattern. If specified, this * field overrides the default method name. Example: * * rpc CreateResource(CreateResourceRequest) returns (CreateResourceResponse) { * option (google.api.http) = { post: "/v1/resources", body: "resource", * rest_method_name: "insert" }; } * * This method has the automatically derived rest method name "create", but for backwards * compatibility with apiary, it is specified as insert. * @return value or {@code null} for none */ public java.lang.String getRestMethodName() { return restMethodName; } /** * DO NOT USE. This is an experimental field. * * Optional. The rest method name is by default derived from the URL pattern. If specified, this * field overrides the default method name. Example: * * rpc CreateResource(CreateResourceRequest) returns (CreateResourceResponse) { * option (google.api.http) = { post: "/v1/resources", body: "resource", * rest_method_name: "insert" }; } * * This method has the automatically derived rest method name "create", but for backwards * compatibility with apiary, it is specified as insert. * @param restMethodName restMethodName or {@code null} for none */ public HttpRule setRestMethodName(java.lang.String restMethodName) { this.restMethodName = restMethodName; return this; } /** * Selects methods to which this rule applies. * * Refer to selector for syntax details. * @return value or {@code null} for none */ public java.lang.String getSelector() { return selector; } /** * Selects methods to which this rule applies. * * Refer to selector for syntax details. * @param selector selector or {@code null} for none */ public HttpRule setSelector(java.lang.String selector) { this.selector = selector; return this; } @Override public HttpRule set(String fieldName, Object value) { return (HttpRule) super.set(fieldName, value); } @Override public HttpRule clone() { return (HttpRule) super.clone(); } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy