1c0b9f4feSDoug Rabson.\" -*- nroff -*- 2c0b9f4feSDoug Rabson.\" 3c0b9f4feSDoug Rabson.\" Copyright (c) 2005 Doug Rabson 4c0b9f4feSDoug Rabson.\" All rights reserved. 5c0b9f4feSDoug Rabson.\" 6c0b9f4feSDoug Rabson.\" Redistribution and use in source and binary forms, with or without 7c0b9f4feSDoug Rabson.\" modification, are permitted provided that the following conditions 8c0b9f4feSDoug Rabson.\" are met: 9c0b9f4feSDoug Rabson.\" 1. Redistributions of source code must retain the above copyright 10c0b9f4feSDoug Rabson.\" notice, this list of conditions and the following disclaimer. 11c0b9f4feSDoug Rabson.\" 2. Redistributions in binary form must reproduce the above copyright 12c0b9f4feSDoug Rabson.\" notice, this list of conditions and the following disclaimer in the 13c0b9f4feSDoug Rabson.\" documentation and/or other materials provided with the distribution. 14c0b9f4feSDoug Rabson.\" 15c0b9f4feSDoug Rabson.\" THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND 16c0b9f4feSDoug Rabson.\" ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 17c0b9f4feSDoug Rabson.\" IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 18c0b9f4feSDoug Rabson.\" ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE 19c0b9f4feSDoug Rabson.\" FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 20c0b9f4feSDoug Rabson.\" DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 21c0b9f4feSDoug Rabson.\" OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 22c0b9f4feSDoug Rabson.\" HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 23c0b9f4feSDoug Rabson.\" LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 24c0b9f4feSDoug Rabson.\" OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 25c0b9f4feSDoug Rabson.\" SUCH DAMAGE. 26c0b9f4feSDoug Rabson.\" 27c0b9f4feSDoug Rabson.\" The following commands are required for all man pages. 28d76ba3efSGavin Atkinson.Dd January 26, 2010 29c0b9f4feSDoug Rabson.Dt GSS_VERIFY_MIC 3 PRM 30aa12cea2SUlrich Spörlein.Os 31c0b9f4feSDoug Rabson.Sh NAME 32c0b9f4feSDoug Rabson.Nm gss_verify_mic , 33c0b9f4feSDoug Rabson.Nm gss_verify 34c0b9f4feSDoug Rabson.Nd Check a MIC against a message; verify integrity of a received message 35c0b9f4feSDoug Rabson.\" This next command is for sections 2 and 3 only. 36c0b9f4feSDoug Rabson.\" .Sh LIBRARY 37c0b9f4feSDoug Rabson.Sh SYNOPSIS 38c0b9f4feSDoug Rabson.In "gssapi/gssapi.h" 39c0b9f4feSDoug Rabson.Ft OM_uint32 40c0b9f4feSDoug Rabson.Fo gss_verify_mic 41c0b9f4feSDoug Rabson.Fa "OM_uint32 *minor_status" 42c0b9f4feSDoug Rabson.Fa "const gss_ctx_id_t context_handle" 43c0b9f4feSDoug Rabson.Fa "const gss_buffer_t message_buffer" 44c0b9f4feSDoug Rabson.Fa "const gss_buffer_t token_buffer" 45c0b9f4feSDoug Rabson.Fa "gss_qop_t *qop_state" 46c0b9f4feSDoug Rabson.Fc 47c0b9f4feSDoug Rabson.Ft OM_uint32 48c0b9f4feSDoug Rabson.Fo gss_verify 49c0b9f4feSDoug Rabson.Fa "OM_uint32 *minor_status" 50c0b9f4feSDoug Rabson.Fa "gss_ctx_id_t context_handle" 51c0b9f4feSDoug Rabson.Fa "gss_buffer_t message_buffer" 52c0b9f4feSDoug Rabson.Fa "gss_buffer_t token_buffer" 53c0b9f4feSDoug Rabson.Fa "gss_qop_t *qop_state" 54c0b9f4feSDoug Rabson.Fc 55c0b9f4feSDoug Rabson.Sh DESCRIPTION 56c0b9f4feSDoug RabsonVerifies that a cryptographic MIC, 57c0b9f4feSDoug Rabsoncontained in the token parameter, 58c0b9f4feSDoug Rabsonfits the supplied message. 59c0b9f4feSDoug RabsonThe 60c0b9f4feSDoug Rabson.Fa qop_state 61c0b9f4feSDoug Rabsonparameter allows a message recipient to determine the strength of 62c0b9f4feSDoug Rabsonprotection that was applied to the message. 63c0b9f4feSDoug Rabson.Pp 64c0b9f4feSDoug RabsonSince some application-level protocols may wish to use tokens emitted 65c0b9f4feSDoug Rabsonby 66c0b9f4feSDoug Rabson.Fn gss_wrap 67c0b9f4feSDoug Rabsonto provide "secure framing", 68c0b9f4feSDoug Rabsonimplementations must support the calculation and verification of MICs 69c0b9f4feSDoug Rabsonover zero-length messages. 70c0b9f4feSDoug Rabson.Pp 71c0b9f4feSDoug RabsonThe 72c0b9f4feSDoug Rabson.Fn gss_verify 73c0b9f4feSDoug Rabsonroutine is an obsolete variant of 74c0b9f4feSDoug Rabson.Fn gss_verify_mic . 75c0b9f4feSDoug RabsonIt is provided for backwards 76c0b9f4feSDoug Rabsoncompatibility with applications using the GSS-API V1 interface. 77c0b9f4feSDoug RabsonA distinct entrypoint (as opposed to #define) is provided, 78c0b9f4feSDoug Rabsonboth to allow GSS-API V1 applications to link 79c0b9f4feSDoug Rabsonand to retain the slight parameter type differences between the 80c0b9f4feSDoug Rabsonobsolete versions of this routine and its current form. 81c0b9f4feSDoug Rabson.Sh PARAMETERS 82*6a557179SJoel Dahl.Bl -tag -width ".It context_handle" 83c0b9f4feSDoug Rabson.It minor_status 84c0b9f4feSDoug RabsonMechanism specific status code. 85c0b9f4feSDoug Rabson.It context_handle 86c0b9f4feSDoug RabsonIdentifies the context on which the message arrived. 87c0b9f4feSDoug Rabson.It message_buffer 88c0b9f4feSDoug RabsonMessage to be verified. 89c0b9f4feSDoug Rabson.It token_buffer 90c0b9f4feSDoug RabsonToken associated with message. 91c0b9f4feSDoug Rabson.It qop_state 92c0b9f4feSDoug RabsonQuality of protection gained from MIC. 93c0b9f4feSDoug RabsonSpecify 94c0b9f4feSDoug Rabson.Dv NULL 95c0b9f4feSDoug Rabsonif not required. 96c0b9f4feSDoug Rabson.El 97c0b9f4feSDoug Rabson.Sh RETURN VALUES 98*6a557179SJoel Dahl.Bl -tag -width ".It GSS_S_CONTEXT_EXPIRED" 99c0b9f4feSDoug Rabson.It GSS_S_COMPLETE 100c0b9f4feSDoug RabsonSuccessful completion 101c0b9f4feSDoug Rabson.It GSS_S_DEFECTIVE_TOKEN 102c0b9f4feSDoug RabsonThe token failed consistency checks 103c0b9f4feSDoug Rabson.It GSS_S_BAD_SIG 104c0b9f4feSDoug RabsonThe MIC was incorrect 105c0b9f4feSDoug Rabson.It GSS_S_DUPLICATE_TOKEN 106c0b9f4feSDoug RabsonThe token was valid, 107c0b9f4feSDoug Rabsonand contained a correct MIC for the message, 108c0b9f4feSDoug Rabsonbut it had already been processed 109c0b9f4feSDoug Rabson.It GSS_S_OLD_TOKEN 110c0b9f4feSDoug RabsonThe token was valid, 111c0b9f4feSDoug Rabsonand contained a correct MIC for the message, 112c0b9f4feSDoug Rabsonbut it is too old to check for duplication 113c0b9f4feSDoug Rabson.It GSS_S_UNSEQ_TOKEN 114c0b9f4feSDoug RabsonThe token was valid, 115c0b9f4feSDoug Rabsonand contained a correct MIC for the message, 116c0b9f4feSDoug Rabsonbut has been verified out of sequence; 117c0b9f4feSDoug Rabsona later token has already been received. 118c0b9f4feSDoug Rabson.It GSS_S_GAP_TOKEN 119c0b9f4feSDoug RabsonThe token was valid, 120c0b9f4feSDoug Rabsonand contained a correct MIC for the message, 121c0b9f4feSDoug Rabsonbut has been verified out of sequence; 122c0b9f4feSDoug Rabsonan earlier expected token has not yet been received 123c0b9f4feSDoug Rabson.It GSS_S_CONTEXT_EXPIRED 124c0b9f4feSDoug RabsonThe context has already expired 125c0b9f4feSDoug Rabson.It GSS_S_NO_CONTEXT 126c0b9f4feSDoug RabsonThe context_handle parameter did not identify a valid context 127c0b9f4feSDoug Rabson.El 128c0b9f4feSDoug Rabson.Sh SEE ALSO 129c0b9f4feSDoug Rabson.Xr gss_wrap 3 130c0b9f4feSDoug Rabson.Sh STANDARDS 131*6a557179SJoel Dahl.Bl -tag -width ".It RFC 2743" 132c0b9f4feSDoug Rabson.It RFC 2743 133c0b9f4feSDoug RabsonGeneric Security Service Application Program Interface Version 2, Update 1 134c0b9f4feSDoug Rabson.It RFC 2744 135c0b9f4feSDoug RabsonGeneric Security Service API Version 2 : C-bindings 136c0b9f4feSDoug Rabson.El 137c0b9f4feSDoug Rabson.Sh HISTORY 138c0b9f4feSDoug RabsonThe 139c0b9f4feSDoug Rabson.Nm 140d76ba3efSGavin Atkinsonfunction first appeared in 141c0b9f4feSDoug Rabson.Fx 7.0 . 142c0b9f4feSDoug Rabson.Sh AUTHORS 143c0b9f4feSDoug RabsonJohn Wray, Iris Associates 14460b9f20aSDoug Rabson.Sh COPYRIGHT 14560b9f20aSDoug RabsonCopyright (C) The Internet Society (2000). All Rights Reserved. 14660b9f20aSDoug Rabson.Pp 14760b9f20aSDoug RabsonThis document and translations of it may be copied and furnished to 14860b9f20aSDoug Rabsonothers, and derivative works that comment on or otherwise explain it 14960b9f20aSDoug Rabsonor assist in its implementation may be prepared, copied, published 15060b9f20aSDoug Rabsonand distributed, in whole or in part, without restriction of any 15160b9f20aSDoug Rabsonkind, provided that the above copyright notice and this paragraph are 15260b9f20aSDoug Rabsonincluded on all such copies and derivative works. However, this 15360b9f20aSDoug Rabsondocument itself may not be modified in any way, such as by removing 15460b9f20aSDoug Rabsonthe copyright notice or references to the Internet Society or other 15560b9f20aSDoug RabsonInternet organizations, except as needed for the purpose of 15660b9f20aSDoug Rabsondeveloping Internet standards in which case the procedures for 15760b9f20aSDoug Rabsoncopyrights defined in the Internet Standards process must be 15860b9f20aSDoug Rabsonfollowed, or as required to translate it into languages other than 15960b9f20aSDoug RabsonEnglish. 16060b9f20aSDoug Rabson.Pp 16160b9f20aSDoug RabsonThe limited permissions granted above are perpetual and will not be 16260b9f20aSDoug Rabsonrevoked by the Internet Society or its successors or assigns. 16360b9f20aSDoug Rabson.Pp 16460b9f20aSDoug RabsonThis document and the information contained herein is provided on an 16560b9f20aSDoug Rabson"AS IS" basis and THE INTERNET SOCIETY AND THE INTERNET ENGINEERING 16660b9f20aSDoug RabsonTASK FORCE DISCLAIMS ALL WARRANTIES, EXPRESS OR IMPLIED, INCLUDING 16760b9f20aSDoug RabsonBUT NOT LIMITED TO ANY WARRANTY THAT THE USE OF THE INFORMATION 16860b9f20aSDoug RabsonHEREIN WILL NOT INFRINGE ANY RIGHTS OR ANY IMPLIED WARRANTIES OF 16960b9f20aSDoug RabsonMERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE. 170