2 * Originally this was supposed to intercept http calls and redirect them
3 * but that is not supported in webkit2 (without using the extension api)
5 * so for now we have modified our server to serve use a base url of xhttp:
7 * so all relative urls are based on that
9 * Idea is to serve the files from the file system, so no need to setup apache etc...
10 * This should work for the static content like css / javascript etc.. but
11 * will cause issues with 'dynamic' xhr files (eg. the php stuff)
13 * the idea is nicked from geary.
16 public errordomain FakeServerError {
20 public class FakeServerCache : Object
24 public string content_type;
27 public static Gee.HashMap<string,FakeServerCache> cache;
29 public static FakeServerCache factory(string fname)
32 cache = new Gee.HashMap<string,FakeServerCache>();
34 if (cache.has_key(fname)) {
35 return cache.get(fname);
37 var el = new FakeServerCache(fname);
44 public FakeServerCache( string fname) {
45 var file = File.new_for_path ( GLib.Environment.get_home_dir() + "/gitlive" + fname);
46 if (!file.query_exists()) {
48 this.content_type = "";
52 var info = file.query_info(
54 FileQueryInfoFlags.NONE
56 this.content_type = info.get_content_type();
57 this.size = info.get_size();
61 GLib.FileUtils.get_contents(file.get_path(), out data, out length);
65 this.content_type = "";
71 print("FakeServerCache :%s, %s (%s/%d)\n", fname ,
72 this.content_type, this.size.to_string(), this.data.length);
78 public InputStream? run_async( )
80 //var f = ensure_resource();
82 var stream = new GLib.MemoryInputStream.from_data (this.data.data, GLib.free);
86 private async InputStream? run_impl(Cancellable? cancellable) throws GLib.Error
88 SourceFunc callback = run_impl.callback;
89 InputStream? ret = null;
91 new Thread<void*>("builder-fake-webserver", () => {
95 ret = this.run_async();
102 // Schedule the callback in idle
103 Idle.add((owned)callback);
107 // Wait for it to finish, yield to caller
115 // Return the input stream
119 public void run(WebKit.URISchemeRequest request, Cancellable? cancellable)
121 var stream = new GLib.MemoryInputStream.from_data (this.data.data, GLib.free);
122 request.finish(stream,
130 //run_impl.begin(cancellable, (obj, res) => {
131 /*InputStream? stream = null;
134 stream = this.run_impl.end(res);
136 request.finish_error(e);
138 if (stream == null) {
139 stream = new MemoryInputStream();
141 print("Send : %s (%s/%d)\n",
142 this.content_type, this.size.to_string(), this.data.length);
144 request.finish(stream,
154 public class FakeServer : Object
158 public FakeServer(WebKit.WebView wkview)
168 //this.view.resource_load_started.connect(on_resource_request_starting);
169 //this.view.navigation_policy_decision_requested.connect(on_navigation_policy_decision_requested);
170 //this.view.new_window_policy_decision_requested.connect(on_navigation_policy_decision_requested);
173 var cx = WebKit.WebContext.get_default();
174 //var cx = this.view.get_context();
175 cx.register_uri_scheme("xhttp", serve);
176 cx.set_cache_model (WebKit.CacheModel.DOCUMENT_VIEWER);
177 // = crash cx.set_process_model (WebKit.ProcessModel.MULTIPLE_SECONDARY_PROCESSES );
181 public void serve(WebKit.URISchemeRequest request)
183 // request is URISchemeRequest
185 print("REQ: %s\n",request.get_path());
186 var cdata = FakeServerCache.factory(request.get_path());
188 if (cdata.size < 1 ) {
189 print("Skip file missing = %s/gitlive%s\n", GLib.Environment.get_home_dir() , request.get_path());
190 request.finish_error(new FakeServerError.FILE_DOES_NOT_EXIST ("My error msg"));
194 print("Send :%s, %s (%s/%d)", request.get_path(),
195 cdata.content_type, cdata.size.to_string(), cdata.data.length);
196 cdata.run(request, null);
197 //var stream = new GLib.MemoryInputStream.from_data (cdata.data.data, GLib.free);
199 // we could cache these memory streams... so no need to keep reading from disk...
200 // then what happens if file get's updated - neet to check the data against the cache..
204 //request.finish ( stream, cdata.size , cdata.content_type);