ea95c5f67a4f98eb1ddea2e374c2e7c393c27bbc
[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 3 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, see <http://www.gnu.org/licenses/>.
18  */
19
20 #include <config.h>
21 #include <stdlib.h>
22 #include <stdio.h>
23 #include <string.h>
24 #include <unistd.h>
25 #include <assert.h>
26
27 #include "keybox-defs.h"
28
29 #define compare_filenames strcmp
30
31 static KB_NAME kb_names;
32
33
34 /* 
35   Register a filename for plain keybox files.  Returns a pointer to be
36   used to create a handles etc or NULL to indicate that it has already
37   been registered */
38 void *
39 keybox_register_file (const char *fname, int secret)
40 {
41   KB_NAME kr;
42
43   for (kr=kb_names; kr; kr = kr->next)
44     {
45       if ( !compare_filenames (kr->fname, fname) )
46         return NULL; /* already registered */
47     }
48
49   kr = xtrymalloc (sizeof *kr + strlen (fname));
50   if (!kr)
51     return NULL;
52   strcpy (kr->fname, fname);
53   kr->secret = !!secret;
54   /* kr->lockhd = NULL;*/
55   kr->is_locked = 0;
56   kr->did_full_scan = 0;
57   /* keep a list of all issued pointers */
58   kr->next = kb_names;
59   kb_names = kr;
60   
61   /* create the offset table the first time a function here is used */
62 /*      if (!kb_offtbl) */
63 /*        kb_offtbl = new_offset_hash_table (); */
64
65   return kr;
66 }
67
68 int
69 keybox_is_writable (void *token)
70 {
71   KB_NAME r = token;
72
73   return r? !access (r->fname, W_OK) : 0;
74 }
75
76     
77
78 /* Create a new handle for the resource associated with TOKEN.  SECRET
79    is just a cross-check.
80    
81    The returned handle must be released using keybox_release (). */
82 KEYBOX_HANDLE
83 keybox_new (void *token, int secret)
84 {
85   KEYBOX_HANDLE hd;
86   KB_NAME resource = token;
87
88   assert (resource && !resource->secret == !secret);
89   hd = xtrycalloc (1, sizeof *hd);
90   if (hd)
91     {
92       hd->kb = resource;
93       hd->secret = !!secret;
94     }
95   return hd;
96 }
97
98 void 
99 keybox_release (KEYBOX_HANDLE hd)
100 {
101   if (!hd)
102     return;
103   _keybox_release_blob (hd->found.blob);
104   if (hd->fp)
105     {
106       fclose (hd->fp);
107       hd->fp = NULL;
108     }
109   xfree (hd->word_match.name);
110   xfree (hd->word_match.pattern);
111   xfree (hd);
112 }
113
114
115 const char *
116 keybox_get_resource_name (KEYBOX_HANDLE hd)
117 {
118   if (!hd || !hd->kb)
119     return NULL;
120   return hd->kb->fname;
121 }
122
123 int
124 keybox_set_ephemeral (KEYBOX_HANDLE hd, int yes)
125 {
126   if (!hd)
127     return gpg_error (GPG_ERR_INV_HANDLE); 
128   hd->ephemeral = yes;
129   return 0;
130 }
131