2004-09-30 Marcus Brinkmann <marcus@g10code.de>
[gpgme.git] / gpgme / export.c
1 /* export.c - Export a key.
2    Copyright (C) 2000 Werner Koch (dd9jn)
3    Copyright (C) 2001, 2002, 2003 g10 Code GmbH
4
5    This file is part of GPGME.
6  
7    GPGME is free software; you can redistribute it and/or modify it
8    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    GPGME is distributed in the hope that it will be useful, but
13    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 GPGME; if not, write to the Free Software Foundation,
19    Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.  */
20
21 #if HAVE_CONFIG_H
22 #include <config.h>
23 #endif
24
25 #include "gpgme.h"
26 #include "context.h"
27 #include "ops.h"
28
29 \f
30 static gpgme_error_t
31 export_status_handler (void *priv, gpgme_status_code_t code, char *args)
32 {
33   return 0;
34 }
35
36
37 static gpgme_error_t
38 export_start (gpgme_ctx_t ctx, int synchronous, const char *pattern,
39               unsigned int reserved, gpgme_data_t keydata)
40 {
41   gpgme_error_t err;
42
43   if (!keydata)
44     return gpg_error (GPG_ERR_INV_VALUE);
45
46   err = _gpgme_op_reset (ctx, synchronous);
47   if (err)
48     return err;
49
50   _gpgme_engine_set_status_handler (ctx->engine, export_status_handler, ctx);
51
52   return _gpgme_engine_op_export (ctx->engine, pattern, reserved, keydata,
53                                   ctx->use_armor);
54 }
55
56
57 /* Export the keys listed in RECP into KEYDATA.  */
58 gpgme_error_t
59 gpgme_op_export_start (gpgme_ctx_t ctx, const char *pattern,
60                        unsigned int reserved, gpgme_data_t keydata)
61 {
62   return export_start (ctx, 0, pattern, reserved, keydata);
63 }
64
65
66 /* Export the keys listed in RECP into KEYDATA.  */
67 gpgme_error_t
68 gpgme_op_export (gpgme_ctx_t ctx, const char *pattern, unsigned int reserved,
69                  gpgme_data_t keydata)
70 {
71   gpgme_error_t err = export_start (ctx, 1, pattern, reserved, keydata);
72   if (!err)
73     err = _gpgme_wait_one (ctx);
74   return err;
75 }
76
77 \f
78 static gpgme_error_t
79 export_ext_start (gpgme_ctx_t ctx, int synchronous, const char *pattern[],
80                   unsigned int reserved, gpgme_data_t keydata)
81 {
82   gpgme_error_t err;
83
84   if (!keydata)
85     return gpg_error (GPG_ERR_INV_VALUE);
86
87   err = _gpgme_op_reset (ctx, synchronous);
88   if (err)
89     return err;
90
91   _gpgme_engine_set_status_handler (ctx->engine, export_status_handler, ctx);
92
93   return _gpgme_engine_op_export_ext (ctx->engine, pattern, reserved, keydata,
94                                       ctx->use_armor);
95 }
96
97
98 /* Export the keys listed in RECP into KEYDATA.  */
99 gpgme_error_t
100 gpgme_op_export_ext_start (gpgme_ctx_t ctx, const char *pattern[],
101                            unsigned int reserved, gpgme_data_t keydata)
102 {
103   return export_ext_start (ctx, 0, pattern, reserved, keydata);
104 }
105
106
107 /* Export the keys listed in RECP into KEYDATA.  */
108 gpgme_error_t
109 gpgme_op_export_ext (gpgme_ctx_t ctx, const char *pattern[],
110                      unsigned int reserved, gpgme_data_t keydata)
111 {
112   gpgme_error_t err = export_ext_start (ctx, 1, pattern, reserved, keydata);
113   if (!err)
114     err = _gpgme_wait_one (ctx);
115   return err;
116 }