diff options
| author | Stanislav Sedov <stas@FreeBSD.org> | 2011-10-05 07:23:29 +0000 | 
|---|---|---|
| committer | Stanislav Sedov <stas@FreeBSD.org> | 2011-10-05 07:23:29 +0000 | 
| commit | 7c450da7b446c557e05f34a100b597800967d987 (patch) | |
| tree | 57a48e7e9b592f2d5b713e80a4455820625c2b7b /lib/krb5/rd_rep.c | |
| parent | b4e3a10e9339a8400197298021d6ca9b8e3aa039 (diff) | |
Diffstat (limited to 'lib/krb5/rd_rep.c')
| -rw-r--r-- | lib/krb5/rd_rep.c | 89 | 
1 files changed, 42 insertions, 47 deletions
| diff --git a/lib/krb5/rd_rep.c b/lib/krb5/rd_rep.c index 8c9b7bb441d7..391d81c191b8 100644 --- a/lib/krb5/rd_rep.c +++ b/lib/krb5/rd_rep.c @@ -1,41 +1,39 @@  /* - * Copyright (c) 1997 - 2001 Kungliga Tekniska Högskolan - * (Royal Institute of Technology, Stockholm, Sweden).  - * All rights reserved.  + * Copyright (c) 1997 - 2001 Kungliga Tekniska Högskolan + * (Royal Institute of Technology, Stockholm, Sweden). + * All rights reserved.   * - * Redistribution and use in source and binary forms, with or without  - * modification, are permitted provided that the following conditions  - * are met:  + * Redistribution and use in source and binary forms, with or without + * modification, are permitted provided that the following conditions + * are met:   * - * 1. Redistributions of source code must retain the above copyright  - *    notice, this list of conditions and the following disclaimer.  + * 1. Redistributions of source code must retain the above copyright + *    notice, this list of conditions and the following disclaimer.   * - * 2. Redistributions in binary form must reproduce the above copyright  - *    notice, this list of conditions and the following disclaimer in the  - *    documentation and/or other materials provided with the distribution.  + * 2. Redistributions in binary form must reproduce the above copyright + *    notice, this list of conditions and the following disclaimer in the + *    documentation and/or other materials provided with the distribution.   * - * 3. Neither the name of the Institute nor the names of its contributors  - *    may be used to endorse or promote products derived from this software  - *    without specific prior written permission.  + * 3. Neither the name of the Institute nor the names of its contributors + *    may be used to endorse or promote products derived from this software + *    without specific prior written permission.   * - * THIS SOFTWARE IS PROVIDED BY THE INSTITUTE AND CONTRIBUTORS ``AS IS'' AND  - * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE  - * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE  - * ARE DISCLAIMED.  IN NO EVENT SHALL THE INSTITUTE OR CONTRIBUTORS BE LIABLE  - * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL  - * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS  - * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)  - * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT  - * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY  - * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF  - * SUCH DAMAGE.  + * THIS SOFTWARE IS PROVIDED BY THE INSTITUTE AND CONTRIBUTORS ``AS IS'' AND + * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE + * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE + * ARE DISCLAIMED.  IN NO EVENT SHALL THE INSTITUTE OR CONTRIBUTORS BE LIABLE + * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL + * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS + * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) + * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT + * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY + * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF + * SUCH DAMAGE.   */ -#include <krb5_locl.h> +#include "krb5_locl.h" -RCSID("$Id: rd_rep.c 17890 2006-08-21 09:19:22Z lha $"); - -krb5_error_code KRB5_LIB_FUNCTION +KRB5_LIB_FUNCTION krb5_error_code KRB5_LIB_CALL  krb5_rd_rep(krb5_context context,  	    krb5_auth_context auth_context,  	    const krb5_data *inbuf, @@ -48,27 +46,26 @@ krb5_rd_rep(krb5_context context,      krb5_crypto crypto;      krb5_data_zero (&data); -    ret = 0;      ret = decode_AP_REP(inbuf->data, inbuf->length, &ap_rep, &len);      if (ret)  	return ret;      if (ap_rep.pvno != 5) {  	ret = KRB5KRB_AP_ERR_BADVERSION; -	krb5_clear_error_string (context); +	krb5_clear_error_message (context);  	goto out;      }      if (ap_rep.msg_type != krb_ap_rep) {  	ret = KRB5KRB_AP_ERR_MSG_TYPE; -	krb5_clear_error_string (context); +	krb5_clear_error_message (context);  	goto out;      }      ret = krb5_crypto_init(context, auth_context->keyblock, 0, &crypto);      if (ret)  	goto out; -    ret = krb5_decrypt_EncryptedData (context,  -				      crypto,	 +    ret = krb5_decrypt_EncryptedData (context, +				      crypto,  				      KRB5_KU_AP_REQ_ENC_PART,  				      &ap_rep.enc_part,  				      &data); @@ -79,25 +76,23 @@ krb5_rd_rep(krb5_context context,      *repl = malloc(sizeof(**repl));      if (*repl == NULL) {  	ret = ENOMEM; -	krb5_set_error_string (context, "malloc: out of memory"); +	krb5_set_error_message(context, ret, N_("malloc: out of memory", ""));  	goto out;      } -    ret = krb5_decode_EncAPRepPart(context, -				   data.data, -				   data.length, -				   *repl,  -				   &len); -    if (ret) +    ret = decode_EncAPRepPart(data.data, data.length, *repl, &len); +    if (ret) { +	krb5_set_error_message(context, ret, N_("Failed to decode EncAPRepPart", ""));  	return ret; -   -    if (auth_context->flags & KRB5_AUTH_CONTEXT_DO_TIME) {  +    } + +    if (auth_context->flags & KRB5_AUTH_CONTEXT_DO_TIME) {  	if ((*repl)->ctime != auth_context->authenticator->ctime || -	    (*repl)->cusec != auth_context->authenticator->cusec)  +	    (*repl)->cusec != auth_context->authenticator->cusec)  	{  	    krb5_free_ap_rep_enc_part(context, *repl);  	    *repl = NULL;  	    ret = KRB5KRB_AP_ERR_MUT_FAIL; -	    krb5_clear_error_string (context); +	    krb5_clear_error_message (context);  	    goto out;  	}      } @@ -106,14 +101,14 @@ krb5_rd_rep(krb5_context context,  					 *((*repl)->seq_number));      if ((*repl)->subkey)  	krb5_auth_con_setremotesubkey(context, auth_context, (*repl)->subkey); -   +   out:      krb5_data_free (&data);      free_AP_REP (&ap_rep);      return ret;  } -void KRB5_LIB_FUNCTION +KRB5_LIB_FUNCTION void KRB5_LIB_CALL  krb5_free_ap_rep_enc_part (krb5_context context,  			   krb5_ap_rep_enc_part *val)  { | 
