+ // 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 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)
+ {
+ 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);
+ return add;
+ }
+
+ public RooRepo addRepo(Json.Object t)
+ {
+ var add = new RooRepo();
+ add.id = t.get_string_member("id");
+ add.shortname = t.get_string_member("shortname");
+ add.description = t.get_string_member("description");
+ add.project_id = t.get_string_member("project_id");
+ this.repos.add(add);
+ GLib.debug("ADD project %s : %s : %s", add.id, add.shortname, add.project_id);
+ return add;
+ }
+
+ public RooProject? getProjectByRepo(GitRepo repo)
+ {
+ var rt = RooTicket.singleton();
+
+ if (rt.repos.size < 1) {
+ rt.loadRepos();
+ }
+
+
+ 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 RooProjects.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();
+ t.id = "-1";
+ t.summary = "";
+ t.description = "";
+ t.project_id_name = "";
+ RooTicket.singleton().tickets.add(t);
+ return t;
+ }
+
+
+ public RooTicket? getById(string id)
+ {
+ foreach(var t in this.tickets) {
+ if (t.id == id) {
+ return t;
+ }
+ }
+ if (id == "-1") {
+ return RooTicket.fakeTicket();
+ }
+
+ return this.loadTicket(id);
+
+
+ }
+
+
+ public RooTicket? loadTicket(string id)
+ {
+
+ var table = new GLib.HashTable<string, string>(str_hash, str_equal);
+ table.insert("_id",id);
+
+ var params = Soup.Form.encode_hash(table);
+ var url = "%s/%s?%s" . printf(roourl, "mtrack_ticket", 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(string project_id, Who who, Status status)
+ {
+ RooTicket.singleton().tickets = new Gee.ArrayList<RooTicket>();
+