blob: 838ccc7b6c19dec2066d4296b9c6419046a96b2f [file] [log] [blame]
"""policy-engine-client communicates with policy-engine thru PolicyEngine client object"""
# org.onap.dcae
# ================================================================================
# Copyright (c) 2017 AT&T Intellectual Property. All rights reserved.
# ================================================================================
# Licensed 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.
# ============LICENSE_END=========================================================
#
# ECOMP is a trademark and service mark of AT&T Intellectual Property.
import logging
import re
from .config import Config, PolicyEngineConfig
from .onap.audit import Audit
from .PolicyEngine import PolicyEngine, NotificationHandler, NotificationScheme
from .policy_updater import PolicyUpdater
class PolicyNotificationHandler(NotificationHandler):
"""handler of the policy-engine push notifications"""
_logger = logging.getLogger("policy_handler.policy_notification")
def __init__(self, policy_updater):
scope_prefixes = [scope_prefix.replace(".", "[.]") \
for scope_prefix in Config.config["scope_prefixes"]]
self._policy_scopes = re.compile("(" + "|".join(scope_prefixes) + ")")
PolicyNotificationHandler._logger.info("_policy_scopes %s", self._policy_scopes.pattern)
self._policy_updater = policy_updater
self._policy_updater.start()
def notificationReceived(self, notification):
if not notification or not notification._loadedPolicies:
return
policy_names = [loaded._policyName \
for loaded in notification._loadedPolicies \
if self._policy_scopes.match(loaded._policyName)]
if not policy_names:
PolicyNotificationHandler._logger.info("no policy updated for scopes %s", \
self._policy_scopes.pattern)
return
audit = Audit(req_message="notificationReceived from PDP")
audit.retry_get_config = True
self._policy_updater.enqueue(audit, policy_names)
class PolicyEngineClient(object):
""" policy-engine client"""
_logger = logging.getLogger("policy_handler.policy_engine")
_policy_updater = None
_pdp_notification_handler = None
_policy_engine = None
@staticmethod
def shutdown(audit):
"""Shutdown the notification-handler"""
PolicyEngineClient._policy_updater.shutdown(audit)
@staticmethod
def catch_up(audit):
"""bring the latest policies from policy-engine"""
PolicyEngineClient._policy_updater.catch_up(audit)
@staticmethod
def create_policy_engine_properties():
"""create the policy_engine.properties file from config.json"""
pass
@staticmethod
def run():
"""Using policy-engine client to talk to policy engine"""
audit = Audit(req_message="start PDP client")
PolicyEngineClient._policy_updater = PolicyUpdater()
PolicyEngineClient._pdp_notification_handler = PolicyNotificationHandler(
PolicyEngineClient._policy_updater)
sub_aud = Audit(aud_parent=audit)
sub_aud.metrics_start("create client to PDP")
PolicyEngineConfig.save_to_file()
PolicyEngineClient._policy_engine = PolicyEngine(PolicyEngineConfig.PATH_TO_PROPERTIES, \
scheme=NotificationScheme.AUTO_ALL_NOTIFICATIONS.name,\
handler=PolicyEngineClient._pdp_notification_handler)
sub_aud.metrics("created client to PDP")
seed_scope = Config.config["scope_prefixes"][0] + ".*"
PolicyEngineClient._policy_engine.getConfig(policyName=seed_scope)
sub_aud.metrics("seeded client by PDP.getConfig for policyName={0}".format(seed_scope))
PolicyEngineClient.catch_up(audit)