diff options
| author | Brandon Kim <brandonkim@google.com> | 2019-10-18 10:08:37 -0700 |
|---|---|---|
| committer | Brandon Kim <brandonkim@google.com> | 2019-10-18 10:33:14 -0700 |
| commit | cc4ef0c5a492968e6e7e7df7e41acbd599f0e23f (patch) | |
| tree | 62f2d41ffe4ad94a5ef933429c3e304d8e00be86 /src/ipmiblob | |
| parent | 0106f57eab1264e86fc9e75afa453ebbed99345d (diff) | |
| download | ipmi-blob-tool-cc4ef0c5a492968e6e7e7df7e41acbd599f0e23f.tar.gz ipmi-blob-tool-cc4ef0c5a492968e6e7e7df7e41acbd599f0e23f.zip | |
blob: implement deleteBlob command
Implement the deleteBlob command for the blob handler. Adding a unit
test to go along with it.
Change-Id: I2bbc93a6e78d5311bd2033d6a8b179374777f794
Signed-off-by: Brandon Kim <brandonkim@google.com>
Diffstat (limited to 'src/ipmiblob')
| -rw-r--r-- | src/ipmiblob/blob_handler.cpp | 18 | ||||
| -rw-r--r-- | src/ipmiblob/blob_handler.hpp | 2 | ||||
| -rw-r--r-- | src/ipmiblob/blob_interface.hpp | 7 | ||||
| -rw-r--r-- | src/ipmiblob/test/blob_interface_mock.hpp | 1 |
4 files changed, 28 insertions, 0 deletions
diff --git a/src/ipmiblob/blob_handler.cpp b/src/ipmiblob/blob_handler.cpp index 40c725d..d93f5c3 100644 --- a/src/ipmiblob/blob_handler.cpp +++ b/src/ipmiblob/blob_handler.cpp @@ -334,6 +334,24 @@ void BlobHandler::closeBlob(std::uint16_t session) return; } +void BlobHandler::deleteBlob(const std::string& id) +{ + std::vector<std::uint8_t> name; + std::copy(id.begin(), id.end(), std::back_inserter(name)); + name.push_back(0x00); /* need to add nul-terminator. */ + + try + { + sendIpmiPayload(BlobOEMCommands::bmcBlobDelete, name); + } + catch (const BlobException& b) + { + std::fprintf(stderr, "Received failure on delete: %s\n", b.what()); + } + + return; +} + std::vector<std::uint8_t> BlobHandler::readBytes(std::uint16_t session, std::uint32_t offset, std::uint32_t length) diff --git a/src/ipmiblob/blob_handler.hpp b/src/ipmiblob/blob_handler.hpp index c57b11d..33634fd 100644 --- a/src/ipmiblob/blob_handler.hpp +++ b/src/ipmiblob/blob_handler.hpp @@ -82,6 +82,8 @@ class BlobHandler : public BlobInterface void closeBlob(std::uint16_t session) override; + void deleteBlob(const std::string& id) override; + /** * @throws BlobException. */ diff --git a/src/ipmiblob/blob_interface.hpp b/src/ipmiblob/blob_interface.hpp index fbd8c6a..ca90cdf 100644 --- a/src/ipmiblob/blob_interface.hpp +++ b/src/ipmiblob/blob_interface.hpp @@ -114,6 +114,13 @@ class BlobInterface virtual void closeBlob(std::uint16_t session) = 0; /** + * Attempt to delete a blobId. + * + * @param[in] path - the blobId path. + */ + virtual void deleteBlob(const std::string& id) = 0; + + /** * Read bytes from a blob. * * @param[in] session - the session id. diff --git a/src/ipmiblob/test/blob_interface_mock.hpp b/src/ipmiblob/test/blob_interface_mock.hpp index 7fb94c5..f5137d5 100644 --- a/src/ipmiblob/test/blob_interface_mock.hpp +++ b/src/ipmiblob/test/blob_interface_mock.hpp @@ -19,6 +19,7 @@ class BlobInterfaceMock : public BlobInterface MOCK_METHOD1(getStat, StatResponse(std::uint16_t)); MOCK_METHOD2(openBlob, std::uint16_t(const std::string&, std::uint16_t)); MOCK_METHOD1(closeBlob, void(std::uint16_t)); + MOCK_METHOD1(deleteBlob, void(const std::string&)); MOCK_METHOD3(readBytes, std::vector<std::uint8_t>(std::uint16_t, std::uint32_t, std::uint32_t)); |

