/* Copyright (C) 2013-2021 Carl Hetherington 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 . */ #include "cinema.h" #include "config.h" #include "film.h" #include "kdm_util.h" #include "kdm_with_metadata.h" #include "screen.h" #include #include #include using std::list; using std::make_shared; using std::shared_ptr; using std::string; using std::vector; using boost::optional; using namespace dcpomatic; Screen::Screen (cxml::ConstNodePtr node) : KDMRecipient (node) { for (auto i: node->node_children ("TrustedDevice")) { if (boost::algorithm::starts_with(i->content(), "-----BEGIN CERTIFICATE-----")) { trusted_devices.push_back (TrustedDevice(dcp::Certificate(i->content()))); } else { trusted_devices.push_back (TrustedDevice(i->content())); } } } void Screen::as_xml (xmlpp::Element* parent) const { KDMRecipient::as_xml (parent); for (auto i: trusted_devices) { cxml::add_text_child(parent, "TrustedDevice", i.as_string()); } } vector Screen::trusted_device_thumbprints () const { vector t; for (auto i: trusted_devices) { t.push_back (i.thumbprint()); } return t; } KDMWithMetadataPtr kdm_for_screen ( std::function make_kdm, shared_ptr screen, dcp::LocalTime valid_from, dcp::LocalTime valid_to, dcp::Formulation formulation, bool disable_forensic_marking_picture, optional disable_forensic_marking_audio, vector& period_checks ) { if (!screen->recipient) { return {}; } auto cinema = screen->cinema; period_checks.push_back(check_kdm_and_certificate_validity_periods(cinema ? cinema->name : "", screen->name, screen->recipient.get(), valid_from, valid_to)); auto signer = Config::instance()->signer_chain(); if (!signer->valid()) { throw InvalidSignerError(); } auto kdm = make_kdm(valid_from, valid_to).encrypt( signer, screen->recipient.get(), screen->trusted_device_thumbprints(), formulation, disable_forensic_marking_picture, disable_forensic_marking_audio ); dcp::NameFormat::Map name_values; if (cinema) { name_values['c'] = cinema->name; } else { name_values['c'] = ""; } name_values['s'] = screen->name; name_values['f'] = kdm.content_title_text(); name_values['b'] = valid_from.date() + " " + valid_from.time_of_day(true, false); name_values['e'] = valid_to.date() + " " + valid_to.time_of_day(true, false); name_values['i'] = kdm.cpl_id(); return make_shared(name_values, cinema.get(), cinema ? cinema->emails : vector(), kdm); }