X-Git-Url: http://git.roojs.org/?p=app.Builder.js;a=blobdiff_plain;f=src%2FBuilder4%2FFakeServer.vala;h=b788213f138c0385af902d29520bd2aecd7a1262;hp=d5d9f03da1ffed0817bea07f869a8f4e22781a4c;hb=HEAD;hpb=b2ebbac89f6a77b48d98894eb9026b781b8c90ec diff --git a/src/Builder4/FakeServer.vala b/src/Builder4/FakeServer.vala index d5d9f03da..b788213f1 100644 --- a/src/Builder4/FakeServer.vala +++ b/src/Builder4/FakeServer.vala @@ -12,7 +12,185 @@ * * the idea is nicked from geary. * + * At present this serves from ~/gitlive/**** - that probably needs more thought.. + * + * */ +public errordomain FakeServerError { + FILE_DOES_NOT_EXIST +} + +public class FakeServerCache : Object +{ + public string fname; + public uint8[] data; + public string content_type; + public int64 size; + + public static Gee.HashMap cache; + + public static FakeServerCache factory(string fname, string scheme) + { + if (cache == null) { + cache = new Gee.HashMap(); + } + + // print ("CACHE look for ==%s==\n", fname); + if (scheme == "resources") { + return new FakeServerCache.from_resource(fname); + } + + if (cache.has_key(fname)) { + print ("CACHE got %s\n", fname); + return cache.get(fname); + } + print ("CACHE create %s\n", fname); + + var el = new FakeServerCache(fname); + + cache.set(fname, el); + return el; + } + // called onload to clear the temporary cached file.. + public static void remove(string fname) { + if (cache == null) { + return; + } + if (!cache.has_key(fname)) { + return; + } + + + FakeServerCache v; + + cache.unset(fname, out v); + + + + } + public static void clear() + { + if (cache == null) { + return; + } + cache.clear(); + } + + public static FakeServerCache factory_with_data(string data) { + if (cache == null) { + cache = new Gee.HashMap(); + } + var el = new FakeServerCache.with_data(data); + print("CACHE - store %s\n", el.fname); + cache.set(el.fname, el); + return el; + } + + + + + public FakeServerCache.with_data( string data ) + { + this.fname = "/" + GLib.Checksum.compute_for_string(GLib.ChecksumType.MD5, data, data.length) + ".js"; + this.data = data.data; + this.content_type = "text/javascript"; + this.size= data.length; + + + } + public FakeServerCache.from_resource( string fname ) + { + + + + this.fname = fname; + + var file = File.new_for_path ( BuilderApplication.configDirectory() + "/resources/" + fname); + if (!file.query_exists()) { + this.data = "".data; + this.content_type = ""; + this.size = 0; + return; + } + try { + var info = file.query_info( + "standard::*", + FileQueryInfoFlags.NONE + ); + + this.content_type = info.get_content_type(); + this.size = info.get_size(); + uint8[] data; + + + GLib.FileUtils.get_data(file.get_path(), out data); + this.data = data; + } catch (Error e) { + this.data = "".data; + this.size = 0; + this.content_type = ""; + return; + } + + + + } + public FakeServerCache( string fname ) { + + this.fname = fname; + + var file = File.new_for_path ( GLib.Environment.get_home_dir() + "/gitlive" + fname); + if (!file.query_exists()) { + this.data = "".data; + this.content_type = ""; + this.size = 0; + return; + } + try { + var info = file.query_info( + "standard::*", + FileQueryInfoFlags.NONE + ); + this.content_type = info.get_content_type(); + this.size = info.get_size(); + uint8[] data; + + + GLib.FileUtils.get_data(file.get_path(), out data); + this.data = data; + } catch (Error e) { + this.data = "".data; + this.size = 0; + this.content_type = ""; + return; + } + + + + print("FakeServerCache :%s, %s (%s/%d)\n", fname , + this.content_type, this.size.to_string(), this.data.length); + + + } + + + public void run(WebKit.URISchemeRequest request, Cancellable? cancellable) + { + var stream = new GLib.MemoryInputStream.from_data (this.data, GLib.free); + print("SEND %s\nwe", this.size.to_string()); + + request.finish(stream, + this.size, + this.content_type); + + + + return; + + } + + +} public class FakeServer : Object { @@ -21,46 +199,41 @@ public class FakeServer : Object public FakeServer(WebKit.WebView wkview) { this.view = wkview; - // - - // Hook up signals. - - //this.view.resource_load_started.connect(on_resource_request_starting); - //this.view.navigation_policy_decision_requested.connect(on_navigation_policy_decision_requested); - //this.view.new_window_policy_decision_requested.connect(on_navigation_policy_decision_requested); - - // - this.view.get_context().register_uri_scheme("xhttp", serve); - - } - + + var cx = WebKit.WebContext.get_default(); + //var cx = this.view.get_context(); + cx.register_uri_scheme("xhttp", serve); + cx.register_uri_scheme("resources", serve); + cx.set_cache_model (WebKit.CacheModel.DOCUMENT_VIEWER); + + // these do not help for cross domain requests.. + + //cx.get_security_manager().register_uri_scheme_as_cors_enabled("xhttp"); + //cx.get_security_manager().register_uri_scheme_as_cors_enabled("http"); + //cx.register_uri_scheme_as_cors_enabled("xhttp"); + // = crash cx.set_process_model (WebKit.ProcessModel.MULTIPLE_SECONDARY_PROCESSES ); + } + + public void serve(WebKit.URISchemeRequest request) { // request is URISchemeRequest print("REQ: %s\n",request.get_path()); - - - var file = File.new_for_path ( GLib.Environment.get_home_dir() + "/gitlive" + request.get_path()); - if (!file.query_exists()) { + var cdata = FakeServerCache.factory(request.get_path() , request.get_scheme()); + + if (cdata.size < 1 ) { print("Skip file missing = %s/gitlive%s\n", GLib.Environment.get_home_dir() , request.get_path()); + request.finish_error(new FakeServerError.FILE_DOES_NOT_EXIST ("My error msg")); return; } - var info = file.query_info( - "standard::*", - FileQueryInfoFlags.NONE - ); - - string data; - size_t length; - GLib.FileUtils.get_contents(file.get_path(), out data, out length); - - var stream = new MemoryInputStream.from_data (data, GLib.free); - - print("Sending %s (%s:%s)\n", request.get_path(), info.get_size().to_string(), info.get_content_type()); - - request.finish ( stream, info.get_size() , info.get_content_type()); - //stream.close(); + + print("Send :%s, %s (%s/%d)", request.get_path(), + cdata.content_type, cdata.size.to_string(), cdata.data.length); + cdata.run(request, null); + } + + }