From 85c310be2b81e73feb708b66da594760df709c6b Mon Sep 17 00:00:00 2001 From: Chris Roberts Date: Wed, 20 Sep 2023 13:33:52 -0400 Subject: [PATCH] Fixes #36766 - Set disks to amount of disks instead of bytes --- .../DetailsTabCards/HwPropertiesCard.js | 21 ++++++++++--------- 1 file changed, 11 insertions(+), 10 deletions(-) diff --git a/webpack/components/extensions/HostDetails/DetailsTabCards/HwPropertiesCard.js b/webpack/components/extensions/HostDetails/DetailsTabCards/HwPropertiesCard.js index 13149278fc8..fe3e680bbdb 100644 --- a/webpack/components/extensions/HostDetails/DetailsTabCards/HwPropertiesCard.js +++ b/webpack/components/extensions/HostDetails/DetailsTabCards/HwPropertiesCard.js @@ -1,6 +1,5 @@ import React from 'react'; import PropTypes from 'prop-types'; -import { propsToCamelCase } from 'foremanReact/common/helpers'; import { translate as __ } from 'foremanReact/common/I18n'; import { DescriptionList, @@ -14,7 +13,12 @@ import CardTemplate from 'foremanReact/components/HostDetails/Templates/CardItem import { TranslatedPlural } from '../../../Table/components/TranslatedPlural'; import { hostIsNotRegistered } from '../hostDetailsHelpers'; -const HostDisks = ({ totalDisks }) => { +const HostDisks = ({ blockDevices }) => { + if (!blockDevices) return null; + // blockDevices fact will look like this by default 'sr0,sda' and increment like sdb etc + const disks = blockDevices.split(','); + // We are filtering out the CDROM drive that gets added by default a lot of the time + const totalDisks = disks.filter(e => !e.startsWith('sr')).length; if (!totalDisks) return null; return ( <> @@ -27,11 +31,11 @@ const HostDisks = ({ totalDisks }) => { }; HostDisks.propTypes = { - totalDisks: PropTypes.number, + blockDevices: PropTypes.string, }; HostDisks.defaultProps = { - totalDisks: null, + blockDevices: '', }; const HwPropertiesCard = ({ isExpandedGlobal, hostDetails }) => { @@ -41,8 +45,7 @@ const HwPropertiesCard = ({ isExpandedGlobal, hostDetails }) => { const cpuCount = facts?.['cpu::cpu(s)']; const cpuSockets = facts?.['cpu::cpu_socket(s)']; const coreSocket = facts?.['cpu::core(s)_per_socket']; - const reportedFacts = propsToCamelCase(hostDetails?.reported_data || {}); - const totalDisks = reportedFacts?.disksTotal; + const blockDevices = facts?.blockdevices; const memory = facts?.['dmi::memory::maximum_capacity']; return ( @@ -74,7 +77,7 @@ const HwPropertiesCard = ({ isExpandedGlobal, hostDetails }) => { {memory} - + @@ -90,9 +93,7 @@ HwPropertiesCard.propTypes = { cpuSockets: PropTypes.number, coreSocket: PropTypes.number, memory: PropTypes.string, - }), - reported_data: PropTypes.shape({ - totalDisks: PropTypes.number, + blockdevices: PropTypes.string, }), }), };