From 3adc3a194c63b8e6e6e321d6734c0fa6fe9ad9da Mon Sep 17 00:00:00 2001 From: Riccardo Piccoli Date: Thu, 14 Nov 2024 11:38:26 +0100 Subject: [PATCH] openstack provider: ignore ec2 metadata if not present Signed-off-by: Riccardo Piccoli --- docs/release-notes.md | 1 + src/providers/openstack/configdrive.rs | 27 ++++++++++++++++---------- 2 files changed, 18 insertions(+), 10 deletions(-) diff --git a/docs/release-notes.md b/docs/release-notes.md index 251df6a6..efca055a 100644 --- a/docs/release-notes.md +++ b/docs/release-notes.md @@ -11,6 +11,7 @@ Major changes: Minor changes: - ProxmoxVE: Fixed instance boot without config drive +- OpenStack: do not fail if ec2 metadata is not found Packaging changes: diff --git a/src/providers/openstack/configdrive.rs b/src/providers/openstack/configdrive.rs index 3a633b91..11825ad5 100644 --- a/src/providers/openstack/configdrive.rs +++ b/src/providers/openstack/configdrive.rs @@ -101,20 +101,24 @@ impl OpenstackConfigDrive { } /// The metadata is stored as key:value pair in ec2/latest/meta-data.json file - fn read_metadata_ec2(&self) -> Result { + fn read_metadata_ec2(&self) -> Result> { + use std::io::ErrorKind::NotFound; + let filename = self.metadata_dir("ec2").join("meta-data.json"); - let file = - File::open(&filename).with_context(|| format!("failed to open file '{filename:?}'"))?; + let file = match File::open(&filename) { + Ok(file) => file, + Err(e) if e.kind() == NotFound => return Ok(None), + Err(e) => return Err(e).with_context(|| format!("failed to open file '{filename:?}'")), + }; let bufrd = BufReader::new(file); Self::parse_metadata_ec2(bufrd) - .with_context(|| format!("failed to parse file '{filename:?}'")) + .with_context(|| format!("failed to parse file '{filename:?}'")).map(|metadata| Some(metadata)) } /// The metadata is stored as key:value pair in openstack/latest/meta_data.json file fn read_metadata_openstack(&self) -> Result { let filename = self.metadata_dir("openstack").join("meta_data.json"); - let file = - File::open(&filename).with_context(|| format!("failed to open file '{filename:?}'"))?; + let file = File::open(&filename).with_context(|| format!("failed to open file '{filename:?}'"))?; let bufrd = BufReader::new(file); Self::parse_metadata_openstack(bufrd) .with_context(|| format!("failed to parse file '{filename:?}'")) @@ -144,17 +148,20 @@ impl OpenstackConfigDrive { impl MetadataProvider for OpenstackConfigDrive { fn attributes(&self) -> Result> { let mut out = HashMap::with_capacity(6); - let metadata_ec2: MetadataEc2JSON = self.read_metadata_ec2()?; let metadata_openstack: MetadataOpenstackJSON = self.read_metadata_openstack()?; if let Some(hostname) = metadata_openstack.hostname { out.insert("OPENSTACK_HOSTNAME".to_string(), hostname); } - if let Some(instance_id) = metadata_ec2.instance_id { - out.insert("OPENSTACK_INSTANCE_ID".to_string(), instance_id); - } if let Some(uuid) = metadata_openstack.uuid { out.insert("OPENSTACK_INSTANCE_UUID".to_string(), uuid); } + + let Some(metadata_ec2) = self.read_metadata_ec2()? else { + return Ok(out); + }; + if let Some(instance_id) = metadata_ec2.instance_id { + out.insert("OPENSTACK_INSTANCE_ID".to_string(), instance_id); + } if let Some(instance_type) = metadata_ec2.instance_type { out.insert("OPENSTACK_INSTANCE_TYPE".to_string(), instance_type); }