X-Git-Url: http://git.roojs.org/?a=blobdiff_plain;f=RooTicket.vala;h=0858d1f10266df0faf193054814e55648fb3076c;hb=40bf1f4bee21b09eedf5d8e2596ee0b72b234c45;hp=a9237da10df55437241d2fd01055bbbd29832d12;hpb=ada0353bbec77d846ddec8e53ab06c6a4c41bc95;p=gitlive diff --git a/RooTicket.vala b/RooTicket.vala index a9237da1..0858d1f1 100644 --- a/RooTicket.vala +++ b/RooTicket.vala @@ -7,9 +7,10 @@ static RooTicket _RooTicket; -class RooTicket : Object +public class RooTicket : Object { + const string baseurl = "https://roojs.com/admin.php/Roo/mtrack_ticket"; public static RooTicket singleton() { @@ -34,7 +35,7 @@ class RooTicket : Object { // first 5 words of summary.. var regex = new Regex ("[^A-Za-z0-9 ]+"); - var str = regex.replace(this.summary, this.summary.length, 0); + var str = regex.replace(this.summary, this.summary.length,0, ""); string[] words = Regex.split_simple ("[ \t]+", str); var ret = ""; for (var i =0; i< (words.length > 5 ? 5 : words.length); i++) { @@ -42,12 +43,17 @@ class RooTicket : Object ret += words[i]; } return ret; - } + public string usernameLocal() + { + // git username is an email addres... - so this reutrns the local part.. + //?? assumes that all members are under the same domain... normally the case...... + return RooTicket.singleton().username.split("@")[0]; + + } - - public void addTicket(Json.Object t) + public RooTicket addTicket(Json.Object t) { var add = new RooTicket(); add.id = t.get_string_member("id"); @@ -56,6 +62,7 @@ class RooTicket : Object add.project_id_name = t.get_string_member("project_id_name"); this.tickets.add(add); GLib.debug("ADD ticket %s : %s : %s", add.id, add.summary, add.project_id_name); + return add; } public RooTicket? getById(string id) @@ -65,16 +72,58 @@ class RooTicket : Object return t; } } - return null; + return this.loadTicket(id); + } + public RooTicket? loadTicket(string id) + { + + var table = new GLib.HashTable(str_hash, str_equal); + table.insert("_id",id); + + var params = Soup.Form.encode_hash(table); + var url = "%s?%s" . printf(baseurl, params); + GLib.debug("request %s", url); + + var session = new Soup.Session (); + session.timeout = 0; + var message = new Soup.Message ("GET", url); + RooTicket.setAuth(message); + 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 null; + } + var rd = response.get_object_member ("data"); + + return this.addTicket(rd); + + + + } catch (Error e) { + GLib.error(e.message); + return null; + } + } public void loadTickets() { RooTicket.singleton().tickets = new Gee.ArrayList(); - var url = "https://roojs.com/admin.php/Roo/mtrack_ticket"; + var table = new GLib.HashTable(str_hash, str_equal); @@ -86,7 +135,7 @@ class RooTicket : Object var params = Soup.Form.encode_hash(table); - url = "%s?%s" . printf(url, params); + var url = "%s?%s" . printf(baseurl, params); GLib.debug("request %s", url); @@ -145,8 +194,7 @@ class RooTicket : Object } GLib.debug("found password?"); // we are gussing.... - username = bits[3]; - password = bits[5]; + RooTicket.singleton().username = bits[3]; RooTicket.singleton().password = bits[5]; } @@ -160,7 +208,50 @@ class RooTicket : Object } - + public void close(string commits) + { + var table = new GLib.HashTable(str_hash, str_equal); + table.insert("id",id); + table.insert("status_name","resolved"); + table.insert("reason","fixed by Commits: %s".printf(commits)); + var params = Soup.Form.encode_hash(table); + + GLib.debug("request POST %s / %s", baseurl, id); + + var session = new Soup.Session (); + session.timeout = 0; + var message = new Soup.Message ("POST", baseurl); + 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 ; + } + + + + + } catch (Error e) { + GLib.error(e.message); + return ; + } + + } + + } \ No newline at end of file