2003-04-25 Marcus Brinkmann <marcus@g10code.de>
[gpgme.git] / gpgme / engine-backend.h
1 /* engine-backend.h -  A crypto backend for the engine interface.
2    Copyright (C) 2002, 2003 g10 Code GmbH
3  
4    This file is part of GPGME.
5  
6    GPGME is free software; you can redistribute it and/or modify it
7    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    GPGME is distributed in the hope that it will be useful, but
12    WITHOUT ANY WARRANTY; without even the implied warranty of
13    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
14    General Public License for more details.
15  
16    You should have received a copy of the GNU General Public License
17    along with GPGME; if not, write to the Free Software Foundation,
18    Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.  */
19
20 #ifndef ENGINE_BACKEND_H
21 #define ENGINE_BACKEND_H
22
23 #include "engine.h"
24
25 /* FIXME: Correct check?  */
26 #ifdef GPGSM_PATH
27 #define ENABLE_GPGSM 1
28 #endif
29
30 struct engine_ops
31 {
32   /* Static functions.  */
33   const char *(*get_file_name) (void);
34   const char *(*get_version) (void);
35   const char *(*get_req_version) (void);
36   GpgmeError (*new) (void **r_engine);
37
38   /* Member functions.  */
39   void (*release) (void *engine);
40   void (*set_status_handler) (void *engine, EngineStatusHandler fnc,
41                               void *fnc_value);
42   GpgmeError (*set_command_handler) (void *engine, EngineCommandHandler fnc,
43                                      void *fnc_value, GpgmeData data);
44   GpgmeError (*set_colon_line_handler) (void *engine,
45                                         EngineColonLineHandler fnc,
46                                         void *fnc_value);
47   GpgmeError (*decrypt) (void *engine, GpgmeData ciph, GpgmeData plain);
48   GpgmeError (*delete) (void *engine, GpgmeKey key, int allow_secret);
49   GpgmeError (*edit) (void *engine, GpgmeKey key, GpgmeData out,
50                          GpgmeCtx ctx /* FIXME */);
51   GpgmeError (*encrypt) (void *engine, GpgmeRecipients recp,
52                             GpgmeData plain, GpgmeData ciph, int use_armor);
53   GpgmeError (*encrypt_sign) (void *engine, GpgmeRecipients recp,
54                                   GpgmeData plain, GpgmeData ciph,
55                                   int use_armor, GpgmeCtx ctx /* FIXME */);
56   GpgmeError (*export) (void *engine, GpgmeRecipients recp,
57                            GpgmeData keydata, int use_armor);
58   GpgmeError (*genkey) (void *engine, GpgmeData help_data, int use_armor,
59                            GpgmeData pubkey, GpgmeData seckey);
60   GpgmeError (*import) (void *engine, GpgmeData keydata);
61   GpgmeError (*keylist) (void *engine, const char *pattern,
62                             int secret_only, int keylist_mode);
63   GpgmeError (*keylist_ext) (void *engine, const char *pattern[],
64                                  int secret_only, int reserved,
65                                 int keylist_mode);
66   GpgmeError (*sign) (void *engine, GpgmeData in, GpgmeData out,
67                          GpgmeSigMode mode, int use_armor, int use_textmode,
68                          int include_certs, GpgmeCtx ctx /* FIXME */);
69   GpgmeError (*trustlist) (void *engine, const char *pattern);
70   GpgmeError (*verify) (void *engine, GpgmeData sig, GpgmeData signed_text,
71                            GpgmeData plaintext);
72   
73   void (*set_io_cbs) (void *engine, struct GpgmeIOCbs *io_cbs);
74   void (*io_event) (void *engine, GpgmeEventIO type, void *type_data);
75 };
76
77
78 extern struct engine_ops _gpgme_engine_ops_gpg;         /* OpenPGP.  */
79 #ifdef ENABLE_GPGSM
80 extern struct engine_ops _gpgme_engine_ops_gpgsm;       /* CMS.  */
81 #endif
82
83 #endif /* ENGINE_BACKEND_H */
84