xref: /freebsd/lib/libgssapi/gss_set_sec_context_option.c (revision 2a63c3be158216222d89a073dcbd6a72ee4aab5a)
1*8a16b7a1SPedro F. Giffuni /*-
2*8a16b7a1SPedro F. Giffuni  * SPDX-License-Identifier: BSD-3-Clause
3*8a16b7a1SPedro F. Giffuni  *
433f12199SDoug Rabson  * Copyright (c) 2004, PADL Software Pty Ltd.
533f12199SDoug Rabson  * All rights reserved.
633f12199SDoug Rabson  *
733f12199SDoug Rabson  * Redistribution and use in source and binary forms, with or without
833f12199SDoug Rabson  * modification, are permitted provided that the following conditions
933f12199SDoug Rabson  * are met:
1033f12199SDoug Rabson  *
1133f12199SDoug Rabson  * 1. Redistributions of source code must retain the above copyright
1233f12199SDoug Rabson  *    notice, this list of conditions and the following disclaimer.
1333f12199SDoug Rabson  *
1433f12199SDoug Rabson  * 2. Redistributions in binary form must reproduce the above copyright
1533f12199SDoug Rabson  *    notice, this list of conditions and the following disclaimer in the
1633f12199SDoug Rabson  *    documentation and/or other materials provided with the distribution.
1733f12199SDoug Rabson  *
1833f12199SDoug Rabson  * 3. Neither the name of PADL Software nor the names of its contributors
1933f12199SDoug Rabson  *    may be used to endorse or promote products derived from this software
2033f12199SDoug Rabson  *    without specific prior written permission.
2133f12199SDoug Rabson  *
2233f12199SDoug Rabson  * THIS SOFTWARE IS PROVIDED BY PADL SOFTWARE AND CONTRIBUTORS ``AS IS'' AND
2333f12199SDoug Rabson  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
2433f12199SDoug Rabson  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
2533f12199SDoug Rabson  * ARE DISCLAIMED.  IN NO EVENT SHALL PADL SOFTWARE OR CONTRIBUTORS BE LIABLE
2633f12199SDoug Rabson  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
2733f12199SDoug Rabson  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
2833f12199SDoug Rabson  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
2933f12199SDoug Rabson  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
3033f12199SDoug Rabson  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
3133f12199SDoug Rabson  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
3233f12199SDoug Rabson  * SUCH DAMAGE.
3333f12199SDoug Rabson  */
3433f12199SDoug Rabson /* RCSID("$Id: gss_set_sec_context_option.c 19928 2007-01-16 10:37:54Z lha $"); */
3533f12199SDoug Rabson 
3633f12199SDoug Rabson #include <gssapi/gssapi.h>
3733f12199SDoug Rabson 
3833f12199SDoug Rabson #include "mech_switch.h"
3933f12199SDoug Rabson #include "context.h"
4033f12199SDoug Rabson 
4133f12199SDoug Rabson OM_uint32
gss_set_sec_context_option(OM_uint32 * minor_status,gss_ctx_id_t * context_handle,const gss_OID object,const gss_buffer_t value)4233f12199SDoug Rabson gss_set_sec_context_option (OM_uint32 *minor_status,
4333f12199SDoug Rabson 			    gss_ctx_id_t *context_handle,
4433f12199SDoug Rabson 			    const gss_OID object,
4533f12199SDoug Rabson 			    const gss_buffer_t value)
4633f12199SDoug Rabson {
4733f12199SDoug Rabson 	struct _gss_context	*ctx;
4833f12199SDoug Rabson 	OM_uint32		major_status;
4933f12199SDoug Rabson 	struct _gss_mech_switch	*m;
5033f12199SDoug Rabson 	int			one_ok = 0;
5133f12199SDoug Rabson 
5233f12199SDoug Rabson 	*minor_status = 0;
5333f12199SDoug Rabson 
5433f12199SDoug Rabson 	if (context_handle == NULL) {
5533f12199SDoug Rabson 		_gss_load_mech();
5633f12199SDoug Rabson 		major_status = GSS_S_BAD_MECH;
5733f12199SDoug Rabson 		SLIST_FOREACH(m, &_gss_mechs, gm_link) {
5833f12199SDoug Rabson 			if (!m->gm_set_sec_context_option)
5933f12199SDoug Rabson 				continue;
6033f12199SDoug Rabson 			major_status = m->gm_set_sec_context_option(
6133f12199SDoug Rabson 				minor_status,
6233f12199SDoug Rabson 				NULL, object, value);
6333f12199SDoug Rabson 			if (major_status == GSS_S_COMPLETE)
6433f12199SDoug Rabson 				one_ok = 1;
6533f12199SDoug Rabson 		}
6633f12199SDoug Rabson 		if (one_ok) {
6733f12199SDoug Rabson 			*minor_status = 0;
6833f12199SDoug Rabson 			return (GSS_S_COMPLETE);
6933f12199SDoug Rabson 		}
7033f12199SDoug Rabson 		return (major_status);
7133f12199SDoug Rabson 	}
7233f12199SDoug Rabson 
7333f12199SDoug Rabson 	ctx = (struct _gss_context *) *context_handle;
7433f12199SDoug Rabson 
7533f12199SDoug Rabson 	if (ctx == NULL)
7633f12199SDoug Rabson 		return (GSS_S_NO_CONTEXT);
7733f12199SDoug Rabson 
7833f12199SDoug Rabson 	m = ctx->gc_mech;
7933f12199SDoug Rabson 
8033f12199SDoug Rabson 	if (m == NULL)
8133f12199SDoug Rabson 		return (GSS_S_BAD_MECH);
8233f12199SDoug Rabson 
8333f12199SDoug Rabson 	if (m->gm_set_sec_context_option != NULL) {
8433f12199SDoug Rabson 		major_status = m->gm_set_sec_context_option(minor_status,
8533f12199SDoug Rabson 		    &ctx->gc_ctx, object, value);
8633f12199SDoug Rabson 		if (major_status != GSS_S_COMPLETE)
8733f12199SDoug Rabson 			_gss_mg_error(m, major_status, *minor_status);
8833f12199SDoug Rabson 	} else
8933f12199SDoug Rabson 		major_status = (GSS_S_BAD_MECH);
9033f12199SDoug Rabson 
9133f12199SDoug Rabson 	return (major_status);
9233f12199SDoug Rabson }
9333f12199SDoug Rabson 
94