summaryrefslogtreecommitdiffstats
path: root/gpglib/export.c
diff options
context:
space:
mode:
authorSam Varshavchik2013-08-19 16:39:41 -0400
committerSam Varshavchik2013-08-25 14:43:51 -0400
commit9c45d9ad13fdf439d44d7443ae75da15ea0223ed (patch)
tree7a81a04cb51efb078ee350859a64be2ebc6b8813 /gpglib/export.c
parenta9520698b770168d1f33d6301463bb70a19655ec (diff)
downloadcourier-libs-9c45d9ad13fdf439d44d7443ae75da15ea0223ed.tar.bz2
Initial checkin
Imported from subversion report, converted to git. Updated all paths in scripts and makefiles, reflecting the new directory hierarchy.
Diffstat (limited to 'gpglib/export.c')
-rw-r--r--gpglib/export.c64
1 files changed, 64 insertions, 0 deletions
diff --git a/gpglib/export.c b/gpglib/export.c
new file mode 100644
index 0000000..66a4a05
--- /dev/null
+++ b/gpglib/export.c
@@ -0,0 +1,64 @@
+/*
+** Copyright 2001-2003 Double Precision, Inc. See COPYING for
+** distribution information.
+*/
+
+
+#include "config.h"
+#include <stdio.h>
+#include <stdlib.h>
+#include <string.h>
+#include <unistd.h>
+#include <signal.h>
+#include <errno.h>
+#include <sys/types.h>
+#include <sys/stat.h>
+#include <sys/time.h>
+
+#include "gpg.h"
+#include "gpglib.h"
+
+#include "unicode/unicode.h"
+#include "numlib/numlib.h"
+
+extern int libmail_gpg_stdin, libmail_gpg_stdout, libmail_gpg_stderr;
+extern pid_t libmail_gpg_pid;
+
+/*
+** List keys
+*/
+
+int libmail_gpg_exportkey(const char *gpgdir,
+ int secret,
+ const char *fingerprint,
+ int (*out_func)(const char *, size_t, void *),
+ int (*err_func)(const char *, size_t, void *),
+ void *voidarg)
+{
+ char *argvec[6];
+ int rc;
+
+ argvec[0]="gpg";
+ argvec[1]="--armor";
+ argvec[2]="--no-tty";
+ argvec[3]= secret ? "--export-secret-keys":"--export";
+ argvec[4]=(char *)fingerprint;
+ argvec[5]=0;
+
+ if (libmail_gpg_fork(&libmail_gpg_stdin, &libmail_gpg_stdout,
+ &libmail_gpg_stderr, gpgdir, argvec) < 0)
+ rc= -1;
+ else
+ {
+ int rc2;
+
+ close(libmail_gpg_stdin);
+ libmail_gpg_stdin=-1;
+
+ rc=libmail_gpg_read(out_func, err_func, NULL, 0, voidarg);
+ rc2=libmail_gpg_cleanup();
+ if (rc2)
+ rc=rc2;
+ }
+ return (rc);
+}