blob: 0dd01dcb78b465bdafe5cc3898995cd59302287f [file] [log] [blame]
Gary Wu9abb61c2018-09-27 10:38:50 -07001import json
2
3import docker
pkarasc7abba82018-10-22 12:22:35 +02004import time
Gary Wu9abb61c2018-09-27 10:38:50 -07005
6
7class PrhLibrary(object):
8
9 def __init__(self):
10 pass
11
12 @staticmethod
13 def check_for_log(search_for):
14 client = docker.from_env()
15 container = client.containers.get('prh')
Joanna Jeremicz0a391482019-03-14 10:58:32 +010016 print ("Check for log searches for pattern: ", search_for )
Gary Wu9abb61c2018-09-27 10:38:50 -070017 for line in container.logs(stream=True):
Joanna Jeremicz0a391482019-03-14 10:58:32 +010018 print ("Check for log analysis line: ", line )
Gary Wu9abb61c2018-09-27 10:38:50 -070019 if search_for in line.strip():
20 return True
21 else:
22 return False
23
24 @staticmethod
Joanna Jeremicz0a391482019-03-14 10:58:32 +010025 def create_invalid_notification(json_file):
Gary Wu9abb61c2018-09-27 10:38:50 -070026 json_to_python = json.loads(json_file)
Joanna Jeremicz0a391482019-03-14 10:58:32 +010027 correlation_id = PrhLibrary.extract_correlation_id_value(json_to_python, "correlationId")
28 ipv4 = PrhLibrary.extract_value_from_pnfRegistrationFields(json_to_python, "oamV4IpAddress", "oamV4IpAddress")
29 ipv6 = PrhLibrary.extract_value_from_pnfRegistrationFields(json_to_python, "oamV6IpAddress", "oamV6IpAddress")
30 serial_number = PrhLibrary.extract_value_from_pnfRegistrationFields(json_to_python, "serialNumber", "serialNumber")
31 vendor_name = PrhLibrary.extract_value_from_pnfRegistrationFields(json_to_python, "vendorName", "vendorName")
32 model_number = PrhLibrary.extract_value_from_pnfRegistrationFields(json_to_python, "modelNumber", "modelNumber")
33 unit_type = PrhLibrary.extract_value_from_pnfRegistrationFields(json_to_python, "unitType", "unitType")
Joanna Jeremicz469a3ef2019-03-19 09:37:59 +010034
35 additional_fields = PrhLibrary.extract_additional_fields(json_to_python)
Marcin Migdal183c8962019-02-13 15:43:12 +010036
Joanna Jeremicz0a391482019-03-14 10:58:32 +010037 str_json = '{' + correlation_id + ipv4 + ipv6 + serial_number + vendor_name + model_number + unit_type + '"nfNamingCode":""' + "," + '"softwareVersion":"",' + additional_fields
38 return json.dumps(str_json).replace("\\", "")[1:-1].replace("\":", "\": ").rstrip(',') + '\\n}'
Gary Wu9abb61c2018-09-27 10:38:50 -070039
40 @staticmethod
Marcin Migdal183c8962019-02-13 15:43:12 +010041 def create_pnf_ready_notification_as_pnf_ready(json_file):
42 json_to_python = json.loads(json_file)
Joanna Jeremicz0a391482019-03-14 10:58:32 +010043 correlation_id = PrhLibrary.extract_correlation_id_value(json_to_python, "correlationId")
44 serial_number = PrhLibrary.extract_value_from_pnfRegistrationFields(json_to_python, "serial-number", "serialNumber")
45 vendor_name = PrhLibrary.extract_value_from_pnfRegistrationFields(json_to_python, "equip-vendor", "vendorName")
46 model_number = PrhLibrary.extract_value_from_pnfRegistrationFields(json_to_python, "equip-model", "modelNumber")
47 unit_type = PrhLibrary.extract_value_from_pnfRegistrationFields(json_to_python, "equip-type", "unitType")
Joanna Jeremicz469a3ef2019-03-19 09:37:59 +010048
49 additional_fields = PrhLibrary.extract_additional_fields_value(json_to_python)
Marcin Migdal183c8962019-02-13 15:43:12 +010050
51 nf_role = json_to_python.get("event").get("commonEventHeader").get("nfNamingCode") if "nfNamingCode" in json_to_python["event"]["commonEventHeader"] else ""
52
Joanna Jeremicz0a391482019-03-14 10:58:32 +010053 str_json = '{' + correlation_id + serial_number + vendor_name + model_number + unit_type + '"nf-role":"' + nf_role + '","sw-version":"",' + additional_fields
54
55 return json.dumps(str_json.rstrip(',') + '}').replace("\\", "")[1:-1]
Marcin Migdal183c8962019-02-13 15:43:12 +010056
57 @staticmethod
Joanna Jeremicz469a3ef2019-03-19 09:37:59 +010058 def extract_additional_fields_value(content):
59 fields = PrhLibrary.get_additional_fields_as_key_value_pairs(content)
60 if len(fields) == 0:
61 return ""
62 return PrhLibrary.build_additional_fields_json(fields)
Marcin Migdal183c8962019-02-13 15:43:12 +010063
64 @staticmethod
Joanna Jeremicz469a3ef2019-03-19 09:37:59 +010065 def extract_additional_fields(content):
66 fields = PrhLibrary.get_additional_fields_as_key_value_pairs(content)
67 if fields == []:
68 return '"additionalFields":null'
69 return PrhLibrary.build_additional_fields_json(fields)
70
71 @staticmethod
72 def get_additional_fields_as_key_value_pairs(content):
73 return content.get("event").get("pnfRegistrationFields").get(
74 "additionalFields") if "additionalFields" in content["event"]["pnfRegistrationFields"] else []
75
76 @staticmethod
77 def build_additional_fields_json(fields):
78 res = '"additionalFields":{'
Joanna Jeremicz0a391482019-03-14 10:58:32 +010079 for f in fields:
Joanna Jeremicz469a3ef2019-03-19 09:37:59 +010080 res += '"' + f + '":"' + fields.get(f) + '",'
Joanna Jeremicz0a391482019-03-14 10:58:32 +010081 return res.rstrip(',') + '},'
Marcin Migdal183c8962019-02-13 15:43:12 +010082
83 @staticmethod
Joanna Jeremicz0a391482019-03-14 10:58:32 +010084 def extract_value_from_pnfRegistrationFields(content, name, key):
85 return '"' + name + '":"' + (content.get("event").get("pnfRegistrationFields").get(key) + '",' if key in content["event"]["pnfRegistrationFields"] else '",')
Marcin Migdal183c8962019-02-13 15:43:12 +010086
87 @staticmethod
Joanna Jeremicz0a391482019-03-14 10:58:32 +010088 def extract_correlation_id_value(content, name):
89 return '"' + name + '":"' + (content.get("event").get("commonEventHeader").get("sourceName") + '",' if "sourceName" in content["event"]["commonEventHeader"] else '",')
Marcin Migdal183c8962019-02-13 15:43:12 +010090
91 @staticmethod
Gary Wu9abb61c2018-09-27 10:38:50 -070092 def create_pnf_name(json_file):
93 json_to_python = json.loads(json_file)
Marcin Migdalb3c48562019-04-05 14:37:51 +020094 correlation_id = json_to_python.get("event").get("commonEventHeader").get("sourceName") + '",' if "sourceName" in json_to_python["event"]["commonEventHeader"] else '",'
Mariusz Wagner1fd732a2018-09-28 09:03:08 +020095 return correlation_id
Gary Wu9abb61c2018-09-27 10:38:50 -070096
97 @staticmethod
pkarasc7abba82018-10-22 12:22:35 +020098 def ensure_container_is_running(name):
Gary Wu9abb61c2018-09-27 10:38:50 -070099 client = docker.from_env()
pkarasc7abba82018-10-22 12:22:35 +0200100
101 if not PrhLibrary.is_in_status(client, name, "running"):
102 print ("starting container", name)
103 container = client.containers.get(name)
104 container.start()
105 PrhLibrary.wait_for_status(client, name, "running")
106
107 PrhLibrary.print_status(client)
108
109 @staticmethod
110 def ensure_container_is_exited(name):
111 client = docker.from_env()
112
113 if not PrhLibrary.is_in_status(client, name, "exited"):
114 print ("stopping container", name)
115 container = client.containers.get(name)
116 container.stop()
117 PrhLibrary.wait_for_status(client, name, "exited")
118
119 PrhLibrary.print_status(client)
120
121 @staticmethod
122 def print_status(client):
123 print("containers status")
124 for c in client.containers.list(all=True):
125 print(c.name, " ", c.status)
126
127 @staticmethod
128 def wait_for_status(client, name, status):
129 while not PrhLibrary.is_in_status(client, name, status):
130 print ("waiting for container: ", name, "to be in status: ", status)
131 time.sleep(3)
132
133 @staticmethod
134 def is_in_status(client, name, status):
135 return len(client.containers.list(all=True, filters={"name": "^/"+name+"$", "status": status})) == 1