Fix build on Centos 6.
[dcpomatic.git] / src / wx / recreate_chain_dialog.cc
1 /*
2     Copyright (C) 2018 Carl Hetherington <cth@carlh.net>
3
4     This file is part of DCP-o-matic.
5
6     DCP-o-matic is free software; you can redistribute it and/or modify
7     it under the terms of the GNU General Public License as published by
8     the Free Software Foundation; either version 2 of the License, or
9     (at your option) any later version.
10
11     DCP-o-matic is distributed in the hope that it will be useful,
12     but WITHOUT ANY WARRANTY; without even the implied warranty of
13     MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
14     GNU General Public License for more details.
15
16     You should have received a copy of the GNU General Public License
17     along with DCP-o-matic.  If not, see <http://www.gnu.org/licenses/>.
18
19 */
20
21 #include "recreate_chain_dialog.h"
22 #include "wx_util.h"
23 #include "static_text.h"
24 #include "check_box.h"
25 #include "lib/config.h"
26 #include "lib/cinema_kdms.h"
27 #include <boost/foreach.hpp>
28
29 using std::list;
30 using std::string;
31 #if BOOST_VERSION >= 106100
32 using namespace boost::placeholders;
33 #endif
34
35 RecreateChainDialog::RecreateChainDialog (wxWindow* parent, Config::BadSignerChainReason reason)
36         : QuestionDialog (parent, _("Certificate chain"), _("Recreate signing certificates"), _("Do nothing"))
37         , _reason (reason)
38 {
39         wxString message;
40         if (_reason & Config::BAD_SIGNER_CHAIN_VALIDITY_TOO_LONG) {
41                 message = _("The certificate chain that DCP-o-matic uses for signing DCPs and KDMs has a validity period\n"
42                             "that is too long.  This will cause problems playing back DCPs on some systems.\n"
43                             "Do you want to re-create the certificate chain for signing DCPs and KDMs?");
44         } else {
45                 message = _("The certificate chain that DCP-o-matic uses for signing DCPs and KDMs contains a small error\n"
46                             "which will prevent DCPs from being validated correctly on some systems.  Do you want to re-create\n"
47                             "the certificate chain for signing DCPs and KDMs?");
48         }
49
50         _sizer->Add (new StaticText (this, message), 1, wxEXPAND | wxALL, DCPOMATIC_DIALOG_BORDER);
51
52         wxCheckBox* shut_up = new CheckBox (this, _("Don't ask this again"));
53         _sizer->Add (shut_up, 0, wxALL, DCPOMATIC_DIALOG_BORDER);
54
55         shut_up->Bind (wxEVT_CHECKBOX, bind (&RecreateChainDialog::shut_up, this, _1));
56
57         layout ();
58 }
59
60 void
61 RecreateChainDialog::shut_up (wxCommandEvent& ev)
62 {
63         if (_reason & Config::BAD_SIGNER_CHAIN_VALIDITY_TOO_LONG) {
64                 Config::instance()->set_nagged (Config::NAG_BAD_SIGNER_CHAIN_VALIDITY_TOO_LONG, ev.IsChecked());
65         } else {
66                 Config::instance()->set_nagged (Config::NAG_BAD_SIGNER_CHAIN_UTF8_STRINGS, ev.IsChecked());
67         }
68 }
69