EventService : Optimize event data buffers

This commit enhances some of the parameters used at the http client

1. Added the buffer limit to requestDataQueue
   This is to control the message length of an event
2. Moved the flat_buffer to a flat_static_buffer
   This is to limit the maximum size to the requestDataQueue
3. Changed requestDataQueue from a queue to circular buffer
   This is to make the requestDataQueue space optimized

Tested by:
  - Subscribe for the events at BMC using DMTF event listener
  - Generate an event and see the same is received at listener's console

Signed-off-by: Sunitha Harish <sunharis@in.ibm.com>
Change-Id: I563b7f8d24e5cd5e12db324b2e02974328ebd955
diff --git a/http/http_client.hpp b/http/http_client.hpp
index 992ac2b..b135999 100644
--- a/http/http_client.hpp
+++ b/http/http_client.hpp
@@ -34,6 +34,7 @@
 {
 
 static constexpr uint8_t maxRequestQueueSize = 50;
+static constexpr unsigned int httpReadBodyLimit = 8192;
 
 enum class ConnState
 {
@@ -58,11 +59,11 @@
     crow::async_resolve::Resolver resolver;
     boost::beast::tcp_stream conn;
     boost::asio::steady_timer timer;
-    boost::beast::flat_buffer buffer;
+    boost::beast::flat_static_buffer<httpReadBodyLimit> buffer;
     boost::beast::http::request<boost::beast::http::string_body> req;
     boost::beast::http::response<boost::beast::http::string_body> res;
     std::vector<std::pair<std::string, std::string>> headers;
-    std::queue<std::string> requestDataQueue;
+    boost::circular_buffer_space_optimized<std::string> requestDataQueue{};
     ConnState state;
     std::string subId;
     std::string host;
@@ -206,7 +207,10 @@
 
                 // Send is successful, Lets remove data from queue
                 // check for next request data in queue.
-                self->requestDataQueue.pop();
+                if (!self->requestDataQueue.empty())
+                {
+                    self->requestDataQueue.pop_front();
+                }
                 self->state = ConnState::idle;
                 self->checkQueue();
             });
@@ -246,7 +250,7 @@
             // Clear queue.
             while (!requestDataQueue.empty())
             {
-                requestDataQueue.pop();
+                requestDataQueue.pop_front();
             }
 
             BMCWEB_LOG_DEBUG << "Retry policy is set to " << retryPolicyAction;
@@ -355,7 +359,7 @@
 
         if (requestDataQueue.size() <= maxRequestQueueSize)
         {
-            requestDataQueue.push(data);
+            requestDataQueue.push_back(data);
             checkQueue(true);
         }
         else