6 Commits

Author SHA1 Message Date
1bce8fbfce fix analytics
All checks were successful
Run Tox Check / tox-py312 (pull_request) Successful in 16s
Run Tox Check / tox-pep8 (pull_request) Successful in 15s
Updates Opensearch filters / update-opensearch-filters (pull_request) Has been skipped
2025-08-11 09:19:51 +00:00
7279e5e043 fix url
All checks were successful
Run Tox Check / tox-py312 (pull_request) Successful in 15s
Run Tox Check / tox-pep8 (pull_request) Successful in 15s
2025-08-11 09:09:13 +00:00
e1ca847868 tune workflow
All checks were successful
Run Tox Check / tox-py312 (pull_request) Successful in 15s
Run Tox Check / tox-pep8 (pull_request) Successful in 15s
2025-08-11 09:04:08 +00:00
f06e62aea3 resolve conflicts
All checks were successful
Run Tox Check / tox-py312 (pull_request) Successful in 15s
Run Tox Check / tox-pep8 (pull_request) Successful in 15s
2025-08-11 08:47:19 +00:00
03072ec4c0 add PR
All checks were successful
Run Tox Check / tox-py312 (pull_request) Successful in 16s
Run Tox Check / tox-pep8 (pull_request) Successful in 15s
2025-08-11 08:44:25 +00:00
f81ba23d8a change workflow
All checks were successful
Run Tox Check / tox-py312 (pull_request) Successful in 16s
Run Tox Check / tox-pep8 (pull_request) Successful in 16s
Updates Opensearch filters / update-opensearch-filters (pull_request) Successful in 10s
2025-08-11 08:30:46 +00:00
7 changed files with 8 additions and 86 deletions

View File

@ -49,14 +49,14 @@ jobs:
--limit "10" --limit "10"
- name: Commit and push results - name: Commit and push results
id: commit_step
run: | run: |
git config --global user.name "gitea-actions[bot]" git config --global user.name "gitea-actions[bot]"
git config --global user.email "actions@users.noreply.local" git config --global user.email "actions@users.noreply.local"
git checkout -B analytics-update git checkout -B analytics-update
git add otc_metadata/analytics/ git add analytics/
if git diff --cached --quiet; then if git diff --cached --quiet; then
echo "No changes to commit"
else else
git commit -m "chore: update analytics data [skip ci]" git commit -m "chore: update analytics data"
git push origin analytics-update --force git push origin analytics-update --force
fi fi

View File

@ -7,6 +7,6 @@
"rds", "rds",
"sfs", "sfs",
"iam", "iam",
"elb", "config",
"vpn" "elb"
] ]

View File

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

View File

@ -1,48 +0,0 @@
# 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.
from pathlib import Path
import json
BASE_DIR = Path(__file__).resolve().parent
analytics_path = BASE_DIR / "public"
cloud_environments = [
'eu_de',
'swiss'
]
analytics_data = {k: [] for k in cloud_environments}
# Open and read the json data files
for env in cloud_environments:
file_path = analytics_path / f"{env}.json"
with file_path.open(encoding="utf-8") as file:
analytics_data[env] = json.load(file)
class AnalyticsData(object):
"""Encapsulate OTC Analystics data"""
def __init__(self):
self._analytics_data = analytics_data
def all_analytics_data(self):
"""returns all analytics data"""
return self._analytics_data
def analytics_data_by_cloud_environment(self, cloud_environment):
"""returns all analytics data"""
if cloud_environment and cloud_environment in self._analytics_data:
return self._analytics_data[cloud_environment]
else:
raise ValueError(f"cloud_environment '{cloud_environment}' does not exist.")

View File

@ -475,33 +475,3 @@ class Services(object):
res.sort(key=lambda x: x.get("service_title", "").lower()) res.sort(key=lambda x: x.get("service_title", "").lower())
return res 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

View File

@ -150,7 +150,7 @@ def save_to_file(data, environment, cloud_environment):
""" """
Saves data in the folder ./analytics/<environment>/<cloud_environment>.json Saves data in the folder ./analytics/<environment>/<cloud_environment>.json
""" """
folder = os.path.join("otc_metadata", "analytics", environment) folder = os.path.join("analytics", environment)
os.makedirs(folder, exist_ok=True) os.makedirs(folder, exist_ok=True)
filename = os.path.join(folder, f"{cloud_environment}.json") filename = os.path.join(folder, f"{cloud_environment}.json")