A collection of CRDs used in Istio, generated by kopium
directly from istio CRDs
.
istio-api-rs
is built on top of kube-rs
as a set of CRDs, which means it can be easily used under kube_rs
like below:
use istio_api_rs::networking::v1beta1::destination_rule::*;
use istio_api_rs::networking::v1beta1::gateway::*;
use istio_api_rs::networking::v1beta1::virtual_service::*;
use kube::{
api::ListParams,
Api, Client,
};
#[tokio::main]
async fn main() -> anyhow::Result<()> {
tracing_subscriber::fmt::init();
let client = Client::try_default().await?;
let list_opt = ListParams::default();
let gws: Api<Gateway> = Api::namespaced(client.clone(), "default");
for gw in gws.list(&list_opt).await? {
println!("Found Gateway: {}", gw.metadata.name.unwrap());
}
let drs: Api<DestinationRule> = Api::namespaced(client.clone(), "default");
for dr in drs.list(&list_opt).await? {
println!("Found Destination Rule: {}", dr.metadata.name.unwrap());
}
let vss: Api<VirtualService> = Api::namespaced(client.clone(), "default");
for vs in vss.list(&list_opt).await? {
let content = serde_yaml::to_string(&vs).unwrap();
println!("Found Virtual Service with YAML content: {}", content);
}
Ok(())
}
And in cargo.toml
, you should specify the API version for both k8s
& istio
like:
[dependencies]
# ...
kube = { version = "0.90.0", features = ["runtime", "derive"] }
k8s-openapi = { version = "0.21.1", features = ["v1_29"] }
istio-api-rs = { version = "0.8.0", features = ["v1_21"] }
# ...
istio-api-rs
is currently developed and tested on istio/api since v1.10, the lower api version is out of this repository's concern.
The repository is using istio-api-rs-codegen
as code generator, go check that repository if you want to know more about how the codes are generated.
For release package, see crate.io.