1 0 stevel /* 2 0 stevel * CDDL HEADER START 3 0 stevel * 4 0 stevel * The contents of this file are subject to the terms of the 5 9698 Peter * Common Development and Distribution License (the "License"). 6 9698 Peter * You may not use this file except in compliance with the License. 7 0 stevel * 8 0 stevel * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE 9 0 stevel * or http://www.opensolaris.org/os/licensing. 10 0 stevel * See the License for the specific language governing permissions 11 0 stevel * and limitations under the License. 12 0 stevel * 13 0 stevel * When distributing Covered Code, include this CDDL HEADER in each 14 0 stevel * file and include the License file at usr/src/OPENSOLARIS.LICENSE. 15 0 stevel * If applicable, add the following below this CDDL HEADER, with the 16 0 stevel * fields enclosed by brackets "[]" replaced with your own identifying 17 0 stevel * information: Portions Copyright [yyyy] [name of copyright owner] 18 0 stevel * 19 0 stevel * CDDL HEADER END 20 0 stevel */ 21 0 stevel /* 22 9698 Peter * Copyright 2009 Sun Microsystems, Inc. All rights reserved. 23 9698 Peter * Use is subject to license terms. 24 0 stevel */ 25 0 stevel 26 0 stevel /* 27 0 stevel * glue routine for gss_seal 28 0 stevel */ 29 0 stevel 30 0 stevel #include <mechglueP.h> 31 9698 Peter 32 9698 Peter static OM_uint32 33 9698 Peter val_seal_args( 34 9698 Peter OM_uint32 *minor_status, 35 9698 Peter gss_ctx_id_t context_handle, 36 9698 Peter gss_buffer_t input_message_buffer, 37 9698 Peter gss_buffer_t output_message_buffer) 38 9698 Peter { 39 9698 Peter 40 9698 Peter /* Initialize outputs. */ 41 9698 Peter 42 9698 Peter if (minor_status != NULL) 43 9698 Peter *minor_status = 0; 44 9698 Peter 45 9698 Peter if (output_message_buffer != GSS_C_NO_BUFFER) { 46 9698 Peter output_message_buffer->length = 0; 47 9698 Peter output_message_buffer->value = NULL; 48 9698 Peter } 49 9698 Peter 50 9698 Peter /* Validate arguments. */ 51 9698 Peter 52 9698 Peter if (minor_status == NULL) 53 9698 Peter return (GSS_S_CALL_INACCESSIBLE_WRITE); 54 9698 Peter 55 9698 Peter if (context_handle == GSS_C_NO_CONTEXT) 56 9698 Peter return (GSS_S_CALL_INACCESSIBLE_READ | GSS_S_NO_CONTEXT); 57 9698 Peter 58 9698 Peter if (input_message_buffer == GSS_C_NO_BUFFER) 59 9698 Peter return (GSS_S_CALL_INACCESSIBLE_READ); 60 9698 Peter 61 9698 Peter if (output_message_buffer == GSS_C_NO_BUFFER) 62 9698 Peter return (GSS_S_CALL_INACCESSIBLE_WRITE); 63 9698 Peter 64 9698 Peter return (GSS_S_COMPLETE); 65 9698 Peter } 66 0 stevel 67 0 stevel /*ARGSUSED*/ 68 0 stevel OM_uint32 69 0 stevel gss_seal(minor_status, 70 0 stevel context_handle, 71 0 stevel conf_req_flag, 72 0 stevel qop_req, 73 0 stevel input_message_buffer, 74 0 stevel conf_state, 75 0 stevel output_message_buffer) 76 0 stevel 77 0 stevel OM_uint32 * minor_status; 78 0 stevel gss_ctx_id_t context_handle; 79 0 stevel int conf_req_flag; 80 0 stevel int qop_req; 81 0 stevel gss_buffer_t input_message_buffer; 82 0 stevel int * conf_state; 83 0 stevel gss_buffer_t output_message_buffer; 84 0 stevel { 85 0 stevel /* EXPORT DELETE START */ 86 0 stevel 87 0 stevel OM_uint32 status; 88 0 stevel gss_union_ctx_id_t ctx; 89 0 stevel gss_mechanism mech; 90 0 stevel 91 9698 Peter status = val_seal_args(minor_status, 92 9698 Peter context_handle, 93 9698 Peter input_message_buffer, 94 9698 Peter output_message_buffer); 95 9698 Peter if (status != GSS_S_COMPLETE) 96 9698 Peter return (status); 97 0 stevel 98 0 stevel /* 99 0 stevel * select the approprate underlying mechanism routine and 100 0 stevel * call it. 101 0 stevel */ 102 0 stevel 103 0 stevel ctx = (gss_union_ctx_id_t) context_handle; 104 0 stevel mech = __gss_get_mechanism(ctx->mech_type); 105 0 stevel 106 0 stevel if (mech) { 107 0 stevel if (mech->gss_seal) 108 0 stevel status = mech->gss_seal( 109 0 stevel mech->context, 110 0 stevel minor_status, 111 0 stevel ctx->internal_ctx_id, 112 0 stevel conf_req_flag, 113 0 stevel qop_req, 114 0 stevel input_message_buffer, 115 0 stevel conf_state, 116 0 stevel output_message_buffer); 117 0 stevel else 118 0 stevel status = GSS_S_UNAVAILABLE; 119 0 stevel 120 0 stevel return (status); 121 0 stevel } 122 0 stevel /* EXPORT DELETE END */ 123 0 stevel 124 0 stevel return (GSS_S_BAD_MECH); 125 0 stevel } 126 0 stevel 127 0 stevel OM_uint32 128 0 stevel gss_wrap(minor_status, 129 0 stevel context_handle, 130 0 stevel conf_req_flag, 131 0 stevel qop_req, 132 0 stevel input_message_buffer, 133 0 stevel conf_state, 134 0 stevel output_message_buffer) 135 0 stevel 136 0 stevel OM_uint32 * minor_status; 137 0 stevel const gss_ctx_id_t context_handle; 138 0 stevel int conf_req_flag; 139 0 stevel gss_qop_t qop_req; 140 0 stevel const gss_buffer_t input_message_buffer; 141 0 stevel int * conf_state; 142 0 stevel gss_buffer_t output_message_buffer; 143 0 stevel 144 0 stevel { 145 0 stevel return gss_seal(minor_status, (gss_ctx_id_t)context_handle, 146 0 stevel conf_req_flag, (int) qop_req, 147 0 stevel (gss_buffer_t)input_message_buffer, conf_state, 148 0 stevel output_message_buffer); 149 0 stevel } 150 0 stevel 151 0 stevel /* 152 0 stevel * New for V2 153 0 stevel */ 154 0 stevel OM_uint32 155 0 stevel gss_wrap_size_limit(minor_status, context_handle, conf_req_flag, 156 0 stevel qop_req, req_output_size, max_input_size) 157 0 stevel OM_uint32 *minor_status; 158 0 stevel const gss_ctx_id_t context_handle; 159 0 stevel int conf_req_flag; 160 0 stevel gss_qop_t qop_req; 161 0 stevel OM_uint32 req_output_size; 162 0 stevel OM_uint32 *max_input_size; 163 0 stevel { 164 0 stevel gss_union_ctx_id_t ctx; 165 0 stevel gss_mechanism mech; 166 0 stevel 167 0 stevel if (minor_status == NULL) 168 0 stevel return (GSS_S_CALL_INACCESSIBLE_WRITE); 169 0 stevel *minor_status = 0; 170 0 stevel 171 0 stevel if (context_handle == GSS_C_NO_CONTEXT) 172 0 stevel return (GSS_S_CALL_INACCESSIBLE_READ | GSS_S_NO_CONTEXT); 173 0 stevel 174 0 stevel if (max_input_size == NULL) 175 0 stevel return (GSS_S_CALL_INACCESSIBLE_WRITE); 176 0 stevel 177 0 stevel /* 178 0 stevel * select the approprate underlying mechanism routine and 179 0 stevel * call it. 180 0 stevel */ 181 0 stevel 182 0 stevel ctx = (gss_union_ctx_id_t) context_handle; 183 0 stevel mech = __gss_get_mechanism(ctx->mech_type); 184 0 stevel 185 0 stevel if (!mech) 186 0 stevel return (GSS_S_BAD_MECH); 187 0 stevel 188 0 stevel if (!mech->gss_wrap_size_limit) 189 0 stevel return (GSS_S_UNAVAILABLE); 190 0 stevel 191 0 stevel return (mech->gss_wrap_size_limit(mech->context, minor_status, 192 0 stevel ctx->internal_ctx_id, conf_req_flag, qop_req, 193 0 stevel req_output_size, max_input_size)); 194 0 stevel } 195