2 * Copyright (c) 1995, Index Data.
3 * See the file LICENSE for details.
4 * Sebastian Hammer, Adam Dickmeiss
7 * Revision 1.2 1995-06-05 10:52:05 quinn
8 * Fixed some negligences.
10 * Revision 1.1 1995/06/02 09:49:15 quinn
11 * Adding access control
18 int z_Encryption1(ODR o, Z_Encryption1 **p, int opt)
20 if (!odr_sequence_begin(o, p, sizeof(**p)))
21 return opt && odr_ok(o);
23 odr_implicit(o, odr_octetstring, &(*p)->cryptType, ODR_CONTEXT, 1, 1) &&
24 odr_implicit(o, odr_octetstring, &(*p)->credential, ODR_CONTEXT, 2,
26 odr_implicit(o, odr_octetstring, &(*p)->data, ODR_CONTEXT, 3, 0) &&
30 int z_EnumeratedPrompt1(ODR o, Z_EnumeratedPrompt1 **p, int opt)
32 if (!odr_sequence_begin(o, p, sizeof(**p)))
33 return opt && odr_ok(o);
35 odr_implicit(o, odr_integer, &(*p)->type, ODR_CONTEXT, 1, 0) &&
36 odr_implicit(o, odr_visiblestring, &(*p)->suggestedString, ODR_CONTEXT,
41 int z_PromptId1(ODR o, Z_PromptId1 **p, int opt)
43 static Odr_arm arm[] =
45 {ODR_IMPLICIT, ODR_CONTEXT, 1, Z_PromptId1_enumeratedPrompt,
47 {ODR_IMPLICIT, ODR_CONTEXT, 2, Z_PromptId1_nonEnumeratedPrompt,
52 if (o->direction == ODR_DECODE)
53 *p = odr_malloc(o, sizeof(**p));
56 if (odr_choice(o, arm, &(*p)->u, &(*p)->which))
59 return opt && odr_ok(o);
62 int z_PromptInfo1(ODR o, Z_PromptInfo1 **p, int opt)
64 static Odr_arm arm[] =
66 {ODR_IMPLICIT, ODR_CONTEXT, 1, Z_Challenge1_character,
68 {ODR_IMPLICIT, ODR_CONTEXT, 2, Z_Challenge1_encrypted,
73 if (o->direction == ODR_DECODE)
74 *p = odr_malloc(o, sizeof(**p));
77 if (odr_choice(o, arm, &(*p)->u, &(*p)->which))
80 return opt && odr_ok(o);
83 int z_ChallengeUnit1(ODR o, Z_ChallengeUnit1 **p, int opt)
85 if (!odr_sequence_begin(o, p, sizeof(**p)))
86 return opt && odr_ok(o);
88 odr_explicit(o, z_PromptId1, &(*p)->promptId, ODR_CONTEXT, 1, 0) &&
89 odr_implicit(o, odr_visiblestring, &(*p)->defaultResponse, ODR_CONTEXT,
91 odr_explicit(o, z_PromptInfo1, &(*p)->promptInfo, ODR_CONTEXT, 3, 1) &&
92 odr_implicit(o, odr_visiblestring, &(*p)->regExpr, ODR_CONTEXT, 4, 1) &&
93 odr_implicit(o, odr_null, &(*p)->responseRequired, ODR_CONTEXT, 5, 1) &&
94 odr_implicit_settag(o, ODR_CONTEXT, 6) &&
95 (odr_sequence_of(o, odr_visiblestring, &(*p)->allowedValues,
96 &(*p)->num_values) || odr_ok(o)) &&
97 odr_implicit(o, odr_null, &(*p)->shouldSave, ODR_CONTEXT, 7, 1) &&
98 odr_implicit(o, odr_integer, &(*p)->dataType, ODR_CONTEXT, 8, 1) &&
102 int z_Challenge1(ODR o, Z_Challenge1 **p, int opt)
104 if (o->direction == ODR_ENCODE)
105 *p = odr_malloc(o, sizeof(**p));
108 if (odr_sequence_of(o, z_ChallengeUnit1, &(*p)->list,
109 &(*p)->num_challenges))
112 return opt && odr_ok(o);
115 int z_DiagRec(ODR, Z_DiagRec **, int);
117 int z_ResponseUnit1(ODR o, Z_ResponseUnit1 **p, int opt)
119 static Odr_arm arm[] =
121 {ODR_IMPLICIT, ODR_CONTEXT, 1, Z_Response1_string, odr_visiblestring},
122 {ODR_IMPLICIT, ODR_CONTEXT, 2, Z_Response1_accept, odr_bool},
123 {ODR_IMPLICIT, ODR_CONTEXT, 3, Z_Response1_acknowledge, odr_null},
124 {ODR_EXPLICIT, ODR_CONTEXT, 4, Z_Response1_diagnostic, z_DiagRec},
125 {ODR_IMPLICIT, ODR_CONTEXT, 5, Z_Response1_encrypted, z_Encryption1},
129 if (odr_sequence_begin(o, p, sizeof(**p)))
130 return opt && odr_ok(o);
132 odr_explicit(o, z_PromptId1, &(*p)->promptId, ODR_CONTEXT, 1, 0) &&
133 odr_constructed_begin(o, p, ODR_CONTEXT, 2) &&
134 odr_choice(o, arm, &(*p)->u, &(*p)->which) &&
135 odr_constructed_end(o) &&
139 int z_Response1(ODR o, Z_Response1 **p, int opt)
141 if (o->direction == ODR_ENCODE)
142 *p = odr_malloc(o, sizeof(**p));
145 if (odr_sequence_of(o, z_ResponseUnit1, &(*p)->list,
146 &(*p)->num_responses))
149 return opt && odr_ok(o);
152 int z_PromptObject1(ODR o, Z_PromptObject1 **p, int opt)
154 static Odr_arm arm[] =
156 {ODR_IMPLICIT, ODR_CONTEXT, 1, Z_PromptObject1_challenge, z_Challenge1},
157 {ODR_IMPLICIT, ODR_CONTEXT, 2, Z_PromptObject1_response, z_Response1},
161 if (o->direction == ODR_DECODE)
162 *p = odr_malloc(o, sizeof(**p));
165 if (odr_choice(o, arm, &(*p)->u, &(*p)->which))
168 return opt && odr_ok(o);