Source code for airflow.providers.mongo.sensors.mongo
## 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.from__future__importannotationsfromcollections.abcimportSequencefromtypingimportTYPE_CHECKINGfromairflow.providers.mongo.hooks.mongoimportMongoHookfromairflow.sensors.baseimportBaseSensorOperatorifTYPE_CHECKING:try:fromairflow.sdk.definitions.contextimportContextexceptImportError:# TODO: Remove once provider drops support for Airflow 2fromairflow.utils.contextimportContext
[docs]classMongoSensor(BaseSensorOperator):""" Checks for the existence of a document which matches the given query in MongoDB. .. code-block:: python mongo_sensor = MongoSensor( collection="coll", query={"key": "value"}, mongo_conn_id="mongo_default", mongo_db="admin", task_id="mongo_sensor", ) :param collection: Target MongoDB collection. :param query: The query to find the target document. :param mongo_conn_id: The :ref:`Mongo connection id <howto/connection:mongo>` to use when connecting to MongoDB. :param mongo_db: Target MongoDB name. """
[docs]defpoke(self,context:Context)->bool:self.log.info("Sensor check existence of the document that matches the following query: %s",self.query)hook=MongoHook(mongo_conn_id=self.mongo_conn_id)returnhook.find(self.collection,self.query,mongo_db=self.mongo_db,find_one=True)isnotNone