BrowserWindow.vala
[app.webkitpdf] / BrowserWindow.vala
index b1693e4..73ac9ce 100644 (file)
@@ -4,7 +4,7 @@ public class BrowserWindow : Object
 {
     public Gtk.Window el;
     private BrowserWindow  _this;
-
+    public string cookie_file;
     public static BrowserWindow singleton()
     {
         if (_BrowserWindow == null) {
@@ -32,6 +32,7 @@ public class BrowserWindow : Object
 
         //listeners
         this.el.destroy.connect( () => {
+                  
             Gtk.main_quit();
         });
         this.el.show.connect( () => {
@@ -53,22 +54,47 @@ public class BrowserWindow : Object
             blog = r.replace(blog, blog.length, 0, ".blogspot.com/ncr/");
           }
           
-         if(webkitpdf.opt_cookies.length > 0) {
-             print("setting cookie %s\n",webkitpdf.opt_cookies);
-             var ses = WebKit.get_default_session();
-             
-             var cookie_jar = new Soup.CookieJar();
-             
-                           var Soup.URI uri = new Soup.URI (blog);
-                           
-                           string[] cookies = webkitpdf.opt_cookies.split ("=", 2);
-                           
-                                cookie_jar.set_accept_policy(Soup.CookieJarAcceptPolicy.ALWAYS);
-                                
-                           cookie_jar.add_cookie(new Soup.Cookie (cookies[0], cookies[1], uri.get_host(), "/", -1));
+         if(webkitpdf.opt_cookies != null) {
+            print("setting cookie %s\n",webkitpdf.opt_cookies);
+               
+            var uri = new Soup.URI (blog);
                            
-                                sess.add_feature(cookie_jar);
-                      
+            string[] cookies = webkitpdf.opt_cookies.split ("=", 2);
+
+            if(cookies.length >=2 ) {             
+#if GTK3               
+                var context = WebKit.WebContext.get_default();          
+                var cookie_manager = context.get_cookie_manager();
+                cookie_manager.set_accept_policy(WebKit.CookieAcceptPolicy.NEVER);
+                string scheme = uri.get_scheme ();
+                var ssl = "FALSE";
+                if (scheme=="https") {
+                    ssl="TRUE";
+                }                
+                try {            
+                    FileIOStream iostream;                           
+                    File file = File.new_tmp ("cookie-XXXXXX.txt", out iostream);
+                    this.cookie_file = file.get_path ();        
+                    print("cookie tmp file name: %s\n", file.get_path ());
+                
+                             OutputStream ostream = iostream.output_stream;
+                             DataOutputStream dostream = new DataOutputStream (ostream);                                            
+                                            
+                             dostream.put_string (uri.get_host() + "\tTRUE\t/\t"+ssl+"\t2147483647\t" + cookies[0] + "\t" + cookies[1] );                            
+                             cookie_manager.set_persistent_storage(file.get_path(), WebKit.CookiePersistentStorage.TEXT);                            
+                    } catch (Error e) {
+                             stdout.printf ("Error: %s\n", e.message);
+                    }          
+#else
+                var sess = WebKit.get_default_session();
+                var cookie_jar = new Soup.CookieJar();                     
+                cookie_jar.set_accept_policy(Soup.CookieJarAcceptPolicy.NEVER);                                 
+                cookie_jar.add_cookie(new Soup.Cookie (cookies[0], cookies[1], uri.get_host(), "/", -1));                          
+                sess.add_feature(cookie_jar);
+#endif                                                                     
+            }
+            
+
          } 
                
          print("loading url %s\n",blog);       
@@ -83,6 +109,7 @@ public class BrowserWindow : Object
             if (cd < 1) {
                print("calling printit - timed out");
                _this.view.printit();
+               
                return false;                   
             }
             return true;
@@ -290,6 +317,7 @@ public class BrowserWindow : Object
             pe.set_page_setup(psetup);
             pe.finished.connect( () => {
                print("print completed\n");
+               
                 Gtk.main_quit();
                        
             });