C++11 tidying.
[libdcp.git] / tools / dcpkdm.cc
index 1e35803f4edabe0bd375362c09e5c15dc914d6f0..20b07ebca513b1476fe2872fccd87b514c91cb0e 100644 (file)
@@ -1,5 +1,5 @@
 /*
-    Copyright (C) 2017 Carl Hetherington <cth@carlh.net>
+    Copyright (C) 2017-2021 Carl Hetherington <cth@carlh.net>
 
     This file is part of libdcp.
 
     files in the program, then also delete it here.
 */
 
-#include "encrypted_kdm.h"
+
+#include "certificate_chain.h"
 #include "decrypted_kdm.h"
-#include "util.h"
+#include "encrypted_kdm.h"
 #include "exceptions.h"
-#include <boost/foreach.hpp>
+#include "util.h"
 #include <getopt.h>
 
-using std::string;
-using std::cout;
+
 using std::cerr;
+using std::cout;
+using std::string;
 using boost::optional;
 
+
 static void
 help (string n)
 {
-       cerr << "Syntax: " << n << " [OPTION] <KDM>]\n"
+       cerr << "Syntax: " << n << " [OPTION] <KDM>\n"
             << "  -h, --help         show this help\n"
             << "  -p, --private-key  private key file\n";
 }
 
+
+static string
+tm_to_string (struct tm t)
+{
+       char buffer[64];
+       snprintf (buffer, 64, "%02d/%02d/%02d %02d:%02d:%02d", t.tm_mday, t.tm_mon + 1, t.tm_year + 1900, t.tm_hour, t.tm_min, t.tm_sec);
+       return buffer;
+}
+
+
 int
 main (int argc, char* argv[])
+try
 {
+       dcp::init ();
+
        optional<boost::filesystem::path> private_key_file;
 
        int option_index = 0;
@@ -90,20 +106,38 @@ main (int argc, char* argv[])
        dcp::EncryptedKDM enc_kdm (dcp::file_to_string (kdm_file));
 
        if (enc_kdm.annotation_text()) {
-               cout << "Annotation:    " << enc_kdm.annotation_text().get() << "\n";
+               cout << "Annotation:       " << enc_kdm.annotation_text().get() << "\n";
+       }
+       cout << "Content title:    " << enc_kdm.content_title_text() << "\n";
+       cout << "CPL id:           " << enc_kdm.cpl_id() << "\n";
+       cout << "Recipient:        " << enc_kdm.recipient_x509_subject_name() << "\n";
+       cout << "Not valid before: " << enc_kdm.not_valid_before().as_string() << "\n";
+       cout << "Not valid after:  " << enc_kdm.not_valid_after().as_string() << "\n";
+
+       cout << "Signer chain:\n";
+       dcp::CertificateChain signer = enc_kdm.signer_certificate_chain ();
+       for (auto const& i: signer.root_to_leaf()) {
+               cout << "\tCertificate:\n";
+               cout << "\t\tSubject: " << i.subject() << "\n";
+               cout << "\t\tSubject common name: " << i.subject_common_name() << "\n";
+               cout << "\t\tSubject organization name: " << i.subject_organization_name() << "\n";
+               cout << "\t\tSubject organizational unit name: " << i.subject_organizational_unit_name() << "\n";
+               cout << "\t\tNot before: " << tm_to_string(i.not_before()) << "\n";
+               cout << "\t\tNot after:  " << tm_to_string(i.not_after()) << "\n";
+               if (i.has_utf8_strings()) {
+                       cout << "\t\tUSES INCORRECT (UTF8) STRING ENCODING\n";
+               }
        }
-       cout << "Content title: " << enc_kdm.content_title_text() << "\n";
-       cout << "CPL id:        " << enc_kdm.cpl_id() << "\n";
-       cout << "Recipient:     " << enc_kdm.recipient_x509_subject_name() << "\n";
 
        if (private_key_file) {
                try {
                        dcp::DecryptedKDM dec_kdm (enc_kdm, dcp::file_to_string (private_key_file.get()));
-                       cout << "\nKeys";
-                       BOOST_FOREACH (dcp::DecryptedKDMKey i, dec_kdm.keys ()) {
+                       cout << "\nKeys:";
+                       for (auto i: dec_kdm.keys()) {
                                cout << "\n";
                                cout << "\tID:       " << i.id() << "\n";
-                               cout << "\tStandard: " << (i.standard() == dcp::SMPTE ? "SMPTE" : "Interop") << "\n";
+                               cout << "\tStandard: " << (i.standard() == dcp::Standard::SMPTE ? "SMPTE" : "Interop") << "\n";
+                               cout << "\tCPL ID:   " << i.cpl_id() << "\n";
                                if (i.type()) {
                                        cout << "\tType:     " << i.type().get() << "\n";
                                }
@@ -117,3 +151,8 @@ main (int argc, char* argv[])
 
        return 0;
 }
+catch (std::exception& e)
+{
+       cerr << "Error: " << e.what() << "\n";
+       exit (EXIT_FAILURE);
+}