From bfa8c0e8a2aedc700a6da9a6ebbdb820271f0543 Mon Sep 17 00:00:00 2001 From: Sunanda Roy Date: Tue, 26 Dec 2017 18:42:29 +0100 Subject: [PATCH] Create goal must check if security is enabled Signed-off-by: Roy, Sunanda --- src/cli/features/core/CreateGoalCommand.cpp | 52 ++++++++++++++++----- src/cli/features/core/CreateGoalCommand.h | 2 + 2 files changed, 43 insertions(+), 11 deletions(-) diff --git a/src/cli/features/core/CreateGoalCommand.cpp b/src/cli/features/core/CreateGoalCommand.cpp index d673f02..aebf0e7 100644 --- a/src/cli/features/core/CreateGoalCommand.cpp +++ b/src/cli/features/core/CreateGoalCommand.cpp @@ -415,19 +415,24 @@ framework::ResultBase *CreateGoalCommand::execute(const framework::ParsedCommand { try { - setupRequestBuilder(); - const core::memory_allocator::MemoryAllocationRequest &request = m_requestBuilder.build(); - core::memory_allocator::MemoryAllocationLayout layout = m_allocator.layout(request, - m_parser.getNamespaceLabelMajor(), m_parser.getNamespaceLabelMinor()); + m_pResult = m_parser.verifySecurityState(); - if (userReallyLikesThisLayout(layout, m_parser.getUnits())) + if (NULL == m_pResult) { - m_allocator.allocate(layout); - m_pResult = m_showGoalAdapter.showCurrentGoal(m_parser.getUnits()); - } - else - { - m_pResult = new NoChangeResult(); + setupRequestBuilder(); + const core::memory_allocator::MemoryAllocationRequest &request = m_requestBuilder.build(); + core::memory_allocator::MemoryAllocationLayout layout = m_allocator.layout(request, + m_parser.getNamespaceLabelMajor(), m_parser.getNamespaceLabelMinor()); + + if (userReallyLikesThisLayout(layout, m_parser.getUnits())) + { + m_allocator.allocate(layout); + m_pResult = m_showGoalAdapter.showCurrentGoal(m_parser.getUnits()); + } + else + { + m_pResult = new NoChangeResult(); + } } } catch (wbem::framework::Exception &e) @@ -659,6 +664,31 @@ void CreateGoalCommand::Parser::parsePropertyConfig() } } +framework::ResultBase *CreateGoalCommand::Parser::verifySecurityState() +{ + LogEnterExit logging(__FUNCTION__, __FILE__, __LINE__); + + std::string dimms = framework::Parser::getTargetValue(m_parsedCommand, TARGET_DIMM.name); + std::vector devices = ShowCommandUtilities::populateDevicesFromDimmsString(dimms, NVM_TRUE); + + // Check for valid device security state + for (std::vector::const_iterator it = devices.begin(); it != devices.end(); it++) + { + core::device::Device device = (*it); + if (!(LOCK_STATE_DISABLED == device.getLockState())) + { + std::string result; + result = "Invalid device security state. Please set device security state to 'disabled' and try again."; + m_pResult = new framework::ErrorResult( + framework::ErrorResult::ERRORCODE_NOTSUPPORTED, + result); + break; + } + } + + return m_pResult; +} + void CreateGoalCommand::Parser::parsePropertyNamespaceLabelVersion() { if (!hasError()) diff --git a/src/cli/features/core/CreateGoalCommand.h b/src/cli/features/core/CreateGoalCommand.h index 4cfbc4a..1580131 100644 --- a/src/cli/features/core/CreateGoalCommand.h +++ b/src/cli/features/core/CreateGoalCommand.h @@ -27,6 +27,7 @@ #ifndef CR_MGMT_CREATEGOALCOMMAND_H #define CR_MGMT_CREATEGOALCOMMAND_H +#include #include #include #include @@ -91,6 +92,7 @@ class NVM_CLI_API CreateGoalCommand : public framework::CommandBase Parser(); framework::ResultBase *parse(const framework::ParsedCommand &parsedCommand); + virtual framework::ResultBase *verifySecurityState(); int getMemoryMode(); NVM_UINT64 getReserved(); bool isPmTypeAppDirect();