0e3817f28b4176c78f2086d88c4abb940f884512
[yaz-moved-to-github.git] / asn / prt-acc.c
1 /*
2  * Copyright (c) 1995-1999, Index Data.
3  * See the file LICENSE for details.
4  * Sebastian Hammer, Adam Dickmeiss
5  *
6  * $Log: prt-acc.c,v $
7  * Revision 1.9  1999-11-30 13:47:11  adam
8  * Improved installation. Moved header files to include/yaz.
9  *
10  * Revision 1.8  1999/04/20 09:56:47  adam
11  * Added 'name' paramter to encoder/decoder routines (typedef Odr_fun).
12  * Modified all encoders/decoders to reflect this change.
13  *
14  * Revision 1.7  1998/02/11 11:53:32  adam
15  * Changed code so that it compiles as C++.
16  *
17  * Revision 1.6  1998/01/05 09:04:57  adam
18  * Fixed bugs in encoders/decoders - Not operator (!) missing.
19  *
20  * Revision 1.5  1995/09/29 17:11:53  quinn
21  * Smallish
22  *
23  * Revision 1.4  1995/09/27  15:02:41  quinn
24  * Modified function heads & prototypes.
25  *
26  * Revision 1.3  1995/08/15  11:59:41  quinn
27  * Updated External
28  *
29  * Revision 1.2  1995/06/05  10:52:05  quinn
30  * Fixed some negligences.
31  *
32  * Revision 1.1  1995/06/02  09:49:15  quinn
33  * Adding access control
34  *
35  *
36  */
37
38 #include <yaz/proto.h>
39
40 int z_Encryption1(ODR o, Z_Encryption1 **p, int opt, const char *name)
41 {
42     if (!odr_sequence_begin(o, p, sizeof(**p), 0))
43         return opt && odr_ok(o);
44     return
45         odr_implicit(o, odr_octetstring, &(*p)->cryptType,
46                      ODR_CONTEXT, 1, 1) &&
47         odr_implicit(o, odr_octetstring, &(*p)->credential,
48                      ODR_CONTEXT, 2, 1) &&
49         odr_implicit(o, odr_octetstring, &(*p)->data, ODR_CONTEXT, 3, 0) &&
50         odr_sequence_end(o);
51 }
52
53 int z_EnumeratedPrompt1(ODR o, Z_EnumeratedPrompt1 **p, int opt,
54                         const char *name)
55 {
56     if (!odr_sequence_begin(o, p, sizeof(**p), 0))
57         return opt && odr_ok(o);
58     return
59         odr_implicit(o, odr_integer, &(*p)->type, ODR_CONTEXT, 1, 0) &&
60         odr_implicit(o, odr_visiblestring, &(*p)->suggestedString, ODR_CONTEXT,
61                      2, 1) &&
62         odr_sequence_end(o);
63 }
64
65 int z_PromptId1(ODR o, Z_PromptId1 **p, int opt, const char *name)
66 {
67     static Odr_arm arm[] =
68     {
69         {ODR_IMPLICIT, ODR_CONTEXT, 1, Z_PromptId1_enumeratedPrompt,
70          (Odr_fun)z_EnumeratedPrompt1, 0},
71         {ODR_IMPLICIT, ODR_CONTEXT, 2, Z_PromptId1_nonEnumeratedPrompt,
72          odr_visiblestring, 0},
73         {-1, -1, -1, -1, 0, 0}
74     };
75     
76     if (o->direction == ODR_DECODE)
77         *p = (Z_PromptId1 *)odr_malloc(o, sizeof(**p));
78     else if (!*p)
79         return opt;
80     if (odr_choice(o, arm, &(*p)->u, &(*p)->which, 0))
81         return 1;
82     *p = 0;
83     return opt && odr_ok(o);
84 }
85
86 int z_PromptInfo1(ODR o, Z_PromptInfo1 **p, int opt, const char *name)
87 {
88     static Odr_arm arm[] =
89     {
90         {ODR_IMPLICIT, ODR_CONTEXT, 1, Z_Challenge1_character,
91          odr_visiblestring, 0},
92         {ODR_IMPLICIT, ODR_CONTEXT, 2, Z_Challenge1_encrypted,
93          (Odr_fun)z_Encryption1, 0},
94         {-1, -1, -1, -1, 0, 0}
95     };
96     
97     if (o->direction == ODR_DECODE)
98         *p = (Z_PromptInfo1 *)odr_malloc(o, sizeof(**p));
99     else if (!*p)
100         return opt;
101     if (odr_choice(o, arm, &(*p)->u, &(*p)->which, 0))
102         return 1;
103     *p = 0;
104     return opt && odr_ok(o);
105 }
106
107 int z_ChallengeUnit1(ODR o, Z_ChallengeUnit1 **p, int opt, const char *name)
108 {
109     if (!odr_sequence_begin(o, p, sizeof(**p), 0))
110         return opt && odr_ok(o);
111     return
112         odr_explicit(o, z_PromptId1, &(*p)->promptId, ODR_CONTEXT, 1, 0) &&
113         odr_implicit(o, odr_visiblestring, &(*p)->defaultResponse,
114                      ODR_CONTEXT, 2, 1) &&
115         odr_explicit(o, z_PromptInfo1, &(*p)->promptInfo,
116                      ODR_CONTEXT, 3, 1) &&
117         odr_implicit(o, odr_visiblestring, &(*p)->regExpr,
118                      ODR_CONTEXT, 4, 1) &&
119         odr_implicit(o, odr_null, &(*p)->responseRequired,
120                      ODR_CONTEXT, 5, 1) &&
121         odr_implicit_settag(o, ODR_CONTEXT, 6) &&
122         (odr_sequence_of(o, odr_visiblestring, &(*p)->allowedValues,
123                          &(*p)->num_values, 0) || odr_ok(o)) &&
124         odr_implicit(o, odr_null, &(*p)->shouldSave, ODR_CONTEXT, 7, 1) &&
125         odr_implicit(o, odr_integer, &(*p)->dataType, ODR_CONTEXT, 8, 1) &&
126         odr_implicit(o, z_External, &(*p)->diagnostic, ODR_CONTEXT, 9, 1) &&
127         odr_sequence_end(o);
128 }
129
130 int z_Challenge1(ODR o, Z_Challenge1 **p, int opt, const char *name)
131 {
132     if (o->direction == ODR_ENCODE)
133         *p = (Z_Challenge1 *)odr_malloc(o, sizeof(**p));
134     else if (!*p)
135         return opt;
136     if (odr_sequence_of(o, (Odr_fun)z_ChallengeUnit1, &(*p)->list,
137                         &(*p)->num_challenges, 0))
138         return 1;
139     *p = 0;
140     return opt && odr_ok(o);
141 }
142
143 int z_ResponseUnit1(ODR o, Z_ResponseUnit1 **p, int opt, const char *name)
144 {
145     static Odr_arm arm[] = 
146     {
147         {ODR_IMPLICIT, ODR_CONTEXT, 1, Z_Response1_string,
148          odr_visiblestring, 0},
149         {ODR_IMPLICIT, ODR_CONTEXT, 2, Z_Response1_accept,
150          (Odr_fun)odr_bool, 0},
151         {ODR_IMPLICIT, ODR_CONTEXT, 3, Z_Response1_acknowledge,
152          (Odr_fun)odr_null, 0},
153         {ODR_EXPLICIT, ODR_CONTEXT, 4, Z_Response1_diagnostic,
154          (Odr_fun)z_DiagRec, 0},
155         {ODR_IMPLICIT, ODR_CONTEXT, 5, Z_Response1_encrypted,
156          (Odr_fun)z_Encryption1, 0},
157         {-1, -1, -1, -1, 0, 0}
158     };
159     
160     if (!odr_sequence_begin(o, p, sizeof(**p), 0))
161         return opt && odr_ok(o);
162     return
163         odr_explicit(o, z_PromptId1, &(*p)->promptId, ODR_CONTEXT, 1, 0) &&
164         odr_constructed_begin(o, p, ODR_CONTEXT, 2, 0) &&
165         odr_choice(o, arm, &(*p)->u, &(*p)->which, 0) &&
166         odr_constructed_end(o) &&
167         odr_sequence_end(o);
168 }
169
170 int z_Response1(ODR o, Z_Response1 **p, int opt, const char *name)
171 {
172     if (o->direction == ODR_ENCODE)
173         *p = (Z_Response1 *)odr_malloc(o, sizeof(**p));
174     else if (!*p)
175         return opt;
176     if (odr_sequence_of(o, (Odr_fun)z_ResponseUnit1, &(*p)->list,
177                         &(*p)->num_responses, 0))
178         return 1;
179     *p = 0;
180     return opt && odr_ok(o);
181 }
182
183 int z_PromptObject1(ODR o, Z_PromptObject1 **p, int opt, const char *name)
184 {
185     static Odr_arm arm[] =
186     {
187         {ODR_IMPLICIT, ODR_CONTEXT, 1, Z_PromptObject1_challenge,
188          (Odr_fun)z_Challenge1, 0},
189         {ODR_IMPLICIT, ODR_CONTEXT, 2, Z_PromptObject1_response,
190          (Odr_fun)z_Response1, 0},
191         {-1, -1, -1, -1, 0, 0}
192     };
193     
194     if (o->direction == ODR_DECODE)
195         *p = (Z_PromptObject1 *)odr_malloc(o, sizeof(**p));
196     else if (!*p)
197         return opt;
198     if (odr_choice(o, arm, &(*p)->u, &(*p)->which, 0))
199         return 1;
200     *p = 0;
201     return opt && odr_ok(o);
202 }