File: pubkeys.c

package info (click to toggle)
secnet 0.6.8
  • links: PTS
  • area: main
  • in suites: forky, sid
  • size: 1,956 kB
  • sloc: ansic: 15,234; python: 1,057; perl: 966; sh: 596; tcl: 484; java: 231; asm: 114; yacc: 89; php: 64; makefile: 48; awk: 40
file content (88 lines) | stat: -rw-r--r-- 2,693 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
/*
 * This file is part of secnet.
 * See README for full list of copyright holders.
 *
 * secnet is free software; you can redistribute it and/or modify it
 * under the terms of the GNU General Public License as published by
 * the Free Software Foundation; either version 3 of the License, or
 * (at your option) any later version.
 * 
 * secnet is distributed in the hope that it will be useful, but
 * WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
 * General Public License for more details.
 * 
 * You should have received a copy of the GNU General Public License
 * version 3 along with secnet; if not, see
 * https://www.gnu.org/licenses/gpl.html.
 */

#include "util.h"
#include "base91s/base91.h"
#include "pubkeys.h"
#include "pubkeys.yy.h"

void keyset_dispose(struct peer_keyset **ks_io)
{
    struct peer_keyset *ks=*ks_io;
    if (!ks) return;
    *ks_io=0;
    ks->refcount--;
    assert(ks->refcount>=0);
    if (ks->refcount) return;
    for (int ki=0; ki<ks->nkeys; ki++) {
	struct sigpubkey_if *pk=ks->keys[ki].pubkey;
	pk->dispose(pk->st);
    }
    free(ks);
}

const struct sigscheme_info *sigscheme_lookup(const char *name)
{
    const struct sigscheme_info *scheme;
    for (scheme=sigschemes; scheme->name; scheme++)
	if (!strcmp(name,scheme->name))
	    return scheme;
    return 0;
}

static list_t *makepublic_apply(closure_t *self, struct cloc loc,
				dict_t *context, list_t *args)
{
    CL_GET_STR_ARG(0,algname,"algorithm name");
    CL_GET_STR_ARG(1,b91d,"base91s-encoded public key");

    const struct sigscheme_info *sch=sigscheme_lookup(algname);
    if (!sch) cfgfatal(algname_i->loc,"make-public",
		       "unknown algorithm `%s'",algname);

    size_t b91l=strlen(b91d);
    if (b91l > INT_MAX/4) cfgfatal(algname_i->loc,"make-public",
				      "base91s data unreasonably long");

    struct buffer_if buf;
    buffer_new(&buf,base91s_decode_maxlen(b91l));
    BUF_ALLOC(&buf,"make-public data buf");
    assert(buf.start == buf.base);
    struct base91s b91;
    base91s_init(&b91);
    buf.size= base91s_decode(&b91,b91d,b91l,buf.start);
    buf.size += base91s_decode_end(&b91,buf.start+buf.size);
    assert(buf.size <= buf.alloclen);

    struct cfgfile_log log;
    cfgfile_log_init(&log,loc,"make-public");

    struct sigpubkey_if *pubkey;
    closure_t *cl;
    bool_t ok=sch->loadpub(sch,&buf,&pubkey,&cl,&log.log,loc);
    if (!ok) cfgfatal(loc,"make-public","public key loading failed");

    BUF_FREE(&buf);
    buffer_destroy(&buf);
    return new_closure(cl);
}

void pubkeys_init(dict_t *dict) {
    add_closure(dict,"make-public",makepublic_apply);
}