xref: /aosp_15_r20/external/googleapis/google/cloud/scheduler/v1/target.proto (revision d5c09012810ac0c9f33fe448fb6da8260d444cc9)
1*d5c09012SAndroid Build Coastguard Worker// Copyright 2022 Google LLC
2*d5c09012SAndroid Build Coastguard Worker//
3*d5c09012SAndroid Build Coastguard Worker// Licensed under the Apache License, Version 2.0 (the "License");
4*d5c09012SAndroid Build Coastguard Worker// you may not use this file except in compliance with the License.
5*d5c09012SAndroid Build Coastguard Worker// You may obtain a copy of the License at
6*d5c09012SAndroid Build Coastguard Worker//
7*d5c09012SAndroid Build Coastguard Worker//     http://www.apache.org/licenses/LICENSE-2.0
8*d5c09012SAndroid Build Coastguard Worker//
9*d5c09012SAndroid Build Coastguard Worker// Unless required by applicable law or agreed to in writing, software
10*d5c09012SAndroid Build Coastguard Worker// distributed under the License is distributed on an "AS IS" BASIS,
11*d5c09012SAndroid Build Coastguard Worker// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12*d5c09012SAndroid Build Coastguard Worker// See the License for the specific language governing permissions and
13*d5c09012SAndroid Build Coastguard Worker// limitations under the License.
14*d5c09012SAndroid Build Coastguard Worker
15*d5c09012SAndroid Build Coastguard Workersyntax = "proto3";
16*d5c09012SAndroid Build Coastguard Worker
17*d5c09012SAndroid Build Coastguard Workerpackage google.cloud.scheduler.v1;
18*d5c09012SAndroid Build Coastguard Worker
19*d5c09012SAndroid Build Coastguard Workerimport "google/api/resource.proto";
20*d5c09012SAndroid Build Coastguard Worker
21*d5c09012SAndroid Build Coastguard Workeroption go_package = "cloud.google.com/go/scheduler/apiv1/schedulerpb;schedulerpb";
22*d5c09012SAndroid Build Coastguard Workeroption java_multiple_files = true;
23*d5c09012SAndroid Build Coastguard Workeroption java_outer_classname = "TargetProto";
24*d5c09012SAndroid Build Coastguard Workeroption java_package = "com.google.cloud.scheduler.v1";
25*d5c09012SAndroid Build Coastguard Workeroption (google.api.resource_definition) = {
26*d5c09012SAndroid Build Coastguard Worker  type: "pubsub.googleapis.com/Topic"
27*d5c09012SAndroid Build Coastguard Worker  pattern: "projects/{project}/topics/{topic}"
28*d5c09012SAndroid Build Coastguard Worker};
29*d5c09012SAndroid Build Coastguard Worker
30*d5c09012SAndroid Build Coastguard Worker// Http target. The job will be pushed to the job handler by means of
31*d5c09012SAndroid Build Coastguard Worker// an HTTP request via an
32*d5c09012SAndroid Build Coastguard Worker// [http_method][google.cloud.scheduler.v1.HttpTarget.http_method] such as HTTP
33*d5c09012SAndroid Build Coastguard Worker// POST, HTTP GET, etc. The job is acknowledged by means of an HTTP
34*d5c09012SAndroid Build Coastguard Worker// response code in the range [200 - 299]. A failure to receive a response
35*d5c09012SAndroid Build Coastguard Worker// constitutes a failed execution. For a redirected request, the response
36*d5c09012SAndroid Build Coastguard Worker// returned by the redirected request is considered.
37*d5c09012SAndroid Build Coastguard Workermessage HttpTarget {
38*d5c09012SAndroid Build Coastguard Worker  // Required. The full URI path that the request will be sent to. This string
39*d5c09012SAndroid Build Coastguard Worker  // must begin with either "http://" or "https://". Some examples of
40*d5c09012SAndroid Build Coastguard Worker  // valid values for [uri][google.cloud.scheduler.v1.HttpTarget.uri] are:
41*d5c09012SAndroid Build Coastguard Worker  // `http://acme.com` and `https://acme.com/sales:8080`. Cloud Scheduler will
42*d5c09012SAndroid Build Coastguard Worker  // encode some characters for safety and compatibility. The maximum allowed
43*d5c09012SAndroid Build Coastguard Worker  // URL length is 2083 characters after encoding.
44*d5c09012SAndroid Build Coastguard Worker  string uri = 1;
45*d5c09012SAndroid Build Coastguard Worker
46*d5c09012SAndroid Build Coastguard Worker  // Which HTTP method to use for the request.
47*d5c09012SAndroid Build Coastguard Worker  HttpMethod http_method = 2;
48*d5c09012SAndroid Build Coastguard Worker
49*d5c09012SAndroid Build Coastguard Worker  // The user can specify HTTP request headers to send with the job's
50*d5c09012SAndroid Build Coastguard Worker  // HTTP request. This map contains the header field names and
51*d5c09012SAndroid Build Coastguard Worker  // values. Repeated headers are not supported, but a header value can
52*d5c09012SAndroid Build Coastguard Worker  // contain commas. These headers represent a subset of the headers
53*d5c09012SAndroid Build Coastguard Worker  // that will accompany the job's HTTP request. Some HTTP request
54*d5c09012SAndroid Build Coastguard Worker  // headers will be ignored or replaced. A partial list of headers that
55*d5c09012SAndroid Build Coastguard Worker  // will be ignored or replaced is below:
56*d5c09012SAndroid Build Coastguard Worker  // - Host: This will be computed by Cloud Scheduler and derived from
57*d5c09012SAndroid Build Coastguard Worker  // [uri][google.cloud.scheduler.v1.HttpTarget.uri].
58*d5c09012SAndroid Build Coastguard Worker  // * `Content-Length`: This will be computed by Cloud Scheduler.
59*d5c09012SAndroid Build Coastguard Worker  // * `User-Agent`: This will be set to `"Google-Cloud-Scheduler"`.
60*d5c09012SAndroid Build Coastguard Worker  // * `X-Google-*`: Google internal use only.
61*d5c09012SAndroid Build Coastguard Worker  // * `X-AppEngine-*`: Google internal use only.
62*d5c09012SAndroid Build Coastguard Worker  // * `X-CloudScheduler`: This header will be set to true.
63*d5c09012SAndroid Build Coastguard Worker  // * `X-CloudScheduler-JobName`: This header will contain the job name.
64*d5c09012SAndroid Build Coastguard Worker  // * `X-CloudScheduler-ScheduleTime`: For Cloud Scheduler jobs specified in
65*d5c09012SAndroid Build Coastguard Worker  // the unix-cron format, this header will contain the job schedule as an
66*d5c09012SAndroid Build Coastguard Worker  // offset of UTC parsed according to RFC3339.
67*d5c09012SAndroid Build Coastguard Worker  //
68*d5c09012SAndroid Build Coastguard Worker  // The total size of headers must be less than 80KB.
69*d5c09012SAndroid Build Coastguard Worker  map<string, string> headers = 3;
70*d5c09012SAndroid Build Coastguard Worker
71*d5c09012SAndroid Build Coastguard Worker  // HTTP request body. A request body is allowed only if the HTTP
72*d5c09012SAndroid Build Coastguard Worker  // method is POST, PUT, or PATCH. It is an error to set body on a job with an
73*d5c09012SAndroid Build Coastguard Worker  // incompatible [HttpMethod][google.cloud.scheduler.v1.HttpMethod].
74*d5c09012SAndroid Build Coastguard Worker  bytes body = 4;
75*d5c09012SAndroid Build Coastguard Worker
76*d5c09012SAndroid Build Coastguard Worker  // The mode for generating an `Authorization` header for HTTP requests.
77*d5c09012SAndroid Build Coastguard Worker  //
78*d5c09012SAndroid Build Coastguard Worker  // If specified, all `Authorization` headers in the
79*d5c09012SAndroid Build Coastguard Worker  // [HttpTarget.headers][google.cloud.scheduler.v1.HttpTarget.headers] field
80*d5c09012SAndroid Build Coastguard Worker  // will be overridden.
81*d5c09012SAndroid Build Coastguard Worker  oneof authorization_header {
82*d5c09012SAndroid Build Coastguard Worker    // If specified, an
83*d5c09012SAndroid Build Coastguard Worker    // [OAuth token](https://developers.google.com/identity/protocols/OAuth2)
84*d5c09012SAndroid Build Coastguard Worker    // will be generated and attached as an `Authorization` header in the HTTP
85*d5c09012SAndroid Build Coastguard Worker    // request.
86*d5c09012SAndroid Build Coastguard Worker    //
87*d5c09012SAndroid Build Coastguard Worker    // This type of authorization should generally only be used when calling
88*d5c09012SAndroid Build Coastguard Worker    // Google APIs hosted on *.googleapis.com.
89*d5c09012SAndroid Build Coastguard Worker    OAuthToken oauth_token = 5;
90*d5c09012SAndroid Build Coastguard Worker
91*d5c09012SAndroid Build Coastguard Worker    // If specified, an
92*d5c09012SAndroid Build Coastguard Worker    // [OIDC](https://developers.google.com/identity/protocols/OpenIDConnect)
93*d5c09012SAndroid Build Coastguard Worker    // token will be generated and attached as an `Authorization` header in the
94*d5c09012SAndroid Build Coastguard Worker    // HTTP request.
95*d5c09012SAndroid Build Coastguard Worker    //
96*d5c09012SAndroid Build Coastguard Worker    // This type of authorization can be used for many scenarios, including
97*d5c09012SAndroid Build Coastguard Worker    // calling Cloud Run, or endpoints where you intend to validate the token
98*d5c09012SAndroid Build Coastguard Worker    // yourself.
99*d5c09012SAndroid Build Coastguard Worker    OidcToken oidc_token = 6;
100*d5c09012SAndroid Build Coastguard Worker  }
101*d5c09012SAndroid Build Coastguard Worker}
102*d5c09012SAndroid Build Coastguard Worker
103*d5c09012SAndroid Build Coastguard Worker// App Engine target. The job will be pushed to a job handler by means
104*d5c09012SAndroid Build Coastguard Worker// of an HTTP request via an
105*d5c09012SAndroid Build Coastguard Worker// [http_method][google.cloud.scheduler.v1.AppEngineHttpTarget.http_method] such
106*d5c09012SAndroid Build Coastguard Worker// as HTTP POST, HTTP GET, etc. The job is acknowledged by means of an
107*d5c09012SAndroid Build Coastguard Worker// HTTP response code in the range [200 - 299]. Error 503 is
108*d5c09012SAndroid Build Coastguard Worker// considered an App Engine system error instead of an application
109*d5c09012SAndroid Build Coastguard Worker// error. Requests returning error 503 will be retried regardless of
110*d5c09012SAndroid Build Coastguard Worker// retry configuration and not counted against retry counts. Any other
111*d5c09012SAndroid Build Coastguard Worker// response code, or a failure to receive a response before the
112*d5c09012SAndroid Build Coastguard Worker// deadline, constitutes a failed attempt.
113*d5c09012SAndroid Build Coastguard Workermessage AppEngineHttpTarget {
114*d5c09012SAndroid Build Coastguard Worker  // The HTTP method to use for the request. PATCH and OPTIONS are not
115*d5c09012SAndroid Build Coastguard Worker  // permitted.
116*d5c09012SAndroid Build Coastguard Worker  HttpMethod http_method = 1;
117*d5c09012SAndroid Build Coastguard Worker
118*d5c09012SAndroid Build Coastguard Worker  // App Engine Routing setting for the job.
119*d5c09012SAndroid Build Coastguard Worker  AppEngineRouting app_engine_routing = 2;
120*d5c09012SAndroid Build Coastguard Worker
121*d5c09012SAndroid Build Coastguard Worker  // The relative URI.
122*d5c09012SAndroid Build Coastguard Worker  //
123*d5c09012SAndroid Build Coastguard Worker  // The relative URL must begin with "/" and must be a valid HTTP relative URL.
124*d5c09012SAndroid Build Coastguard Worker  // It can contain a path, query string arguments, and `#` fragments.
125*d5c09012SAndroid Build Coastguard Worker  // If the relative URL is empty, then the root path "/" will be used.
126*d5c09012SAndroid Build Coastguard Worker  // No spaces are allowed, and the maximum length allowed is 2083 characters.
127*d5c09012SAndroid Build Coastguard Worker  string relative_uri = 3;
128*d5c09012SAndroid Build Coastguard Worker
129*d5c09012SAndroid Build Coastguard Worker  // HTTP request headers.
130*d5c09012SAndroid Build Coastguard Worker  //
131*d5c09012SAndroid Build Coastguard Worker  // This map contains the header field names and values. Headers can be set
132*d5c09012SAndroid Build Coastguard Worker  // when the job is created.
133*d5c09012SAndroid Build Coastguard Worker  //
134*d5c09012SAndroid Build Coastguard Worker  // Cloud Scheduler sets some headers to default values:
135*d5c09012SAndroid Build Coastguard Worker  //
136*d5c09012SAndroid Build Coastguard Worker  // * `User-Agent`: By default, this header is
137*d5c09012SAndroid Build Coastguard Worker  //   `"AppEngine-Google; (+http://code.google.com/appengine)"`.
138*d5c09012SAndroid Build Coastguard Worker  //   This header can be modified, but Cloud Scheduler will append
139*d5c09012SAndroid Build Coastguard Worker  //   `"AppEngine-Google; (+http://code.google.com/appengine)"` to the
140*d5c09012SAndroid Build Coastguard Worker  //   modified `User-Agent`.
141*d5c09012SAndroid Build Coastguard Worker  // * `X-CloudScheduler`: This header will be set to true.
142*d5c09012SAndroid Build Coastguard Worker  // * `X-CloudScheduler-JobName`: This header will contain the job name.
143*d5c09012SAndroid Build Coastguard Worker  // * `X-CloudScheduler-ScheduleTime`: For Cloud Scheduler jobs specified in
144*d5c09012SAndroid Build Coastguard Worker  // the unix-cron format, this header will contain the job schedule as an
145*d5c09012SAndroid Build Coastguard Worker  // offset of UTC parsed according to RFC3339.
146*d5c09012SAndroid Build Coastguard Worker  //
147*d5c09012SAndroid Build Coastguard Worker  // If the job has an
148*d5c09012SAndroid Build Coastguard Worker  // [body][google.cloud.scheduler.v1.AppEngineHttpTarget.body], Cloud Scheduler
149*d5c09012SAndroid Build Coastguard Worker  // sets the following headers:
150*d5c09012SAndroid Build Coastguard Worker  //
151*d5c09012SAndroid Build Coastguard Worker  // * `Content-Type`: By default, the `Content-Type` header is set to
152*d5c09012SAndroid Build Coastguard Worker  //   `"application/octet-stream"`. The default can be overridden by explictly
153*d5c09012SAndroid Build Coastguard Worker  //   setting `Content-Type` to a particular media type when the job is
154*d5c09012SAndroid Build Coastguard Worker  //   created.
155*d5c09012SAndroid Build Coastguard Worker  //   For example, `Content-Type` can be set to `"application/json"`.
156*d5c09012SAndroid Build Coastguard Worker  // * `Content-Length`: This is computed by Cloud Scheduler. This value is
157*d5c09012SAndroid Build Coastguard Worker  //   output only. It cannot be changed.
158*d5c09012SAndroid Build Coastguard Worker  //
159*d5c09012SAndroid Build Coastguard Worker  // The headers below are output only. They cannot be set or overridden:
160*d5c09012SAndroid Build Coastguard Worker  //
161*d5c09012SAndroid Build Coastguard Worker  // * `X-Google-*`: For Google internal use only.
162*d5c09012SAndroid Build Coastguard Worker  // * `X-AppEngine-*`: For Google internal use only.
163*d5c09012SAndroid Build Coastguard Worker  //
164*d5c09012SAndroid Build Coastguard Worker  // In addition, some App Engine headers, which contain
165*d5c09012SAndroid Build Coastguard Worker  // job-specific information, are also be sent to the job handler.
166*d5c09012SAndroid Build Coastguard Worker  map<string, string> headers = 4;
167*d5c09012SAndroid Build Coastguard Worker
168*d5c09012SAndroid Build Coastguard Worker  // Body.
169*d5c09012SAndroid Build Coastguard Worker  //
170*d5c09012SAndroid Build Coastguard Worker  // HTTP request body. A request body is allowed only if the HTTP method is
171*d5c09012SAndroid Build Coastguard Worker  // POST or PUT. It will result in invalid argument error to set a body on a
172*d5c09012SAndroid Build Coastguard Worker  // job with an incompatible
173*d5c09012SAndroid Build Coastguard Worker  // [HttpMethod][google.cloud.scheduler.v1.HttpMethod].
174*d5c09012SAndroid Build Coastguard Worker  bytes body = 5;
175*d5c09012SAndroid Build Coastguard Worker}
176*d5c09012SAndroid Build Coastguard Worker
177*d5c09012SAndroid Build Coastguard Worker// Pub/Sub target. The job will be delivered by publishing a message to
178*d5c09012SAndroid Build Coastguard Worker// the given Pub/Sub topic.
179*d5c09012SAndroid Build Coastguard Workermessage PubsubTarget {
180*d5c09012SAndroid Build Coastguard Worker  // Required. The name of the Cloud Pub/Sub topic to which messages will
181*d5c09012SAndroid Build Coastguard Worker  // be published when a job is delivered. The topic name must be in the
182*d5c09012SAndroid Build Coastguard Worker  // same format as required by Pub/Sub's
183*d5c09012SAndroid Build Coastguard Worker  // [PublishRequest.name](https://cloud.google.com/pubsub/docs/reference/rpc/google.pubsub.v1#publishrequest),
184*d5c09012SAndroid Build Coastguard Worker  // for example `projects/PROJECT_ID/topics/TOPIC_ID`.
185*d5c09012SAndroid Build Coastguard Worker  //
186*d5c09012SAndroid Build Coastguard Worker  // The topic must be in the same project as the Cloud Scheduler job.
187*d5c09012SAndroid Build Coastguard Worker  string topic_name = 1 [
188*d5c09012SAndroid Build Coastguard Worker    (google.api.resource_reference) = { type: "pubsub.googleapis.com/Topic" }
189*d5c09012SAndroid Build Coastguard Worker  ];
190*d5c09012SAndroid Build Coastguard Worker
191*d5c09012SAndroid Build Coastguard Worker  // The message payload for PubsubMessage.
192*d5c09012SAndroid Build Coastguard Worker  //
193*d5c09012SAndroid Build Coastguard Worker  // Pubsub message must contain either non-empty data, or at least one
194*d5c09012SAndroid Build Coastguard Worker  // attribute.
195*d5c09012SAndroid Build Coastguard Worker  bytes data = 3;
196*d5c09012SAndroid Build Coastguard Worker
197*d5c09012SAndroid Build Coastguard Worker  // Attributes for PubsubMessage.
198*d5c09012SAndroid Build Coastguard Worker  //
199*d5c09012SAndroid Build Coastguard Worker  // Pubsub message must contain either non-empty data, or at least one
200*d5c09012SAndroid Build Coastguard Worker  // attribute.
201*d5c09012SAndroid Build Coastguard Worker  map<string, string> attributes = 4;
202*d5c09012SAndroid Build Coastguard Worker}
203*d5c09012SAndroid Build Coastguard Worker
204*d5c09012SAndroid Build Coastguard Worker// App Engine Routing.
205*d5c09012SAndroid Build Coastguard Worker//
206*d5c09012SAndroid Build Coastguard Worker// For more information about services, versions, and instances see
207*d5c09012SAndroid Build Coastguard Worker// [An Overview of App
208*d5c09012SAndroid Build Coastguard Worker// Engine](https://cloud.google.com/appengine/docs/python/an-overview-of-app-engine),
209*d5c09012SAndroid Build Coastguard Worker// [Microservices Architecture on Google App
210*d5c09012SAndroid Build Coastguard Worker// Engine](https://cloud.google.com/appengine/docs/python/microservices-on-app-engine),
211*d5c09012SAndroid Build Coastguard Worker// [App Engine Standard request
212*d5c09012SAndroid Build Coastguard Worker// routing](https://cloud.google.com/appengine/docs/standard/python/how-requests-are-routed),
213*d5c09012SAndroid Build Coastguard Worker// and [App Engine Flex request
214*d5c09012SAndroid Build Coastguard Worker// routing](https://cloud.google.com/appengine/docs/flexible/python/how-requests-are-routed).
215*d5c09012SAndroid Build Coastguard Workermessage AppEngineRouting {
216*d5c09012SAndroid Build Coastguard Worker  // App service.
217*d5c09012SAndroid Build Coastguard Worker  //
218*d5c09012SAndroid Build Coastguard Worker  // By default, the job is sent to the service which is the default
219*d5c09012SAndroid Build Coastguard Worker  // service when the job is attempted.
220*d5c09012SAndroid Build Coastguard Worker  string service = 1;
221*d5c09012SAndroid Build Coastguard Worker
222*d5c09012SAndroid Build Coastguard Worker  // App version.
223*d5c09012SAndroid Build Coastguard Worker  //
224*d5c09012SAndroid Build Coastguard Worker  // By default, the job is sent to the version which is the default
225*d5c09012SAndroid Build Coastguard Worker  // version when the job is attempted.
226*d5c09012SAndroid Build Coastguard Worker  string version = 2;
227*d5c09012SAndroid Build Coastguard Worker
228*d5c09012SAndroid Build Coastguard Worker  // App instance.
229*d5c09012SAndroid Build Coastguard Worker  //
230*d5c09012SAndroid Build Coastguard Worker  // By default, the job is sent to an instance which is available when
231*d5c09012SAndroid Build Coastguard Worker  // the job is attempted.
232*d5c09012SAndroid Build Coastguard Worker  //
233*d5c09012SAndroid Build Coastguard Worker  // Requests can only be sent to a specific instance if
234*d5c09012SAndroid Build Coastguard Worker  // [manual scaling is used in App Engine
235*d5c09012SAndroid Build Coastguard Worker  // Standard](https://cloud.google.com/appengine/docs/python/an-overview-of-app-engine?#scaling_types_and_instance_classes).
236*d5c09012SAndroid Build Coastguard Worker  // App Engine Flex does not support instances. For more information, see
237*d5c09012SAndroid Build Coastguard Worker  // [App Engine Standard request
238*d5c09012SAndroid Build Coastguard Worker  // routing](https://cloud.google.com/appengine/docs/standard/python/how-requests-are-routed)
239*d5c09012SAndroid Build Coastguard Worker  // and [App Engine Flex request
240*d5c09012SAndroid Build Coastguard Worker  // routing](https://cloud.google.com/appengine/docs/flexible/python/how-requests-are-routed).
241*d5c09012SAndroid Build Coastguard Worker  string instance = 3;
242*d5c09012SAndroid Build Coastguard Worker
243*d5c09012SAndroid Build Coastguard Worker  // Output only. The host that the job is sent to.
244*d5c09012SAndroid Build Coastguard Worker  //
245*d5c09012SAndroid Build Coastguard Worker  // For more information about how App Engine requests are routed, see
246*d5c09012SAndroid Build Coastguard Worker  // [here](https://cloud.google.com/appengine/docs/standard/python/how-requests-are-routed).
247*d5c09012SAndroid Build Coastguard Worker  //
248*d5c09012SAndroid Build Coastguard Worker  // The host is constructed as:
249*d5c09012SAndroid Build Coastguard Worker  //
250*d5c09012SAndroid Build Coastguard Worker  //
251*d5c09012SAndroid Build Coastguard Worker  // * `host = [application_domain_name]`</br>
252*d5c09012SAndroid Build Coastguard Worker  //   `| [service] + '.' + [application_domain_name]`</br>
253*d5c09012SAndroid Build Coastguard Worker  //   `| [version] + '.' + [application_domain_name]`</br>
254*d5c09012SAndroid Build Coastguard Worker  //   `| [version_dot_service]+ '.' + [application_domain_name]`</br>
255*d5c09012SAndroid Build Coastguard Worker  //   `| [instance] + '.' + [application_domain_name]`</br>
256*d5c09012SAndroid Build Coastguard Worker  //   `| [instance_dot_service] + '.' + [application_domain_name]`</br>
257*d5c09012SAndroid Build Coastguard Worker  //   `| [instance_dot_version] + '.' + [application_domain_name]`</br>
258*d5c09012SAndroid Build Coastguard Worker  //   `| [instance_dot_version_dot_service] + '.' + [application_domain_name]`
259*d5c09012SAndroid Build Coastguard Worker  //
260*d5c09012SAndroid Build Coastguard Worker  // * `application_domain_name` = The domain name of the app, for
261*d5c09012SAndroid Build Coastguard Worker  //   example <app-id>.appspot.com, which is associated with the
262*d5c09012SAndroid Build Coastguard Worker  //   job's project ID.
263*d5c09012SAndroid Build Coastguard Worker  //
264*d5c09012SAndroid Build Coastguard Worker  // * `service =` [service][google.cloud.scheduler.v1.AppEngineRouting.service]
265*d5c09012SAndroid Build Coastguard Worker  //
266*d5c09012SAndroid Build Coastguard Worker  // * `version =` [version][google.cloud.scheduler.v1.AppEngineRouting.version]
267*d5c09012SAndroid Build Coastguard Worker  //
268*d5c09012SAndroid Build Coastguard Worker  // * `version_dot_service =`
269*d5c09012SAndroid Build Coastguard Worker  //   [version][google.cloud.scheduler.v1.AppEngineRouting.version] `+ '.' +`
270*d5c09012SAndroid Build Coastguard Worker  //   [service][google.cloud.scheduler.v1.AppEngineRouting.service]
271*d5c09012SAndroid Build Coastguard Worker  //
272*d5c09012SAndroid Build Coastguard Worker  // * `instance =`
273*d5c09012SAndroid Build Coastguard Worker  // [instance][google.cloud.scheduler.v1.AppEngineRouting.instance]
274*d5c09012SAndroid Build Coastguard Worker  //
275*d5c09012SAndroid Build Coastguard Worker  // * `instance_dot_service =`
276*d5c09012SAndroid Build Coastguard Worker  //   [instance][google.cloud.scheduler.v1.AppEngineRouting.instance] `+ '.' +`
277*d5c09012SAndroid Build Coastguard Worker  //   [service][google.cloud.scheduler.v1.AppEngineRouting.service]
278*d5c09012SAndroid Build Coastguard Worker  //
279*d5c09012SAndroid Build Coastguard Worker  // * `instance_dot_version =`
280*d5c09012SAndroid Build Coastguard Worker  //   [instance][google.cloud.scheduler.v1.AppEngineRouting.instance] `+ '.' +`
281*d5c09012SAndroid Build Coastguard Worker  //   [version][google.cloud.scheduler.v1.AppEngineRouting.version]
282*d5c09012SAndroid Build Coastguard Worker  //
283*d5c09012SAndroid Build Coastguard Worker  // * `instance_dot_version_dot_service =`
284*d5c09012SAndroid Build Coastguard Worker  //   [instance][google.cloud.scheduler.v1.AppEngineRouting.instance] `+ '.' +`
285*d5c09012SAndroid Build Coastguard Worker  //   [version][google.cloud.scheduler.v1.AppEngineRouting.version] `+ '.' +`
286*d5c09012SAndroid Build Coastguard Worker  //   [service][google.cloud.scheduler.v1.AppEngineRouting.service]
287*d5c09012SAndroid Build Coastguard Worker  //
288*d5c09012SAndroid Build Coastguard Worker  //
289*d5c09012SAndroid Build Coastguard Worker  // If [service][google.cloud.scheduler.v1.AppEngineRouting.service] is empty,
290*d5c09012SAndroid Build Coastguard Worker  // then the job will be sent to the service which is the default service when
291*d5c09012SAndroid Build Coastguard Worker  // the job is attempted.
292*d5c09012SAndroid Build Coastguard Worker  //
293*d5c09012SAndroid Build Coastguard Worker  // If [version][google.cloud.scheduler.v1.AppEngineRouting.version] is empty,
294*d5c09012SAndroid Build Coastguard Worker  // then the job will be sent to the version which is the default version when
295*d5c09012SAndroid Build Coastguard Worker  // the job is attempted.
296*d5c09012SAndroid Build Coastguard Worker  //
297*d5c09012SAndroid Build Coastguard Worker  // If [instance][google.cloud.scheduler.v1.AppEngineRouting.instance] is
298*d5c09012SAndroid Build Coastguard Worker  // empty, then the job will be sent to an instance which is available when the
299*d5c09012SAndroid Build Coastguard Worker  // job is attempted.
300*d5c09012SAndroid Build Coastguard Worker  //
301*d5c09012SAndroid Build Coastguard Worker  // If [service][google.cloud.scheduler.v1.AppEngineRouting.service],
302*d5c09012SAndroid Build Coastguard Worker  // [version][google.cloud.scheduler.v1.AppEngineRouting.version], or
303*d5c09012SAndroid Build Coastguard Worker  // [instance][google.cloud.scheduler.v1.AppEngineRouting.instance] is invalid,
304*d5c09012SAndroid Build Coastguard Worker  // then the job will be sent to the default version of the default service
305*d5c09012SAndroid Build Coastguard Worker  // when the job is attempted.
306*d5c09012SAndroid Build Coastguard Worker  string host = 4;
307*d5c09012SAndroid Build Coastguard Worker}
308*d5c09012SAndroid Build Coastguard Worker
309*d5c09012SAndroid Build Coastguard Worker// The HTTP method used to execute the job.
310*d5c09012SAndroid Build Coastguard Workerenum HttpMethod {
311*d5c09012SAndroid Build Coastguard Worker  // HTTP method unspecified. Defaults to POST.
312*d5c09012SAndroid Build Coastguard Worker  HTTP_METHOD_UNSPECIFIED = 0;
313*d5c09012SAndroid Build Coastguard Worker
314*d5c09012SAndroid Build Coastguard Worker  // HTTP POST
315*d5c09012SAndroid Build Coastguard Worker  POST = 1;
316*d5c09012SAndroid Build Coastguard Worker
317*d5c09012SAndroid Build Coastguard Worker  // HTTP GET
318*d5c09012SAndroid Build Coastguard Worker  GET = 2;
319*d5c09012SAndroid Build Coastguard Worker
320*d5c09012SAndroid Build Coastguard Worker  // HTTP HEAD
321*d5c09012SAndroid Build Coastguard Worker  HEAD = 3;
322*d5c09012SAndroid Build Coastguard Worker
323*d5c09012SAndroid Build Coastguard Worker  // HTTP PUT
324*d5c09012SAndroid Build Coastguard Worker  PUT = 4;
325*d5c09012SAndroid Build Coastguard Worker
326*d5c09012SAndroid Build Coastguard Worker  // HTTP DELETE
327*d5c09012SAndroid Build Coastguard Worker  DELETE = 5;
328*d5c09012SAndroid Build Coastguard Worker
329*d5c09012SAndroid Build Coastguard Worker  // HTTP PATCH
330*d5c09012SAndroid Build Coastguard Worker  PATCH = 6;
331*d5c09012SAndroid Build Coastguard Worker
332*d5c09012SAndroid Build Coastguard Worker  // HTTP OPTIONS
333*d5c09012SAndroid Build Coastguard Worker  OPTIONS = 7;
334*d5c09012SAndroid Build Coastguard Worker}
335*d5c09012SAndroid Build Coastguard Worker
336*d5c09012SAndroid Build Coastguard Worker// Contains information needed for generating an
337*d5c09012SAndroid Build Coastguard Worker// [OAuth token](https://developers.google.com/identity/protocols/OAuth2).
338*d5c09012SAndroid Build Coastguard Worker// This type of authorization should generally only be used when calling Google
339*d5c09012SAndroid Build Coastguard Worker// APIs hosted on *.googleapis.com.
340*d5c09012SAndroid Build Coastguard Workermessage OAuthToken {
341*d5c09012SAndroid Build Coastguard Worker  // [Service account email](https://cloud.google.com/iam/docs/service-accounts)
342*d5c09012SAndroid Build Coastguard Worker  // to be used for generating OAuth token.
343*d5c09012SAndroid Build Coastguard Worker  // The service account must be within the same project as the job. The caller
344*d5c09012SAndroid Build Coastguard Worker  // must have iam.serviceAccounts.actAs permission for the service account.
345*d5c09012SAndroid Build Coastguard Worker  string service_account_email = 1;
346*d5c09012SAndroid Build Coastguard Worker
347*d5c09012SAndroid Build Coastguard Worker  // OAuth scope to be used for generating OAuth access token.
348*d5c09012SAndroid Build Coastguard Worker  // If not specified, "https://www.googleapis.com/auth/cloud-platform"
349*d5c09012SAndroid Build Coastguard Worker  // will be used.
350*d5c09012SAndroid Build Coastguard Worker  string scope = 2;
351*d5c09012SAndroid Build Coastguard Worker}
352*d5c09012SAndroid Build Coastguard Worker
353*d5c09012SAndroid Build Coastguard Worker// Contains information needed for generating an
354*d5c09012SAndroid Build Coastguard Worker// [OpenID Connect
355*d5c09012SAndroid Build Coastguard Worker// token](https://developers.google.com/identity/protocols/OpenIDConnect).
356*d5c09012SAndroid Build Coastguard Worker// This type of authorization can be used for many scenarios, including
357*d5c09012SAndroid Build Coastguard Worker// calling Cloud Run, or endpoints where you intend to validate the token
358*d5c09012SAndroid Build Coastguard Worker// yourself.
359*d5c09012SAndroid Build Coastguard Workermessage OidcToken {
360*d5c09012SAndroid Build Coastguard Worker  // [Service account email](https://cloud.google.com/iam/docs/service-accounts)
361*d5c09012SAndroid Build Coastguard Worker  // to be used for generating OIDC token.
362*d5c09012SAndroid Build Coastguard Worker  // The service account must be within the same project as the job. The caller
363*d5c09012SAndroid Build Coastguard Worker  // must have iam.serviceAccounts.actAs permission for the service account.
364*d5c09012SAndroid Build Coastguard Worker  string service_account_email = 1;
365*d5c09012SAndroid Build Coastguard Worker
366*d5c09012SAndroid Build Coastguard Worker  // Audience to be used when generating OIDC token. If not specified, the URI
367*d5c09012SAndroid Build Coastguard Worker  // specified in target will be used.
368*d5c09012SAndroid Build Coastguard Worker  string audience = 2;
369*d5c09012SAndroid Build Coastguard Worker}
370