From 94749e02259c84850a8258c11e47e6a057dc877d Mon Sep 17 00:00:00 2001 From: Gonzalo Rafuls Date: Tue, 4 Jun 2024 16:50:44 +0200 Subject: [PATCH] fix: support for uefi boot mode --- config/idrac_interfaces.yml | 3 +++ rpm/python3-badfish.spec.tpl | 2 +- src/badfish/main.py | 7 ++++--- 3 files changed, 8 insertions(+), 4 deletions(-) diff --git a/config/idrac_interfaces.yml b/config/idrac_interfaces.yml index eeb11a6..b61bb07 100644 --- a/config/idrac_interfaces.yml +++ b/config/idrac_interfaces.yml @@ -75,3 +75,6 @@ uefi_e28_r750_interfaces: NIC.Slot.3-1-1,HardDisk.List.1-1,NIC.Embedded.1-1-1 # h35 (should resemble other r640 hosts) #director_f04_h35_r640_interfaces: NIC.Slot.1-2-1,HardDisk.List.1-1,NIC.Integrated.1-1-1 #foreman_f04_h35_r640_interfaces: NIC.Integrated.1-1-1,HardDisk.List.1-1,NIC.Slot.1-2-1 + +director_r660_interfaces: NIC.PxeDevice.2-1,RAID.SL.3-2,NIC.PxeDevice.1-1 +foreman_r660_interfaces: NIC.PxeDevice.1-1,RAID.SL.3-2,NIC.PxeDevice.2-1 diff --git a/rpm/python3-badfish.spec.tpl b/rpm/python3-badfish.spec.tpl index e928c0d..9307bd1 100644 --- a/rpm/python3-badfish.spec.tpl +++ b/rpm/python3-badfish.spec.tpl @@ -14,7 +14,7 @@ Summary: %{sum} License: GPLv3 URL: https://github.com/%{org}/%{project} -Source: %{url}/archive/v%{version}/%{name}-%{version}.tar.gz +Source: %{url}/archive/v%{version}/%{name}-%{version}.tar.gz BuildArch: noarch BuildRequires: %{py3_dist setuptools} diff --git a/src/badfish/main.py b/src/badfish/main.py index ac51379..f8bb963 100755 --- a/src/badfish/main.py +++ b/src/badfish/main.py @@ -1098,7 +1098,7 @@ async def boot_to_type(self, host_type, _interfaces_path): device = await self.get_host_type_boot_device(host_type, _interfaces_path) - await self.boot_to(device) + await self.boot_to(device, True) async def boot_to_mac(self, mac_address): interfaces_endpoints = await self.get_interfaces_endpoints() @@ -1116,10 +1116,11 @@ async def boot_to_mac(self, mac_address): raise BadfishException("MAC Address does not match any of the existing") async def send_one_time_boot(self, device): + boot_seq = await self.get_boot_seq() _payload = { "Attributes": { - "OneTimeBootMode": "OneTimeBootSeq", - "OneTimeBootSeqDev": device, + "OneTimeBootMode": f"OneTime{boot_seq}", + f"OneTime{boot_seq}Dev": device, } } await self.patch_bios(_payload)