#[macro_use] extern crate log;
use kube::{
api::{Api, Reflector},
client::APIClient,
config,
};
fn main() -> Result<(), failure::Error> {
std::env::set_var("RUST_LOG", "info,kube=trace");
env_logger::init();
let config = config::load_kube_config().expect("failed to load kubeconfig");
let client = APIClient::new(config);
let namespace = std::env::var("NAMESPACE").unwrap_or("default".into());
let resource = Api::v1Pod(client).within(&namespace);
let rf = Reflector::new(resource).init()?;
rf.read()?.into_iter().for_each(|(name, p)| {
info!("Found pod {} ({}) with {:?}",
name,
p.status.unwrap().phase.unwrap(),
p.spec.containers.into_iter().map(|c| c.name).collect::<Vec<_>>(),
);
});
loop {
rf.poll()?;
let pods = rf.read()?.into_iter().map(|(name, _)| name).collect::<Vec<_>>();
info!("Current pods: {:?}", pods);
}
}