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)
44 struct gss_eap_attr_ctx;
46 struct gss_eap_attr_provider
49 gss_eap_attr_provider(const gss_eap_attr_ctx *ctx,
50 gss_cred_id_t acceptorCred = GSS_C_NO_CREDENTIAL,
51 gss_ctx_id_t acceptorCtx = GSS_C_NO_CONTEXT)
56 gss_eap_attr_provider(const gss_eap_attr_provider &ctx) {}
57 virtual ~gss_eap_attr_provider(void) {}
60 gss_eap_attr_enumeration_cb(const gss_eap_attr_provider *provider,
61 const gss_buffer_t attribute,
64 virtual bool getAttributeTypes(gss_eap_attr_enumeration_cb, void *data) const
69 virtual void setAttribute(int complete,
70 const gss_buffer_t attr,
71 const gss_buffer_t value) {}
72 virtual void deleteAttribute(const gss_buffer_t value) {}
73 virtual bool getAttribute(const gss_buffer_t attr,
77 gss_buffer_t display_value,
78 int *more) const { return false; }
80 virtual gss_any_t mapToAny(int authenticated,
81 gss_buffer_t type_id) const { return NULL; }
82 virtual void releaseAnyNameMapping(gss_buffer_t type_id,
83 gss_any_t input) const {}
85 virtual void marshall(gss_buffer_t buffer) const {}
86 virtual bool unmarshall(const gss_eap_attr_ctx *ctx,
87 const gss_buffer_t buffer) { return false; }
89 static bool init() { return true; }
90 static void finalize() {}
92 static gss_eap_attr_provider *
93 createAttrContext(const gss_eap_attr_ctx *ctx,
94 gss_cred_id_t acceptorCred,
95 gss_ctx_id_t acceptorCtx) { return NULL; }
98 const gss_eap_attr_ctx *m_source;
101 typedef gss_eap_attr_provider * (*gss_eap_attr_create_cb)(
102 const gss_eap_attr_ctx *ctx,
103 gss_cred_id_t acceptorCred,
104 gss_ctx_id_t acceptorCtx);
106 struct gss_eap_attr_ctx : gss_eap_attr_provider
109 gss_eap_attr_ctx(const gss_eap_attr_ctx *ctx,
110 gss_cred_id_t acceptorCred,
111 gss_ctx_id_t acceptorCtx) :
112 gss_eap_attr_provider(ctx, acceptorCred, acceptorCtx) {}
114 gss_eap_attr_ctx(const gss_eap_attr_ctx &ctx);
116 ~gss_eap_attr_ctx(void);
118 static gss_eap_attr_ctx *createAttrContext(gss_cred_id_t acceptorCred,
119 gss_ctx_id_t acceptorCtx);
121 bool getAttributeTypes(gss_eap_attr_enumeration_cb, void *data) const;
122 bool getAttributeTypes(gss_buffer_set_t *attrs);
124 void setAttribute(int complete,
125 const gss_buffer_t attr,
126 const gss_buffer_t value);
127 void deleteAttribute(const gss_buffer_t value);
128 bool getAttribute(const gss_buffer_t attr,
132 gss_buffer_t display_value,
134 gss_any_t mapToAny(int authenticated,
135 gss_buffer_t type_id) const;
136 void releaseAnyNameMapping(gss_buffer_t type_id,
137 gss_any_t input) const;
139 void marshall(gss_buffer_t buffer) const;
140 bool unmarshall(const gss_eap_attr_ctx *ctx,
141 const gss_buffer_t buffer);
143 static void finalize();
146 attributePrefixToType(const gss_buffer_t prefix);
149 attributeTypeToPrefix(unsigned int type);
152 decomposeAttributeName(const gss_buffer_t attribute,
154 gss_buffer_t suffix);
156 composeAttributeName(const gss_buffer_t prefix,
157 const gss_buffer_t suffix,
158 gss_buffer_t attribute);
160 decomposeAttributeName(const gss_buffer_t attribute,
162 gss_buffer_t suffix);
164 composeAttributeName(unsigned int type,
165 const gss_buffer_t suffix,
166 gss_buffer_t attribute);
168 gss_eap_attr_provider *getProvider(unsigned int type) const;
169 gss_eap_attr_provider *getProvider(const gss_buffer_t prefix) const;
172 gss_eap_attr_provider *m_providers[ATTR_TYPE_MAX];
175 #include "util_radius.h"
176 #include "util_saml.h"
177 #include "util_shib.h"
183 duplicateBuffer(gss_buffer_desc &src, gss_buffer_t dst)
187 if (GSS_ERROR(duplicateBuffer(&minor, &src, dst)))
188 throw new std::bad_alloc();
192 duplicateBuffer(std::string &str, gss_buffer_t buffer)
196 tmp.length = str.length();
197 tmp.value = (char *)str.c_str();
199 duplicateBuffer(tmp, buffer);
203 struct gss_eap_attr_ctx;
210 struct gss_eap_attr_ctx *
211 gssEapCreateAttrContext(gss_cred_id_t acceptorCred,
212 gss_ctx_id_t acceptorCtx);
215 gssEapInquireName(OM_uint32 *minor,
219 gss_buffer_set_t *attrs);
222 gssEapGetNameAttribute(OM_uint32 *minor,
228 gss_buffer_t display_value,
232 gssEapDeleteNameAttribute(OM_uint32 *minor,
237 gssEapSetNameAttribute(OM_uint32 *minor,
244 gssEapExportAttrContext(OM_uint32 *minor,
246 gss_buffer_t buffer);
249 gssEapImportAttrContext(OM_uint32 *minor,
254 gssEapDuplicateAttrContext(OM_uint32 *minor,
259 gssEapMapNameToAny(OM_uint32 *minor,
262 gss_buffer_t type_id,
266 gssEapReleaseAnyNameMapping(OM_uint32 *minor,
268 gss_buffer_t type_id,
272 gssEapReleaseAttrContext(OM_uint32 *minor,
276 gssEapAttrProvidersInit(OM_uint32 *minor);
279 gssEapAttrProvidersFinalize(OM_uint32 *minor);
285 #endif /* _UTIL_ATTR_H_ */