Class: Google::Cloud::Tasks::V2::AppEngineHttpRequest
- Inherits:
-
Object
- Object
- Google::Cloud::Tasks::V2::AppEngineHttpRequest
- Defined in:
- lib/google/cloud/tasks/v2/doc/google/cloud/tasks/v2/target.rb
Overview
App Engine HTTP request.
The message defines the HTTP request that is sent to an App Engine app when the task is dispatched.
Using AppEngineHttpRequest requires
appengine.applications.get
Google IAM permission for the project
and the following scope:
https://www.googleapis.com/auth/cloud-platform
The task will be delivered to the App Engine app which belongs to the same project as the queue. For more information, see How Requests are Routed and how routing is affected by dispatch files. Traffic is encrypted during transport and never leaves Google datacenters. Because this traffic is carried over a communication mechanism internal to Google, you cannot explicitly set the protocol (for example, HTTP or HTTPS). The request to the handler, however, will appear to have used the HTTP protocol.
The AppEngineRouting used to construct the URL that the task is delivered to can be set at the queue-level or task-level:
- If [app_engine_routing_override is set on the queue][Queue.app_engine_routing_override], this value is used for all tasks in the queue, no matter what the setting is for the [task-level app_engine_routing][AppEngineHttpRequest.app_engine_routing].
The url that the task will be sent to is:
url =host+relative_uri
Tasks can be dispatched to secure app handlers, unsecure app handlers, and
URIs restricted with
login:
admin.
Because tasks are not run as any user, they cannot be dispatched to URIs
restricted with
login:
required
Task dispatches also do not follow redirects.
The task attempt has succeeded if the app's request handler returns an HTTP
response code in the range [200 - 299]. The task attempt has failed if
the app's handler returns a non-2xx response code or Cloud Tasks does
not receive response before the deadline. Failed
tasks will be retried according to the
retry configuration. 503 (Service Unavailable) is
considered an App Engine system error instead of an application error and
will cause Cloud Tasks' traffic congestion control to temporarily throttle
the queue's dispatches. Unlike other types of task targets, a 429 (Too Many
Requests) response from an app handler does not cause traffic congestion
control to throttle the queue.
Instance Attribute Summary collapse
-
#app_engine_routing ⇒ Google::Cloud::Tasks::V2::AppEngineRouting
Task-level setting for App Engine routing.
-
#body ⇒ String
HTTP request body.
-
#headers ⇒ Hash{String => String}
HTTP request headers.
-
#http_method ⇒ Google::Cloud::Tasks::V2::HttpMethod
The HTTP method to use for the request.
-
#relative_uri ⇒ String
The relative URI.
Instance Attribute Details
#app_engine_routing ⇒ Google::Cloud::Tasks::V2::AppEngineRouting
259 |
# File 'lib/google/cloud/tasks/v2/doc/google/cloud/tasks/v2/target.rb', line 259 class AppEngineHttpRequest; end |
#body ⇒ String
259 |
# File 'lib/google/cloud/tasks/v2/doc/google/cloud/tasks/v2/target.rb', line 259 class AppEngineHttpRequest; end |
#headers ⇒ Hash{String => String}
259 |
# File 'lib/google/cloud/tasks/v2/doc/google/cloud/tasks/v2/target.rb', line 259 class AppEngineHttpRequest; end |
#http_method ⇒ Google::Cloud::Tasks::V2::HttpMethod
259 |
# File 'lib/google/cloud/tasks/v2/doc/google/cloud/tasks/v2/target.rb', line 259 class AppEngineHttpRequest; end |
#relative_uri ⇒ String
259 |
# File 'lib/google/cloud/tasks/v2/doc/google/cloud/tasks/v2/target.rb', line 259 class AppEngineHttpRequest; end |