summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorCarl Hetherington <cth@carlh.net>2020-04-30 01:06:13 +0200
committerCarl Hetherington <cth@carlh.net>2020-05-03 23:28:31 +0200
commit4b87e8c5292953ab7d717630f6e4ed9884bb5a2a (patch)
treee6b22fd52abffdc1fb5d17e1b7b80c7d9a835957
parentb0c11dce0d5a37122d7a1126a330ff7f16f8c9bb (diff)
Derive Screen from a new class KDMRecipient.
-rw-r--r--src/lib/kdm_recipient.cc45
-rw-r--r--src/lib/kdm_recipient.h43
-rw-r--r--src/lib/screen.cc17
-rw-r--r--src/lib/screen.h14
-rw-r--r--src/lib/wscript1
5 files changed, 96 insertions, 24 deletions
diff --git a/src/lib/kdm_recipient.cc b/src/lib/kdm_recipient.cc
new file mode 100644
index 000000000..d05192ac6
--- /dev/null
+++ b/src/lib/kdm_recipient.cc
@@ -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
index 000000000..ee4e8c39c
--- /dev/null
+++ b/src/lib/kdm_recipient.h
@@ -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;
+};
diff --git a/src/lib/screen.cc b/src/lib/screen.cc
index 2453e1eaf..ea23ba39a 100644
--- a/src/lib/screen.cc
+++ b/src/lib/screen.cc
@@ -28,15 +28,8 @@ using std::vector;
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())));
@@ -49,13 +42,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());
}
diff --git a/src/lib/screen.h b/src/lib/screen.h
index abc229ec6..8eb7b4161 100644
--- a/src/lib/screen.h
+++ b/src/lib/screen.h
@@ -21,6 +21,7 @@
#ifndef DCPOMATIC_SCREEN_H
#define DCPOMATIC_SCREEN_H
+#include "kdm_recipient.h"
#include "trusted_device.h"
#include <dcp/certificate.h>
#include <libcxml/cxml.h>
@@ -38,14 +39,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);
@@ -54,9 +53,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;
};
diff --git a/src/lib/wscript b/src/lib/wscript
index f8f251cf1..4c16d0df3 100644
--- a/src/lib/wscript
+++ b/src/lib/wscript
@@ -125,6 +125,7 @@ sources = """
job_manager.cc
j2k_encoder.cc
json_server.cc
+ kdm_recipient.cc
lock_file_checker.cc
log.cc
log_entry.cc