fix: unjank the demo #85
| @ -247,39 +247,53 @@ impl K8sClient { | ||||
| 
 | ||||
|     pub async fn apply_yaml_many( | ||||
|         &self, | ||||
|         api_resource: &ApiResource, | ||||
|         yaml: &Vec<serde_yaml::Value>, | ||||
|         ns: Option<&str>, | ||||
|     ) -> Result<(), Error> { | ||||
|         for y in yaml.iter() { | ||||
|             self.apply_yaml(api_resource, y, ns).await?; | ||||
|             self.apply_yaml(y, ns).await?; | ||||
|         } | ||||
|         Ok(()) | ||||
|     } | ||||
| 
 | ||||
|     pub async fn apply_yaml( | ||||
|         &self, | ||||
|         api_resource: &ApiResource, | ||||
|         yaml: &serde_yaml::Value, | ||||
|         ns: Option<&str>, | ||||
|     ) -> Result<(), Error> { | ||||
|         let obj: DynamicObject = serde_yaml::from_value(yaml.clone()).expect("TODO do not unwrap"); | ||||
|         let name = obj.metadata.name.as_ref().expect("YAML must have a name"); | ||||
| 
 | ||||
|         let api_version = yaml | ||||
|             .get("apiVersion") | ||||
|             .expect("couldn't get apiVersion from YAML") | ||||
|             .as_str() | ||||
|             .expect("couldn't get apiVersion as str"); | ||||
|         let kind = yaml | ||||
|             .get("kind") | ||||
|             .expect("couldn't get kind from YAML") | ||||
|             .as_str() | ||||
|             .expect("couldn't get kind as str"); | ||||
| 
 | ||||
|         let split: Vec<&str> = api_version.splitn(2, "/").collect(); | ||||
|         let g = split[0]; | ||||
|         let v = split[1]; | ||||
| 
 | ||||
|         let gvk = GroupVersionKind::gvk(g, v, kind); | ||||
|         let api_resource = ApiResource::from_gvk(&gvk); | ||||
| 
 | ||||
|         let namespace = match ns { | ||||
|             Some(n) => n, | ||||
|             None => { | ||||
|                 obj | ||||
|                     .metadata | ||||
|                     .namespace | ||||
|                     .as_ref() | ||||
|                     .expect("YAML must have a namespace") | ||||
|             }, | ||||
|             None => obj | ||||
|                 .metadata | ||||
|                 .namespace | ||||
|                 .as_ref() | ||||
|                 .expect("YAML must have a namespace"), | ||||
|         }; | ||||
| 
 | ||||
|         // 5. Create a dynamic API client for this resource type.
 | ||||
|         let api: Api<DynamicObject> = | ||||
|             Api::namespaced_with(self.client.clone(), namespace, api_resource); | ||||
|             Api::namespaced_with(self.client.clone(), namespace, &api_resource); | ||||
| 
 | ||||
|         // 6. Apply the object to the cluster using Server-Side Apply.
 | ||||
|         //    This will create the resource if it doesn't exist, or update it if it does.
 | ||||
|  | ||||
| @ -57,16 +57,9 @@ impl<T: Topology + K8sclient + HelmCommand> Interpret<T> for ArgoInterpret { | ||||
|             .execute(inventory, topology) | ||||
|             .await?; | ||||
| 
 | ||||
|         let gvk = GroupVersionKind::gvk("argoproj.io", "v1alpha1", "Application"); | ||||
|         let api_resource = ApiResource::from_gvk_with_plural(&gvk, "applications"); | ||||
| 
 | ||||
|         let k8s_client = topology.k8s_client().await?; | ||||
|         k8s_client | ||||
|  | ||||
|             .apply_yaml_many( | ||||
|                 &api_resource, | ||||
|                 &self.argo_apps.iter().map(|a| a.to_yaml()).collect(), | ||||
|                 None, | ||||
|             ) | ||||
|             .apply_yaml_many(&self.argo_apps.iter().map(|a| a.to_yaml()).collect(), None) | ||||
|             .await | ||||
|             .unwrap(); | ||||
|         Ok(Outcome::success(format!( | ||||
|  | ||||
		Loading…
	
		Reference in New Issue
	
	Block a user
	
This is binding Harmony's usage to kube-rs API, which is wrong.
I think it would be doable to extract the gvk from the manifest itself and have
apply_yamlreturnErr("Could not build gvk from input yaml, missing property {missing_property}"). Then I think the only missing bit will be the plural which is not kube-rs specific so more acceptable.