1 /* keybox-file.c - File operations
2 * Copyright (C) 2001, 2003 Free Software Foundation, Inc.
4 * This file is part of GnuPG.
6 * GnuPG is free software; you can redistribute it and/or modify
7 * it under the terms of the GNU General Public License as published by
8 * the Free Software Foundation; either version 3 of the License, or
9 * (at your option) any later version.
11 * GnuPG is distributed in the hope that it will be useful,
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 * GNU General Public License for more details.
16 * You should have received a copy of the GNU General Public License
17 * along with this program; if not, see <http://www.gnu.org/licenses/>.
27 #include "keybox-defs.h"
30 #if !defined(HAVE_FTELLO) && !defined(ftello)
41 #endif /* !defined(HAVE_FTELLO) && !defined(ftello) */
45 /* Read a block at the current postion and return it in r_blob.
46 r_blob may be NULL to simply skip the current block */
48 _keybox_read_blob2 (KEYBOXBLOB
*r_blob
, FILE *fp
, int *skipped_deleted
)
52 int c1
, c2
, c3
, c4
, type
;
61 return gpg_error_from_syserror ();
63 if ((c1
= getc (fp
)) == EOF
64 || (c2
= getc (fp
)) == EOF
65 || (c3
= getc (fp
)) == EOF
66 || (c4
= getc (fp
)) == EOF
67 || (type
= getc (fp
)) == EOF
)
69 if ( c1
== EOF
&& !ferror (fp
) )
72 return gpg_error (GPG_ERR_TOO_SHORT
);
73 return gpg_error_from_syserror ();
76 imagelen
= (c1
<< 24) | (c2
<< 16) | (c3
<< 8 ) | c4
;
77 if (imagelen
> 500000) /* Sanity check. */
78 return gpg_error (GPG_ERR_TOO_LARGE
);
81 return gpg_error (GPG_ERR_TOO_SHORT
);
85 /* Special treatment for empty blobs. */
86 if (fseek (fp
, imagelen
-5, SEEK_CUR
))
87 return gpg_error_from_syserror ();
92 image
= xtrymalloc (imagelen
);
94 return gpg_error_from_syserror ();
96 image
[0] = c1
; image
[1] = c2
; image
[2] = c3
; image
[3] = c4
; image
[4] = type
;
97 if (fread (image
+5, imagelen
-5, 1, fp
) != 1)
99 gpg_error_t tmperr
= gpg_error_from_syserror ();
104 rc
= r_blob
? _keybox_new_blob (r_blob
, image
, imagelen
, off
) : 0;
111 _keybox_read_blob (KEYBOXBLOB
*r_blob
, FILE *fp
)
114 return _keybox_read_blob2 (r_blob
, fp
, &dummy
);
118 /* Write the block to the current file position */
120 _keybox_write_blob (KEYBOXBLOB blob
, FILE *fp
)
122 const unsigned char *image
;
125 image
= _keybox_get_blob_image (blob
, &length
);
126 if (fwrite (image
, length
, 1, fp
) != 1)
127 return gpg_error_from_syserror ();
132 /* Write a fresh header type blob. */
134 _keybox_write_header_blob (FILE *fp
)
136 unsigned char image
[32];
139 memset (image
, 0, sizeof image
);
140 /* Length of this blob. */
143 image
[4] = BLOBTYPE_HEADER
;
144 image
[5] = 1; /* Version */
146 memcpy (image
+8, "KBXf", 4);
148 /* created_at and last maintenance run. */
149 image
[16] = (val
>> 24);
150 image
[16+1] = (val
>> 16);
151 image
[16+2] = (val
>> 8);
152 image
[16+3] = (val
);
153 image
[20] = (val
>> 24);
154 image
[20+1] = (val
>> 16);
155 image
[20+2] = (val
>> 8);
156 image
[20+3] = (val
);
158 if (fwrite (image
, 32, 1, fp
) != 1)
159 return gpg_error_from_syserror ();