| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144 |
- // Copyright (c) 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.
- syntax = "proto3";
- package google.longrunning;
- import "google/api/annotations.proto";
- import "google/protobuf/any.proto";
- import "google/protobuf/empty.proto";
- import "google/rpc/status.proto";
- option java_multiple_files = true;
- option java_outer_classname = "OperationsProto";
- option java_package = "com.google.longrunning";
- // Manages long-running operations with an API service.
- //
- // When an API method normally takes long time to complete, it can be designed
- // to return [Operation][google.longrunning.Operation] to the client, and the client can use this
- // interface to receive the real response asynchronously by polling the
- // operation resource, or using `google.watcher.v1.Watcher` interface to watch
- // the response, or pass the operation resource to another API (such as Google
- // Cloud Pub/Sub API) to receive the response. Any API service that returns
- // long-running operations should implement the `Operations` interface so
- // developers can have a consistent client experience.
- service Operations {
- // Gets the latest state of a long-running operation. Clients may use this
- // method to poll the operation result at intervals as recommended by the API
- // service.
- rpc GetOperation(GetOperationRequest) returns (Operation) {
- //option (google.api.http) = { get: "/v1/{name=operations/**}" };
- }
- // Lists operations that match the specified filter in the request. If the
- // server doesn't support this method, it returns
- // `google.rpc.Code.UNIMPLEMENTED`.
- rpc ListOperations(ListOperationsRequest) returns (ListOperationsResponse) {
- //option (google.api.http) = { get: "/v1/{name=operations}" };
- }
- // Starts asynchronous cancellation on a long-running operation. The server
- // makes a best effort to cancel the operation, but success is not
- // guaranteed. If the server doesn't support this method, it returns
- // `google.rpc.Code.UNIMPLEMENTED`. Clients may use
- // [Operations.GetOperation] or other methods to check whether the
- // cancellation succeeded or the operation completed despite cancellation.
- rpc CancelOperation(CancelOperationRequest) returns (google.protobuf.Empty) {
- //option (google.api.http) = { post: "/v1/{name=operations/**}:cancel" body: "*" };
- }
- // Deletes a long-running operation. It indicates the client is no longer
- // interested in the operation result. It does not cancel the operation.
- rpc DeleteOperation(DeleteOperationRequest) returns (google.protobuf.Empty) {
- //option (google.api.http) = { delete: "/v1/{name=operations/**}" };
- }
- }
- // This resource represents a long-running operation that is the result of a
- // network API call.
- message Operation {
- // The name of the operation resource, which is only unique within the same
- // service that originally returns it.
- string name = 1;
- // Some service-specific metadata associated with the operation. It typically
- // contains progress information and common metadata such as create time.
- // Some services may not provide such metadata. Any method that returns a
- // long-running operation should document the metadata type, if any.
- google.protobuf.Any metadata = 2;
- // If the value is false, it means the operation is still in progress.
- // If true, the operation is completed and the `result` is available.
- bool done = 3;
- oneof result {
- // The error result of the operation in case of failure.
- google.rpc.Status error = 4;
- // The normal response of the operation in case of success. If the original
- // method returns no data on success, such as `Delete`, the response will be
- // `google.protobuf.Empty`. If the original method is standard
- // `Get`/`Create`/`Update`, the response should be the resource. For other
- // methods, the response should have the type `XxxResponse`, where `Xxx`
- // is the original method name. For example, if the original method name
- // is `TakeSnapshot()`, the inferred response type will be
- // `TakeSnapshotResponse`.
- google.protobuf.Any response = 5;
- }
- }
- // The request message for [Operations.GetOperation][google.longrunning.Operations.GetOperation].
- message GetOperationRequest {
- // The name of the operation resource.
- string name = 1;
- }
- // The request message for [Operations.ListOperations][google.longrunning.Operations.ListOperations].
- message ListOperationsRequest {
- // The name of the operation collection.
- string name = 4;
- // The standard List filter.
- string filter = 1;
- // The standard List page size.
- int32 page_size = 2;
- // The standard List page token.
- string page_token = 3;
- }
- // The response message for [Operations.ListOperations][google.longrunning.Operations.ListOperations].
- message ListOperationsResponse {
- // A list of operations that match the specified filter in the request.
- repeated Operation operations = 1;
- // The standard List next-page token.
- string next_page_token = 2;
- }
- // The request message for [Operations.CancelOperation][google.longrunning.Operations.CancelOperation].
- message CancelOperationRequest {
- // The name of the operation resource to be cancelled.
- string name = 1;
- }
- // The request message for [Operations.DeleteOperation][google.longrunning.Operations.DeleteOperation].
- message DeleteOperationRequest {
- // The name of the operation resource to be deleted.
- string name = 1;
- }
|