X-Git-Url: https://gerrit.o-ran-sc.org/r/gitweb?a=blobdiff_plain;f=o2app%2Fentrypoints%2Fredis_eventconsumer.py;h=56301747563ae87b21ffa9b65cd436df911f5d34;hb=209f349b35b0919ac133bc2264f25753a73e5b8f;hp=84729490f4569ac2ecf3f705133d834141d817ba;hpb=d14329a57d8d01d443e4158fa5030a5b5ada4060;p=pti%2Fo2.git diff --git a/o2app/entrypoints/redis_eventconsumer.py b/o2app/entrypoints/redis_eventconsumer.py index 8472949..5630174 100644 --- a/o2app/entrypoints/redis_eventconsumer.py +++ b/o2app/entrypoints/redis_eventconsumer.py @@ -13,26 +13,32 @@ # limitations under the License. # import json -from logging import log import redis import json from o2app import bootstrap from o2common.config import config # from o2common.domain import commands from o2dms.domain import commands -from o2dms.domain import events +from o2ims.domain import commands as imscmd from o2common.helper import o2logging +from o2ims.domain.subscription_obj import Message2SMO, NotificationEventEnum,\ + RegistrationMessage logger = o2logging.get_logger(__name__) r = redis.Redis(**config.get_redis_host_and_port()) +apibase = config.get_o2ims_api_base() + def main(): logger.info("Redis pubsub starting") bus = bootstrap.bootstrap() pubsub = r.pubsub(ignore_subscribe_messages=True) pubsub.subscribe("NfDeploymentStateChanged") + pubsub.subscribe('ResourceChanged') + pubsub.subscribe('ConfigurationChanged') + pubsub.subscribe('OcloudChanged') for m in pubsub.listen(): try: @@ -50,11 +56,35 @@ def handle_dms_changed(m, bus): data = json.loads(datastr) logger.info('HandleNfDeploymentStateChanged with cmd:{}'.format(data)) cmd = commands.HandleNfDeploymentStateChanged( - NfDeploymentId = data['NfDeploymentId'], - FromState = data['FromState'], - ToState = data['ToState'] + NfDeploymentId=data['NfDeploymentId'], + FromState=data['FromState'], + ToState=data['ToState'] ) bus.handle(cmd) + elif channel == 'ResourceChanged': + datastr = m['data'] + data = json.loads(datastr) + logger.info('ResourceChanged with cmd:{}'.format(data)) + ref = apibase + '/resourcePools/' + data['resourcePoolId'] +\ + '/resources/' + data['id'] + cmd = imscmd.PubMessage2SMO(data=Message2SMO( + id=data['id'], ref=ref, + eventtype=data['notificationEventType'], + updatetime=data['updatetime'])) + bus.handle(cmd) + elif channel == 'ConfigurationChanged': + datastr = m['data'] + data = json.loads(datastr) + logger.info('ConfigurationChanged with cmd:{}'.format(data)) + cmd = imscmd.Register2SMO(data=RegistrationMessage(id=data['id'])) + bus.handle(cmd) + elif channel == 'OcloudChanged': + datastr = m['data'] + data = json.loads(datastr) + logger.info('OcloudChanged with cmd:{}'.format(data)) + if data['notificationEventType'] == NotificationEventEnum.CREATE: + cmd = imscmd.Register2SMO(data=RegistrationMessage(is_all=True)) + bus.handle(cmd) else: logger.info("unhandled:{}".format(channel))