X-Git-Url: http://git.roojs.org/?a=blobdiff_plain;f=RooTicket.vala;h=f845baaf816c3738dee8b6946f427ee136f9d2c5;hb=265adcf86cbf103f51c08f6a02ba486633b148b0;hp=b0998f0429aedde710649d3df643e32ca5631c1e;hpb=eb8c973393ade7a0cee9267a032fee902d430356;p=gitlive diff --git a/RooTicket.vala b/RooTicket.vala index b0998f04..f845baaf 100644 --- a/RooTicket.vala +++ b/RooTicket.vala @@ -2,7 +2,6 @@ code to fetch ticket info... - */ static RooTicket _RooTicket; @@ -21,6 +20,9 @@ class RooTicket : Object return _RooTicket; } public Gee.ArrayList tickets; // only available for singletonn. + public string username = ""; // only available for singletonn. + public string password = ""; // only available for singletonn. + public string id; // not really important that they are numbers.. public string summary; @@ -28,23 +30,56 @@ class RooTicket : Object public string project_id_name; - - public void addTicket(JSON.Object t) + public string summaryToBranchName() + { + // first 5 words of summary.. + var regex = new Regex ("[^A-Za-z0-9 ]+"); + 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++) { + ret += ret.length > 0 ? "_" : ""; + ret += words[i]; + } + return ret; + } + public string usernameLocal() { - var add = new Roo.Ticket(); - this.id = t.get_string_member("id"); - this.summary = t.get_string_member("summary"); - this.description = t.get_string_member("description"); - this.project_id_name = t.get_string_member("project_id_name"); - - + // 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) + { + var add = new RooTicket(); + add.id = t.get_string_member("id"); + add.summary = t.get_string_member("summary"); + add.description = t.get_string_member("description"); + 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); + } + + public RooTicket? getById(string id) + { + foreach(var t in this.tickets) { + if (t.id == id) { + return t; + } + } + return null; + + } + - static public void loadTickets() + public void loadTickets() { - var url = "https://roojs.com/admin.php/Roo/mtrack_ticket"); + 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); @@ -54,7 +89,6 @@ class RooTicket : Object table.insert("sort","summary"); table.insert("dir","ASC"); - var params = Soup.Form.encode_hash(table); url = "%s?%s" . printf(url, params); @@ -83,14 +117,14 @@ class RooTicket : Object GLib.error(response.get_string_member("errorMsg")); return; } - var data = response.get_array_member ("data"); + var rd = response.get_array_member ("data"); // got a valid result... - _this = RooTicket.singleton(); - for(var i = 0; i < data.get_length(); i++) { - _this.addTicket(data.get_object_element(i); + var _this = RooTicket.singleton(); + for(var i = 0; i < rd.get_length(); i++) { + _this.addTicket(rd.get_object_element(i)); } - + } catch (Error e) { GLib.error(e.message); @@ -99,30 +133,38 @@ class RooTicket : Object } - static public void setAuth(message) { - - string str; - var username = ""; - var password = ""; - GLib.FileUtils.get_contents(GLib.Environment.get_home_dir() + "/.netrc"), out str); - var lines = str.split("\n"); - for(var i=0; i< lines.length; i++) { - // assumes one line per entry.. if not we are buggered... - var bits = Regex.split_simple ("[ \t]+", line[i].strip()); - if (bits.length < 7 || bits[0] != "machine" || bits[1] != "git.roojs.com") { - continue; - } - // we are gussing.... - username = bits[3]; - password = bits[5]; + public static void setAuth(Soup.Message message) + { + var rs = RooTicket.singleton(); + if (rs.username.length < 1) { + string str; + GLib.FileUtils.get_contents(GLib.Environment.get_home_dir() + "/.netrc", out str); + var lines = str.split("\n"); + for(var i=0; i< lines.length; i++) { + // assumes one line per entry.. if not we are buggered... + GLib.debug("got %s" , lines[i]); + var bits = Regex.split_simple ("[ \t]+", lines[i].strip()); + if (bits.length < 6 || bits[0] != "machine" || bits[1] != "git.roojs.com") { + continue; + } + GLib.debug("found password?"); + // we are gussing.... + + RooTicket.singleton().username = bits[3]; + RooTicket.singleton().password = bits[5]; + } } - var authCode = Base64.encode ("%s:%s".printf(username), password)).data); + + + var authCode = Base64.encode ("%s:%s".printf(rs.username, rs.password).data); message.request_headers.append("Authorization", "Basic %s".printf(authCode)); } + + - \ No newline at end of file + } \ No newline at end of file