Don't prompt for password when sending 'no identity' card
[moonshot-ui.git] / src / moonshot-webp-parser.vala
index f1d3570..5d9775f 100644 (file)
@@ -1,103 +1,8 @@
+using Moonshot;
+
 namespace WebProvisioning
 { 
-  public IdCard card;
 
-  
-
-  bool
-  display_name_handler (SList<string> stack)
-  {
-    string[] display_name_path = {"display-name", "identity", "identities"};
-    
-    if (stack.length () != display_name_path.length)
-      return false;
-    
-    for (int i = 0; i<display_name_path.length; i++)
-    {
-      if (stack.nth_data(i) != display_name_path[i])
-        return false;
-    }
-    
-    return true;
-  }
-
-  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")
-    {
-    }
-    else if (stack.nth_data(0) == "password")
-    {
-    }
-    else if (stack.nth_data(0) == "realm")
-    {
-    }
-    else if (stack.nth_data(0) == "service")
-    {
-    }
-    else if (stack.nth_data(0) == "pattern")
-    {
-    }
-    else if (stack.nth_data(0) == "always_confirm")
-    {
-    }
-    
-    /*Trust anchor*/
-    else if (stack.nth_data(0) == "ca-cert")
-    {
-    }
-    else if (stack.nth_data(0) == "subject")
-    {
-    }
-    else if (stack.nth_data(0) == "ca-cert")
-    {
-    }
-  }
-
-  class WebProvisionParser
-  {
-    public WebProvisionParser (string path)
-    {
-      string text = "";
-      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 (Error e)
-      {
-        error ("Could not retreive file size");
-      }
-      
-      MarkupParser parser = {null, null, text_element_func, null, null};
-      
-      var ctx = new MarkupParseContext(parser, 0, null, null);
-      
-      try
-      {
-        ctx.parse (text, text.length);
-      }
-      catch (Error e)
-      {
-        error ("Could not parse %s, invalid content", path);
-      } 
-    }
-  }
 
   public static int main (string[] args)
   {
@@ -111,12 +16,48 @@ namespace WebProvisioning
       error ("%s does not exist", args[1]);
     }
     
-    card = new IdCard();
-    
-    var webp = new WebProvisionParser (args[1]);
+    var webp = new Parser (args[1]);
+    webp.parse();
     
-    debug ("%s", card.display_name);
+    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;
   }
 }