Derive Screen from a new class KDMRecipient.
authorCarl Hetherington <cth@carlh.net>
Wed, 29 Apr 2020 23:06:13 +0000 (01:06 +0200)
committerCarl Hetherington <cth@carlh.net>
Wed, 6 May 2020 18:37:13 +0000 (20:37 +0200)
src/lib/kdm_recipient.cc [new file with mode: 0644]
src/lib/kdm_recipient.h [new file with mode: 0644]
src/lib/screen.cc
src/lib/screen.h
src/lib/wscript

diff --git a/src/lib/kdm_recipient.cc b/src/lib/kdm_recipient.cc
new file mode 100644 (file)
index 0000000..d05192a
--- /dev/null
@@ -0,0 +1,45 @@
+/*
+    Copyright (C) 2020 Carl Hetherington <cth@carlh.net>
+
+    This file is part of DCP-o-matic.
+
+    DCP-o-matic 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 2 of the License, or
+    (at your option) any later version.
+
+    DCP-o-matic 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 DCP-o-matic.  If not, see <http://www.gnu.org/licenses/>.
+
+*/
+
+#include "kdm_recipient.h"
+
+KDMRecipient::KDMRecipient (cxml::ConstNodePtr node)
+       : name (node->string_child("Name"))
+       , notes (node->optional_string_child("Notes").get_value_or (""))
+{
+       if (node->optional_string_child("Certificate")) {
+               recipient = dcp::Certificate (node->string_child("Certificate"));
+       } else if (node->optional_string_child("Recipient")) {
+               recipient = dcp::Certificate (node->string_child("Recipient"));
+       }
+}
+
+
+void
+KDMRecipient::as_xml (xmlpp::Element* parent) const
+{
+       parent->add_child("Name")->add_child_text(name);
+       if (recipient) {
+               parent->add_child("Recipient")->add_child_text(recipient->certificate(true));
+       }
+
+       parent->add_child("Notes")->add_child_text(notes);
+}
+
diff --git a/src/lib/kdm_recipient.h b/src/lib/kdm_recipient.h
new file mode 100644 (file)
index 0000000..ee4e8c3
--- /dev/null
@@ -0,0 +1,43 @@
+/*
+    Copyright (C) 2020 Carl Hetherington <cth@carlh.net>
+
+    This file is part of DCP-o-matic.
+
+    DCP-o-matic 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 2 of the License, or
+    (at your option) any later version.
+
+    DCP-o-matic 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 DCP-o-matic.  If not, see <http://www.gnu.org/licenses/>.
+
+*/
+
+#include <dcp/certificate.h>
+#include <libcxml/cxml.h>
+#include <libxml++/libxml++.h>
+#include <boost/optional.hpp>
+#include <string>
+
+class KDMRecipient
+{
+public:
+       KDMRecipient (std::string const& name_, std::string const& notes_, boost::optional<dcp::Certificate> recipient_)
+               : name (name_)
+               , notes (notes_)
+               , recipient (recipient_)
+       {}
+
+       explicit KDMRecipient (cxml::ConstNodePtr);
+
+       virtual void as_xml (xmlpp::Element *) const;
+
+       std::string name;
+       std::string notes;
+       boost::optional<dcp::Certificate> recipient;
+};
index c4bcb41c7d18a1a4aef1d98ed6032b1480910f5b..2441efccbf7bbec1c40fac18875fb7f961134391 100644 (file)
@@ -34,15 +34,8 @@ using boost::optional;
 using namespace dcpomatic;
 
 Screen::Screen (cxml::ConstNodePtr node)
-       : name (node->string_child("Name"))
-       , notes (node->optional_string_child("Notes").get_value_or (""))
+       : KDMRecipient (node)
 {
-       if (node->optional_string_child ("Certificate")) {
-               recipient = dcp::Certificate (node->string_child ("Certificate"));
-       } else if (node->optional_string_child ("Recipient")) {
-               recipient = dcp::Certificate (node->string_child ("Recipient"));
-       }
-
        BOOST_FOREACH (cxml::ConstNodePtr i, node->node_children ("TrustedDevice")) {
                if (boost::algorithm::starts_with(i->content(), "-----BEGIN CERTIFICATE-----")) {
                        trusted_devices.push_back (TrustedDevice(dcp::Certificate(i->content())));
@@ -55,13 +48,7 @@ Screen::Screen (cxml::ConstNodePtr node)
 void
 Screen::as_xml (xmlpp::Element* parent) const
 {
-       parent->add_child("Name")->add_child_text (name);
-       if (recipient) {
-               parent->add_child("Recipient")->add_child_text (recipient->certificate (true));
-       }
-
-       parent->add_child("Notes")->add_child_text (notes);
-
+       KDMRecipient::as_xml (parent);
        BOOST_FOREACH (TrustedDevice i, trusted_devices) {
                parent->add_child("TrustedDevice")->add_child_text(i.as_string());
        }
index a564f1ed30b23b4fae242030454bb06c4b69ab31..013afff856627f43bfd477921418c0b6dfde67cc 100644 (file)
@@ -22,6 +22,7 @@
 #define DCPOMATIC_SCREEN_H
 
 #include "kdm_with_metadata.h"
+#include "kdm_recipient.h"
 #include "trusted_device.h"
 #include <dcp/certificate.h>
 #include <libcxml/cxml.h>
@@ -40,14 +41,12 @@ namespace dcpomatic {
  *  `recipient' (i.e. the mediablock) and the certificates/thumbprints
  *  of any trusted devices.
  */
-class Screen
+class Screen : public KDMRecipient
 {
 public:
-       Screen (std::string const & na, std::string const & no, boost::optional<dcp::Certificate> rec, std::vector<TrustedDevice> td)
-               : name (na)
-               , notes (no)
-               , recipient (rec)
-               , trusted_devices (td)
+       Screen (std::string const & name_, std::string const & notes_, boost::optional<dcp::Certificate> recipient_, std::vector<TrustedDevice> trusted_devices_)
+               : KDMRecipient (name_, notes_, recipient_)
+               , trusted_devices (trusted_devices_)
        {}
 
        explicit Screen (cxml::ConstNodePtr);
@@ -56,9 +55,6 @@ public:
        std::vector<std::string> trusted_device_thumbprints () const;
 
        boost::shared_ptr<Cinema> cinema;
-       std::string name;
-       std::string notes;
-       boost::optional<dcp::Certificate> recipient;
        std::vector<TrustedDevice> trusted_devices;
 };
 
index 508e5f990e0a2c4785862cbc0c6534ce4bcf32ce..828f0290bea339ec5b6d6e9c3a6c7b8a325034e4 100644 (file)
@@ -125,6 +125,7 @@ sources = """
           j2k_encoder.cc
           json_server.cc
           kdm_with_metadata.cc
+          kdm_recipient.cc
           lock_file_checker.cc
           log.cc
           log_entry.cc