Ticket.bjs
[gitlive] / RooTicket.vala
index 4764c8e..5d3c357 100644 (file)
@@ -1,4 +1,4 @@
-/**
+/** 
 
 code to fetch ticket info...
 
@@ -13,7 +13,7 @@ public class RooRepo : Object
        public string project_id;
        public string description;
        public string shortname;
-
+       
 
 }
 
@@ -21,8 +21,15 @@ public class RooOption : Object
 {
        
        public string id; // not really important that they are numbers..
+       public string name;     
        public string display_name;
  
+       public RooOption (string id, string name, string display_name)
+       {
+               this.id = id;
+               this.name = name;
+               this.display_name = name;
+       }
 
 }
 
@@ -68,6 +75,14 @@ public class RooTicket : Object
        public Gee.ArrayList<RooTicket> tickets; // only available for singletonn.
        public Gee.ArrayList<RooProject> projects; // only available for singletonn.    
        public Gee.ArrayList<RooRepo> repos; // only available for singletonn.          
+       
+       public Gee.ArrayList<RooOption> milestones;
+       public Gee.ArrayList<RooOption> priorities;
+       public Gee.ArrayList<RooOption> serverities;
+       public Gee.ArrayList<RooOption> classifications;
+       public Gee.ArrayList<RooOption> developers;
+                
+       
        public string username = ""; // only available for singletonn.
        public string password = ""; // only available for singletonn.
 
@@ -99,6 +114,20 @@ public class RooTicket : Object
        
        }
 
+       public Gee.ArrayList<RooOption> readJsonArray(Json.Array a)
+       {
+               var ret = new Gee.ArrayList<RooOption>();
+               for(var i = 0; i < a.get_length(); i++) {
+                       var t = a.get_object_element(i);
+                       ret.add(new RooOption(
+                               t.get_string_member("id"),
+                               t.get_string_member("name"),                            
+                               t.get_string_member("display_name")
+                       ));
+               }
+               return ret;
+                        
+       }
 
        public RooTicket addTicket(Json.Object t)
        {
@@ -424,9 +453,19 @@ public class RooTicket : Object
        }
        public void loadProjectOptions(string pid)
        {
-               RooTicket.singleton().repos = new Gee.ArrayList<RooRepo>();
-        
-               
+               var rt = RooTicket.singleton();
+               rt.milestones = new Gee.ArrayList<RooOption>();
+               rt.priorities =  new Gee.ArrayList<RooOption>();
+               rt.serverities =  new Gee.ArrayList<RooOption>();
+               rt.classifications  =  new Gee.ArrayList<RooOption>();
+               rt.developers =  new Gee.ArrayList<RooOption>();
+               if (pid == "") {
+                       return;
+               }
+               
+
+
                var table = new GLib.HashTable<string, string>(str_hash, str_equal);
         
                table.insert("_options_for",pid);
@@ -459,22 +498,18 @@ public class RooTicket : Object
                                GLib.error(response.get_string_member("errorMsg"));
                                return;
                        }
-                       var rd = response.get_array_member ("data");
+                       var rd = response.get_object_member ("data");
                        
-                       this.milestones = this.readJsonArray( rd.get_array_member("milestone"));
-                       this.priorities = this.readJsonArray( rd.get_array_member("priority"));
-                       this.serverities = this.readJsonArray( rd.get_array_member("severity"));
-                       this.classifications  = this.readJsonArray( rd.get_array_member("classification"));
-                       this.developers = this.readJsonArray( rd.get_array_member("developer"));
+                       rt.milestones = this.readJsonArray( rd.get_array_member("milestone"));
+                       rt.priorities = this.readJsonArray( rd.get_array_member("priority"));
+                       rt.serverities = this.readJsonArray( rd.get_array_member("severity"));
+                       rt.classifications  = this.readJsonArray( rd.get_array_member("classification"));
+                       rt.developers = this.readJsonArray( rd.get_array_member("developer"));
  
                        
                        
                        
                        // got a valid result...
-                       var _this = RooTicket.singleton();
-                       for(var i = 0; i < rd.get_length(); i++) {
-                               _this.addRepo(rd.get_object_element(i));
-                       }
                         
                
                } catch (Error e) {
@@ -560,7 +595,64 @@ public class RooTicket : Object
                }
 
    }
+       public string createTicket(     
+                       string project_id,
+                       string milestone_id,
+                       string priority_id,
+                       string classification_id,
+                       string developer_id,
+                       string summary,
+                       string description
+               ) 
+       {
+                
+               var table = new GLib.HashTable<string, string>(str_hash, str_equal);
+                
+               table.insert("project_id", project_id);
+               table.insert("milestone_id", milestone_id);
+               table.insert("priority_id", priority_id);
+               table.insert("classification_id", classification_id);
+               table.insert("developer_id", developer_id);
+               table.insert("summary", summary);
+               table.insert("description", description);
+                
+               var params = Soup.Form.encode_hash(table);              
+
+               GLib.debug("request POST %s / %s", roourl, id);
 
+               var session = new Soup.Session ();
+               session.timeout = 0;
+               var message = new Soup.Message ("POST", roourl + "/mtrack_ticket");
+               RooTicket.setAuth(message);
+
+               message.set_request ("application/x-www-form-urlencoded", Soup.MemoryUse.STATIC, params.data);
+               session.send_message (message);
+
+
+               var data = (string) message.response_body.flatten().data;
+               GLib.debug("got %s", data);
+               try {
+                          var parser = new Json.Parser ();
+                          parser.load_from_data (data, -1);
+
+                          var response = parser.get_root().get_object();
+                          var status = response.get_boolean_member("success");
+
+                          if(!status){
+                                          GLib.error(response.get_string_member("errorMsg"));
+                                          return "" ;
+                          }
+                               var rd = response.get_object_member ("data");
+                               return rd.get_string_member("id");
+                          
+                               
+
+               } catch (Error e) {
+                          GLib.error(e.message);
+                          return "";
+               }
+   
+       }
        
 }