tools: improve user experience by choosing best certificate
automatically and print final response in a pretty way
ndns-update
- pick the best certificate to sign the Update automatically
- support multiple token for content option
ndns-dig
- enhance output option
- change behavior of iterative query controller when NS query is NACKed
logger
- set default logger output to std::cerr
Change-Id: Ib06981c224ccad2a122a4505c84a60977184a55b
diff --git a/src/util/util.cpp b/src/util/util.cpp
new file mode 100644
index 0000000..1b14896
--- /dev/null
+++ b/src/util/util.cpp
@@ -0,0 +1,60 @@
+/* -*- Mode:C++; c-file-style:"gnu"; indent-tabs-mode:nil; -*- */
+/**
+ * Copyright (c) 2014, Regents of the University of California.
+ *
+ * This file is part of NDNS (Named Data Networking Domain Name Service).
+ * See AUTHORS.md for complete list of NDNS authors and contributors.
+ *
+ * NDNS is free software: you can redistribute it and/or modify it under the terms
+ * of the GNU General Public License as published by the Free Software Foundation,
+ * either version 3 of the License, or (at your option) any later version.
+ *
+ * NDNS is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY;
+ * without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
+ * PURPOSE. See the GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License along with
+ * NDNS, e.g., in COPYING.md file. If not, see <http://www.gnu.org/licenses/>.
+ */
+
+#include "util.hpp"
+#include <ndn-cxx/security/cryptopp.hpp>
+
+namespace ndn {
+namespace ndns {
+
+NdnsType
+toNdnsType(const std::string& str)
+{
+ if (str == "resp")
+ return NDNS_RESP;
+ else if (str == "nack")
+ return NDNS_NACK;
+ else if (str == "auth")
+ return NDNS_AUTH;
+ else if (str == "raw")
+ return NDNS_RAW;
+ else
+ return NDNS_UNKNOWN;
+}
+
+void
+output(const Data& data, std::ostream& os, const bool isPretty)
+{
+ using namespace CryptoPP;
+ const Block& block = data.wireEncode();
+ if (!isPretty) {
+ StringSource ss(block.wire(), block.size(), true,
+ new Base64Encoder(new FileSink(os), true, 64));
+ }
+ else {
+ os << "Name: " << data.getName().toUri() << std::endl;
+ os << "KeyLocator: " << data.getSignature().getKeyLocator().getName().toUri() << std::endl;
+ StringSource ss(block.wire(), block.size(), true,
+ new Base64Encoder(new FileSink(os), true, 64));
+ os << std::endl;
+ }
+}
+
+} // namespace ndns
+} // namespace ndn