allow DigestSha256 signing

refs: #4

Change-Id: I94c6499107e31ebfed0dbab71fc204e0443b7754
diff --git a/ndn-traffic-server.conf.sample b/ndn-traffic-server.conf.sample
index 852a0f9..dbd8370 100644
--- a/ndn-traffic-server.conf.sample
+++ b/ndn-traffic-server.conf.sample
@@ -12,7 +12,7 @@
 #   (Optional) MEANS OTHERWISE
 # * ALSO PROVIDED ARE VALID VALUES POSSIBLE FOR EACH PARAMETER
 # * NNI STANDS FOR NON-NEGATIVE INTEGER
-# * RANGE OF POSSIBLE VALUES IS SPECIFIED IN [] 
+# * RANGE OF POSSIBLE VALUES IS SPECIFIED IN []
 #
 #
 #(Mandatory)
@@ -25,6 +25,7 @@
 #ContentBytes=NNI [>0]
 #Content=String
 #ContentDelay=NNI [Milliseconds]
+#SignWithSha256=Bool [0:default, 1:Sha256]
 #
 #
 ##########
@@ -33,5 +34,4 @@
 ##########
 Name=/example/B
 Content=BBBBBBBB
-##########
-
+##########
\ No newline at end of file
diff --git a/src/ndn-traffic-server.cpp b/src/ndn-traffic-server.cpp
index 9351f75..b0f572d 100644
--- a/src/ndn-traffic-server.cpp
+++ b/src/ndn-traffic-server.cpp
@@ -32,6 +32,7 @@
 
 #include <ndn-cxx/face.hpp>
 #include <ndn-cxx/security/key-chain.hpp>
+#include <ndn-cxx/security/signing-helpers.hpp>
 
 #include "logger.hpp"
 
@@ -64,6 +65,7 @@
       , m_contentBytes(-1)
       , m_contentDelay(time::milliseconds(-1))
       , m_nInterestsReceived(0)
+      , m_signWithSha256(false)
     {
     }
 
@@ -85,6 +87,7 @@
         detail += "ContentDelay=" + std::to_string(m_contentDelay.count()) + ", ";
       if (!m_content.empty())
         detail += "Content=" + m_content + ", ";
+      detail += "SignWithSha256=" + std::to_string(m_signWithSha256) + ", ";
       if (detail.length() >= 2)
         detail = detail.substr(0, detail.length() - 2);
 
@@ -126,30 +129,48 @@
                                int lineNumber)
     {
       std::string parameter, value;
-      if (extractParameterValue(detail, parameter, value))
-        {
-          if (parameter == "Name")
-            m_name = value;
-          else if (parameter == "ContentType")
-            m_contentType = std::stoi(value);
-          else if (parameter == "FreshnessPeriod")
-            m_freshnessPeriod = time::milliseconds(std::stoi(value));
-          else if (parameter == "ContentDelay")
-            m_contentDelay = time::milliseconds(std::stoi(value));
-          else if (parameter == "ContentBytes")
-            m_contentBytes = std::stoi(value);
-          else if (parameter == "Content")
-            m_content = value;
-          else
+      if (extractParameterValue(detail, parameter, value)) {
+        if (parameter == "Name") {
+          m_name = value;
+        }
+        else if (parameter == "ContentType") {
+          m_contentType = std::stoi(value);
+        }
+        else if (parameter == "FreshnessPeriod") {
+          m_freshnessPeriod = time::milliseconds(std::stoi(value));
+        }
+        else if (parameter == "ContentDelay") {
+          m_contentDelay = time::milliseconds(std::stoi(value));
+        }
+        else if (parameter == "ContentBytes") {
+          m_contentBytes = std::stoi(value);
+        }
+        else if (parameter == "Content") {
+          m_content = value;
+        }
+        else if (parameter == "SignWithSha256") {
+          if (value == "0") {
+            m_signWithSha256 = false;
+          }
+          else if (value == "1") {
+            m_signWithSha256 = true;
+          }
+          else {
             logger.log("Line " + std::to_string(lineNumber) +
-                       " \t- Invalid Parameter='" + parameter + "'", false, true);
+                       " \t- Invalid SignWithSha256 Value='" + value + "'", false, true);
+          }
         }
-      else
-        {
+        else {
           logger.log("Line " + std::to_string(lineNumber) +
-            " \t- Improper Traffic Configuration Line - " + detail, false, true);
-          return false;
+                     " \t- Invalid Parameter='" + parameter + "'", false, true);
         }
+      }
+      else {
+        logger.log("Line " + std::to_string(lineNumber) +
+                   " \t- Improper Traffic Configuration Line - " + detail, false, true);
+        return false;
+      }
+
       return true;
     }
 
