+using Moonshot;
+
namespace WebProvisioning
{
- public IdCard card;
+ IdCard card;
+ IdCard[] cards;
bool
check_stack (SList<string> stack, string[] reference)
}
bool
+ always_confirm_handler (SList<string> stack)
+ {
+ string[] always_confirm_path = {"always-confirm", "rule", "selection-rules", "identity", "identities"};
+
+ return check_stack (stack, always_confirm_path);
+ }
+
+ bool
+ pattern_handler (SList<string> stack)
+ {
+ string[] pattern_path = {"pattern", "rule", "selection-rules", "identity", "identities"};
+
+ return check_stack (stack, pattern_path);
+ }
+
+ bool
+ server_cert_handler (SList<string> stack)
+ {
+ string[] server_cert_path = {"server-cert", "trust-anchor", "identity", "identities"};
+
+ return check_stack (stack, server_cert_path);
+ }
+
+ bool
+ subject_alt_handler (SList<string> stack)
+ {
+ string[] subject_alt_path = {"subject-alt", "trust-anchor", "identity", "identities"};
+
+ return check_stack (stack, subject_alt_path);
+ }
+
+ bool
+ subject_handler (SList<string> stack)
+ {
+ string[] subject_path = {"subject", "trust-anchor", "identity", "identities"};
+
+ return check_stack (stack, subject_path);
+ }
+
+ bool
+ ca_cert_handler (SList<string> stack)
+ {
+ string[] ca_path = {"ca-cert", "trust-anchor", "identity", "identities"};
+
+ return check_stack (stack, ca_path);
+ }
+
+ bool
realm_handler (SList<string> stack)
{
string[] realm_path = {"realm", "identity", "identities"};
return check_stack (stack, display_name_path);
}
+
+ public void
+ start_element_func (MarkupParseContext context,
+ string element_name,
+ string[] attribute_names,
+ string[] attribute_values) throws MarkupError
+ {
+ if (element_name == "identity")
+ {
+ IdCard[] tmp_cards = cards;
+
+ cards = new IdCard[tmp_cards.length + 1];
+ for (int i=0; i<tmp_cards.length; i++)
+ {
+ cards[i] = tmp_cards[i];
+ }
+ card = new IdCard();
+ cards[tmp_cards.length] = card;
+ }
+ else if (element_name == "rule")
+ {
+ Rule[] tmp_rules = card.rules;
+ card.rules = new Rule[tmp_rules.length + 1];
+ for (int i=0; i<tmp_rules.length; i++)
+ {
+ card.rules[i] = tmp_rules[i];
+ }
+
+ card.rules[tmp_rules.length] = Rule();
+ }
+ }
- public void text_element_func (MarkupParseContext context,
- string text,
- size_t text_len) throws MarkupError
+ public void
+ text_element_func (MarkupParseContext context,
+ string text,
+ size_t text_len) throws MarkupError
{
unowned SList<string> stack = context.get_element_stack ();
}
else if (stack.nth_data(0) == "service")
{
+ string[] services = card.services;
+ card.services = new string[services.length + 1];
+ for (int i = 0; i<services.length; i++)
+ {
+ card.services[i] = services[i];
+ }
+ card.services[services.length] = text;
}
- else if (stack.nth_data(0) == "pattern")
+ /* Rules */
+ else if (stack.nth_data(0) == "pattern" && pattern_handler (stack))
{
+ card.rules[card.rules.length - 1].pattern = text;
}
- else if (stack.nth_data(0) == "always_confirm")
+ else if (stack.nth_data(0) == "always-confirm" && always_confirm_handler (stack))
{
+ if (text == "true" || text == "false")
+ card.rules[card.rules.length - 1].always_confirm = text;
}
-
/*Trust anchor*/
- else if (stack.nth_data(0) == "ca-cert")
+ else if (stack.nth_data(0) == "ca-cert" && ca_cert_handler (stack))
+ {
+ card.trust_anchor.ca_cert = text;
+ }
+ else if (stack.nth_data(0) == "subject" && subject_handler (stack))
{
+ card.trust_anchor.subject = text;
}
- else if (stack.nth_data(0) == "subject")
+ else if (stack.nth_data(0) == "subject-alt" && subject_alt_handler (stack))
{
+ card.trust_anchor.subject_alt = text;
}
- else if (stack.nth_data(0) == "ca-cert")
+ else if (stack.nth_data(0) == "server-cert" && server_cert_handler (stack))
{
+ card.trust_anchor.server_cert = text;
}
}
- class WebProvisionParser
+ class Parser
{
- public WebProvisionParser (string path)
+ private MarkupParser parser;
+ private string text;
+ private string path;
+ public Parser (string path)
{
- string text = "";
+ text = "";
+ this.path = path;
+
var file = File.new_for_path (path);
try
while ((line = dis.read_line (null)) != null)
text += line;
}
- catch (Error e)
+ catch (GLib.Error e)
{
error ("Could not retreive file size");
}
- MarkupParser parser = {null, null, text_element_func, null, null};
-
+ parser = {start_element_func, null, text_element_func, null, null};
+ }
+
+ public void
+ parse ()
+ {
var ctx = new MarkupParseContext(parser, 0, null, null);
try
{
ctx.parse (text, text.length);
}
- catch (Error e)
+ catch (GLib.Error e)
{
error ("Could not parse %s, invalid content", path);
}
error ("%s does not exist", args[1]);
}
- card = new IdCard();
+ var webp = new Parser (args[1]);
+ webp.parse();
- var webp = new WebProvisionParser (args[1]);
-
- debug ("'%s' '%s' '%s' '%s'", card.display_name, card.username, card.password, card.issuer);
+ foreach (IdCard card in cards)
+ {
+ Moonshot.Error error;
+ string[] rules_patterns = {};
+ string[] rules_always_confirm = {};
+
+ if (card.rules.length > 0)
+ {
+ int i = 0;
+ rules_patterns = new string[card.rules.length];
+ rules_always_confirm = new string[card.rules.length];
+ foreach (Rule r in card.rules)
+ {
+ rules_patterns[i] = r.pattern;
+ rules_always_confirm[i] = r.always_confirm;
+ i++;
+ }
+ }
+
+ Moonshot.install_id_card (card.display_name,
+ card.username,
+ card.password,
+ card.issuer,
+ rules_patterns,
+ rules_always_confirm,
+ card.services,
+ card.trust_anchor.ca_cert,
+ card.trust_anchor.subject,
+ card.trust_anchor.subject_alt,
+ card.trust_anchor.server_cert,
+ out error);
+
+ if (error != null)
+ {
+ stderr.printf ("Error: %s", error.message);
+ continue;
+ }
+ }
return 0;
}