1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
|
# ============LICENSE_START===================================================
# Copyright (C) 2019-2021 Nordix Foundation.
# ============================================================================
# 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.
#
# SPDX-License-Identifier: Apache-2.0
# ============LICENSE_END=====================================================
from http import HTTPStatus
from mod import logger
from mod.api.services import subscription_service
from connexion import NoContent
from mod.api.custom_exception import InvalidDataException, DuplicateDataException
def status():
"""
Returns the health of the PMSH service
Args:
NA
Returns:
Dictionary detailing 'status' of either 'healthy' or 'unhealthy'.
Raises:
NA
"""
return {'status': 'healthy'}
def post_subscription(body):
"""
Creates a subscription
Args:
body (dict): subscription request body to save.
Returns:
Success : NoContent, 201
Invalid Data : Invalid message, 400
Duplicate Data : Duplicate field detail, 409
Raises:
Error: If anything fails in the server.
"""
response = NoContent, HTTPStatus.CREATED.value
try:
subscription_service.create_subscription(body['subscription'])
except DuplicateDataException as e:
logger.error(f'Failed to create subscription for '
f'{body["subscription"]["subscriptionName"]} due to duplicate data: {e}',
exc_info=True)
response = e.duplicate_field_info, HTTPStatus.CONFLICT.value
except InvalidDataException as e:
logger.error(f'Failed to create subscription for '
f'{body["subscription"]["subscriptionName"]} due to invalid data: {e}',
exc_info=True)
response = e.invalid_message, HTTPStatus.BAD_REQUEST.value
return response
def get_subscription_by_name(subscription_name):
"""
Retrieves subscription based on the name
Args:
subscription_name (String): Name of the subscription.
Returns:
success: dict of single Subscription, 200
None: subscription not defined, 404
Exception: Details about exception, 500
"""
logger.info('API call received to fetch subscription by name')
try:
subscription = subscription_service.get_subscription_by_name(subscription_name)
if subscription is not None:
logger.info(f'subscription object with the name "{subscription_name}" '
'was fetched successfully from database')
return subscription.serialize(), HTTPStatus.OK
else:
logger.error(f'subscription object with the name "{subscription_name}" '
'was un successful to fetch from database')
return {'error': 'Subscription was not defined with the name : '
f'{subscription_name}'}, HTTPStatus.NOT_FOUND
except Exception as exception:
logger.error(f'The following exception occurred "{exception}" while fetching subscription '
f'with the name "{subscription_name}"')
return {'error': 'Request was not processed due to Exception : '
f'{exception}'}, HTTPStatus.INTERNAL_SERVER_ERROR
|