@@ -167,6 +188,7 @@
     time::milliseconds m_contentDelay;
     std::string m_content;
     int m_nInterestsReceived;
+    bool m_signWithSha256;
 
     friend class NdnTrafficServer;
   };
@@ -368,38 +390,47 @@
   void
   onInterest(const Name& name, const Interest& interest, int patternId)
   {
+    auto& pattern = m_trafficPatterns[patternId];
+
     if (m_nMaximumInterests < 0 || m_nInterestsReceived < m_nMaximumInterests)
       {
         Data data(interest.getName());
 
-        if (m_trafficPatterns[patternId].m_contentType >= 0)
-          data.setContentType(m_trafficPatterns[patternId].m_contentType);
+        if (pattern.m_contentType >= 0)
+          data.setContentType(pattern.m_contentType);
 
-        if (m_trafficPatterns[patternId].m_freshnessPeriod >= time::milliseconds(0))
-          data.setFreshnessPeriod(m_trafficPatterns[patternId].m_freshnessPeriod);
+        if (pattern.m_freshnessPeriod >= time::milliseconds(0))
+          data.setFreshnessPeriod(pattern.m_freshnessPeriod);
 
         std::string content;
-        if (m_trafficPatterns[patternId].m_contentBytes >= 0)
-          content = getRandomByteString(m_trafficPatterns[patternId].m_contentBytes);
-        if (!m_trafficPatterns[patternId].m_content.empty())
-          content = m_trafficPatterns[patternId].m_content;
+        if (pattern.m_contentBytes >= 0)
+          content = getRandomByteString(pattern.m_contentBytes);
+        if (!pattern.m_content.empty())
+          content = pattern.m_content;
 
         data.setContent(reinterpret_cast<const uint8_t*>(content.c_str()), content.length());
-        m_keyChain.sign(data);
+
+        if (pattern.m_signWithSha256) {
+          m_keyChain.sign(data, security::signingWithSha256());
+        }
+        else {
+          m_keyChain.sign(data);
+        }
+
         m_nInterestsReceived++;
-        m_trafficPatterns[patternId].m_nInterestsReceived++;
+        pattern.m_nInterestsReceived++;
 
         if (!m_hasQuietLogging) {
           std::string logLine =
             "Interest Received          - PatternType=" + std::to_string(patternId + 1) +
             ", GlobalID=" + std::to_string(m_nInterestsReceived) +
-            ", LocalID=" + std::to_string(m_trafficPatterns[patternId].m_nInterestsReceived) +
-            ", Name=" + m_trafficPatterns[patternId].m_name;
+            ", LocalID=" + std::to_string(pattern.m_nInterestsReceived) +
+            ", Name=" + pattern.m_name;
           m_logger.log(logLine, true, false);
         }
 
-        if (m_trafficPatterns[patternId].m_contentDelay > time::milliseconds(-1))
-          usleep(m_trafficPatterns[patternId].m_contentDelay.count() * 1000);
+        if (pattern.m_contentDelay > time::milliseconds(-1))
+          usleep(pattern.m_contentDelay.count() * 1000);
         if (m_contentDelay > time::milliseconds(-1))
           usleep(m_contentDelay.count() * 1000);
         m_face.put(data);
@@ -517,4 +548,4 @@
   server.run();
 
   return server.hasError() ? EXIT_FAILURE : EXIT_SUCCESS;
-}
+}
\ No newline at end of file