delowan.googlecloud.gcp_cloudscheduler_job (1.0.2) — module

Creates a GCP Job

Authors: Google Inc. (@googlecloudplatform)

preview | supported by community

Install collection

Install with ansible-galaxy collection install delowan.googlecloud:==1.0.2


Add to requirements.yml

  collections:
    - name: delowan.googlecloud
      version: 1.0.2

Description

A scheduled job that can publish a pubsub message or a http request every X interval of time, using crontab format string.

To use Cloud Scheduler your project must contain an App Engine app that is located in one of the supported regions. If your project does not have an App Engine app, you must create one.


Requirements

Usage examples

  • Success
    Steampunk Spotter scan finished with no errors, warnings or hints.
- name: create a job
  google.cloud.gcp_cloudscheduler_job:
    name: job
    region: us-central1
    schedule: "*/4 * * * *"
    description: test app engine job
    time_zone: Europe/London
    attempt_deadline: 320s
    app_engine_http_target:
      http_method: POST
      app_engine_routing:
        service: web
        version: prod
        instance: my-instance-001
      relative_uri: "/ping"
    project: test_project
    auth_kind: serviceaccount
    service_account_file: "/tmp/auth.pem"
    state: present

Inputs

    
name:
    description:
    - The name of the job.
    required: true
    type: str

state:
    choices:
    - present
    - absent
    default: present
    description:
    - Whether the given object should exist in GCP
    type: str

region:
    description:
    - Region where the scheduler job resides .
    required: true
    type: str

scopes:
    description:
    - Array of scopes to be used
    elements: str
    type: list

project:
    description:
    - The Google Cloud Platform project to use.
    type: str

env_type:
    description:
    - Specifies which Ansible environment you're running this module within.
    - This should not be set unless you know what you're doing.
    - This only alters the User Agent string for any API requests.
    type: str

schedule:
    description:
    - Describes the schedule on which the job will be executed.
    required: false
    type: str

auth_kind:
    choices:
    - application
    - machineaccount
    - serviceaccount
    description:
    - The type of credential used.
    required: true
    type: str

time_zone:
    default: Etc/UTC
    description:
    - Specifies the time zone to be used in interpreting schedule.
    - The value of this field must be a time zone name from the tz database.
    required: false
    type: str

description:
    description:
    - A human-readable description for the job. This string must not contain more than
      500 characters.
    required: false
    type: str

http_target:
    description:
    - HTTP target.
    - If the job providers a http_target the cron will send a request to the targeted
      url .
    required: false
    suboptions:
      body:
        description:
        - HTTP request body. A request body is allowed only if the HTTP method is POST,
          PUT, or PATCH. It is an error to set body on a job with an incompatible HttpMethod.
        - A base64-encoded string.
        required: false
        type: str
      headers:
        description:
        - This map contains the header field names and values. Repeated headers are not
          supported, but a header value can contain commas.
        required: false
        type: dict
      http_method:
        description:
        - Which HTTP method to use for the request.
        required: false
        type: str
      oauth_token:
        description:
        - Contains information needed for generating an OAuth token.
        - This type of authorization should be used when sending requests to a GCP endpoint.
        required: false
        suboptions:
          scope:
            description:
            - OAuth scope to be used for generating OAuth access token. If not specified,
              "U(https://www.googleapis.com/auth/cloud-platform") will be used.
            required: false
            type: str
          service_account_email:
            description:
            - Service account email to be used for generating OAuth token.
            - The service account must be within the same project as the job.
            required: true
            type: str
        type: dict
      oidc_token:
        description:
        - Contains information needed for generating an OpenID Connect token.
        - This type of authorization should be used when sending requests to third party
          endpoints or Cloud Run.
        required: false
        suboptions:
          audience:
            description:
            - Audience to be used when generating OIDC token. If not specified, the URI
              specified in target will be used.
            required: false
            type: str
          service_account_email:
            description:
            - Service account email to be used for generating OAuth token.
            - The service account must be within the same project as the job.
            required: true
            type: str
        type: dict
      uri:
        description:
        - The full URI path that the request will be sent to.
        required: true
        type: str
    type: dict

retry_config:
    description:
    - By default, if a job does not complete successfully, meaning that an acknowledgement
      is not received from the handler, then it will be retried with exponential backoff
      according to the settings .
    required: false
    suboptions:
      max_backoff_duration:
        description:
        - The maximum amount of time to wait before retrying a job after it fails.
        - A duration in seconds with up to nine fractional digits, terminated by 's'.
        required: false
        type: str
      max_doublings:
        description:
        - The time between retries will double maxDoublings times.
        - A job's retry interval starts at minBackoffDuration, then doubles maxDoublings
          times, then increases linearly, and finally retries retries at intervals of
          maxBackoffDuration up to retryCount times.
        required: false
        type: int
      max_retry_duration:
        description:
        - The time limit for retrying a failed job, measured from time when an execution
          was first attempted. If specified with retryCount, the job will be retried until
          both limits are reached.
        - A duration in seconds with up to nine fractional digits, terminated by 's'.
        required: false
        type: str
      min_backoff_duration:
        description:
        - The minimum amount of time to wait before retrying a job after it fails.
        - A duration in seconds with up to nine fractional digits, terminated by 's'.
        required: false
        type: str
      retry_count:
        description:
        - The number of attempts that the system will make to run a job using the exponential
          backoff procedure described by maxDoublings.
        - Values greater than 5 and negative values are not allowed.
        required: false
        type: int
    type: dict

