| // Copyright 2016 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 csharp_namespace = "Google.LongRunning"; |
| option go_package = "google.golang.org/genproto/googleapis/longrunning;longrunning"; |
| 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 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 { |
| // Lists operations that match the specified filter in the request. If the |
| // server doesn't support this method, it returns `UNIMPLEMENTED`. |
| // |
| // NOTE: the `name` binding below allows API services to override the binding |
| // to use different resource name schemes, such as `users/*/operations`. |
| rpc ListOperations(ListOperationsRequest) returns (ListOperationsResponse) { |
| option (google.api.http) = { get: "/v1/{name=operations}" }; |
| } |
| |
| // Gets the latest state of a long-running operation. Clients can 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/**}" }; |
| } |
| |
| // Deletes a long-running operation. This method indicates that the client is |
| // no longer interested in the operation result. It does not cancel the |
| // operation. If the server doesn't support this method, it returns |
| // `google.rpc.Code.UNIMPLEMENTED`. |
| rpc DeleteOperation(DeleteOperationRequest) returns (google.protobuf.Empty) { |
| option (google.api.http) = { delete: "/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 can use |
| // [Operations.GetOperation][google.longrunning.Operations.GetOperation] or |
| // other methods to check whether the cancellation succeeded or whether the |
| // operation completed despite cancellation. On successful cancellation, |
| // the operation is not deleted; instead, it becomes an operation with |
| // an [Operation.error][google.longrunning.Operation.error] value with a [google.rpc.Status.code][google.rpc.Status.code] of 1, |
| // corresponding to `Code.CANCELLED`. |
| rpc CancelOperation(CancelOperationRequest) returns (google.protobuf.Empty) { |
| option (google.api.http) = { post: "/v1/{name=operations/**}:cancel" body: "*" }; |
| } |
| } |
| |
| // This resource represents a long-running operation that is the result of a |
| // network API call. |
| message Operation { |
| // The server-assigned name, which is only unique within the same service that |
| // originally returns it. If you use the default HTTP mapping, the |
| // `name` should have the format of `operations/some/unique/name`. |
| string name = 1; |
| |
| // Service-specific metadata associated with the operation. It typically |
| // contains progress information and common metadata such as create time. |
| // Some services might 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 either `error` or `response` is |
| // available. |
| bool done = 3; |
| |
| // The operation result, which can be either an `error` or a valid `response`. |
| // If `done` == `false`, neither `error` nor `response` is set. |
| // If `done` == `true`, exactly one of `error` or `response` is set. |
| oneof result { |
| // The error result of the operation in case of failure or cancellation. |
| 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 is |
| // `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 is |
| // `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 matches 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; |
| } |
| |