X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=src%2Flib%2Fscreen.cc;h=fe62a5e6cdd9841394e03760601aea466f80065c;hb=e0b2ef3dbac6fc4900cad6fea4395c212578602b;hp=347e1d655a76aae7fc954bb4d7b69e7ec344b488;hpb=c2a97b6f83a32483817d02194a1e7c8d6828b0bb;p=dcpomatic.git diff --git a/src/lib/screen.cc b/src/lib/screen.cc index 347e1d655..fe62a5e6c 100644 --- a/src/lib/screen.cc +++ b/src/lib/screen.cc @@ -1,30 +1,48 @@ /* - 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")) { - certificate = dcp::Certificate (node->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()))); + } else { + trusted_devices.push_back (TrustedDevice(i->content())); + } } } @@ -32,7 +50,55 @@ void Screen::as_xml (xmlpp::Element* parent) const { parent->add_child("Name")->add_child_text (name); - if (certificate) { - parent->add_child("Certificate")->add_child_text (certificate->certificate (true)); + if (recipient) { + parent->add_child("Recipient")->add_child_text (recipient->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; }