~ubuntu-branches/ubuntu/maverick/krb5/maverick

« back to all changes in this revision

Viewing changes to src/lib/crypto/encrypt_iov.c

  • Committer: Bazaar Package Importer
  • Author(s): Sam Hartman
  • Date: 2009-05-07 16:16:34 UTC
  • mfrom: (13.1.7 sid)
  • Revision ID: james.westby@ubuntu.com-20090507161634-xqyk0s9na0le4flj
Tags: 1.7dfsg~beta1-4
When  decrypting the TGS response fails with the subkey, try with the
session key to work around Heimdal bug, Closes: #527353 

Show diffs side-by-side

added added

removed removed

Lines of Context:
 
1
/*
 
2
 * lib/crypto/encrypt_iov.c
 
3
 *
 
4
 * Copyright 2008 by the Massachusetts Institute of Technology.
 
5
 * All Rights Reserved.
 
6
 *
 
7
 * Export of this software from the United States of America may
 
8
 *   require a specific license from the United States Government.
 
9
 *   It is the responsibility of any person or organization contemplating
 
10
 *   export to obtain such a license before exporting.
 
11
 * 
 
12
 * WITHIN THAT CONSTRAINT, permission to use, copy, modify, and
 
13
 * distribute this software and its documentation for any purpose and
 
14
 * without fee is hereby granted, provided that the above copyright
 
15
 * notice appear in all copies and that both that copyright notice and
 
16
 * this permission notice appear in supporting documentation, and that
 
17
 * the name of M.I.T. not be used in advertising or publicity pertaining
 
18
 * to distribution of the software without specific, written prior
 
19
 * permission.  Furthermore if you modify this software you must label
 
20
 * your software as modified software and not distribute it in such a
 
21
 * fashion that it might be confused with the original M.I.T. software.
 
22
 * M.I.T. makes no representations about the suitability of
 
23
 * this software for any purpose.  It is provided "as is" without express
 
24
 * or implied warranty.
 
25
 */
 
26
 
 
27
#include "k5-int.h"
 
28
#include "etypes.h"
 
29
 
 
30
krb5_error_code KRB5_CALLCONV
 
31
krb5_c_encrypt_iov(krb5_context context,
 
32
                   const krb5_keyblock *key,
 
33
                   krb5_keyusage usage,
 
34
                   const krb5_data *cipher_state,
 
35
                   krb5_crypto_iov *data,
 
36
                   size_t num_data)
 
37
{
 
38
    int i;
 
39
    const struct krb5_keytypes *ktp = NULL;
 
40
 
 
41
    for (i = 0; i < krb5_enctypes_length; i++) {
 
42
        if (krb5_enctypes_list[i].etype == key->enctype) {
 
43
            ktp = &krb5_enctypes_list[i];
 
44
            break;
 
45
        }
 
46
    }
 
47
 
 
48
    if (ktp == NULL || ktp->aead == NULL) {
 
49
        return KRB5_BAD_ENCTYPE;
 
50
    }
 
51
 
 
52
    return ktp->aead->encrypt_iov(ktp->aead, ktp->enc, ktp->hash,
 
53
                                  key, usage, cipher_state, data, num_data);
 
54
}
 
55