2 * Copyright (c) 2011-2016, JANET(UK)
5 * Redistribution and use in source and binary forms, with or without
6 * modification, are permitted provided that the following conditions
9 * 1. Redistributions of source code must retain the above copyright
10 * notice, this list of conditions and the following disclaimer.
12 * 2. Redistributions in binary form must reproduce the above copyright
13 * notice, this list of conditions and the following disclaimer in the
14 * documentation and/or other materials provided with the distribution.
16 * 3. Neither the name of JANET(UK) nor the names of its contributors
17 * may be used to endorse or promote products derived from this software
18 * without specific prior written permission.
20 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
21 * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
22 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
23 * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE
24 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
25 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
26 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
27 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
28 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
29 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
35 namespace WebProvisioning
37 bool check_stack(SList<string> stack, string[] reference) {
39 if (stack.length() < reference.length)
42 for (int i = 0; i < reference.length; i++)
44 if (stack.nth_data(i) != reference[i])
51 bool always_confirm_handler(SList<string> stack)
53 string[] always_confirm_path = {"always-confirm", "rule", "selection-rules", "identity", "identities"};
55 return check_stack(stack, always_confirm_path);
59 pattern_handler(SList<string> stack)
61 string[] pattern_path = {"pattern", "rule", "selection-rules", "identity", "identities"};
63 return check_stack(stack, pattern_path);
66 bool server_cert_handler(SList<string> stack)
68 string[] server_cert_path = {"server-cert", "trust-anchor", "identity", "identities"};
70 return check_stack(stack, server_cert_path);
73 bool subject_alt_handler(SList<string> stack)
75 string[] subject_alt_path = {"subject-alt", "trust-anchor", "identity", "identities"};
77 return check_stack(stack, subject_alt_path);
80 bool subject_handler(SList<string> stack)
82 string[] subject_path = {"subject", "trust-anchor", "identity", "identities"};
84 return check_stack(stack, subject_path);
87 bool ca_cert_handler(SList<string> stack)
89 string[] ca_path = {"ca-cert", "trust-anchor", "identity", "identities"};
91 return check_stack(stack, ca_path);
94 bool realm_handler(SList<string> stack)
96 string[] realm_path = {"realm", "identity", "identities"};
98 return check_stack(stack, realm_path);
101 bool password_handler(SList<string> stack)
103 string[] password_path = {"password", "identity", "identities"};
105 return check_stack(stack, password_path);
108 bool user_handler(SList<string> stack)
110 string[] user_path = {"user", "identity", "identities"};
112 return check_stack(stack, user_path);
115 bool display_name_handler(SList<string> stack)
117 string[] display_name_path = {"display-name", "identity", "identities"};
119 return check_stack(stack, display_name_path);
122 public class Parser : Object
124 private static MoonshotLogger logger = new MoonshotLogger("WebProvisioning");
126 private void start_element_func(MarkupParseContext context,
128 string[] attribute_names,
129 string[] attribute_values) throws MarkupError
131 if (element_name == "identity")
141 else if (element_name == "rule")
143 card.add_rule(Rule());
147 private void end_element_func(MarkupParseContext context,
148 string element_name) throws MarkupError
150 if (element_name == "identity")
152 if (ta_ca_cert != "" || ta_server_cert != "") {
153 var ta = new TrustAnchor(ta_ca_cert,
158 if (!ta.is_empty()) {
159 string ta_datetime_added = TrustAnchor.format_datetime_now();
160 ta.set_datetime_added(ta_datetime_added);
161 logger.trace("end_element_func : Set ta_datetime_added for '%s' to '%s'".printf(card.display_name, ta_datetime_added));
162 card.set_trust_anchor_from_store(ta);
165 card.set_trust_anchor_from_store(ta);
171 text_element_func(MarkupParseContext context,
173 size_t text_len) throws MarkupError {
174 unowned SList<string> stack = context.get_element_stack();
179 if (stack.nth_data(0) == "display-name" && display_name_handler(stack))
181 card.display_name = text;
183 else if (stack.nth_data(0) == "user" && user_handler(stack))
185 card.username = text;
187 else if (stack.nth_data(0) == "password" && password_handler(stack))
189 card.password = text;
191 else if (stack.nth_data(0) == "realm" && realm_handler(stack))
195 else if (stack.nth_data(0) == "service")
197 card.services.add(text);
201 else if (stack.nth_data(0) == "pattern" && pattern_handler(stack))
203 /* use temp array to workaround valac 0.10 bug accessing array property length */
204 var temp = card.rules;
205 card.rules[temp.length - 1].pattern = text;
207 else if (stack.nth_data(0) == "always-confirm" && always_confirm_handler(stack))
209 if (text == "true" || text == "false") {
210 /* use temp array to workaround valac 0.10 bug accessing array property length*/
211 var temp = card.rules;
212 card.rules[temp.length - 1].always_confirm = text;
215 else if (stack.nth_data(0) == "ca-cert" && ca_cert_handler(stack))
217 ta_ca_cert = text ?? "";
219 else if (stack.nth_data(0) == "server-cert" && server_cert_handler(stack))
221 ta_server_cert = text ?? "";
223 else if (stack.nth_data(0) == "subject" && subject_handler(stack))
227 else if (stack.nth_data(0) == "subject-alt" && subject_alt_handler(stack))
229 ta_subject_alt = text;
233 private const MarkupParser parser = {
234 start_element_func, end_element_func, text_element_func, null, null
237 private MarkupParseContext ctx;
242 private string ta_ca_cert;
243 private string ta_server_cert;
244 private string ta_subject;
245 private string ta_subject_alt;
248 private IdCard[] _cards = {};
250 public IdCard[] cards {
252 private set {_cards = value ?? new IdCard[0] ;}
255 public Parser(string path) {
257 ctx = new MarkupParseContext(parser, 0, this, null);
262 var file = File.new_for_path(path);
266 var dis = new DataInputStream(file.read());
268 while ((line = dis.read_line(null)) != null) {
271 // Preserve newlines.
273 // This may add an extra newline at EOF. Maybe use
274 // dis.read_upto("\n", ...) followed by dis.read_byte() instead?
280 error("Could not retreive file size");
284 public void parse() {
287 ctx.parse(text, text.length);
291 error("Could not parse %s, invalid content", path);