Compare commits
	
		
			7 Commits
		
	
	
		
			ed-service
			...
			add_cloud_
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| e6e9a747ca | |||
| a957e7ff26 | |||
| 3e0dc71b90 | |||
| 2c4002cb84 | |||
| 5f367e0185 | |||
| 2bb9971769 | |||
| 04bf5aaa52 | 
| @ -14,8 +14,7 @@ | ||||
| from pathlib import Path | ||||
| import json | ||||
|  | ||||
| BASE_DIR = Path(__file__).resolve().parent | ||||
| analytics_path = BASE_DIR / "public" | ||||
| analytics_path = Path("otc_metadata/analytics/public") | ||||
|  | ||||
| cloud_environments = [ | ||||
|     'eu_de', | ||||
| @ -25,8 +24,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 / f"{env}.json" | ||||
|     with file_path.open(encoding="utf-8") as file: | ||||
|     file_path = analytics_path.joinpath(f"{env}.json") | ||||
|     with open(file_path, 'r') as file: | ||||
|         analytics_data[env] = json.load(file) | ||||
|  | ||||
|  | ||||
|  | ||||
| @ -8,5 +8,5 @@ | ||||
|   "sfs", | ||||
|   "iam", | ||||
|   "elb", | ||||
|   "cbr" | ||||
|   "apig" | ||||
| ] | ||||
							
								
								
									
										2
									
								
								otc_metadata/data/cloud_environments/eu_de.yaml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										2
									
								
								otc_metadata/data/cloud_environments/eu_de.yaml
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,2 @@ | ||||
| --- | ||||
| name: eu_de | ||||
							
								
								
									
										2
									
								
								otc_metadata/data/cloud_environments/swiss.yaml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										2
									
								
								otc_metadata/data/cloud_environments/swiss.yaml
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,2 @@ | ||||
| --- | ||||
| name: swiss | ||||
| @ -1,11 +0,0 @@ | ||||
| --- | ||||
| link: /enterprise-dashboard/alerting/ | ||||
| rst_location: doc/alerting/source | ||||
| service_type: ed | ||||
| title: Alerting | ||||
| type: alerting | ||||
| cloud_environments: | ||||
|   - name: eu_de | ||||
|     visibility: public | ||||
|     pdf_visibility: public | ||||
|     pdf_enabled: true | ||||
| @ -17,6 +17,7 @@ | ||||
| # documents/services/service_categories is being merged with | ||||
| # the content here. | ||||
| --- | ||||
| cloud_environments: [] | ||||
| documents: [] | ||||
| service_categories: [] | ||||
| services: [] | ||||
|  | ||||
| @ -10,4 +10,3 @@ cloud_environments: | ||||
| teams: | ||||
|   - name: docs-paas-rw | ||||
|     permission: write | ||||
| description: API Gateway (APIG) is a high-performance, high-availability, and high-security API hosting service that helps you build, manage, and deploy APIs at any scale. With just a few clicks, you can integrate internal systems, and selectively expose capabilities with minimal costs and risks. | ||||
|  | ||||
| @ -12,4 +12,3 @@ cloud_environments: | ||||
|     visibility: public | ||||
|   - name: swiss | ||||
|     visibility: public | ||||
| description: Cloud Backup and Recovery (CBR) allows you to back up cloud disks, elastic cloud servers, and bare metal servers, protecting the security and accuracy of your data to the greatest extent for service security. | ||||
|  | ||||
| @ -12,4 +12,3 @@ cloud_environments: | ||||
|   - name: swiss | ||||
|     visibility: public | ||||
| is_global: false | ||||
| description: CCE provides highly scalable, high-performance, enterprise-class Kubernetes clusters. It supports native Kubernetes applications, tools and easy setup of container runtime environment. | ||||
|  | ||||
| @ -12,4 +12,3 @@ cloud_environments: | ||||
|   - name: swiss | ||||
|     visibility: public | ||||
| is_global: false | ||||
| description: An ECS is a computing server consisting of CPUs, memory, images, and Elastic Volume Service (EVS) disks that allow on-demand allocation and elastic scaling. ECSs integrate virtual private cloud (VPC), virtual firewalls, and multi-data-copy capabilities to create an efficient, reliable, and secure computing environment. This ensures stable and uninterrupted operation of services. | ||||
|  | ||||
| @ -12,4 +12,3 @@ cloud_environments: | ||||
|   - name: swiss | ||||
|     visibility: public | ||||
| is_global: false | ||||
| description: Elastic Load Balancing (ELB) is a service that automatically distributes access traffic to multiple Elastic Cloud Servers (ECSs) to balance their service load. ELB enables you to achieve higher levels of fault tolerance in your applications and expand application service capabilities. | ||||
|  | ||||
| @ -12,4 +12,3 @@ cloud_environments: | ||||
|   - name: swiss | ||||
|     visibility: public | ||||
| is_global: false | ||||
| description: Elastic Volume Service (EVS) offers scalable block storage for servers. With high reliability, high performance, and rich specifications, EVS disks can be used for distributed file systems, development and testing environments, data warehouse applications, and high-performance computing (HPC) scenarios to meet diverse service requirements. | ||||
|  | ||||
| @ -12,4 +12,3 @@ cloud_environments: | ||||
|   - name: swiss | ||||
|     visibility: public | ||||
| is_global: false | ||||
| description: Identity and Access Management (IAM) provides a public cloud system (Open Telekom Cloud) with user identity management and access control. | ||||
|  | ||||
| @ -12,4 +12,3 @@ cloud_environments: | ||||
|   - name: swiss | ||||
|     visibility: public | ||||
| is_global: false | ||||
| description: Image Management Service (IMS) provides flexible self-service and comprehensive image management capabilities. You can use a public image or create a private image to apply for an Elastic Cloud Server (ECS) or multiple ECSs in batches. | ||||
|  | ||||
| @ -12,4 +12,3 @@ cloud_environments: | ||||
|   - name: swiss | ||||
|     visibility: public | ||||
| is_global: false | ||||
| description: Object Storage Service (OBS) is an object-based storage service that provides customers with massive, secure, reliable, and cost-effective data storage capabilities, such as bucket creation, modification, and deletion, as well as object upload, download, and deletion. | ||||
|  | ||||
| @ -12,4 +12,3 @@ cloud_environments: | ||||
|   - name: swiss | ||||
|     visibility: public | ||||
| is_global: false | ||||
| description: Relational Database Service (RDS) is an online relational database service based on the cloud computing platform. The RDS is reliable, scalable, secure, and easy to manage, allowing you to deploy a database within minutes. | ||||
|  | ||||
| @ -10,4 +10,3 @@ cloud_environments: | ||||
|   - name: eu_de | ||||
|     visibility: public | ||||
| is_global: false | ||||
| description: Scalable File Service (SFS) provides high-performance file storage that is scalable on demand. It can be shared with multiple Elastic Cloud Servers (ECS). | ||||
|  | ||||
| @ -12,4 +12,3 @@ cloud_environments: | ||||
|   - name: swiss | ||||
|     visibility: public | ||||
| is_global: false | ||||
| description: The Virtual Private Cloud (VPC) service enables you to provision logically isolated, configurable, and manageable virtual networks for Elastic Cloud Servers (ECSs), improving the security of resources in the cloud system and simplifying network deployment. | ||||
|  | ||||
| @ -62,10 +62,20 @@ class Services(object): | ||||
|         if other in self._service_data["service_categories"]: | ||||
|             self._service_data["service_categories"].remove(other) | ||||
|             self._service_data["service_categories"].append(other) | ||||
|         # sort cloud environments by <name> | ||||
|         self._service_data["cloud_environments"] = sorted( | ||||
|             self._service_data["cloud_environments"], | ||||
|             key=lambda x: f"{x.get('name')}", | ||||
|         ) | ||||
|  | ||||
|     def _rewrite_data(self): | ||||
|         otc_metadata.data.rewrite_data("services.yaml", self._service_data) | ||||
|  | ||||
|     @property | ||||
|     def all_cloud_environments(self): | ||||
|         "Cloud Environments data listing." | ||||
|         return copy.deepcopy(self._service_data["cloud_environments"]) | ||||
|  | ||||
|     @property | ||||
|     def all_services(self): | ||||
|         "Service Categories data listing." | ||||
| @ -475,33 +485,3 @@ 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