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