First go at using Gtk3. Everything builds but there is stuff (Pango modules) missing...
[moonshot-ui.git] / src / moonshot-webp-parser.vala
index 4283e37..94b8e52 100644 (file)
@@ -1,6 +1,9 @@
+using Moonshot;
+
 namespace WebProvisioning
 { 
-  public IdCard card;
+  IdCard card;
+  IdCard[] cards;
 
   bool
   check_stack (SList<string> stack, string[] reference)
@@ -18,6 +21,54 @@ namespace WebProvisioning
   }
 
   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"};
@@ -48,10 +99,42 @@ namespace WebProvisioning
     
     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 ();
     
@@ -76,31 +159,53 @@ namespace WebProvisioning
     }
     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
@@ -110,20 +215,24 @@ namespace WebProvisioning
         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);
       } 
@@ -142,11 +251,47 @@ namespace WebProvisioning
       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;
   }