Add support for SocketAttributes interface

Tested:

1) Network services bmcweb and phosphor-ipmi-net implement the interface
   xyz.openbmc_project.Control.Service.SocketAttributes and property Port
   is populated correctly.
2) Verified services like VUART does not implement the SocketAttributes interface.
3) Modified the Port of phosphor-ipmi-net and verified.
3a) Network IPMI works on the new port.
3b) The new port is reflected when quering the IPMI protocol details via Redfish.

Signed-off-by: Tom Joseph <tomjoseph@in.ibm.com>
Change-Id: I4511ce9e5426d99895f8074617cdb41d6085fd13
diff --git a/inc/srvcfg_manager.hpp b/inc/srvcfg_manager.hpp
index adfa89a..023b1d8 100644
--- a/inc/srvcfg_manager.hpp
+++ b/inc/srvcfg_manager.hpp
@@ -27,9 +27,11 @@
     "xyz.openbmc_project.Control.Service.Manager";

 static constexpr const char* serviceConfigIntfName =

     "xyz.openbmc_project.Control.Service.Attributes";

+static constexpr const char* sockAttrIntfName =

+    "xyz.openbmc_project.Control.Service.SocketAttributes";

 static constexpr const char* srcCfgMgrBasePath =

     "/xyz/openbmc_project/control/service";

-static constexpr const char* srvCfgPropPort = "Port";

+static constexpr const char* sockAttrPropPort = "Port";

 static constexpr const char* srvCfgPropMasked = "Masked";

 static constexpr const char* srvCfgPropEnabled = "Enabled";

 static constexpr const char* srvCfgPropRunning = "Running";

@@ -67,7 +69,9 @@
 

   private:

     sdbusplus::asio::object_server& server;

-    std::shared_ptr<sdbusplus::asio::dbus_interface> iface;

+    std::shared_ptr<sdbusplus::asio::dbus_interface> srvCfgIface;

+    std::shared_ptr<sdbusplus::asio::dbus_interface> sockAttrIface;

+

     bool internalSet = false;

     std::string objPath;

     std::string baseUnitName;

diff --git a/src/srvcfg_manager.cpp b/src/srvcfg_manager.cpp
index 0a6fcd9..2d346c2 100644
--- a/src/srvcfg_manager.cpp
+++ b/src/srvcfg_manager.cpp
@@ -58,10 +58,10 @@
                 throw std::out_of_range("Out of range");

             }

             portNum = tmp;

-            if (iface && iface->is_initialized())

+            if (sockAttrIface && sockAttrIface->is_initialized())

             {

                 internalSet = true;

-                iface->set_property(srvCfgPropPort, portNum);

+                sockAttrIface->set_property(sockAttrPropPort, portNum);

                 internalSet = false;

             }

         }

@@ -84,11 +84,11 @@
         {

             unitEnabledState = true;

         }

-        if (iface && iface->is_initialized())

+        if (srvCfgIface && srvCfgIface->is_initialized())

         {

             internalSet = true;

-            iface->set_property(srvCfgPropMasked, unitMaskedState);

-            iface->set_property(srvCfgPropEnabled, unitEnabledState);

+            srvCfgIface->set_property(srvCfgPropMasked, unitMaskedState);

+            srvCfgIface->set_property(srvCfgPropEnabled, unitEnabledState);

             internalSet = false;

         }

     }

@@ -100,10 +100,10 @@
         {

             unitRunningState = true;

         }

-        if (iface && iface->is_initialized())

+        if (srvCfgIface && srvCfgIface->is_initialized())

         {

             internalSet = true;

-            iface->set_property(srvCfgPropRunning, unitRunningState);

+            srvCfgIface->set_property(srvCfgPropRunning, unitRunningState);

             internalSet = false;

         }

     }

@@ -142,7 +142,7 @@
                             try

                             {

                                 updateSocketProperties(propertyMap);

-                                if (!iface)

+                                if (!srvCfgIface)

                                 {

                                     registerProperties();

                                 }

@@ -160,7 +160,7 @@
                         sysdService, socketObjectPath, dBusPropIntf,

                         dBusGetAllMethod, sysdSocketIntf);

                 }

-                else if (!iface)

+                else if (!srvCfgIface)

                 {

                     registerProperties();

                 }

@@ -380,12 +380,13 @@
 

 void ServiceConfig::registerProperties()

 {

-    iface = server.add_interface(objPath, serviceConfigIntfName);

+    srvCfgIface = server.add_interface(objPath, serviceConfigIntfName);

 

     if (!socketObjectPath.empty())

     {

-        iface->register_property(

-            srvCfgPropPort, portNum,

+        sockAttrIface = server.add_interface(objPath, sockAttrIntfName);

+        sockAttrIface->register_property(

+            sockAttrPropPort, portNum,

             [this](const uint16_t& req, uint16_t& res) {

                 if (!internalSet)

                 {

@@ -407,7 +408,7 @@
             });

     }

 

-    iface->register_property(

+    srvCfgIface->register_property(

         srvCfgPropMasked, unitMaskedState, [this](const bool& req, bool& res) {

             if (!internalSet)

             {

@@ -427,8 +428,8 @@
                     (1 << static_cast<uint8_t>(UpdatedProp::enabledState)) |

                     (1 << static_cast<uint8_t>(UpdatedProp::runningState));

                 internalSet = true;

-                iface->set_property(srvCfgPropEnabled, unitEnabledState);

-                iface->set_property(srvCfgPropRunning, unitRunningState);

+                srvCfgIface->set_property(srvCfgPropEnabled, unitEnabledState);

+                srvCfgIface->set_property(srvCfgPropRunning, unitRunningState);

                 internalSet = false;

                 startServiceRestartTimer();

             }

@@ -436,7 +437,7 @@
             return 1;

         });

 

-    iface->register_property(

+    srvCfgIface->register_property(

         srvCfgPropEnabled, unitEnabledState,

         [this](const bool& req, bool& res) {

             if (!internalSet)

@@ -464,7 +465,7 @@
             return 1;

         });

 

-    iface->register_property(

+    srvCfgIface->register_property(

         srvCfgPropRunning, unitRunningState,

         [this](const bool& req, bool& res) {

             if (!internalSet)

@@ -492,7 +493,11 @@
             return 1;

         });

 

-    iface->initialize();

+    srvCfgIface->initialize();

+    if (!socketObjectPath.empty())

+    {

+        sockAttrIface->initialize();

+    }

     return;

 }