Clones.bjs
[gitlive] / RooTicket.vala
index 17444d2..d675621 100644 (file)
@@ -33,7 +33,15 @@ static RooTicket  _RooTicket;
 
 public class RooTicket : Object
 {
-       
+       public enum NotMe {
+               TRUE,
+               FALSE
+       }
+       public enum Closed {
+               TRUE,
+               FALSE
+       }
+       
    //const string baseurl = "https://roojs.com/admin.php/Ro/mtrack_ticket"; 
        const string roourl = "https://roojs.com/admin.php/Roo";        
        public static RooTicket singleton()
@@ -117,6 +125,41 @@ public class RooTicket : Object
                return add;
        }
        
+       public RooProject? getProjectByRepo(GitRepo repo)
+       {
+               var rt = RooTicket.singleton();
+               
+               if (rt.repos.size < 1) {
+                       rt.loadRepos();
+               }
+               if (rt.projects.size < 1) {
+                       rt.loadProjects();
+               }
+               
+               var pid = "";
+               foreach(var roo_repo in rt.repos) {
+                       if (roo_repo.shortname == repo.name) {
+                               pid = roo_repo.project_id;
+                               break;
+                       }
+               }
+               if (pid == "") {
+                       GLib.debug("getProjectByRepo: repo has no project");            
+                       return null;
+               }
+               // get project by id...
+               foreach(var roo_project in rt.projects) {
+                       if (roo_project.id == pid) {
+                               GLib.debug("getProjectByRepo: project_id = %s", pid);
+                               return roo_project;
+                       }
+               }
+               GLib.debug("getProjectByRepo: can not find project");                           
+               return null;
+       
+       }
+       
+       
        public static RooTicket fakeTicket()
        {
                var t = new RooTicket();
@@ -188,17 +231,31 @@ public class RooTicket : Object
                   }
        }
 
-       public void loadTickets()
+       public void loadTickets(string project_id, NotMe not_me, Closed closed)
        {
                RooTicket.singleton().tickets = new Gee.ArrayList<RooTicket>();
         
                
                var table = new GLib.HashTable<string, string>(str_hash, str_equal);
-        
-               table.insert("query[viewtype]","me");
+               if (not_me  == NotMe.FALSE) {
+                       table.insert("query[viewtype]","me");
+               } else {
+               
+               }               
+               if (closed  == Closed.TRUE) {
+                       table.insert("query[viewtype]","me");
+               } else {
+               
+               }
+
                table.insert("limit","999");
                table.insert("sort","summary");
                table.insert("dir","ASC");
+               
+               if (project_id != "") {
+                       table.insert("project_id",project_id);
+               }
+
 
                var params = Soup.Form.encode_hash(table);
                
@@ -216,7 +273,7 @@ public class RooTicket : Object
                session.send_message (message);
                
                var data = (string) message.response_body.flatten().data;
-               GLib.debug("got %s", data);
+               //GLib.debug("got %s", data);
                try {
                        var parser = new Json.Parser ();
                        parser.load_from_data (data, -1);
@@ -273,7 +330,7 @@ public class RooTicket : Object
                session.send_message (message);
                
                var data = (string) message.response_body.flatten().data;
-               GLib.debug("got %s", data);
+               //GLib.debug("got %s", data);
                try {
                        var parser = new Json.Parser ();
                        parser.load_from_data (data, -1);
@@ -328,7 +385,7 @@ public class RooTicket : Object
                session.send_message (message);
                
                var data = (string) message.response_body.flatten().data;
-               GLib.debug("got %s", data);
+               //GLib.debug("got %s", data);
                try {
                        var parser = new Json.Parser ();
                        parser.load_from_data (data, -1);