X-Git-Url: https://git.carlh.net/gitweb/?a=blobdiff_plain;f=src%2Flib%2Fscreen.cc;h=fe62a5e6cdd9841394e03760601aea466f80065c;hb=f41818f14369f170475b7f2bde1a2dd856517b14;hp=159c4326bc5b08e7e4ad26af87cffd7f54391efe;hpb=e170d9908c191180aefe71ff7cfa81a5ba08ed83;p=dcpomatic.git diff --git a/src/lib/screen.cc b/src/lib/screen.cc index 159c4326b..fe62a5e6c 100644 --- a/src/lib/screen.cc +++ b/src/lib/screen.cc @@ -1,28 +1,35 @@ /* - Copyright (C) 2013-2015 Carl Hetherington + Copyright (C) 2013-2016 Carl Hetherington - This program is free software; you can redistribute it and/or modify + 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. - This program is distributed in the hope that it will be useful, + 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 this program; if not, write to the Free Software - Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. + along with DCP-o-matic. If not, see . */ #include "screen.h" #include #include +#include + +using std::string; +using std::vector; +using namespace dcpomatic; Screen::Screen (cxml::ConstNodePtr node) - : name (node->string_child ("Name")) + : 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")); @@ -31,7 +38,11 @@ Screen::Screen (cxml::ConstNodePtr node) } BOOST_FOREACH (cxml::ConstNodePtr i, node->node_children ("TrustedDevice")) { - trusted_devices.push_back (dcp::Certificate (i->content ())); + 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())); + } } } @@ -43,7 +54,51 @@ Screen::as_xml (xmlpp::Element* parent) const parent->add_child("Recipient")->add_child_text (recipient->certificate (true)); } - BOOST_FOREACH (dcp::Certificate const & i, trusted_devices) { - parent->add_child("TrustedDevice")->add_child_text (i.certificate (true)); + parent->add_child("Notes")->add_child_text (notes); + + BOOST_FOREACH (TrustedDevice i, trusted_devices) { + parent->add_child("TrustedDevice")->add_child_text(i.as_string()); + } +} + +vector +Screen::trusted_device_thumbprints () const +{ + vector t; + BOOST_FOREACH (TrustedDevice i, trusted_devices) { + t.push_back (i.thumbprint()); } + return t; +} + +TrustedDevice::TrustedDevice (string thumbprint) + : _thumbprint (thumbprint) +{ + +} + +TrustedDevice::TrustedDevice (dcp::Certificate certificate) + : _certificate (certificate) +{ + +} + +string +TrustedDevice::as_string () const +{ + if (_certificate) { + return _certificate->certificate(true); + } + + return *_thumbprint; +} + +string +TrustedDevice::thumbprint () const +{ + if (_certificate) { + return _certificate->thumbprint (); + } + + return *_thumbprint; }