Browse Source

enhance: add opfs check

Tienson Qin 1 year ago
parent
commit
0849f801c9
2 changed files with 16 additions and 19 deletions
  1. 12 18
      src/main/frontend/db_worker.cljs
  2. 4 1
      src/main/frontend/persist_db/browser.cljs

+ 12 - 18
src/main/frontend/db_worker.cljs

@@ -22,12 +22,11 @@
   [repo]
   [repo]
   (get @*sqlite-conns repo))
   (get @*sqlite-conns repo))
 
 
-(defn- get-opfs-pool
+(defn- <get-opfs-pool
   []
   []
   (or @*opfs-pool
   (or @*opfs-pool
       (p/let [^js pool (.installOpfsSAHPoolVfs @*sqlite #js {:name "logseq-db"
       (p/let [^js pool (.installOpfsSAHPoolVfs @*sqlite #js {:name "logseq-db"
                                                              :initialCapacity 100})]
                                                              :initialCapacity 100})]
-        ;; (.removeVfs pool)
         (reset! *opfs-pool pool)
         (reset! *opfs-pool pool)
         pool)))
         pool)))
 
 
@@ -45,20 +44,20 @@
 (defn- remove-pfs!
 (defn- remove-pfs!
   "!! use it only for development"
   "!! use it only for development"
   []
   []
-  (p/let [^js pool (get-opfs-pool)]
+  (p/let [^js pool (<get-opfs-pool)]
     (when pool
     (when pool
       (.removeVfs ^js pool))))
       (.removeVfs ^js pool))))
 
 
 (defn- get-file-names
 (defn- get-file-names
   []
   []
-  (p/let [^js pool (get-opfs-pool)]
+  (p/let [^js pool (<get-opfs-pool)]
     (when pool
     (when pool
       (.getFileNames pool))))
       (.getFileNames pool))))
 
 
 (defn- export-db-file
 (defn- export-db-file
   [file-path]
   [file-path]
   ;; TODO: get file name by repo
   ;; TODO: get file name by repo
-  (p/let [^js pool (get-opfs-pool)]
+  (p/let [^js pool (<get-opfs-pool)]
     (when pool
     (when pool
       (.exportFile ^js pool file-path))))
       (.exportFile ^js pool file-path))))
 
 
@@ -107,10 +106,9 @@
 (defn- create-or-open-db!
 (defn- create-or-open-db!
   [repo]
   [repo]
   (when-not (get-sqlite-conn repo)
   (when-not (get-sqlite-conn repo)
-    (p/let [pool (get-opfs-pool)
+    (p/let [pool (<get-opfs-pool)
             db (new (.-OpfsSAHPoolDb pool) (str "/" repo ".sqlite"))
             db (new (.-OpfsSAHPoolDb pool) (str "/" repo ".sqlite"))
             storage (new-sqlite-storage repo {})]
             storage (new-sqlite-storage repo {})]
-      (js/console.dir db)
       (swap! *sqlite-conns assoc repo db)
       (swap! *sqlite-conns assoc repo db)
       (.exec db "PRAGMA locking_mode=exclusive")
       (.exec db "PRAGMA locking_mode=exclusive")
       (.exec db "create table if not exists kvs (addr INTEGER primary key, content TEXT)")
       (.exec db "create table if not exists kvs (addr INTEGER primary key, content TEXT)")
@@ -129,18 +127,14 @@
 
 
   Object
   Object
 
 
-  ;; ;; dev-only, close all db connections and db files
-  ;; (unsafeDevCloseAll
-  ;;  [_this]
-  ;;  (.dev_close sqlite-db))
-
-  ;; (getVersion
-  ;;  [_this]
-  ;;  (.get_version sqlite-db))
+  (getVersion
+   [_this]
+   (when-let [sqlite @*sqlite]
+     (.-version sqlite)))
 
 
-  ;; (supportOPFS
-  ;;  [_this]
-  ;;  (.has_opfs_support sqlite-db))
+  (supportOPFS
+   [_this]
+   (some? (.-createSyncAccessHandle (.-prototype js/FileSystemFileHandle))))
 
 
   (init
   (init
    [_this]
    [_this]

+ 4 - 1
src/main/frontend/persist_db/browser.cljs

@@ -22,7 +22,10 @@
           worker (js/Worker. worker-url)
           worker (js/Worker. worker-url)
           sqlite (Comlink/wrap worker)]
           sqlite (Comlink/wrap worker)]
       (reset! *sqlite sqlite)
       (reset! *sqlite sqlite)
-      (.init sqlite))))
+      (p/let [opfs-supported? (.supportOPFS sqlite)]
+        (if opfs-supported?
+          (.init sqlite)
+          (notification/show! "It seems that OPFS is not supported on this browser, please upgrade it to the latest version or use another browser." :error))))))
 
 
 (defrecord InBrowser []
 (defrecord InBrowser []
   protocol/PersistentDB
   protocol/PersistentDB