changed trustdb design
[gnupg.git] / g10 / tdbio.h
1 /* tdbio.h - Trust database I/O functions
2  *      Copyright (C) 1998 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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA
19  */
20
21 #ifndef G10_TDBIO_H
22 #define G10_TDBIO_H
23
24
25 #define TRUST_RECORD_LEN 40
26 #define SIGS_PER_RECORD         ((TRUST_RECORD_LEN-10)/5)
27 #define ITEMS_PER_HTBL_RECORD   ((TRUST_RECORD_LEN-2)/4)
28 #define ITEMS_PER_HLST_RECORD   ((TRUST_RECORD_LEN-6)/5)
29 #define MAX_LIST_SIGS_DEPTH  20
30
31
32 #define RECTYPE_VER  1
33 #define RECTYPE_DIR  2
34 #define RECTYPE_KEY  3
35 #define RECTYPE_UID  4
36 #define RECTYPE_PREF 5
37 #define RECTYPE_SIG  6
38 #define RECTYPE_CACH 9
39 #define RECTYPE_HTBL 10
40 #define RECTYPE_HLST 11
41
42
43
44 #define DIRF_CHECKED  1 /* everything has been checked, the other bits are
45                            valid */
46 #define DIRF_MISKEY   2 /* some keys are missing, so they could not be checked*/
47 #define DIRF_ERROR    4 /* severe errors: the key is not valid for some reasons
48                            but we mark it to avoid duplicate checks */
49 #define DIRF_REVOKED  8 /* the complete key has been revoked */
50
51 #define KEYF_REVOKED DIRF_REVOKED   /* this key has been revoked
52                                        (only useful on subkeys)*/
53 #define UIDF_REVOKED DIRF_REVOKED   /* this user id has been revoked */
54
55
56 struct trust_record {
57     int  rectype;
58     struct trust_record *next;  /* help pointer to build lists in memory */
59     struct trust_record *help_pref;
60     int  mark;
61     ulong recnum;
62     union {
63         struct {            /* version record: */
64             byte version;   /* should be 1 */
65             ulong locked;    /* pid of process which holds a lock */
66             ulong created;   /* timestamp of trustdb creation  */
67             ulong modified;  /* timestamp of last modification */
68             ulong validated; /* timestamp of last validation   */
69             byte marginals_needed;
70             byte completes_needed;
71             byte max_cert_depth;
72         } ver;
73         struct {            /* directory record */
74             ulong lid;
75             ulong keylist;  /* List of keys (the first is the primary key)*/
76             ulong uidlist;  /* list of uid records */
77             ulong cacherec; /* the cache record */
78             byte ownertrust;
79             byte dirflags;
80         } dir;
81         struct {            /* primary public key record */
82             ulong lid;
83             ulong next;    /* next key */
84             byte keyflags;
85             byte pubkey_algo;
86             byte fingerprint_len;
87             byte fingerprint[20];
88         } key;
89         struct {            /* user id reord */
90             ulong lid;      /* point back to the directory record */
91             ulong next;    /* points to next user id record */
92             ulong prefrec;   /* recno of preference record */
93             ulong siglist;   /* list of valid signatures (w/o self-sig)*/
94             byte uidflags;
95             byte namehash[20]; /* ripemd hash of the username */
96         } uid;
97         struct {            /* preference reord */
98             ulong lid;      /* point back to the directory record */
99                             /* or 0 for a glocal pref record */
100             ulong next;    /* points to next pref record */
101         } pref;
102         struct {            /* signature record */
103             ulong lid;
104             ulong next;   /* recnno of next record or NULL for last one */
105             struct {
106                 ulong lid;       /* of pubkey record of signator (0=unused) */
107                 byte flag;       /* SIGRF_xxxxx */
108             } sig[SIGS_PER_RECORD];
109         } sig;
110         struct {            /* cache record */
111             ulong lid;
112             byte blockhash[20];
113             byte trustlevel;   /* calculated trustlevel */
114         } cache;
115         struct {
116             ulong item[ITEMS_PER_HTBL_RECORD];
117         } htbl;
118         struct {
119             ulong next;
120             struct {
121                 byte hash;
122                 ulong rnum;
123             } item[ITEMS_PER_HLST_RECORD];
124         } hlst;
125     } r;
126 };
127 typedef struct trust_record TRUSTREC;
128
129 typedef struct {
130     ulong     lid;         /* localid */
131     ulong     sigrec;
132     ulong     sig_lid;     /* returned signatures LID */
133     unsigned  sig_flag;    /* returned signature record flag */
134     struct {               /* internal data */
135         int init_done;
136         int eof;
137         TRUSTREC rec;
138         ulong nextuid;
139         int index;
140     } ctl;
141 } SIGREC_CONTEXT;
142
143
144 /*-- tdbio.c --*/
145 int tdbio_set_dbname( const char *new_dbname, int create );
146 const char *tdbio_get_dbname(void);
147 void tdbio_dump_record( TRUSTREC *rec, FILE *fp );
148 int tdbio_read_record( ulong recnum, TRUSTREC *rec, int expected );
149 int tdbio_write_record( TRUSTREC *rec );
150 int tdbio_delete_record( ulong recnum );
151 ulong tdbio_new_recnum(void);
152 int tdbio_search_dir_record( PKT_public_key *pk, TRUSTREC *rec );
153 int tdbio_delete_uidrec( ulong dirlid, ulong uidlid );
154
155
156 #define buftoulong( p )  ((*(byte*)(p) << 24) | (*((byte*)(p)+1)<< 16) | \
157                        (*((byte*)(p)+2) << 8) | (*((byte*)(p)+3)))
158 #define buftoushort( p )  ((*((byte*)(p)) << 8) | (*((byte*)(p)+1)))
159 #define ulongtobuf( p, a ) do {                           \
160                             ((byte*)p)[0] = a >> 24;    \
161                             ((byte*)p)[1] = a >> 16;    \
162                             ((byte*)p)[2] = a >>  8;    \
163                             ((byte*)p)[3] = a      ;    \
164                         } while(0)
165 #define ushorttobuf( p, a ) do {                           \
166                             ((byte*)p)[0] = a >>  8;    \
167                             ((byte*)p)[1] = a      ;    \
168                         } while(0)
169 #define buftou32( p)    buftoulong( (p) )
170 #define u32tobuf( p, a) ulongtobuf( (p), (a) )
171
172
173
174 #endif /*G10_TDBIO_H*/