Source code for airflow.providers.redis.sensors.redis_pub_sub
## 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.abcimportSequencefromfunctoolsimportcached_propertyfromtypingimportTYPE_CHECKINGfromairflow.providers.redis.hooks.redisimportRedisHookfromairflow.sensors.baseimportBaseSensorOperatorifTYPE_CHECKING:fromairflow.utils.contextimportContext
[docs]classRedisPubSubSensor(BaseSensorOperator):""" Redis sensor for reading a message from pub sub channels. :param channels: The channels to be subscribed to (templated) :param redis_conn_id: the redis connection id """
[docs]defpoke(self,context:Context)->bool:""" Check for message on subscribed channels and write to xcom the message with key ``message``. An example of message ``{'type': 'message', 'pattern': None, 'channel': b'test', 'data': b'hello'}`` :param context: the context object :return: ``True`` if message (with type 'message') is available or ``False`` if not """self.log.info("RedisPubSubSensor checking for message on channels: %s",self.channels)message=self.pubsub.get_message()self.log.info("Message %s from channel %s",message,self.channels)# Process only message typesifmessageandmessage["type"]=="message":context["ti"].xcom_push(key="message",value=message)self.pubsub.unsubscribe(self.channels)returnTruereturnFalse