Source code for airflow.providers.google.cloud.triggers.dataproc
## Licensed to the Apache Software Foundation (ASF) under one# or more contributor license agreements. See the NOTICE file# distributed with this work for additional information# regarding copyright ownership. The ASF licenses this file# to you 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."""This module contains Google Dataproc triggers."""from__future__importannotationsimportasynciofromtypingimportSequencefromgoogle.cloud.dataproc_v1importJobStatusfromairflowimportAirflowExceptionfromairflow.providers.google.cloud.hooks.dataprocimportDataprocAsyncHookfromairflow.triggers.baseimportBaseTrigger,TriggerEvent
[docs]classDataprocBaseTrigger(BaseTrigger):""" Trigger that periodically polls information from Dataproc API to verify job status. Implementation leverages asynchronous transport. """def__init__(self,job_id:str,region:str,project_id:str|None=None,gcp_conn_id:str="google_cloud_default",impersonation_chain:str|Sequence[str]|None=None,delegate_to:str|None=None,polling_interval_seconds:int=30,):super().__init__()self.gcp_conn_id=gcp_conn_idself.impersonation_chain=impersonation_chainself.job_id=job_idself.project_id=project_idself.region=regionself.polling_interval_seconds=polling_interval_secondsself.delegate_to=delegate_toself.hook=DataprocAsyncHook(delegate_to=self.delegate_to,gcp_conn_id=self.gcp_conn_id,impersonation_chain=self.impersonation_chain,)