2 * Copyright (c) 2010, JANET(UK)
5 * Redistribution and use in source and binary forms, with or without
6 * modification, are permitted provided that the following conditions
9 * 1. Redistributions of source code must retain the above copyright
10 * notice, this list of conditions and the following disclaimer.
12 * 2. Redistributions in binary form must reproduce the above copyright
13 * notice, this list of conditions and the following disclaimer in the
14 * documentation and/or other materials provided with the distribution.
16 * 3. Neither the name of JANET(UK) nor the names of its contributors
17 * may be used to endorse or promote products derived from this software
18 * without specific prior written permission.
20 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
21 * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
22 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
23 * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE
24 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
25 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
26 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
27 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
28 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
29 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
34 #define _UTIL_ATTR_H_ 1
36 #define ATTR_TYPE_RADIUS 0U
37 #define ATTR_TYPE_SAML_ASSERTION 1U
38 #define ATTR_TYPE_SAML 2U
39 #define ATTR_TYPE_LOCAL 3U
40 #define ATTR_TYPE_MIN ATTR_TYPE_RADIUS
41 #define ATTR_TYPE_MAX (ATTR_TYPE_LOCAL + 1U)
46 struct gss_eap_attr_ctx;
48 struct gss_eap_attr_source
51 gss_eap_attr_source(void) {}
52 virtual ~gss_eap_attr_source(void) {}
54 bool initWithManager(const gss_eap_attr_ctx *manager)
60 virtual bool initFromExistingContext(const gss_eap_attr_ctx *manager,
61 const gss_eap_attr_source *ctx)
63 return initWithManager(manager);
66 virtual bool initFromGssContext(const gss_eap_attr_ctx *manager,
67 const gss_cred_id_t cred,
68 const gss_ctx_id_t ctx)
70 return initWithManager(manager);
74 gss_eap_attr_enumeration_cb(const gss_eap_attr_source *source,
75 const gss_buffer_t attribute,
78 virtual bool getAttributeTypes(gss_eap_attr_enumeration_cb, void *data) const
83 virtual void setAttribute(int complete,
84 const gss_buffer_t attr,
85 const gss_buffer_t value) {}
86 virtual void deleteAttribute(const gss_buffer_t value) {}
87 virtual bool getAttribute(const gss_buffer_t attr,
91 gss_buffer_t display_value,
92 int *more) const { return false; }
94 virtual gss_any_t mapToAny(int authenticated,
95 gss_buffer_t type_id) const { return NULL; }
96 virtual void releaseAnyNameMapping(gss_buffer_t type_id,
97 gss_any_t input) const {}
99 virtual void exportToBuffer(gss_buffer_t buffer) const {}
100 virtual bool initFromBuffer(const gss_eap_attr_ctx *manager,
101 const gss_buffer_t buffer)
103 return initWithManager(manager);
106 static bool init() { return true; }
107 static void finalize() {}
109 static gss_eap_attr_source *createAttrContext(void) { return NULL; }
112 const gss_eap_attr_ctx *m_manager;
115 /* make non-copyable */
116 gss_eap_attr_source(const gss_eap_attr_source&);
117 gss_eap_attr_source& operator=(const gss_eap_attr_source&);
120 typedef gss_eap_attr_source *(*gss_eap_attr_create_factory)(void);
122 struct gss_eap_attr_ctx : gss_eap_attr_source
125 gss_eap_attr_ctx(void);
126 ~gss_eap_attr_ctx(void);
128 bool initFromExistingContext(const gss_eap_attr_ctx *manager,
129 const gss_eap_attr_source *ctx);
130 bool initFromGssContext(const gss_eap_attr_ctx *manager,
131 const gss_cred_id_t cred,
132 const gss_ctx_id_t ctx);
134 bool getAttributeTypes(gss_eap_attr_enumeration_cb, void *data) const;
135 bool getAttributeTypes(gss_buffer_set_t *attrs);
137 void setAttribute(int complete,
138 const gss_buffer_t attr,
139 const gss_buffer_t value);
140 void deleteAttribute(const gss_buffer_t value);
141 bool getAttribute(const gss_buffer_t attr,
145 gss_buffer_t display_value,
147 gss_any_t mapToAny(int authenticated,
148 gss_buffer_t type_id) const;
149 void releaseAnyNameMapping(gss_buffer_t type_id,
150 gss_any_t input) const;
152 void exportToBuffer(gss_buffer_t buffer) const;
153 bool initFromBuffer(const gss_eap_attr_ctx *ctx,
154 const gss_buffer_t buffer);
156 static void finalize();
159 attributePrefixToType(const gss_buffer_t prefix);
161 static const gss_buffer_t
162 attributeTypeToPrefix(unsigned int type);
165 decomposeAttributeName(const gss_buffer_t attribute,
167 gss_buffer_t suffix);
169 composeAttributeName(const gss_buffer_t prefix,
170 const gss_buffer_t suffix,
171 gss_buffer_t attribute);
173 decomposeAttributeName(const gss_buffer_t attribute,
175 gss_buffer_t suffix);
177 composeAttributeName(unsigned int type,
178 const gss_buffer_t suffix,
179 gss_buffer_t attribute);
182 composeAttributeName(const gss_buffer_t prefix,
183 const gss_buffer_t suffix);
185 composeAttributeName(unsigned int type,
186 const gss_buffer_t suffix);
188 gss_eap_attr_source *getProvider(unsigned int type) const;
189 gss_eap_attr_source *getProvider(const gss_buffer_t prefix) const;
192 /* make non-copyable */
193 gss_eap_attr_ctx(const gss_eap_attr_ctx&);
194 gss_eap_attr_ctx& operator=(const gss_eap_attr_ctx&);
196 gss_eap_attr_source *m_sources[ATTR_TYPE_MAX];
199 #include "util_radius.h"
200 #include "util_saml.h"
201 #include "util_shib.h"
207 duplicateBuffer(gss_buffer_desc &src, gss_buffer_t dst)
211 if (GSS_ERROR(duplicateBuffer(&minor, &src, dst)))
212 throw new std::bad_alloc();
216 duplicateBuffer(std::string &str, gss_buffer_t buffer)
220 tmp.length = str.length();
221 tmp.value = (char *)str.c_str();
223 duplicateBuffer(tmp, buffer);
227 struct gss_eap_attr_ctx;
234 struct gss_eap_attr_ctx *
235 gssEapCreateAttrContext(gss_cred_id_t acceptorCred,
236 gss_ctx_id_t acceptorCtx);
239 gssEapInquireName(OM_uint32 *minor,
243 gss_buffer_set_t *attrs);
246 gssEapGetNameAttribute(OM_uint32 *minor,
252 gss_buffer_t display_value,
256 gssEapDeleteNameAttribute(OM_uint32 *minor,
261 gssEapSetNameAttribute(OM_uint32 *minor,
268 gssEapExportAttrContext(OM_uint32 *minor,
270 gss_buffer_t buffer);
273 gssEapImportAttrContext(OM_uint32 *minor,
278 gssEapDuplicateAttrContext(OM_uint32 *minor,
283 gssEapMapNameToAny(OM_uint32 *minor,
286 gss_buffer_t type_id,
290 gssEapReleaseAnyNameMapping(OM_uint32 *minor,
292 gss_buffer_t type_id,
296 gssEapReleaseAttrContext(OM_uint32 *minor,
300 gssEapAttrProvidersInit(OM_uint32 *minor);
303 gssEapAttrProvidersFinalize(OM_uint32 *minor);
309 #endif /* _UTIL_ATTR_H_ */