pubsub_target:
    description:
    - Pub/Sub target If the job providers a Pub/Sub target the cron will publish a message
      to the provided topic .
    required: false
    suboptions:
      attributes:
        description:
        - Attributes for PubsubMessage.
        - Pubsub message must contain either non-empty data, or at least one attribute.
        required: false
        type: dict
      data:
        description:
        - The message payload for PubsubMessage.
        - Pubsub message must contain either non-empty data, or at least one attribute.
        - A base64-encoded string.
        required: false
        type: str
      topic_name:
        description:
        - The full resource name for the Cloud Pub/Sub topic to which messages will be
          published when a job is delivered. ~>**NOTE:** The topic name must be in the
          same format as required by PubSub's PublishRequest.name, e.g. `projects/my-project/topics/my-topic`.
        required: true
        type: str
    type: dict

attempt_deadline:
    default: 180s
    description:
    - The deadline for job attempts. If the request handler does not respond by this deadline
      then the request is cancelled and the attempt is marked as a DEADLINE_EXCEEDED failure.
      The failed attempt can be viewed in execution logs. Cloud Scheduler will retry the
      job according to the RetryConfig.
    - 'The allowed duration for this deadline is: * For HTTP targets, between 15 seconds
      and 30 minutes.'
    - '* For App Engine HTTP targets, between 15 seconds and 24 hours.'
    - '* **Note**: For PubSub targets, this field is ignored - setting it will introduce
      an unresolvable diff.'
    - 'A duration in seconds with up to nine fractional digits, terminated by ''s''. Example:
      "3.5s" .'
    required: false
    type: str

service_account_file:
    description:
    - The path of a Service Account JSON file if serviceaccount is selected as type.
    type: path

service_account_email:
    description:
    - An optional service account email address if machineaccount is selected and the
      user does not wish to use the default email.
    type: str

app_engine_http_target:
    description:
    - App Engine HTTP target.
    - If the job providers a App Engine HTTP target the cron will send a request to the
      service instance .
    required: false
    suboptions:
      app_engine_routing:
        description:
        - App Engine Routing setting for the job.
        required: false
        suboptions:
          instance:
            description:
            - App instance.
            - By default, the job is sent to an instance which is available when the job
              is attempted.
            required: false
            type: str
          service:
            description:
            - App service.
            - By default, the job is sent to the service which is the default service
              when the job is attempted.
            required: false
            type: str
          version:
            description:
            - App version.
            - By default, the job is sent to the version which is the default version
              when the job is attempted.
            required: false
            type: str
        type: dict
      body:
        description:
        - HTTP request body. A request body is allowed only if the HTTP method is POST
          or PUT. It will result in invalid argument error to set a body on a job with
          an incompatible HttpMethod.
        - A base64-encoded string.
        required: false
        type: str
      headers:
        description:
        - HTTP request headers.
        - This map contains the header field names and values. Headers can be set when
          the job is created.
        required: false
        type: dict
      http_method:
        description:
        - Which HTTP method to use for the request.
        required: false
        type: str
      relative_uri:
        description:
        - The relative URI.
        required: true
        type: str
    type: dict

service_account_contents:
    description:
    - The contents of a Service Account JSON file, either in a dictionary or as a JSON
      string that represents it.
    type: jsonarg

Outputs

appEngineHttpTarget:
  contains:
    appEngineRouting:
      contains:
        instance:
          description:
          - App instance.
          - By default, the job is sent to an instance which is available when the
            job is attempted.
          returned: success
          type: str
        service:
          description:
          - App service.
          - By default, the job is sent to the service which is the default service
            when the job is attempted.
          returned: success
          type: str
        version:
          description:
          - App version.
          - By default, the job is sent to the version which is the default version
            when the job is attempted.
          returned: success
          type: str
      description:
      - App Engine Routing setting for the job.
      returned: success
      type: complex
    body:
      description:
      - HTTP request body. A request body is allowed only if the HTTP method is POST
        or PUT. It will result in invalid argument error to set a body on a job with
        an incompatible HttpMethod.
      - A base64-encoded string.
      returned: success
      type: str
    headers:
      description:
      - HTTP request headers.
      - This map contains the header field names and values. Headers can be set when
        the job is created.
      returned: success
      type: dict
    httpMethod:
      description:
      - Which HTTP method to use for the request.
      returned: success
      type: str
    relativeUri:
      description:
      - The relative URI.
      returned: success
      type: str
  description:
  - App Engine HTTP target.
  - If the job providers a App Engine HTTP target the cron will send a request to
    the service instance .
  returned: success
  type: complex
