Windows global stuff:
[krb5.git] / src / lib / krb5 / krb / copy_auth.c
1 /*
2  * lib/krb5/krb/copy_auth.c
3  *
4  * Copyright 1990 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.  M.I.T. makes no representations about the suitability of
20  * this software for any purpose.  It is provided "as is" without express
21  * or implied warranty.
22  * 
23  *
24  * krb5_copy_authdata()
25  */
26
27 #include "k5-int.h"
28
29 static krb5_error_code
30 krb5_copy_authdatum(context, inad, outad)
31     krb5_context context;
32 const krb5_authdata *inad;
33 krb5_authdata **outad;
34 {
35     krb5_authdata *tmpad;
36
37     if (!(tmpad = (krb5_authdata *)malloc(sizeof(*tmpad))))
38         return ENOMEM;
39     *tmpad = *inad;
40     if (!(tmpad->contents = (krb5_octet *)malloc(inad->length))) {
41         krb5_xfree(tmpad);
42         return ENOMEM;
43     }
44     memcpy((char *)tmpad->contents, (char *)inad->contents, inad->length);
45     *outad = tmpad;
46     return 0;
47 }
48
49 /*
50  * Copy an authdata array, with fresh allocation.
51  */
52 krb5_error_code
53 krb5_copy_authdata(context, inauthdat, outauthdat)
54     krb5_context context;
55 krb5_authdata * const * inauthdat;
56 krb5_authdata ***outauthdat;
57 {
58     krb5_error_code retval;
59     krb5_authdata ** tempauthdat;
60     register int nelems = 0;
61
62     if (!inauthdat) {
63             *outauthdat = 0;
64             return 0;
65     }
66
67     while (inauthdat[nelems]) nelems++;
68
69     /* one more for a null terminated list */
70     if (!(tempauthdat = (krb5_authdata **) calloc(nelems+1,
71                                                   sizeof(*tempauthdat))))
72         return ENOMEM;
73
74     for (nelems = 0; inauthdat[nelems]; nelems++) {
75         retval = krb5_copy_authdatum(context, inauthdat[nelems],
76                                      &tempauthdat[nelems]);
77         if (retval) {
78             krb5_free_authdata(context, tempauthdat);
79             return retval;
80         }
81     }
82
83     *outauthdat = tempauthdat;
84     return 0;
85 }