mirror of
git://git.gnupg.org/gnupg.git
synced 2024-12-23 10:29:58 +01:00
3032fc3ad7
* agent/call-scd.c (start_scd): Replace int by assuan_fd_t. (start_pinentry): Ditto. * common/asshelp.c (start_new_gpg_agent): Replace int by assuan_fd_t. * common/dotlock.c (GNUPG_MAJOR_VERSION): Include stringhelp.h for prototypes on Windows and some other platforms. * common/logging.c (fun_writer): Declare addrbuf only if needed. * g10/decrypt.c (decrypt_message_fd) [W32]: Return not_implemented. * g10/encrypt.c (encrypt_crypt) [W32]: Return error if used in server mode. * g10/dearmor.c (dearmor_file, enarmor_file): Replace GNUPG_INVALID_FD by -1 as temporary hack for Windows. * g10/export.c (do_export): Ditto. * g10/revoke.c (gen_desig_revoke, gen_revoke): Ditto. * g10/sign.c (sign_file, clearsign_file, sign_symencrypt_file): Ditto. * g10/server.c (cmd_verify, gpg_server) [W32]: Return an error. -- The gpg server mode is not actual working and thus we can avoid the warnings by explicitly disabling the mode. We keep it working under Unix, though.
133 lines
2.9 KiB
C
133 lines
2.9 KiB
C
/* dearmor.c - Armor utility
|
|
* Copyright (C) 1998, 1999, 2000, 2001 Free Software Foundation, Inc.
|
|
*
|
|
* This file is part of GnuPG.
|
|
*
|
|
* GnuPG is free software; you can redistribute it and/or modify
|
|
* it under the terms of the GNU General Public License as published by
|
|
* the Free Software Foundation; either version 3 of the License, or
|
|
* (at your option) any later version.
|
|
*
|
|
* GnuPG is distributed in the hope that it will be useful,
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
* GNU General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU General Public License
|
|
* along with this program; if not, see <http://www.gnu.org/licenses/>.
|
|
*/
|
|
|
|
#include <config.h>
|
|
#include <stdio.h>
|
|
#include <stdlib.h>
|
|
#include <string.h>
|
|
#include <errno.h>
|
|
#include <assert.h>
|
|
|
|
#include "gpg.h"
|
|
#include "status.h"
|
|
#include "iobuf.h"
|
|
#include "util.h"
|
|
#include "filter.h"
|
|
#include "packet.h"
|
|
#include "options.h"
|
|
#include "main.h"
|
|
#include "i18n.h"
|
|
|
|
/****************
|
|
* Take an armor file and write it out without armor
|
|
*/
|
|
int
|
|
dearmor_file( const char *fname )
|
|
{
|
|
armor_filter_context_t *afx;
|
|
IOBUF inp = NULL, out = NULL;
|
|
int rc = 0;
|
|
int c;
|
|
|
|
afx = new_armor_context ();
|
|
|
|
/* prepare iobufs */
|
|
inp = iobuf_open(fname);
|
|
if (inp && is_secured_file (iobuf_get_fd (inp)))
|
|
{
|
|
iobuf_close (inp);
|
|
inp = NULL;
|
|
gpg_err_set_errno (EPERM);
|
|
}
|
|
if (!inp) {
|
|
rc = gpg_error_from_syserror ();
|
|
log_error(_("can't open '%s': %s\n"), fname? fname: "[stdin]",
|
|
strerror(errno) );
|
|
goto leave;
|
|
}
|
|
|
|
push_armor_filter ( afx, inp );
|
|
|
|
if( (rc = open_outfile (-1, fname, 0, &out )) )
|
|
goto leave;
|
|
|
|
while( (c = iobuf_get(inp)) != -1 )
|
|
iobuf_put( out, c );
|
|
|
|
leave:
|
|
if( rc )
|
|
iobuf_cancel(out);
|
|
else
|
|
iobuf_close(out);
|
|
iobuf_close(inp);
|
|
release_armor_context (afx);
|
|
return rc;
|
|
}
|
|
|
|
|
|
/****************
|
|
* Take file and write it out with armor
|
|
*/
|
|
int
|
|
enarmor_file( const char *fname )
|
|
{
|
|
armor_filter_context_t *afx;
|
|
IOBUF inp = NULL, out = NULL;
|
|
int rc = 0;
|
|
int c;
|
|
|
|
afx = new_armor_context ();
|
|
|
|
/* prepare iobufs */
|
|
inp = iobuf_open(fname);
|
|
if (inp && is_secured_file (iobuf_get_fd (inp)))
|
|
{
|
|
iobuf_close (inp);
|
|
inp = NULL;
|
|
gpg_err_set_errno (EPERM);
|
|
}
|
|
if (!inp) {
|
|
rc = gpg_error_from_syserror ();
|
|
log_error(_("can't open '%s': %s\n"), fname? fname: "[stdin]",
|
|
strerror(errno) );
|
|
goto leave;
|
|
}
|
|
|
|
|
|
if( (rc = open_outfile (-1, fname, 1, &out )) )
|
|
goto leave;
|
|
|
|
afx->what = 4;
|
|
afx->hdrlines = "Comment: Use \"gpg --dearmor\" for unpacking\n";
|
|
push_armor_filter ( afx, out );
|
|
|
|
while( (c = iobuf_get(inp)) != -1 )
|
|
iobuf_put( out, c );
|
|
|
|
|
|
leave:
|
|
if( rc )
|
|
iobuf_cancel(out);
|
|
else
|
|
iobuf_close(out);
|
|
iobuf_close(inp);
|
|
release_armor_context (afx);
|
|
return rc;
|
|
}
|