Do not exit app when responding to identity request, just hide.
[moonshot-ui.git] / src / moonshot-identities-manager.vala
index a0654b3..e0b1dd2 100644 (file)
@@ -1,65 +1,33 @@
-class IdentitiesManager : Object {
-
-    public SList<IdCard> id_card_list;
+using Gee;
 
+public class IdentityManagerModel : Object {
     private const string FILE_NAME = "identities.txt";
 
-    public IdentitiesManager ()
-    {
-        var key_file = new KeyFile ();
-
-        try
-        {
-            key_file.load_from_file (FILE_NAME, KeyFileFlags.NONE);
-        }
-        catch (Error e)
-        {
-            stdout.printf("Error: %s\n", e.message);
-        }
-
-       var identities_uris = key_file.get_groups ();
-       foreach (string identity in identities_uris)
-        {
-            try
-            {
-                IdCard id_card = new IdCard ();
-
-                id_card.issuer = key_file.get_string (identity, "Issuer");
-                id_card.username = key_file.get_string (identity, "Username");
-                id_card.password = key_file.get_string (identity, "Password");
-                id_card.services = key_file.get_string_list (identity, "Services");
-
-                id_card_list.prepend (id_card);
-            }
-            catch (Error e)
-            {
-                stdout.printf ("Error:  %s\n", e.message);
-            }
-        }
+    private IIdentityCardStore store;
+    public LinkedList<IdCard>  get_card_list() {
+         return store.get_card_list(); 
     }
+    public signal void card_list_changed();
 
-    public void store_id_cards ()
-    {
-        var key_file = new KeyFile ();
+    public void add_card(IdCard card) {
+        store.add_card(card);
+        card_list_changed();
+     }
 
-        foreach (IdCard id_card in this.id_card_list)
-        {
-            key_file.set_string (id_card.issuer, "Issuer", id_card.issuer);
-            key_file.set_string (id_card.issuer, "Username", id_card.username);
-            key_file.set_string (id_card.issuer, "Password", id_card.password);
-            key_file.set_string_list (id_card.issuer, "Services", id_card.services);
-        }
+     public void update_card(IdCard card) {
+        store.update_card(card);
+        card_list_changed();
+     }
 
-        var text = key_file.to_data (null);
+     public void remove_card(IdCard card) {
+        store.remove_card(card);
+        card_list_changed();
+     }
 
-        try
-        {
-            FileUtils.set_contents (FILE_NAME, text, -1);
-        }
-        catch (Error e)
-        {
-            stdout.printf ("Error:  %s\n", e.message);
-        }
-    }
+    private IdentityManagerApp parent;
 
+    public IdentityManagerModel(IdentityManagerApp parent_app) {
+        parent = parent_app;
+        store = new LocalFlatFileStore();
+    }
 }