Annotation of embedaddon/strongswan/src/libstrongswan/plugins/ccm/ccm_plugin.c, revision 1.1.1.1
1.1 misho 1: /*
2: * Copyright (C) 2010 Martin Willi
3: * Copyright (C) 2010 revosec AG
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 "ccm_plugin.h"
17:
18: #include <library.h>
19:
20: #include "ccm_aead.h"
21:
22: typedef struct private_ccm_plugin_t private_ccm_plugin_t;
23:
24: /**
25: * private data of ccm_plugin
26: */
27: struct private_ccm_plugin_t {
28:
29: /**
30: * public functions
31: */
32: ccm_plugin_t public;
33: };
34:
35: METHOD(plugin_t, get_name, char*,
36: private_ccm_plugin_t *this)
37: {
38: return "ccm";
39: }
40:
41: METHOD(plugin_t, get_features, int,
42: private_ccm_plugin_t *this, plugin_feature_t *features[])
43: {
44: static plugin_feature_t f[] = {
45: PLUGIN_REGISTER(AEAD, ccm_aead_create),
46: PLUGIN_PROVIDE(AEAD, ENCR_AES_CCM_ICV8, 16),
47: PLUGIN_DEPENDS(CRYPTER, ENCR_AES_CBC, 16),
48: PLUGIN_PROVIDE(AEAD, ENCR_AES_CCM_ICV8, 24),
49: PLUGIN_DEPENDS(CRYPTER, ENCR_AES_CBC, 24),
50: PLUGIN_PROVIDE(AEAD, ENCR_AES_CCM_ICV8, 32),
51: PLUGIN_DEPENDS(CRYPTER, ENCR_AES_CBC, 32),
52: PLUGIN_PROVIDE(AEAD, ENCR_AES_CCM_ICV12, 16),
53: PLUGIN_DEPENDS(CRYPTER, ENCR_AES_CBC, 16),
54: PLUGIN_PROVIDE(AEAD, ENCR_AES_CCM_ICV12, 24),
55: PLUGIN_DEPENDS(CRYPTER, ENCR_AES_CBC, 24),
56: PLUGIN_PROVIDE(AEAD, ENCR_AES_CCM_ICV12, 32),
57: PLUGIN_DEPENDS(CRYPTER, ENCR_AES_CBC, 32),
58: PLUGIN_PROVIDE(AEAD, ENCR_AES_CCM_ICV16, 16),
59: PLUGIN_DEPENDS(CRYPTER, ENCR_AES_CBC, 16),
60: PLUGIN_PROVIDE(AEAD, ENCR_AES_CCM_ICV16, 24),
61: PLUGIN_DEPENDS(CRYPTER, ENCR_AES_CBC, 24),
62: PLUGIN_PROVIDE(AEAD, ENCR_AES_CCM_ICV16, 32),
63: PLUGIN_DEPENDS(CRYPTER, ENCR_AES_CBC, 32),
64: PLUGIN_PROVIDE(AEAD, ENCR_CAMELLIA_CCM_ICV8, 16),
65: PLUGIN_DEPENDS(CRYPTER, ENCR_CAMELLIA_CBC, 16),
66: PLUGIN_PROVIDE(AEAD, ENCR_CAMELLIA_CCM_ICV8, 24),
67: PLUGIN_DEPENDS(CRYPTER, ENCR_CAMELLIA_CBC, 24),
68: PLUGIN_PROVIDE(AEAD, ENCR_CAMELLIA_CCM_ICV8, 32),
69: PLUGIN_DEPENDS(CRYPTER, ENCR_CAMELLIA_CBC, 32),
70: PLUGIN_PROVIDE(AEAD, ENCR_CAMELLIA_CCM_ICV12, 16),
71: PLUGIN_DEPENDS(CRYPTER, ENCR_CAMELLIA_CBC, 16),
72: PLUGIN_PROVIDE(AEAD, ENCR_CAMELLIA_CCM_ICV12, 24),
73: PLUGIN_DEPENDS(CRYPTER, ENCR_CAMELLIA_CBC, 24),
74: PLUGIN_PROVIDE(AEAD, ENCR_CAMELLIA_CCM_ICV12, 32),
75: PLUGIN_DEPENDS(CRYPTER, ENCR_CAMELLIA_CBC, 32),
76: PLUGIN_PROVIDE(AEAD, ENCR_CAMELLIA_CCM_ICV16, 16),
77: PLUGIN_DEPENDS(CRYPTER, ENCR_CAMELLIA_CBC, 16),
78: PLUGIN_PROVIDE(AEAD, ENCR_CAMELLIA_CCM_ICV16, 24),
79: PLUGIN_DEPENDS(CRYPTER, ENCR_CAMELLIA_CBC, 24),
80: PLUGIN_PROVIDE(AEAD, ENCR_CAMELLIA_CCM_ICV16, 32),
81: PLUGIN_DEPENDS(CRYPTER, ENCR_CAMELLIA_CBC, 32),
82: };
83: *features = f;
84: return countof(f);
85: }
86:
87: METHOD(plugin_t, destroy, void,
88: private_ccm_plugin_t *this)
89: {
90: free(this);
91: }
92:
93: /*
94: * see header file
95: */
96: plugin_t *ccm_plugin_create()
97: {
98: private_ccm_plugin_t *this;
99:
100: INIT(this,
101: .public = {
102: .plugin = {
103: .get_name = _get_name,
104: .get_features = _get_features,
105: .destroy = _destroy,
106: },
107: },
108: );
109:
110: return &this->public.plugin;
111: }
FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>