Included LIBICONV in all Makefiles.
[gnupg.git] / kbx / keybox-init.c
1 /* keybox-init.c - Initalization of the library 
2  *      Copyright (C) 2001 Free Software Foundation, Inc.
3  *
4  * This file is part of GnuPG.
5  *
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 2 of the License, or
9  * (at your option) any later version.
10  *
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.
15  *
16  * You should have received a copy of the GNU General Public License
17  * along with this program; if not, write to the Free Software
18  * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301,
19  * USA.
20  */
21
22 #include <config.h>
23 #include <stdlib.h>
24 #include <stdio.h>
25 #include <string.h>
26 #include <unistd.h>
27 #include <assert.h>
28
29 #include "keybox-defs.h"
30
31 #define compare_filenames strcmp
32
33 static KB_NAME kb_names;
34
35
36 /* 
37   Register a filename for plain keybox files.  Returns a pointer to be
38   used to create a handles etc or NULL to indicate that it has already
39   been registered */
40 void *
41 keybox_register_file (const char *fname, int secret)
42 {
43   KB_NAME kr;
44
45   for (kr=kb_names; kr; kr = kr->next)
46     {
47       if ( !compare_filenames (kr->fname, fname) )
48         return NULL; /* already registered */
49     }
50
51   kr = xtrymalloc (sizeof *kr + strlen (fname));
52   if (!kr)
53     return NULL;
54   strcpy (kr->fname, fname);
55   kr->secret = !!secret;
56   /* kr->lockhd = NULL;*/
57   kr->is_locked = 0;
58   kr->did_full_scan = 0;
59   /* keep a list of all issued pointers */
60   kr->next = kb_names;
61   kb_names = kr;
62   
63   /* create the offset table the first time a function here is used */
64 /*      if (!kb_offtbl) */
65 /*        kb_offtbl = new_offset_hash_table (); */
66
67   return kr;
68 }
69
70 int
71 keybox_is_writable (void *token)
72 {
73   KB_NAME r = token;
74
75   return r? !access (r->fname, W_OK) : 0;
76 }
77
78     
79
80 /* Create a new handle for the resource associated with TOKEN.  SECRET
81    is just a cross-check.
82    
83    The returned handle must be released using keybox_release (). */
84 KEYBOX_HANDLE
85 keybox_new (void *token, int secret)
86 {
87   KEYBOX_HANDLE hd;
88   KB_NAME resource = token;
89
90   assert (resource && !resource->secret == !secret);
91   hd = xtrycalloc (1, sizeof *hd);
92   if (hd)
93     {
94       hd->kb = resource;
95       hd->secret = !!secret;
96     }
97   return hd;
98 }
99
100 void 
101 keybox_release (KEYBOX_HANDLE hd)
102 {
103   if (!hd)
104     return;
105   _keybox_release_blob (hd->found.blob);
106   if (hd->fp)
107     {
108       fclose (hd->fp);
109       hd->fp = NULL;
110     }
111   xfree (hd->word_match.name);
112   xfree (hd->word_match.pattern);
113   xfree (hd);
114 }
115
116
117 const char *
118 keybox_get_resource_name (KEYBOX_HANDLE hd)
119 {
120   if (!hd || !hd->kb)
121     return NULL;
122   return hd->kb->fname;
123 }
124
125 int
126 keybox_set_ephemeral (KEYBOX_HANDLE hd, int yes)
127 {
128   if (!hd)
129     return gpg_error (GPG_ERR_INV_HANDLE); 
130   hd->ephemeral = yes;
131   return 0;
132 }
133