* gpgsm/t-encrypt.c (main): Add a simple option parser and allow
[gpgme.git] / gpgme / signers.c
1 /* signers.c - maintain signer sets
2  *      Copyright (C) 2001 Werner Koch (dd9jn)
3  *      Copyright (C) 2001, 2002 g10 Code GmbH
4  *
5  * This file is part of GPGME.
6  *
7  * GPGME is free software; you can redistribute it and/or modify
8  * it 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,
13  * but WITHOUT ANY WARRANTY; without even the implied warranty of
14  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
15  * GNU General Public License for more details.
16  *
17  * You should have received a copy of the GNU General Public License
18  * along with this program; if not, write to the Free Software
19  * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA
20  */
21
22 #include <config.h>
23 #include <stdio.h>
24 #include <stdlib.h>
25 #include <assert.h>
26
27 #include "util.h"
28 #include "context.h"
29 #include "rungpg.h"
30
31 /* The signers are directly stored in the context.
32  * So this is quite different to a recipient set.
33  */
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 mk_error (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 = xtryrealloc (ctx->signers, n * sizeof (*newarr));
86       if (!newarr)
87         return mk_error (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 }