mirror of
git://git.gnupg.org/gnupg.git
synced 2025-01-05 12:31:50 +01:00
2002-09-03 Neal H. Walfield <neal@g10code.de>
* findkey.c: Include <fcntl.h>. (agent_write_private_key): Prefer POSIX compatibity, open and fdopen, over the simplicity of GNU extensions, fopen(file, "x").
This commit is contained in:
parent
f27e05f3aa
commit
712af9e3ca
@ -1,3 +1,9 @@
|
|||||||
|
2002-09-03 Neal H. Walfield <neal@g10code.de>
|
||||||
|
|
||||||
|
* findkey.c: Include <fcntl.h>.
|
||||||
|
(agent_write_private_key): Prefer POSIX compatibity, open and
|
||||||
|
fdopen, over the simplicity of GNU extensions, fopen(file, "x").
|
||||||
|
|
||||||
2002-08-22 Werner Koch <wk@gnupg.org>
|
2002-08-22 Werner Koch <wk@gnupg.org>
|
||||||
|
|
||||||
* query.c (agent_askpin): Provide the default desc text depending
|
* query.c (agent_askpin): Provide the default desc text depending
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/* findkey.c - locate the secret key
|
/* findkey.c - locate the secret key
|
||||||
* Copyright (C) 2001 Free Software Foundation, Inc.
|
* Copyright (C) 2001,02 Free Software Foundation, Inc.
|
||||||
*
|
*
|
||||||
* This file is part of GnuPG.
|
* This file is part of GnuPG.
|
||||||
*
|
*
|
||||||
@ -24,6 +24,7 @@
|
|||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include <ctype.h>
|
#include <ctype.h>
|
||||||
|
#include <fcntl.h>
|
||||||
#include <assert.h>
|
#include <assert.h>
|
||||||
#include <unistd.h>
|
#include <unistd.h>
|
||||||
#include <sys/stat.h>
|
#include <sys/stat.h>
|
||||||
@ -57,15 +58,33 @@ agent_write_private_key (const unsigned char *grip,
|
|||||||
fp = fopen (fname, "wb");
|
fp = fopen (fname, "wb");
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
int fd;
|
||||||
|
|
||||||
if (!access (fname, F_OK))
|
if (!access (fname, F_OK))
|
||||||
{
|
{
|
||||||
log_error ("secret key file `%s' already exists\n", fname);
|
log_error ("secret key file `%s' already exists\n", fname);
|
||||||
xfree (fname);
|
xfree (fname);
|
||||||
return seterr (General_Error);
|
return seterr (General_Error);
|
||||||
}
|
}
|
||||||
fp = fopen (fname, "wbx"); /* FIXME: the x is a GNU extension - let
|
|
||||||
configure check whether this actually
|
/* We would like to create FNAME but only if it does not already
|
||||||
works */
|
exist. We cannot make this guarantee just using POSIX (GNU
|
||||||
|
provides the "x" opentype for fopen, however, this is not
|
||||||
|
portable). Thus, we use the more flexible open function and
|
||||||
|
then use fdopen to obtain a stream.
|
||||||
|
|
||||||
|
The mode parameter to open is what fopen uses. It will be
|
||||||
|
combined with the process' umask automatically. */
|
||||||
|
fd = open (fname, O_CREAT | O_EXCL | O_RDWR,
|
||||||
|
S_IRUSR | S_IWUSR | S_IRGRP | S_IWGRP | S_IROTH | S_IWOTH);
|
||||||
|
if (fd < 0)
|
||||||
|
fp = 0;
|
||||||
|
else
|
||||||
|
{
|
||||||
|
fp = fdopen (fd, "wb");
|
||||||
|
if (! fp)
|
||||||
|
close (fd);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!fp)
|
if (!fp)
|
||||||
|
Loading…
x
Reference in New Issue
Block a user