Fix copyright year.
[gpgme.git] / gpgme / signers.c
1 /* signers.c - maintain signer sets
2    Copyright (C) 2001 Werner Koch (dd9jn)
3    Copyright (C) 2001, 2002, 2003 g10 Code GmbH
4  
5    This file is part of GPGME.
6  
7    GPGME is free software; you can redistribute it and/or modify it
8    under the terms of the GNU General Public License as published by
9    the Free Software Foundation; either version 2 of the License, or
10    (at your option) any later version.
11  
12    GPGME is distributed in the hope that it will be useful, but
13    WITHOUT ANY WARRANTY; without even the implied warranty of
14    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
15    General Public License for more details.
16  
17    You should have received a copy of the GNU General Public License
18    along with GPGME; if not, write to the Free Software Foundation,
19    Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.  */
20
21 #if HAVE_CONFIG_H
22 #include <config.h>
23 #endif
24
25 #include <stdio.h>
26 #include <stdlib.h>
27 #include <assert.h>
28
29 #include "util.h"
30 #include "context.h"
31
32 /* The signers are directly stored in the context.  So this is quite
33    different to a recipient set.  */
34
35
36 /**
37  * gpgme_signers_clear:
38  * @c: context to clear from signers
39  *
40  * Remove the list of signers from the context and release the
41  * references to the signers keys.
42  *
43  * Return value: The version string or NULL
44  **/
45 void
46 gpgme_signers_clear (GpgmeCtx ctx)
47 {
48   int i;
49
50   return_if_fail (ctx);
51
52   if (!ctx->signers)
53     return;
54   for (i = 0; i < ctx->signers_len; i++)
55     {
56       assert (ctx->signers[i]);
57       gpgme_key_unref (ctx->signers[i]);
58       ctx->signers[i] = NULL;
59     }
60   ctx->signers_len = 0;
61 }
62
63 /**
64  * gpgme_signers_add:
65  * @c: context to add signer to
66  * @key: key to add
67  *
68  * Add the key as a signer to the context.  Acquires a reference to
69  * the key.
70  *
71  * Return value: NULL on success, or an error code.
72  **/
73 GpgmeError
74 gpgme_signers_add (GpgmeCtx ctx, const GpgmeKey key)
75 {
76   if (!ctx || !key)
77     return GPGME_Invalid_Value;
78
79   if (ctx->signers_len == ctx->signers_size)
80     {
81       GpgmeKey *newarr;
82       int n = ctx->signers_size + 5;
83       int j;
84
85       newarr = realloc (ctx->signers, n * sizeof (*newarr));
86       if (!newarr)
87         return GPGME_Out_Of_Core;
88       for (j = ctx->signers_size; j < n; j++)
89         newarr[j] = NULL;
90       ctx->signers = newarr;
91       ctx->signers_size = n;
92     }
93
94   gpgme_key_ref (key);
95   ctx->signers[ctx->signers_len++] = key;
96   return 0;
97 }
98
99 /**
100  * gpgme_signers_enum:
101  * @c: context to retrieve signer from
102  * @seq: index of key to retrieve
103  *
104  * Acquire a reference to the signers key with the specified index
105  * number in the context and return it to the caller.
106  *
107  * Return value: A GpgmeKey or NULL on failure.
108  **/
109 GpgmeKey
110 gpgme_signers_enum (const GpgmeCtx ctx, int seq)
111 {
112   return_null_if_fail (ctx);
113   return_null_if_fail (seq >= 0);
114
115   if (seq >= ctx->signers_len)
116     return NULL;
117
118   gpgme_key_ref (ctx->signers[seq]);
119   return ctx->signers[seq];
120 }