diff options
Diffstat (limited to 'components/pm-subscription-handler/pmsh_service/mod')
-rwxr-xr-x | components/pm-subscription-handler/pmsh_service/mod/exit_handler.py | 2 | ||||
-rwxr-xr-x | components/pm-subscription-handler/pmsh_service/mod/subscription.py | 26 |
2 files changed, 26 insertions, 2 deletions
diff --git a/components/pm-subscription-handler/pmsh_service/mod/exit_handler.py b/components/pm-subscription-handler/pmsh_service/mod/exit_handler.py index adc4941c..3cb05daa 100755 --- a/components/pm-subscription-handler/pmsh_service/mod/exit_handler.py +++ b/components/pm-subscription-handler/pmsh_service/mod/exit_handler.py @@ -42,7 +42,7 @@ class ExitHandler: logger.debug(f'Cancelling periodic task with thread name: {thread.name}.') thread.cancel() current_sub.administrativeState = AdministrativeState.LOCKED.value - current_sub.process_subscription(self.subscription_handler.current_nfs, + current_sub.process_subscription(current_sub.get_network_functions(), self.subscription_handler.mr_pub, self.subscription_handler.app_conf) ExitHandler.shutdown_signal_received = True diff --git a/components/pm-subscription-handler/pmsh_service/mod/subscription.py b/components/pm-subscription-handler/pmsh_service/mod/subscription.py index 99a787da..3add7200 100755 --- a/components/pm-subscription-handler/pmsh_service/mod/subscription.py +++ b/components/pm-subscription-handler/pmsh_service/mod/subscription.py @@ -22,7 +22,8 @@ from tenacity import retry, retry_if_exception_type, wait_exponential, stop_afte import mod.pmsh_logging as logger from mod import db -from mod.db_models import SubscriptionModel, NfSubRelationalModel +from mod.db_models import SubscriptionModel, NfSubRelationalModel, NetworkFunctionModel +from mod.network_function import NetworkFunction class SubNfState(Enum): @@ -218,3 +219,26 @@ class Subscription: update({NfSubRelationalModel.nf_sub_status: status}, synchronize_session='evaluate') db.session.commit() + + def _get_nf_models(self): + nf_sub_relationships = NfSubRelationalModel.query.filter( + NfSubRelationalModel.subscription_name == self.subscriptionName) + nf_models = [] + for nf_sub_entry in nf_sub_relationships: + nf_model_object = NetworkFunctionModel.query.filter( + NetworkFunctionModel.nf_name == nf_sub_entry.nf_name).one_or_none() + nf_models.append(nf_model_object) + + return nf_models + + def get_network_functions(self): + nfs = [] + nf_models = self._get_nf_models() + for nf_model in nf_models: + nf = NetworkFunction( + nf_name=nf_model.nf_name, + orchestration_status=nf_model.orchestration_status + ) + nfs.append(nf) + + return nfs |