fix: unjank the demo #85
| @ -1,4 +1,5 @@ | |||||||
| use async_trait::async_trait; | use async_trait::async_trait; | ||||||
|  | use kube::api::{ApiResource, GroupVersionKind}; | ||||||
| use log::error; | use log::error; | ||||||
| use non_blank_string_rs::NonBlankString; | use non_blank_string_rs::NonBlankString; | ||||||
| use serde::Serialize; | use serde::Serialize; | ||||||
| @ -56,9 +57,16 @@ impl<T: Topology + K8sclient + HelmCommand> Interpret<T> for ArgoInterpret { | |||||||
|             .execute(inventory, topology) |             .execute(inventory, topology) | ||||||
|             .await?; |             .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?; |         let k8s_client = topology.k8s_client().await?; | ||||||
|         k8s_client |         k8s_client | ||||||
|             .apply_yaml_many(&self.argo_apps.iter().map(|a| a.to_yaml()).collect(), None) |             .apply_yaml_many( | ||||||
|  |                 &api_resource, | ||||||
|  |                 &self.argo_apps.iter().map(|a| a.to_yaml()).collect(), | ||||||
|  |                 None, | ||||||
|  |             ) | ||||||
|             .await |             .await | ||||||
|             .unwrap(); |             .unwrap(); | ||||||
|         Ok(Outcome::success(format!( |         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.