xref: /onnv-gate/usr/src/lib/krb5/plugins/preauth/pkinit/pkinit_accessor.c (revision 7934:6aeeafc994de)
1*7934SMark.Phalan@Sun.COM /*
2*7934SMark.Phalan@Sun.COM  * COPYRIGHT (C) 2006,2007
3*7934SMark.Phalan@Sun.COM  * THE REGENTS OF THE UNIVERSITY OF MICHIGAN
4*7934SMark.Phalan@Sun.COM  * ALL RIGHTS RESERVED
5*7934SMark.Phalan@Sun.COM  *
6*7934SMark.Phalan@Sun.COM  * Permission is granted to use, copy, create derivative works
7*7934SMark.Phalan@Sun.COM  * and redistribute this software and such derivative works
8*7934SMark.Phalan@Sun.COM  * for any purpose, so long as the name of The University of
9*7934SMark.Phalan@Sun.COM  * Michigan is not used in any advertising or publicity
10*7934SMark.Phalan@Sun.COM  * pertaining to the use of distribution of this software
11*7934SMark.Phalan@Sun.COM  * without specific, written prior authorization.  If the
12*7934SMark.Phalan@Sun.COM  * above copyright notice or any other identification of the
13*7934SMark.Phalan@Sun.COM  * University of Michigan is included in any copy of any
14*7934SMark.Phalan@Sun.COM  * portion of this software, then the disclaimer below must
15*7934SMark.Phalan@Sun.COM  * also be included.
16*7934SMark.Phalan@Sun.COM  *
17*7934SMark.Phalan@Sun.COM  * THIS SOFTWARE IS PROVIDED AS IS, WITHOUT REPRESENTATION
18*7934SMark.Phalan@Sun.COM  * FROM THE UNIVERSITY OF MICHIGAN AS TO ITS FITNESS FOR ANY
19*7934SMark.Phalan@Sun.COM  * PURPOSE, AND WITHOUT WARRANTY BY THE UNIVERSITY OF
20*7934SMark.Phalan@Sun.COM  * MICHIGAN OF ANY KIND, EITHER EXPRESS OR IMPLIED, INCLUDING
21*7934SMark.Phalan@Sun.COM  * WITHOUT LIMITATION THE IMPLIED WARRANTIES OF
22*7934SMark.Phalan@Sun.COM  * MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. THE
23*7934SMark.Phalan@Sun.COM  * REGENTS OF THE UNIVERSITY OF MICHIGAN SHALL NOT BE LIABLE
24*7934SMark.Phalan@Sun.COM  * FOR ANY DAMAGES, INCLUDING SPECIAL, INDIRECT, INCIDENTAL, OR
25*7934SMark.Phalan@Sun.COM  * CONSEQUENTIAL DAMAGES, WITH RESPECT TO ANY CLAIM ARISING
26*7934SMark.Phalan@Sun.COM  * OUT OF OR IN CONNECTION WITH THE USE OF THE SOFTWARE, EVEN
27*7934SMark.Phalan@Sun.COM  * IF IT HAS BEEN OR IS HEREAFTER ADVISED OF THE POSSIBILITY OF
28*7934SMark.Phalan@Sun.COM  * SUCH DAMAGES.
29*7934SMark.Phalan@Sun.COM  */
30*7934SMark.Phalan@Sun.COM 
31*7934SMark.Phalan@Sun.COM #include <k5-int.h>
32*7934SMark.Phalan@Sun.COM #include "pkinit_accessor.h"
33*7934SMark.Phalan@Sun.COM 
34*7934SMark.Phalan@Sun.COM #define DEF_FUNC_PTRS(type) \
35*7934SMark.Phalan@Sun.COM krb5_error_code (*k5int_encode_##type)(const type *, krb5_data **); \
36*7934SMark.Phalan@Sun.COM krb5_error_code (*k5int_decode_##type)(const krb5_data *, type **)
37*7934SMark.Phalan@Sun.COM 
38*7934SMark.Phalan@Sun.COM #define DEF_FUNC_PTRS_ARRAY(type) \
39*7934SMark.Phalan@Sun.COM krb5_error_code (*k5int_encode_##type)(const type **, krb5_data **); \
40*7934SMark.Phalan@Sun.COM krb5_error_code (*k5int_decode_##type)(const krb5_data *, type ***)
41*7934SMark.Phalan@Sun.COM 
42*7934SMark.Phalan@Sun.COM DEF_FUNC_PTRS(krb5_auth_pack);
43*7934SMark.Phalan@Sun.COM DEF_FUNC_PTRS(krb5_auth_pack_draft9);
44*7934SMark.Phalan@Sun.COM DEF_FUNC_PTRS(krb5_kdc_dh_key_info);
45*7934SMark.Phalan@Sun.COM DEF_FUNC_PTRS(krb5_pa_pk_as_rep);
46*7934SMark.Phalan@Sun.COM DEF_FUNC_PTRS(krb5_pa_pk_as_rep_draft9);
47*7934SMark.Phalan@Sun.COM DEF_FUNC_PTRS(krb5_pa_pk_as_req);
48*7934SMark.Phalan@Sun.COM DEF_FUNC_PTRS(krb5_pa_pk_as_req_draft9);
49*7934SMark.Phalan@Sun.COM DEF_FUNC_PTRS(krb5_reply_key_pack);
50*7934SMark.Phalan@Sun.COM DEF_FUNC_PTRS(krb5_reply_key_pack_draft9);
51*7934SMark.Phalan@Sun.COM DEF_FUNC_PTRS_ARRAY(krb5_typed_data);
52*7934SMark.Phalan@Sun.COM 
53*7934SMark.Phalan@Sun.COM /* special cases... */
54*7934SMark.Phalan@Sun.COM krb5_error_code (*k5int_decode_krb5_principal_name)
55*7934SMark.Phalan@Sun.COM 	(const krb5_data *, krb5_principal_data **);
56*7934SMark.Phalan@Sun.COM 
57*7934SMark.Phalan@Sun.COM krb5_error_code (*k5int_encode_krb5_td_dh_parameters)
58*7934SMark.Phalan@Sun.COM 	(const krb5_algorithm_identifier **, krb5_data **code);
59*7934SMark.Phalan@Sun.COM krb5_error_code (*k5int_decode_krb5_td_dh_parameters)
60*7934SMark.Phalan@Sun.COM 	(const krb5_data *, krb5_algorithm_identifier ***);
61*7934SMark.Phalan@Sun.COM 
62*7934SMark.Phalan@Sun.COM krb5_error_code (*k5int_encode_krb5_td_trusted_certifiers)
63*7934SMark.Phalan@Sun.COM 	(const krb5_external_principal_identifier **, krb5_data **code);
64*7934SMark.Phalan@Sun.COM krb5_error_code (*k5int_decode_krb5_td_trusted_certifiers)
65*7934SMark.Phalan@Sun.COM 	(const krb5_data *, krb5_external_principal_identifier ***);
66*7934SMark.Phalan@Sun.COM 
67*7934SMark.Phalan@Sun.COM krb5_error_code (*k5int_decode_krb5_as_req)
68*7934SMark.Phalan@Sun.COM 	(const krb5_data *output, krb5_kdc_req **rep);
69*7934SMark.Phalan@Sun.COM krb5_error_code (*k5int_encode_krb5_kdc_req_body)
70*7934SMark.Phalan@Sun.COM 	(const krb5_kdc_req *rep, krb5_data **code);
71*7934SMark.Phalan@Sun.COM void KRB5_CALLCONV (*k5int_krb5_free_kdc_req)
72*7934SMark.Phalan@Sun.COM 	(krb5_context, krb5_kdc_req * );
73*7934SMark.Phalan@Sun.COM void (*k5int_set_prompt_types)
74*7934SMark.Phalan@Sun.COM 	(krb5_context, krb5_prompt_type *);
75*7934SMark.Phalan@Sun.COM krb5_error_code (*k5int_encode_krb5_authdata_elt)
76*7934SMark.Phalan@Sun.COM 	(const krb5_authdata *rep, krb5_data **code);
77*7934SMark.Phalan@Sun.COM 
78*7934SMark.Phalan@Sun.COM 
79*7934SMark.Phalan@Sun.COM 
80*7934SMark.Phalan@Sun.COM /*
81*7934SMark.Phalan@Sun.COM  * Grab internal function pointers from the krb5int_accessor
82*7934SMark.Phalan@Sun.COM  * structure and make them available
83*7934SMark.Phalan@Sun.COM  */
84*7934SMark.Phalan@Sun.COM krb5_error_code
pkinit_accessor_init(void)85*7934SMark.Phalan@Sun.COM pkinit_accessor_init(void)
86*7934SMark.Phalan@Sun.COM {
87*7934SMark.Phalan@Sun.COM     krb5_error_code retval;
88*7934SMark.Phalan@Sun.COM     krb5int_access k5int;
89*7934SMark.Phalan@Sun.COM 
90*7934SMark.Phalan@Sun.COM     retval = krb5int_accessor(&k5int, KRB5INT_ACCESS_VERSION);
91*7934SMark.Phalan@Sun.COM     if (retval)
92*7934SMark.Phalan@Sun.COM 	return retval;
93*7934SMark.Phalan@Sun.COM #define SET_PTRS(type) \
94*7934SMark.Phalan@Sun.COM k5int_encode_##type = k5int.encode_##type; \
95*7934SMark.Phalan@Sun.COM k5int_decode_##type = k5int.decode_##type;
96*7934SMark.Phalan@Sun.COM 
97*7934SMark.Phalan@Sun.COM     SET_PTRS(krb5_auth_pack);
98*7934SMark.Phalan@Sun.COM     SET_PTRS(krb5_auth_pack_draft9);
99*7934SMark.Phalan@Sun.COM     SET_PTRS(krb5_kdc_dh_key_info);
100*7934SMark.Phalan@Sun.COM     SET_PTRS(krb5_pa_pk_as_rep);
101*7934SMark.Phalan@Sun.COM     SET_PTRS(krb5_pa_pk_as_rep_draft9);
102*7934SMark.Phalan@Sun.COM     SET_PTRS(krb5_pa_pk_as_req);
103*7934SMark.Phalan@Sun.COM     SET_PTRS(krb5_pa_pk_as_req_draft9);
104*7934SMark.Phalan@Sun.COM     SET_PTRS(krb5_reply_key_pack);
105*7934SMark.Phalan@Sun.COM     SET_PTRS(krb5_reply_key_pack_draft9);
106*7934SMark.Phalan@Sun.COM     SET_PTRS(krb5_td_dh_parameters);
107*7934SMark.Phalan@Sun.COM     SET_PTRS(krb5_td_trusted_certifiers);
108*7934SMark.Phalan@Sun.COM     SET_PTRS(krb5_typed_data);
109*7934SMark.Phalan@Sun.COM 
110*7934SMark.Phalan@Sun.COM     /* special cases... */
111*7934SMark.Phalan@Sun.COM     k5int_decode_krb5_principal_name = k5int.decode_krb5_principal_name;
112*7934SMark.Phalan@Sun.COM     k5int_decode_krb5_as_req = k5int.decode_krb5_as_req;
113*7934SMark.Phalan@Sun.COM     k5int_encode_krb5_kdc_req_body = k5int.encode_krb5_kdc_req_body;
114*7934SMark.Phalan@Sun.COM     k5int_krb5_free_kdc_req = k5int.krb5_free_kdc_req;
115*7934SMark.Phalan@Sun.COM     k5int_set_prompt_types = k5int.krb5int_set_prompt_types;
116*7934SMark.Phalan@Sun.COM     k5int_encode_krb5_authdata_elt = k5int.encode_krb5_authdata_elt;
117*7934SMark.Phalan@Sun.COM     return 0;
118*7934SMark.Phalan@Sun.COM }
119