2  * merge.h - Routines to merge OpenPGP public keys.
 
   4  * Jonathan McDowell <noodles@earth.li>
 
   6  * Copyright 2002 Project Purple
 
  11 #include "keystructs.h"
 
  14  *      merge_keys - Takes 2 public keys and merges them.
 
  15  *      @a: The old key. The merged key is returned in this structure.
 
  16  *      @b: The new key. The changed from old to new keys are returned in this
 
  19  *      This function takes 2 keys and merges them. It then returns the merged
 
  20  *      key in a and the difference between this new key and the original a
 
  21  *      in b (ie newb contains the minimum amount of detail necessary to
 
  22  *      convert olda to newa). The intention is that olda is provided from
 
  23  *      internal storage and oldb from the remote user. newa is then stored in
 
  24  *      internal storage and newb is sent to all our keysync peers.
 
  26 int merge_keys(struct openpgp_publickey *a, struct openpgp_publickey *b);
 
  29  *      update_keys - Takes a list of public keys and updates them in the DB.
 
  30  *      @keys: The keys to update in the DB.
 
  32  *      Takes a list of keys and adds them to the database, merging them with
 
  33  *      the key in the database if it's already present there. The key list is
 
  34  *      update to contain the minimum set of updates required to get from what
 
  35  *      we had before to what we have now (ie the set of data that was added to
 
  36  *      the DB). Returns the number of entirely new keys added.
 
  38 int update_keys(struct openpgp_publickey **keys);
 
  41  *      get_signed_packet - Gets a signed packet from a list.
 
  42  *      @packet_list: The list of packets to look in.
 
  43  *      @packet: The packet to look for.
 
  45  *      Walks through the signedpacket_list looking for the supplied packet and
 
  46  *      returns it if found. Otherwise returns NULL.
 
  48 struct openpgp_signedpacket_list *find_signed_packet(
 
  49                 struct openpgp_signedpacket_list *packet_list,
 
  50                 struct openpgp_packet *packet);
 
  53  *      merge_packet_sigs - Takes 2 signed packets and merges their sigs.
 
  54  *      @old: The old signed packet.
 
  55  *      @new: The new signed packet.
 
  57  *      Takes 2 signed packet list structures and the sigs of the packets on
 
  58  *      the head of these structures. These packets must both be the same and
 
  59  *      the fully merged structure is returned in old and the minimal
 
  60  *      difference to get from old to new in new.
 
  62 int merge_packet_sigs(struct openpgp_signedpacket_list *old,
 
  63                         struct openpgp_signedpacket_list *new);