From 89c7f6b980b5ab5bac6fe50cf6021a55e5fd43bb Mon Sep 17 00:00:00 2001 From: Tsu-ba-me Date: Fri, 24 Mar 2023 14:51:18 -0400 Subject: [PATCH] fix(striker-ui): build fence and ups list from manifest template --- .../AnvilHostConfigInputGroup.tsx | 62 ++++++++++++++----- 1 file changed, 47 insertions(+), 15 deletions(-) diff --git a/striker-ui/components/ManageManifest/AnvilHostConfigInputGroup.tsx b/striker-ui/components/ManageManifest/AnvilHostConfigInputGroup.tsx index d755395c..083fe36e 100644 --- a/striker-ui/components/ManageManifest/AnvilHostConfigInputGroup.tsx +++ b/striker-ui/components/ManageManifest/AnvilHostConfigInputGroup.tsx @@ -10,29 +10,19 @@ const INPUT_GROUP_CELL_ID_PREFIX_ANVIL_HOST_CONFIG = `${INPUT_GROUP_ID_PREFIX_AN const DEFAULT_HOST_LIST: ManifestHostList = { node1: { - fences: { - fence1: { fenceName: 'ex_pdu01', fencePort: 0 }, - fence2: { fenceName: 'ex_pdu02', fencePort: 0 }, - }, hostNumber: 1, hostType: 'node', - upses: { - ups1: { isPowerHost: true, upsName: 'ex_ups01' }, - ups2: { isPowerHost: false, upsName: 'ex_ups02' }, - }, }, node2: { hostNumber: 2, hostType: 'node', }, - dr1: { - hostNumber: 1, - hostType: 'dr', - }, }; const AnvilHostConfigInputGroup = ({ formUtils, + knownFences = {}, + knownUpses = {}, networkListEntries, previous: { hosts: previousHostList = DEFAULT_HOST_LIST } = {}, }: AnvilHostConfigInputGroupProps): ReactElement => { @@ -40,6 +30,14 @@ const AnvilHostConfigInputGroup = ({ () => Object.entries(previousHostList), [previousHostList], ); + const knownFenceListValues = useMemo( + () => Object.values(knownFences), + [knownFences], + ); + const knownUpsListValues = useMemo( + () => Object.values(knownUpses), + [knownUpses], + ); const hostNetworkList = useMemo( () => @@ -63,13 +61,41 @@ const AnvilHostConfigInputGroup = ({ hostListEntries.reduce( (previous, [hostId, previousHostArgs]) => { const { + fences: previousFenceList = {}, hostNumber, hostType, networks = hostNetworkList, + upses: previousUpsList = {}, }: ManifestHost = previousHostArgs; - const cellId = `${INPUT_GROUP_CELL_ID_PREFIX_ANVIL_HOST_CONFIG}-${hostId}`; + const fences = knownFenceListValues.reduce( + (fenceList, { fenceName }) => { + const { fencePort = '' } = previousFenceList[fenceName] ?? {}; + fenceList[fenceName] = { + fenceName, + fencePort, + }; + + return fenceList; + }, + {}, + ); + const upses = knownUpsListValues.reduce( + (upsList, { upsName }) => { + const { isUsed = true } = previousUpsList[upsName] ?? {}; + + upsList[upsName] = { + isUsed, + upsName, + }; + + return upsList; + }, + {}, + ); + + const cellId = `${INPUT_GROUP_CELL_ID_PREFIX_ANVIL_HOST_CONFIG}-${hostId}`; const hostLabel = `${hostType} ${hostNumber}`; previous[cellId] = { @@ -77,7 +103,7 @@ const AnvilHostConfigInputGroup = ({ ), md: 3, @@ -88,7 +114,13 @@ const AnvilHostConfigInputGroup = ({ }, {}, ), - [formUtils, hostListEntries, hostNetworkList], + [ + formUtils, + hostListEntries, + hostNetworkList, + knownFenceListValues, + knownUpsListValues, + ], ); return (