From 2573b2897cb15085423ed1e1cdf3fe340f187532 Mon Sep 17 00:00:00 2001 From: Alan Knowles Date: Mon, 24 Dec 2018 14:58:59 +0800 Subject: [PATCH] RooProject.vala --- RooProject.vala | 55 +++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 55 insertions(+) diff --git a/RooProject.vala b/RooProject.vala index 5a486578..d869bbea 100644 --- a/RooProject.vala +++ b/RooProject.vala @@ -43,6 +43,61 @@ public class RooProject : Object } + static void loadProjects() // called from singleton... + { + RooTicket.singleton().projects = new Gee.ArrayList(); + + + var table = new GLib.HashTable(str_hash, str_equal); + + table.insert("query[project_filter]","P,N,U"); + table.insert("limit","200"); + table.insert("sort","name"); + table.insert("dir","ASC"); + + var params = Soup.Form.encode_hash(table); + + var url = "%s/%s?%s" . printf(roourl, "core_project", 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; + } + var rd = response.get_array_member ("data"); + + // got a valid result... + var _this = RooTicket.singleton(); + for(var i = 0; i < rd.get_length(); i++) { + _this.addProject(rd.get_object_element(i)); + } + + + } catch (Error e) { + GLib.error(e.message); + return; + } + + } -- 2.39.2