2 * keydb.h - Routines to store and fetch keys.
4 * Jonathan McDowell <noodles@earth.li>
6 * Copyright 2002 Project Purple
12 // #include <stdint.h>
15 #include "keystructs.h"
19 * initdb - Initialize the key database.
21 * This function should be called before any of the other functions in
22 * this file are called in order to allow the DB to be initialized ready
28 * cleanupdb - De-initialize the key database.
30 * This function should be called upon program exit to allow the DB to
31 * cleanup after itself.
36 * fetch_key - Given a keyid fetch the key from storage.
37 * @keyid: The keyid to fetch.
38 * @publickey: A pointer to a structure to return the key in.
40 * This function returns a public key from whatever storage mechanism we
43 * TODO: What about keyid collisions? Should we use fingerprint instead?
45 int fetch_key(uint64_t keyid, struct openpgp_publickey **publickey);
48 * store_key - Takes a key and stores it.
49 * @publickey: A pointer to the public key to store.
51 * This function stores a public key in whatever storage mechanism we are
54 * TODO: Do we store multiple keys of the same id? Or only one and replace
57 int store_key(struct openpgp_publickey *publickey);
60 * delete_key - Given a keyid delete the key from storage.
61 * @keyid: The keyid to delete.
63 * This function deletes a public key from whatever storage mechanism we
64 * are using. Returns 0 if the key existed.
66 int delete_key(uint64_t keyid);
69 * keyid2uid - Takes a keyid and returns the primary UID for it.
70 * @keyid: The keyid to lookup.
72 * This function returns a UID for the given key. Returns NULL if the key
75 char *keyid2uid(uint64_t keyid);
78 * getkeysigs - Gets a linked list of the signatures on a key.
79 * @keyid: The keyid to get the sigs for.
81 * This function gets the list of signatures on a key. Used for key
82 * indexing and doing stats bits.
84 struct ll *getkeysigs(uint64_t keyid);
86 #endif /* __KEYDB_H__ */