Merge remote-tracking branch 'origin/master' into refactor/ns
This commit is contained in:
		
						commit
						3959c07261
					
				| @ -8,7 +8,7 @@ use async_trait::async_trait; | ||||
| use derive_new::new; | ||||
| use k8s_openapi::{ | ||||
|     api::{ | ||||
|         core::v1::{Namespace, ResourceQuota}, | ||||
|         core::v1::{LimitRange, Namespace, ResourceQuota}, | ||||
|         networking::v1::{ | ||||
|             NetworkPolicy, NetworkPolicyEgressRule, NetworkPolicyIngressRule, NetworkPolicyPort, | ||||
|         }, | ||||
| @ -132,6 +132,43 @@ impl K8sTenantManager { | ||||
|         }) | ||||
|     } | ||||
| 
 | ||||
|     fn build_limit_range(&self, config: &TenantConfig) -> Result<LimitRange, ExecutorError> { | ||||
|         let limit_range = json!({ | ||||
|           "apiVersion": "v1", | ||||
|           "kind": "LimitRange", | ||||
|           "metadata": { | ||||
|             "name": format!("{}-defaults", config.name), | ||||
|             "labels": { | ||||
|               "harmony.nationtech.io/tenant.id": config.id.to_string(), | ||||
|               "harmony.nationtech.io/tenant.name": config.name, | ||||
|             }, | ||||
|             "namespace": self.get_namespace_name(config), | ||||
|           }, | ||||
|           "spec": { | ||||
|             "limits": [ | ||||
|               { | ||||
|                 "type": "Container", 
 | ||||
|                 "default": { | ||||
|                   "cpu": "500m", | ||||
|                   "memory": "500Mi" | ||||
|                 }, | ||||
|                 "defaultRequest": { | ||||
|                   "cpu": "100m", | ||||
|                   "memory": "100Mi" | ||||
|                 }, | ||||
|               } | ||||
|             ] | ||||
|           } | ||||
|         }); | ||||
| 
 | ||||
|         serde_json::from_value(limit_range).map_err(|e| { | ||||
|             ExecutorError::ConfigurationError(format!( | ||||
|                 "Could not build TenantManager LimitRange. {}", | ||||
|                 e | ||||
|             )) | ||||
|         }) | ||||
|     } | ||||
| 
 | ||||
|     fn build_network_policy(&self, config: &TenantConfig) -> Result<NetworkPolicy, ExecutorError> { | ||||
|         let network_policy = json!({ | ||||
|           "apiVersion": "networking.k8s.io/v1", | ||||
| @ -362,6 +399,7 @@ impl TenantManager for K8sTenantManager { | ||||
|         let namespace = self.build_namespace(config)?; | ||||
|         let resource_quota = self.build_resource_quota(config)?; | ||||
|         let network_policy = self.build_network_policy(config)?; | ||||
|         let resource_limit_range = self.build_limit_range(config)?; | ||||
| 
 | ||||
|         self.ensure_constraints(&namespace)?; | ||||
| 
 | ||||
| @ -371,6 +409,9 @@ impl TenantManager for K8sTenantManager { | ||||
|         debug!("Creating resource_quota for tenant {}", config.name); | ||||
|         self.apply_resource(resource_quota, config).await?; | ||||
| 
 | ||||
|         debug!("Creating limit_range for tenant {}", config.name); | ||||
|         self.apply_resource(resource_limit_range, config).await?; | ||||
| 
 | ||||
|         debug!("Creating network_policy for tenant {}", config.name); | ||||
|         self.apply_resource(network_policy, config).await?; | ||||
| 
 | ||||
|  | ||||
							
								
								
									
										41
									
								
								harmony/src/modules/application/feature.rs
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										41
									
								
								harmony/src/modules/application/feature.rs
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,41 @@ | ||||
| use async_trait::async_trait; | ||||
| use serde::Serialize; | ||||
| 
 | ||||
| use crate::topology::Topology; | ||||
| /// An ApplicationFeature provided by harmony, such as Backups, Monitoring, MultisiteAvailability,
 | ||||
| /// ContinuousIntegration, ContinuousDelivery
 | ||||
| #[async_trait] | ||||
| pub trait ApplicationFeature<T: Topology>: | ||||
|     std::fmt::Debug + Send + Sync + ApplicationFeatureClone<T> | ||||
| { | ||||
|     async fn ensure_installed(&self, topology: &T) -> Result<(), String>; | ||||
|     fn name(&self) -> String; | ||||
| } | ||||
| 
 | ||||
| trait ApplicationFeatureClone<T: Topology> { | ||||
|     fn clone_box(&self) -> Box<dyn ApplicationFeature<T>>; | ||||
| } | ||||
| 
 | ||||
| impl<A, T: Topology> ApplicationFeatureClone<T> for A | ||||
| where | ||||
|     A: ApplicationFeature<T> + Clone + 'static, | ||||
| { | ||||
|     fn clone_box(&self) -> Box<dyn ApplicationFeature<T>> { | ||||
|         Box::new(self.clone()) | ||||
|     } | ||||
| } | ||||
| 
 | ||||
| impl<T: Topology> Serialize for Box<dyn ApplicationFeature<T>> { | ||||
|     fn serialize<S>(&self, serializer: S) -> Result<S::Ok, S::Error> | ||||
|     where | ||||
|         S: serde::Serializer, | ||||
|     { | ||||
|         todo!() | ||||
|     } | ||||
| } | ||||
| 
 | ||||
| impl<T: Topology> Clone for Box<dyn ApplicationFeature<T>> { | ||||
|     fn clone(&self) -> Self { | ||||
|         self.clone_box() | ||||
|     } | ||||
| } | ||||
		Loading…
	
		Reference in New Issue
	
	Block a user