Compare commits
3 Commits
add_cloud_
...
analytics-
Author | SHA1 | Date | |
---|---|---|---|
4fa8cf1a69 | |||
0f4da3d79b | |||
ed2a5f575e |
@ -14,7 +14,8 @@
|
||||
from pathlib import Path
|
||||
import json
|
||||
|
||||
analytics_path = Path("otc_metadata/analytics/public")
|
||||
BASE_DIR = Path(__file__).resolve().parent
|
||||
analytics_path = BASE_DIR / "public"
|
||||
|
||||
cloud_environments = [
|
||||
'eu_de',
|
||||
@ -24,8 +25,8 @@ analytics_data = {k: [] for k in cloud_environments}
|
||||
|
||||
# Open and read the json data files
|
||||
for env in cloud_environments:
|
||||
file_path = analytics_path.joinpath(f"{env}.json")
|
||||
with open(file_path, 'r') as file:
|
||||
file_path = analytics_path / f"{env}.json"
|
||||
with file_path.open(encoding="utf-8") as file:
|
||||
analytics_data[env] = json.load(file)
|
||||
|
||||
|
||||
|
@ -8,5 +8,5 @@
|
||||
"sfs",
|
||||
"iam",
|
||||
"elb",
|
||||
"apig"
|
||||
"vpn"
|
||||
]
|
@ -7,6 +7,6 @@
|
||||
"rds",
|
||||
"iam",
|
||||
"elb",
|
||||
"cbr",
|
||||
"vpc"
|
||||
"vpn",
|
||||
"cbr"
|
||||
]
|
@ -475,3 +475,33 @@ class Services(object):
|
||||
res.sort(key=lambda x: x.get("service_title", "").lower())
|
||||
|
||||
return res
|
||||
|
||||
def all_services_by_cloud_environment_as_dict(self, cloud_environment, environments):
|
||||
"""Retrieve all services filtered by cloud_environment
|
||||
Returns a dict keyed by service_type.
|
||||
"""
|
||||
|
||||
res = {}
|
||||
|
||||
if not (environments and cloud_environment):
|
||||
raise Exception(
|
||||
"No cloud_environment or environments specified in function all_services_by_cloud_environment."
|
||||
)
|
||||
|
||||
for srv in self.all_services:
|
||||
for srv_cloud_environment in srv.get("cloud_environments", []):
|
||||
if srv_cloud_environment.get("name") == cloud_environment:
|
||||
for environment in environments:
|
||||
if srv_cloud_environment.get("visibility") == environment:
|
||||
service_type = srv.get("service_type")
|
||||
if service_type:
|
||||
res[service_type] = srv
|
||||
break
|
||||
res = dict(
|
||||
sorted(
|
||||
res.items(),
|
||||
key=lambda item: item[1].get("service_type", "").lower()
|
||||
)
|
||||
)
|
||||
|
||||
return res
|
||||
|
Reference in New Issue
Block a user