File open association works, but crashes on exit with message
authorPete Fotheringham <pete.fotheringham@codethink.co.uk>
Tue, 17 Jan 2012 13:02:09 +0000 (13:02 +0000)
committerPete Fotheringham <pete.fotheringham@codethink.co.uk>
Tue, 17 Jan 2012 13:02:09 +0000 (13:02 +0000)
   Exception Type:  EXC_BAD_ACCESS (SIGBUS)
   Exception Codes: KERN_PROTECTION_FAILURE at 0x0000000000000021
   Crashed Thread:  0  Dispatch queue: com.apple.main-thread

mac/moonshot-ui.icns [new file with mode: 0644]
src/moonshot-provisioning-common.vala [new file with mode: 0644]

diff --git a/mac/moonshot-ui.icns b/mac/moonshot-ui.icns
new file mode 100644 (file)
index 0000000..7e0b7e2
Binary files /dev/null and b/mac/moonshot-ui.icns differ
diff --git a/src/moonshot-provisioning-common.vala b/src/moonshot-provisioning-common.vala
new file mode 100644 (file)
index 0000000..23a6b3c
--- /dev/null
@@ -0,0 +1,239 @@
+namespace WebProvisioning
+{ 
+  IdCard card;
+  IdCard[] cards;
+
+  bool
+  check_stack (SList<string> stack, string[] reference)
+  {
+    if (stack.length () < reference.length)
+      return false;
+    
+    for (int i = 0; i<reference.length; i++)
+    {
+      if (stack.nth_data(i) != reference[i])
+        return false;
+    }
+
+    return true;
+  }
+
+  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, realm_path);
+  }
+
+  bool
+  password_handler (SList<string> stack)
+  {
+    string[] password_path = {"password", "identity", "identities"};
+    
+    return check_stack (stack, password_path);
+  }
+
+  bool
+  user_handler (SList<string> stack)
+  {
+    string[] user_path = {"user", "identity", "identities"};
+    
+    return check_stack (stack, user_path);
+  }
+
+  bool
+  display_name_handler (SList<string> stack)
+  {
+    string[] display_name_path = {"display-name", "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
+  {
+    unowned SList<string> stack = context.get_element_stack ();
+    
+    if (text_len < 1)
+      return;
+    
+    if (stack.nth_data(0) == "display-name" && display_name_handler (stack))
+    {
+      card.display_name = text;
+    }
+    else if (stack.nth_data(0) == "user" && user_handler (stack))
+    {
+      card.username = text;
+    }
+    else if (stack.nth_data(0) == "password" && password_handler (stack))
+    {
+      card.password = text;
+    }
+    else if (stack.nth_data(0) == "realm" && realm_handler (stack))
+    {
+      card.issuer = text;
+    }
+    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;
+    }
+    /* 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" && 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" && 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-alt" && subject_alt_handler (stack))
+    {
+      card.trust_anchor.subject_alt = text;
+    }
+    else if (stack.nth_data(0) == "server-cert" && server_cert_handler (stack))
+    {
+      card.trust_anchor.server_cert = text;
+    }
+  }
+
+  class Parser
+  {
+    private MarkupParser parser;
+    private string       text;
+    private string       path;
+    public Parser (string path)
+    {
+      text = "";
+      this.path = path;
+
+      var file = File.new_for_path (path);
+    
+      try
+      {
+        var dis = new DataInputStream (file.read ());
+        string line;
+        while ((line = dis.read_line (null)) != null)
+          text += line;
+      }
+      catch (GLib.Error e)
+      {
+        error ("Could not retreive file size");
+      }
+      
+      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 (GLib.Error e)
+      {
+        error ("Could not parse %s, invalid content", path);
+      } 
+    }
+  }
+}