1a9148abdSDoug Rabson#- 2a9148abdSDoug Rabson# Copyright (c) 2008 Isilon Inc http://www.isilon.com/ 3a9148abdSDoug Rabson# Authors: Doug Rabson <dfr@rabson.org> 4a9148abdSDoug Rabson# Developed with Red Inc: Alfred Perlstein <alfred@freebsd.org> 5a9148abdSDoug Rabson# 6a9148abdSDoug Rabson# Redistribution and use in source and binary forms, with or without 7a9148abdSDoug Rabson# modification, are permitted provided that the following conditions 8a9148abdSDoug Rabson# are met: 9a9148abdSDoug Rabson# 1. Redistributions of source code must retain the above copyright 10a9148abdSDoug Rabson# notice, this list of conditions and the following disclaimer. 11a9148abdSDoug Rabson# 2. Redistributions in binary form must reproduce the above copyright 12a9148abdSDoug Rabson# notice, this list of conditions and the following disclaimer in the 13a9148abdSDoug Rabson# documentation and/or other materials provided with the distribution. 14a9148abdSDoug Rabson# 15a9148abdSDoug Rabson# THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND 16a9148abdSDoug Rabson# ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 17a9148abdSDoug Rabson# IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 18a9148abdSDoug Rabson# ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE 19a9148abdSDoug Rabson# FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 20a9148abdSDoug Rabson# DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 21a9148abdSDoug Rabson# OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 22a9148abdSDoug Rabson# HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 23a9148abdSDoug Rabson# LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 24a9148abdSDoug Rabson# OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 25a9148abdSDoug Rabson# SUCH DAMAGE. 26a9148abdSDoug Rabson# 27a9148abdSDoug Rabson# $FreeBSD$ 28a9148abdSDoug Rabson 29a9148abdSDoug Rabson# Interface for the in-kernel part of a GSS-API mechanism 30a9148abdSDoug Rabson 31a9148abdSDoug Rabson#include <kgssapi/gssapi.h> 32a9148abdSDoug Rabson#include "gssd.h" 33a9148abdSDoug Rabson 34a9148abdSDoug RabsonINTERFACE kgss; 35a9148abdSDoug Rabson 36a9148abdSDoug RabsonMETHOD void init { 37a9148abdSDoug Rabson gss_ctx_id_t ctx; 38a9148abdSDoug Rabson}; 39a9148abdSDoug Rabson 40a9148abdSDoug RabsonMETHOD OM_uint32 import { 41a9148abdSDoug Rabson gss_ctx_id_t ctx; 42a9148abdSDoug Rabson enum sec_context_format format; 43a9148abdSDoug Rabson const gss_buffer_t context_token; 44a9148abdSDoug Rabson}; 45a9148abdSDoug Rabson 46a9148abdSDoug RabsonMETHOD void delete { 47a9148abdSDoug Rabson gss_ctx_id_t ctx; 48a9148abdSDoug Rabson gss_buffer_t output_token; 49a9148abdSDoug Rabson}; 50a9148abdSDoug Rabson 51a9148abdSDoug RabsonMETHOD gss_OID mech_type { 52a9148abdSDoug Rabson gss_ctx_id_t ctx; 53a9148abdSDoug Rabson}; 54a9148abdSDoug Rabson 55a9148abdSDoug RabsonMETHOD OM_uint32 get_mic { 56a9148abdSDoug Rabson gss_ctx_id_t ctx; 57a9148abdSDoug Rabson OM_uint32 *minor_status; 58a9148abdSDoug Rabson gss_qop_t qop_req; 59a9148abdSDoug Rabson struct mbuf *message_buffer; 60a9148abdSDoug Rabson struct mbuf **message_token; 61a9148abdSDoug Rabson}; 62a9148abdSDoug Rabson 63a9148abdSDoug RabsonMETHOD OM_uint32 verify_mic { 64a9148abdSDoug Rabson gss_ctx_id_t ctx; 65a9148abdSDoug Rabson OM_uint32 *minor_status; 66a9148abdSDoug Rabson struct mbuf *message_buffer; 67a9148abdSDoug Rabson struct mbuf *token_buffer; 68a9148abdSDoug Rabson gss_qop_t *qop_state; 69a9148abdSDoug Rabson}; 70a9148abdSDoug Rabson 71a9148abdSDoug RabsonMETHOD OM_uint32 wrap { 72a9148abdSDoug Rabson gss_ctx_id_t ctx; 73a9148abdSDoug Rabson OM_uint32 *minor_status; 74a9148abdSDoug Rabson int conf_req_flag; 75a9148abdSDoug Rabson gss_qop_t qop_req; 76a9148abdSDoug Rabson struct mbuf **message_buffer; 77a9148abdSDoug Rabson int *conf_state; 78a9148abdSDoug Rabson}; 79a9148abdSDoug Rabson 80a9148abdSDoug RabsonMETHOD OM_uint32 unwrap { 81a9148abdSDoug Rabson gss_ctx_id_t ctx; 82a9148abdSDoug Rabson OM_uint32 *minor_status; 83a9148abdSDoug Rabson struct mbuf **message_buffer; 84a9148abdSDoug Rabson int *conf_state; 85a9148abdSDoug Rabson gss_qop_t *qop_state; 86a9148abdSDoug Rabson}; 87a9148abdSDoug Rabson 88a9148abdSDoug RabsonMETHOD OM_uint32 wrap_size_limit { 89a9148abdSDoug Rabson gss_ctx_id_t ctx; 90a9148abdSDoug Rabson OM_uint32 *minor_status; 91a9148abdSDoug Rabson int conf_req_flag; 92a9148abdSDoug Rabson gss_qop_t qop_req; 93a9148abdSDoug Rabson OM_uint32 req_ouput_size; 94a9148abdSDoug Rabson OM_uint32 *max_input_size; 95a9148abdSDoug Rabson} 96