attemptDeadline:
  description:
  - The deadline for job attempts. If the request handler does not respond by this
    deadline then the request is cancelled and the attempt is marked as a DEADLINE_EXCEEDED
    failure. The failed attempt can be viewed in execution logs. Cloud Scheduler will
    retry the job according to the RetryConfig.
  - 'The allowed duration for this deadline is: * For HTTP targets, between 15 seconds
    and 30 minutes.'
  - '* For App Engine HTTP targets, between 15 seconds and 24 hours.'
  - '* **Note**: For PubSub targets, this field is ignored - setting it will introduce
    an unresolvable diff.'
  - 'A duration in seconds with up to nine fractional digits, terminated by ''s''.
    Example: "3.5s" .'
  returned: success
  type: str
description:
  description:
  - A human-readable description for the job. This string must not contain more than
    500 characters.
  returned: success
  type: str
httpTarget:
  contains:
    body:
      description:
      - HTTP request body. A request body is allowed only if the HTTP method is POST,
        PUT, or PATCH. It is an error to set body on a job with an incompatible HttpMethod.
      - A base64-encoded string.
      returned: success
      type: str
    headers:
      description:
      - This map contains the header field names and values. Repeated headers are
        not supported, but a header value can contain commas.
      returned: success
      type: dict
    httpMethod:
      description:
      - Which HTTP method to use for the request.
      returned: success
      type: str
    oauthToken:
      contains:
        scope:
          description:
          - OAuth scope to be used for generating OAuth access token. If not specified,
            "U(https://www.googleapis.com/auth/cloud-platform") will be used.
          returned: success
          type: str
        serviceAccountEmail:
          description:
          - Service account email to be used for generating OAuth token.
          - The service account must be within the same project as the job.
          returned: success
          type: str
      description:
      - Contains information needed for generating an OAuth token.
      - This type of authorization should be used when sending requests to a GCP endpoint.
      returned: success
      type: complex
    oidcToken:
      contains:
        audience:
          description:
          - Audience to be used when generating OIDC token. If not specified, the
            URI specified in target will be used.
          returned: success
          type: str
        serviceAccountEmail:
          description:
          - Service account email to be used for generating OAuth token.
          - The service account must be within the same project as the job.
          returned: success
          type: str
      description:
      - Contains information needed for generating an OpenID Connect token.
      - This type of authorization should be used when sending requests to third party
        endpoints or Cloud Run.
      returned: success
      type: complex
    uri:
      description:
      - The full URI path that the request will be sent to.
      returned: success
      type: str
  description:
  - HTTP target.
  - If the job providers a http_target the cron will send a request to the targeted
    url .
  returned: success
  type: complex
name:
  description:
  - The name of the job.
  returned: success
  type: str
pubsubTarget:
  contains:
    attributes:
      description:
      - Attributes for PubsubMessage.
      - Pubsub message must contain either non-empty data, or at least one attribute.
      returned: success
      type: dict
    data:
      description:
      - The message payload for PubsubMessage.
      - Pubsub message must contain either non-empty data, or at least one attribute.
      - A base64-encoded string.
      returned: success
      type: str
    topicName:
      description:
      - The full resource name for the Cloud Pub/Sub topic to which messages will
        be published when a job is delivered. ~>**NOTE:** The topic name must be in
        the same format as required by PubSub's PublishRequest.name, e.g. `projects/my-project/topics/my-topic`.
      returned: success
      type: str
  description:
  - Pub/Sub target If the job providers a Pub/Sub target the cron will publish a message
    to the provided topic .
  returned: success
  type: complex
region:
  description:
  - Region where the scheduler job resides .
  returned: success
  type: str
retryConfig:
  contains:
    maxBackoffDuration:
      description:
      - The maximum amount of time to wait before retrying a job after it fails.
      - A duration in seconds with up to nine fractional digits, terminated by 's'.
      returned: success
      type: str
    maxDoublings:
      description:
      - The time between retries will double maxDoublings times.
      - A job's retry interval starts at minBackoffDuration, then doubles maxDoublings
        times, then increases linearly, and finally retries retries at intervals of
        maxBackoffDuration up to retryCount times.
      returned: success
      type: int
    maxRetryDuration:
      description:
      - The time limit for retrying a failed job, measured from time when an execution
        was first attempted. If specified with retryCount, the job will be retried
        until both limits are reached.
      - A duration in seconds with up to nine fractional digits, terminated by 's'.
      returned: success
      type: str
    minBackoffDuration:
      description:
      - The minimum amount of time to wait before retrying a job after it fails.
      - A duration in seconds with up to nine fractional digits, terminated by 's'.
      returned: success
      type: str
    retryCount:
      description:
      - The number of attempts that the system will make to run a job using the exponential
        backoff procedure described by maxDoublings.
      - Values greater than 5 and negative values are not allowed.
      returned: success
      type: int
  description:
  - By default, if a job does not complete successfully, meaning that an acknowledgement
    is not received from the handler, then it will be retried with exponential backoff
    according to the settings .
  returned: success
  type: complex
schedule:
  description:
  - Describes the schedule on which the job will be executed.
  returned: success
  type: str
timeZone:
  description:
  - Specifies the time zone to be used in interpreting schedule.
  - The value of this field must be a time zone name from the tz database.
  returned: success
  type: str