diff options
| author | Carl Hetherington <cth@carlh.net> | 2020-04-30 01:06:13 +0200 |
|---|---|---|
| committer | Carl Hetherington <cth@carlh.net> | 2020-05-03 23:28:31 +0200 |
| commit | 4b87e8c5292953ab7d717630f6e4ed9884bb5a2a (patch) | |
| tree | e6b22fd52abffdc1fb5d17e1b7b80c7d9a835957 | |
| parent | b0c11dce0d5a37122d7a1126a330ff7f16f8c9bb (diff) | |
Derive Screen from a new class KDMRecipient.
| -rw-r--r-- | src/lib/kdm_recipient.cc | 45 | ||||
| -rw-r--r-- | src/lib/kdm_recipient.h | 43 | ||||
| -rw-r--r-- | src/lib/screen.cc | 17 | ||||
| -rw-r--r-- | src/lib/screen.h | 14 | ||||
| -rw-r--r-- | src/lib/wscript | 1 |
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 |
