3 Commits

Author SHA1 Message Date
4fa8cf1a69 chore: update analytics data [skip ci] 2025-08-18 03:00:21 +00:00
0f4da3d79b add dict function for services by cloud_env (#46)
All checks were successful
Create Weekly Analytics Stats / run-analytics (push) Successful in 9s
Reviewed-on: #46
Reviewed-by: Gode, Sebastian <sebastian.gode@t-systems.com>
Co-authored-by: tischrei <tino.schreiber@t-systems.com>
Co-committed-by: tischrei <tino.schreiber@t-systems.com>
2025-08-13 13:45:17 +00:00
ed2a5f575e fix file_path (#45)
Reviewed-on: #45
Reviewed-by: Gode, Sebastian <sebastian.gode@t-systems.com>
Co-authored-by: tischrei <tino.schreiber@t-systems.com>
Co-committed-by: tischrei <tino.schreiber@t-systems.com>
2025-08-13 13:15:37 +00:00
4 changed files with 37 additions and 6 deletions

View File

@ -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)

View File

@ -8,5 +8,5 @@
"sfs",
"iam",
"elb",
"apig"
"vpn"
]

View File

@ -7,6 +7,6 @@
"rds",
"iam",
"elb",
"cbr",
"vpc"
"vpn",
"cbr"
]

View File

@ -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