• Skip to content
  • Skip to link menu
KDE API Reference
  • KDE API Reference
  • kdepim API Reference
  • KDE Home
  • Contact Us
 

kleopatra

  • sources
  • kde-4.12
  • kdepim
  • kleopatra
  • commands
commands/signencryptfilescommand.cpp
Go to the documentation of this file.
1 /* -*- mode: c++; c-basic-offset:4 -*-
2  commands/signencryptfilescommand.cpp
3 
4  This file is part of Kleopatra, the KDE keymanager
5  Copyright (c) 2008 Klarälvdalens Datakonsult AB
6 
7  Kleopatra is free software; you can redistribute it and/or modify
8  it under the terms of the GNU General Public License as published by
9  the Free Software Foundation; either version 2 of the License, or
10  (at your option) any later version.
11 
12  Kleopatra is distributed in the hope that it will be useful,
13  but WITHOUT ANY WARRANTY; without even the implied warranty of
14  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
15  General Public License for more details.
16 
17  You should have received a copy of the GNU General Public License
18  along with this program; if not, write to the Free Software
19  Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
20 
21  In addition, as a special exception, the copyright holders give
22  permission to link the code of this program with any edition of
23  the Qt library by Trolltech AS, Norway (or with modified versions
24  of Qt that use the same license as Qt), and distribute linked
25  combinations including the two. You must obey the GNU General
26  Public License in all respects for all of the code used other than
27  Qt. If you modify this file, you may extend this exception to
28  your version of the file, but you are not obligated to do so. If
29  you do not wish to do so, delete this exception statement from
30  your version.
31 */
32 
33 #include <config-kleopatra.h>
34 
35 #include "signencryptfilescommand.h"
36 
37 #include "command_p.h"
38 
39 #include <crypto/signencryptfilescontroller.h>
40 
41 #include <utils/filedialog.h>
42 
43 #include <kleo/stl_util.h>
44 
45 #include <KLocale>
46 #include <KMessageBox>
47 #include <kdebug.h>
48 
49 #include <QStringList>
50 
51 #include <exception>
52 
53 using namespace Kleo;
54 using namespace Kleo::Commands;
55 using namespace Kleo::Crypto;
56 using namespace boost;
57 
58 class SignEncryptFilesCommand::Private : public Command::Private {
59  friend class ::Kleo::Commands::SignEncryptFilesCommand;
60  SignEncryptFilesCommand * q_func() const { return static_cast<SignEncryptFilesCommand*>( q ); }
61 public:
62  explicit Private( SignEncryptFilesCommand * qq, KeyListController * c );
63  ~Private();
64 
65  QStringList selectFiles() const;
66 
67  void init();
68 
69 private:
70  void slotControllerDone() {
71  finished();
72  }
73  void slotControllerError( int, const QString & ) {
74  finished();
75  }
76 
77 private:
78  QStringList files;
79  shared_ptr<const ExecutionContext> shared_qq;
80  SignEncryptFilesController controller;
81 };
82 
83 
84 SignEncryptFilesCommand::Private * SignEncryptFilesCommand::d_func() { return static_cast<Private*>( d.get() ); }
85 const SignEncryptFilesCommand::Private * SignEncryptFilesCommand::d_func() const { return static_cast<const Private*>( d.get() ); }
86 
87 #define d d_func()
88 #define q q_func()
89 
90 SignEncryptFilesCommand::Private::Private( SignEncryptFilesCommand * qq, KeyListController * c )
91  : Command::Private( qq, c ),
92  files(),
93  shared_qq( qq, kdtools::nodelete() ),
94  controller()
95 {
96  controller.setOperationMode( SignEncryptFilesController::SignAllowed | SignEncryptFilesController::EncryptAllowed | SignEncryptFilesController::ArchiveAllowed );
97 }
98 
99 SignEncryptFilesCommand::Private::~Private() { kDebug(); }
100 
101 SignEncryptFilesCommand::SignEncryptFilesCommand( KeyListController * c )
102  : Command( new Private( this, c ) )
103 {
104  d->init();
105 }
106 
107 SignEncryptFilesCommand::SignEncryptFilesCommand( QAbstractItemView * v, KeyListController * c )
108  : Command( v, new Private( this, c ) )
109 {
110  d->init();
111 }
112 
113 SignEncryptFilesCommand::SignEncryptFilesCommand( const QStringList & files, KeyListController * c )
114  : Command( new Private( this, c ) )
115 {
116  d->init();
117  d->files = files;
118 }
119 
120 SignEncryptFilesCommand::SignEncryptFilesCommand( const QStringList & files, QAbstractItemView * v, KeyListController * c )
121  : Command( v, new Private( this, c ) )
122 {
123  d->init();
124  d->files = files;
125 }
126 
127 void SignEncryptFilesCommand::Private::init() {
128  controller.setExecutionContext( shared_qq );
129  connect( &controller, SIGNAL(done()), q, SLOT(slotControllerDone()) );
130  connect( &controller, SIGNAL(error(int,QString)), q, SLOT(slotControllerError(int,QString)) );
131 }
132 
133 SignEncryptFilesCommand::~SignEncryptFilesCommand() { kDebug(); }
134 
135 void SignEncryptFilesCommand::setFiles( const QStringList & files ) {
136  d->files = files;
137 }
138 
139 void SignEncryptFilesCommand::setSigningPolicy( Policy policy ) {
140  unsigned int mode = d->controller.operationMode();
141  mode &= ~SignEncryptFilesController::SignMask;
142  switch ( policy ) {
143  case NoPolicy:
144  case Allow:
145  mode |= SignEncryptFilesController::SignAllowed ;
146  break;
147  case Deny:
148  mode |= SignEncryptFilesController::SignDisallowed ;
149  break;
150  case Force:
151  mode |= SignEncryptFilesController::SignForced ;
152  break;
153  }
154  try {
155  d->controller.setOperationMode( mode );
156  } catch ( ... ) {}
157 }
158 
159 Policy SignEncryptFilesCommand::signingPolicy() const {
160  const unsigned int mode = d->controller.operationMode();
161  switch ( mode & SignEncryptFilesController::SignMask ) {
162  default:
163  assert( !"This should not happen!" );
164  return NoPolicy;
165  case SignEncryptFilesController::SignAllowed:
166  return Allow;
167  case SignEncryptFilesController::SignForced:
168  return Force;
169  case SignEncryptFilesController::SignDisallowed:
170  return Deny;
171  }
172 }
173 
174 void SignEncryptFilesCommand::setEncryptionPolicy( Policy policy ) {
175  unsigned int mode = d->controller.operationMode();
176  mode &= ~SignEncryptFilesController::EncryptMask;
177  switch ( policy ) {
178  case NoPolicy:
179  case Allow:
180  mode |= SignEncryptFilesController::EncryptAllowed ;
181  break;
182  case Deny:
183  mode |= SignEncryptFilesController::EncryptDisallowed ;
184  break;
185  case Force:
186  mode |= SignEncryptFilesController::EncryptForced ;
187  break;
188  }
189  try {
190  d->controller.setOperationMode( mode );
191  } catch ( ... ) {}
192 }
193 
194 Policy SignEncryptFilesCommand::encryptionPolicy() const {
195  const unsigned int mode = d->controller.operationMode();
196  switch ( mode & SignEncryptFilesController::EncryptMask ) {
197  default:
198  assert( !"This should not happen!" );
199  return NoPolicy;
200  case SignEncryptFilesController::EncryptAllowed:
201  return Allow;
202  case SignEncryptFilesController::EncryptForced:
203  return Force;
204  case SignEncryptFilesController::EncryptDisallowed:
205  return Deny;
206  }
207 }
208 
209 void SignEncryptFilesCommand::setProtocol( GpgME::Protocol proto ) {
210  d->controller.setProtocol( proto );
211 }
212 
213 GpgME::Protocol SignEncryptFilesCommand::protocol() const {
214  return d->controller.protocol();
215 }
216 
217 void SignEncryptFilesCommand::doStart() {
218 
219  try {
220 
221  if ( d->files.empty() )
222  d->files = d->selectFiles();
223  if ( d->files.empty() ) {
224  d->finished();
225  return;
226  }
227 
228  d->controller.setFiles( d->files );
229  d->controller.start();
230 
231  } catch ( const std::exception & e ) {
232  d->information( i18n("An error occurred: %1",
233  QString::fromLocal8Bit( e.what() ) ),
234  i18n("Sign/Encrypt Files Error") );
235  d->finished();
236  }
237 }
238 
239 void SignEncryptFilesCommand::doCancel() {
240  kDebug();
241  d->controller.cancel();
242 }
243 
244 QStringList SignEncryptFilesCommand::Private::selectFiles() const {
245  return FileDialog::getOpenFileNames( parentWidgetOrView(), i18n( "Select One or More Files to Sign and/or Encrypt" ), QLatin1String("enc") );
246 }
247 
248 #undef d
249 #undef q
250 
251 #include "moc_signencryptfilescommand.cpp"
d
#define d
Definition: commands/signencryptfilescommand.cpp:87
Kleo::Force
Definition: types.h:61
Kleo::Command::Private
Definition: commands/command_p.h:52
Kleo::Deny
Definition: types.h:62
Kleo::KeyListController
Definition: keylistcontroller.h:55
Kleo::Policy
Policy
Definition: types.h:58
Kleo::Allow
Definition: types.h:60
Kleo::Command::d
kdtools::pimpl_ptr< Private > d
Definition: commands/command.h:129
Kleo::Command::Private::q
Command *const q
Definition: commands/command_p.h:55
boost::shared_ptr
Definition: encryptemailcontroller.h:51
Kleo::Commands::SignEncryptFilesCommand::SignEncryptFilesCommand
SignEncryptFilesCommand(QAbstractItemView *view, KeyListController *parent)
Definition: commands/signencryptfilescommand.cpp:107
signencryptfilescontroller.h
Kleo::FileDialog::getOpenFileNames
QStringList getOpenFileNames(QWidget *parent=0, const QString &caption=QString(), const QString &dirID=QString(), const QString &filter=QString())
Definition: filedialog.cpp:115
command_p.h
Kleo::Command::Private::controller
KeyListController * controller() const
Definition: commands/command_p.h:63
Kleo::NoPolicy
Definition: types.h:59
signencryptfilescommand.h
Kleo::Command::Private::finished
void finished()
Definition: commands/command_p.h:72
q
#define q
Definition: commands/signencryptfilescommand.cpp:88
Kleo::Command::Private::information
void information(const QString &text, const QString &caption=QString(), const QString &dontShowAgainName=QString(), KMessageBox::Options options=KMessageBox::Notify) const
Definition: commands/command_p.h:89
Kleo::Crypto::SignEncryptFilesController
Definition: signencryptfilescontroller.h:50
Kleo::Commands::SignEncryptFilesCommand
Definition: commands/signencryptfilescommand.h:47
Kleo::Command::Private::Private
Private(Command *qq, KeyListController *controller)
Definition: commands/command.cpp:48
Kleo::Command
Definition: commands/command.h:58
Kleo::SignEncryptFilesCommand::~SignEncryptFilesCommand
virtual ~SignEncryptFilesCommand()
Definition: uiserver/signencryptfilescommand.cpp:77
Kleo::Command::Private::error
void error(const QString &text, const QString &caption=QString(), KMessageBox::Options options=KMessageBox::Notify) const
Definition: commands/command_p.h:83
filedialog.h
This file is part of the KDE documentation.
Documentation copyright © 1996-2014 The KDE developers.
Generated on Tue Oct 14 2014 22:56:42 by doxygen 1.8.7 written by Dimitri van Heesch, © 1997-2006

KDE's Doxygen guidelines are available online.

kleopatra

Skip menu "kleopatra"
  • Main Page
  • Namespace List
  • Namespace Members
  • Alphabetical List
  • Class List
  • Class Hierarchy
  • Class Members
  • File List
  • File Members

kdepim API Reference

Skip menu "kdepim API Reference"
  • akonadi_next
  • akregator
  • blogilo
  • calendarsupport
  • console
  •   kabcclient
  •   konsolekalendar
  • kaddressbook
  • kalarm
  •   lib
  • kdgantt2
  • kjots
  • kleopatra
  • kmail
  • knode
  • knotes
  • kontact
  • korgac
  • korganizer
  • ktimetracker
  • libkdepim
  • libkleo
  • libkpgp
  • mailcommon
  • messagelist
  • messageviewer

Search



Report problems with this website to our bug tracking system.
Contact the specific authors with questions and comments about the page contents.

KDE® and the K Desktop Environment® logo are registered trademarks of KDE e.V. | Legal