Annotation of embedaddon/strongswan/src/libtpmtss/plugins/tpm/tpm_plugin.c, revision 1.1.1.1
1.1 misho 1: /*
2: * Copyright (C) 2017 Andreas Steffen
3: * HSR Hochschule fuer Technik Rapperswil
4: *
5: * This program is free software; you can redistribute it and/or modify it
6: * under the terms of the GNU General Public License as published by the
7: * Free Software Foundation; either version 2 of the License, or (at your
8: * option) any later version. See <http://www.fsf.org/copyleft/gpl.txt>.
9: *
10: * This program is distributed in the hope that it will be useful, but
11: * WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
12: * or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
13: * for more details.
14: */
15:
16: #include "tpm_plugin.h"
17: #include "tpm_private_key.h"
18: #include "tpm_cert.h"
19: #include "tpm_rng.h"
20:
21: #include <tpm_tss.h>
22: #include <library.h>
23:
24: typedef struct private_tpm_plugin_t private_tpm_plugin_t;
25:
26: /**
27: * private data of tpm_plugin
28: */
29: struct private_tpm_plugin_t {
30:
31: /**
32: * public functions
33: */
34: tpm_plugin_t public;
35: };
36:
37: METHOD(plugin_t, get_name, char*,
38: private_tpm_plugin_t *this)
39: {
40: return "tpm";
41: }
42:
43: METHOD(plugin_t, get_features, int,
44: private_tpm_plugin_t *this, plugin_feature_t *features[])
45: {
46: static plugin_feature_t f_rng[] = {
47: PLUGIN_REGISTER(RNG, tpm_rng_create),
48: PLUGIN_PROVIDE(RNG, RNG_STRONG),
49: PLUGIN_PROVIDE(RNG, RNG_TRUE),
50: };
51: static plugin_feature_t f_privkey[] = {
52: PLUGIN_REGISTER(PRIVKEY, tpm_private_key_connect, FALSE),
53: PLUGIN_PROVIDE(PRIVKEY, KEY_ANY),
54: };
55: static plugin_feature_t f_cert[] = {
56: PLUGIN_REGISTER(CERT_DECODE, tpm_cert_load, FALSE),
57: PLUGIN_PROVIDE(CERT_DECODE, CERT_X509),
58: PLUGIN_DEPENDS(CERT_DECODE, CERT_X509),
59: };
60: static plugin_feature_t f[countof(f_rng) + countof(f_privkey) +
61: countof(f_cert)] = {};
62: static int count = 0;
63:
64: if (!count)
65: {
66: plugin_features_add(f, f_privkey, countof(f_privkey), &count);
67: plugin_features_add(f, f_cert, countof(f_cert), &count);
68:
69: if (lib->settings->get_bool(lib->settings,
70: "%s.plugins.tpm.use_rng", FALSE, lib->ns))
71: {
72: plugin_features_add(f, f_rng, countof(f_rng), &count);
73: }
74: }
75: *features = f;
76:
77: return count;
78: }
79:
80: METHOD(plugin_t, destroy, void,
81: private_tpm_plugin_t *this)
82: {
83: free(this);
84: libtpmtss_deinit();
85: }
86:
87: /*
88: * see header file
89: */
90: plugin_t *tpm_plugin_create()
91: {
92: private_tpm_plugin_t *this;
93:
94: if (!libtpmtss_init())
95: {
96: return NULL;
97: }
98:
99: INIT(this,
100: .public = {
101: .plugin = {
102: .get_name = _get_name,
103: .get_features = _get_features,
104: .destroy = _destroy,
105: },
106: },
107: );
108:
109: return &this->public.plugin;
110: }
FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>