#[macro_use] extern crate log;
use k8s_openapi::api::core::v1::ConfigMap;
use kube::{
api::{ListParams, Meta, Resource},
client::APIClient,
config,
runtime::Reflector,
};
#[tokio::main]
async fn main() -> anyhow::Result<()> {
std::env::set_var("RUST_LOG", "info,kube=debug");
env_logger::init();
let config = config::load_kube_config().await?;
let client = APIClient::new(config);
let namespace = std::env::var("NAMESPACE").unwrap_or("default".into());
let resource = Resource::namespaced::<ConfigMap>(&namespace);
let lp = ListParams::default().timeout(10); let rf: Reflector<ConfigMap> = Reflector::new(client, lp, resource).init().await?;
rf.state().await?.into_iter().for_each(|cm| {
info!("Found configmap {} with data: {:?}", Meta::name(&cm), cm.data);
});
loop {
rf.poll().await?;
let pods: Vec<_> = rf.state().await?.iter().map(Meta::name).collect();
info!("Current configmaps: {:?}", pods);
}
}