|  | @@ -1,263 +1,78 @@
 | 
											
												
													
														|  |  (ns frontend.fs
 |  |  (ns frontend.fs
 | 
											
												
													
														|  |    (:require [frontend.util :as util :refer-macros [profile]]
 |  |    (:require [frontend.util :as util :refer-macros [profile]]
 | 
											
												
													
														|  |              [frontend.config :as config]
 |  |              [frontend.config :as config]
 | 
											
												
													
														|  | -            [frontend.state :as state]
 |  | 
 | 
											
												
													
														|  |              [clojure.string :as string]
 |  |              [clojure.string :as string]
 | 
											
												
													
														|  | -            [frontend.idb :as idb]
 |  | 
 | 
											
												
													
														|  | -            [frontend.db :as db]
 |  | 
 | 
											
												
													
														|  | -            [frontend.handler.common :as common-handler]
 |  | 
 | 
											
												
													
														|  |              [promesa.core :as p]
 |  |              [promesa.core :as p]
 | 
											
												
													
														|  | -            [goog.object :as gobj]
 |  | 
 | 
											
												
													
														|  | -            [clojure.set :as set]
 |  | 
 | 
											
												
													
														|  |              [lambdaisland.glogi :as log]
 |  |              [lambdaisland.glogi :as log]
 | 
											
												
													
														|  | -            ["/frontend/utils" :as utils]))
 |  | 
 | 
											
												
													
														|  | 
 |  | +            [frontend.fs.protocol :as protocol]
 | 
											
												
													
														|  | 
 |  | +            [frontend.fs.nfs :as nfs]
 | 
											
												
													
														|  | 
 |  | +            [frontend.fs.bfs :as bfs]
 | 
											
												
													
														|  | 
 |  | +            [frontend.fs.node :as node]))
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | -;; We need to cache the file handles in the memory so that
 |  | 
 | 
											
												
													
														|  | -;; the browser will not keep asking permissions.
 |  | 
 | 
											
												
													
														|  | -(defonce nfs-file-handles-cache (atom {}))
 |  | 
 | 
											
												
													
														|  | -
 |  | 
 | 
											
												
													
														|  | -(defn get-nfs-file-handle
 |  | 
 | 
											
												
													
														|  | -  [handle-path]
 |  | 
 | 
											
												
													
														|  | -  (get @nfs-file-handles-cache handle-path))
 |  | 
 | 
											
												
													
														|  | -
 |  | 
 | 
											
												
													
														|  | -(defn add-nfs-file-handle!
 |  | 
 | 
											
												
													
														|  | -  [handle-path handle]
 |  | 
 | 
											
												
													
														|  | -  (swap! nfs-file-handles-cache assoc handle-path handle))
 |  | 
 | 
											
												
													
														|  | -
 |  | 
 | 
											
												
													
														|  | -(defn remove-nfs-file-handle!
 |  | 
 | 
											
												
													
														|  | -  [handle-path]
 |  | 
 | 
											
												
													
														|  | -  (swap! nfs-file-handles-cache dissoc handle-path))
 |  | 
 | 
											
												
													
														|  | -
 |  | 
 | 
											
												
													
														|  | -;; TODO:
 |  | 
 | 
											
												
													
														|  | -;; We need to support several platforms:
 |  | 
 | 
											
												
													
														|  | -;; 1. Chrome native file system API (lighting-fs wip)
 |  | 
 | 
											
												
													
														|  | -;; 2. IndexedDB (lighting-fs)
 |  | 
 | 
											
												
													
														|  | -;; 3. NodeJS
 |  | 
 | 
											
												
													
														|  | -#_(defprotocol Fs
 |  | 
 | 
											
												
													
														|  | -    (mkdir! [this dir])
 |  | 
 | 
											
												
													
														|  | -    (readdir! [this dir])
 |  | 
 | 
											
												
													
														|  | -    (unlink! [this path opts])
 |  | 
 | 
											
												
													
														|  | -    (rename! [this old-path new-path])
 |  | 
 | 
											
												
													
														|  | -    (rmdir! [this dir])
 |  | 
 | 
											
												
													
														|  | -    (read-file [dir path option])
 |  | 
 | 
											
												
													
														|  | -    (write-file! [dir path content])
 |  | 
 | 
											
												
													
														|  | -    (stat [dir path]))
 |  | 
 | 
											
												
													
														|  | 
 |  | +(defonce nfs-record (nfs/->Nfs))
 | 
											
												
													
														|  | 
 |  | +(defonce bfs-record (bfs/->Bfs))
 | 
											
												
													
														|  | 
 |  | +(defonce node-record (node/->Node))
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  (defn local-db?
 |  |  (defn local-db?
 | 
											
												
													
														|  |    [dir]
 |  |    [dir]
 | 
											
												
													
														|  |    (and (string? dir)
 |  |    (and (string? dir)
 | 
											
												
													
														|  |         (config/local-db? (subs dir 1))))
 |  |         (config/local-db? (subs dir 1))))
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | -(defn mkdir
 |  | 
 | 
											
												
													
														|  | 
 |  | +(defn get-fs
 | 
											
												
													
														|  |    [dir]
 |  |    [dir]
 | 
											
												
													
														|  |    (cond
 |  |    (cond
 | 
											
												
													
														|  | -    (local-db? dir)
 |  | 
 | 
											
												
													
														|  | -    (let [[root new-dir] (rest (string/split dir "/"))
 |  | 
 | 
											
												
													
														|  | -          root-handle (str "handle/" root)]
 |  | 
 | 
											
												
													
														|  | -      (->
 |  | 
 | 
											
												
													
														|  | -       (p/let [handle (idb/get-item root-handle)
 |  | 
 | 
											
												
													
														|  | -               _ (when handle (common-handler/verify-permission nil handle true))]
 |  | 
 | 
											
												
													
														|  | -         (when (and handle new-dir
 |  | 
 | 
											
												
													
														|  | -                    (not (string/blank? new-dir)))
 |  | 
 | 
											
												
													
														|  | -           (p/let [handle (.getDirectoryHandle ^js handle new-dir
 |  | 
 | 
											
												
													
														|  | -                                               #js {:create true})
 |  | 
 | 
											
												
													
														|  | -                   handle-path (str root-handle "/" new-dir)
 |  | 
 | 
											
												
													
														|  | -                   _ (idb/set-item! handle-path handle)]
 |  | 
 | 
											
												
													
														|  | -             (add-nfs-file-handle! handle-path handle)
 |  | 
 | 
											
												
													
														|  | -             (println "Stored handle: " (str root-handle "/" new-dir)))))
 |  | 
 | 
											
												
													
														|  | -       (p/catch (fn [error]
 |  | 
 | 
											
												
													
														|  | -                  (js/console.debug "mkdir error: " error ", dir: " dir)
 |  | 
 | 
											
												
													
														|  | -                  (throw error)))))
 |  | 
 | 
											
												
													
														|  | 
 |  | +    (util/electron?)
 | 
											
												
													
														|  | 
 |  | +    node-record
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | -    (and dir js/window.pfs)
 |  | 
 | 
											
												
													
														|  | -    (js/window.pfs.mkdir dir)
 |  | 
 | 
											
												
													
														|  | 
 |  | +    (local-db? dir)
 | 
											
												
													
														|  | 
 |  | +    nfs-record
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |      :else
 |  |      :else
 | 
											
												
													
														|  | -    (println (str "mkdir " dir " failed"))))
 |  | 
 | 
											
												
													
														|  | 
 |  | +    bfs-record))
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | -(defn readdir
 |  | 
 | 
											
												
													
														|  | 
 |  | +(defn mkdir!
 | 
											
												
													
														|  |    [dir]
 |  |    [dir]
 | 
											
												
													
														|  | -  (cond
 |  | 
 | 
											
												
													
														|  | -    (local-db? dir)
 |  | 
 | 
											
												
													
														|  | -    (let [prefix (str "handle/" dir)
 |  | 
 | 
											
												
													
														|  | -          cached-files (keys @nfs-file-handles-cache)]
 |  | 
 | 
											
												
													
														|  | -      (p/resolved
 |  | 
 | 
											
												
													
														|  | -       (->> (filter #(string/starts-with? % (str prefix "/")) cached-files)
 |  | 
 | 
											
												
													
														|  | -            (map (fn [path]
 |  | 
 | 
											
												
													
														|  | -                   (string/replace path prefix ""))))))
 |  | 
 | 
											
												
													
														|  | -
 |  | 
 | 
											
												
													
														|  | -    (and dir js/window.pfs)
 |  | 
 | 
											
												
													
														|  | -    (js/window.pfs.readdir dir)
 |  | 
 | 
											
												
													
														|  | 
 |  | +  (protocol/mkdir! (get-fs dir) dir))
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | -    :else
 |  | 
 | 
											
												
													
														|  | -    nil))
 |  | 
 | 
											
												
													
														|  | 
 |  | +(defn readdir
 | 
											
												
													
														|  | 
 |  | +  [dir]
 | 
											
												
													
														|  | 
 |  | +  (protocol/readdir (get-fs dir) dir))
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | -(defn unlink
 |  | 
 | 
											
												
													
														|  | 
 |  | +(defn unlink!
 | 
											
												
													
														|  |    [path opts]
 |  |    [path opts]
 | 
											
												
													
														|  | -  (cond
 |  | 
 | 
											
												
													
														|  | -    (local-db? path)
 |  | 
 | 
											
												
													
														|  | -    (let [[dir basename] (util/get-dir-and-basename path)
 |  | 
 | 
											
												
													
														|  | -          handle-path (str "handle" path)]
 |  | 
 | 
											
												
													
														|  | -      (->
 |  | 
 | 
											
												
													
														|  | -       (p/let [handle (idb/get-item (str "handle" dir))
 |  | 
 | 
											
												
													
														|  | -               _ (idb/remove-item! handle-path)]
 |  | 
 | 
											
												
													
														|  | -         (when handle
 |  | 
 | 
											
												
													
														|  | -           (.removeEntry ^js handle basename))
 |  | 
 | 
											
												
													
														|  | -         (remove-nfs-file-handle! handle-path))
 |  | 
 | 
											
												
													
														|  | -       (p/catch (fn [error]
 |  | 
 | 
											
												
													
														|  | -                  (log/error :unlink/path {:path path
 |  | 
 | 
											
												
													
														|  | -                                           :error error})))))
 |  | 
 | 
											
												
													
														|  | -
 |  | 
 | 
											
												
													
														|  | -    :else
 |  | 
 | 
											
												
													
														|  | -    (p/let [stat (js/window.pfs.stat path)]
 |  | 
 | 
											
												
													
														|  | -      (if (= (.-type stat) "file")
 |  | 
 | 
											
												
													
														|  | -        (js/window.pfs.unlink path opts)
 |  | 
 | 
											
												
													
														|  | -        (p/rejected "Unlinking a directory is not allowed")))))
 |  | 
 | 
											
												
													
														|  | 
 |  | +  (protocol/unlink! (get-fs path) path opts))
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | -(defn rmdir
 |  | 
 | 
											
												
													
														|  | -  "Remove the directory recursively."
 |  | 
 | 
											
												
													
														|  | 
 |  | +(defn rmdir!
 | 
											
												
													
														|  | 
 |  | +  "Remove the directory recursively.
 | 
											
												
													
														|  | 
 |  | +   Warning: only run it for browser cache."
 | 
											
												
													
														|  |    [dir]
 |  |    [dir]
 | 
											
												
													
														|  | -  (cond
 |  | 
 | 
											
												
													
														|  | -    (local-db? dir)
 |  | 
 | 
											
												
													
														|  | -    nil
 |  | 
 | 
											
												
													
														|  | -
 |  | 
 | 
											
												
													
														|  | -    :else
 |  | 
 | 
											
												
													
														|  | -    (js/window.workerThread.rimraf dir)))
 |  | 
 | 
											
												
													
														|  | 
 |  | +  (protocol/rmdir! (get-fs dir) dir))
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  (defn read-file
 |  |  (defn read-file
 | 
											
												
													
														|  | -  ([dir path]
 |  | 
 | 
											
												
													
														|  | -   (read-file dir path (clj->js {:encoding "utf8"})))
 |  | 
 | 
											
												
													
														|  | -  ([dir path option]
 |  | 
 | 
											
												
													
														|  | -   (cond
 |  | 
 | 
											
												
													
														|  | -     (local-db? dir)
 |  | 
 | 
											
												
													
														|  | -     (let [handle-path (str "handle" dir "/" path)]
 |  | 
 | 
											
												
													
														|  | -       (p/let [handle (idb/get-item handle-path)
 |  | 
 | 
											
												
													
														|  | -               local-file (and handle (.getFile handle))]
 |  | 
 | 
											
												
													
														|  | -         (and local-file (.text local-file))))
 |  | 
 | 
											
												
													
														|  | -
 |  | 
 | 
											
												
													
														|  | -     :else
 |  | 
 | 
											
												
													
														|  | -     (js/window.pfs.readFile (str dir "/" path) option))))
 |  | 
 | 
											
												
													
														|  | -
 |  | 
 | 
											
												
													
														|  | -(defn nfs-saved-handler
 |  | 
 | 
											
												
													
														|  | -  [repo path file]
 |  | 
 | 
											
												
													
														|  | -  (when-let [last-modified (gobj/get file "lastModified")]
 |  | 
 | 
											
												
													
														|  | -    ;; TODO: extract
 |  | 
 | 
											
												
													
														|  | -    (let [path (if (= \/ (first path))
 |  | 
 | 
											
												
													
														|  | -                 (subs path 1)
 |  | 
 | 
											
												
													
														|  | -                 path)]
 |  | 
 | 
											
												
													
														|  | -      (db/set-file-last-modified-at! repo path last-modified))))
 |  | 
 | 
											
												
													
														|  | -
 |  | 
 | 
											
												
													
														|  | -(defn write-file
 |  | 
 | 
											
												
													
														|  | -  ([repo dir path content]
 |  | 
 | 
											
												
													
														|  | -   (write-file repo dir path content nil))
 |  | 
 | 
											
												
													
														|  | -  ([repo dir path content {:keys [old-content last-modified-at]}]
 |  | 
 | 
											
												
													
														|  | -   (->
 |  | 
 | 
											
												
													
														|  | -    (cond
 |  | 
 | 
											
												
													
														|  | -      (local-db? dir)
 |  | 
 | 
											
												
													
														|  | -      (let [parts (string/split path "/")
 |  | 
 | 
											
												
													
														|  | -            basename (last parts)
 |  | 
 | 
											
												
													
														|  | -            sub-dir (->> (butlast parts)
 |  | 
 | 
											
												
													
														|  | -                         (remove string/blank?)
 |  | 
 | 
											
												
													
														|  | -                         (string/join "/"))
 |  | 
 | 
											
												
													
														|  | -            sub-dir-handle-path (str "handle/"
 |  | 
 | 
											
												
													
														|  | -                                     (subs dir 1)
 |  | 
 | 
											
												
													
														|  | -                                     (if sub-dir
 |  | 
 | 
											
												
													
														|  | -                                       (str "/" sub-dir)))
 |  | 
 | 
											
												
													
														|  | -            handle-path (if (= "/" (last sub-dir-handle-path))
 |  | 
 | 
											
												
													
														|  | -                          (subs sub-dir-handle-path 0 (dec (count sub-dir-handle-path)))
 |  | 
 | 
											
												
													
														|  | -                          sub-dir-handle-path)
 |  | 
 | 
											
												
													
														|  | -            basename-handle-path (str handle-path "/" basename)]
 |  | 
 | 
											
												
													
														|  | -        (p/let [file-handle (idb/get-item basename-handle-path)]
 |  | 
 | 
											
												
													
														|  | -          (when file-handle
 |  | 
 | 
											
												
													
														|  | -            (add-nfs-file-handle! basename-handle-path file-handle))
 |  | 
 | 
											
												
													
														|  | -          (if file-handle
 |  | 
 | 
											
												
													
														|  | -            (p/let [local-file (.getFile file-handle)
 |  | 
 | 
											
												
													
														|  | -                    local-content (.text local-file)
 |  | 
 | 
											
												
													
														|  | -                    local-last-modified-at (gobj/get local-file "lastModified")
 |  | 
 | 
											
												
													
														|  | -                    current-time (util/time-ms)
 |  | 
 | 
											
												
													
														|  | -                    new? (> current-time local-last-modified-at)
 |  | 
 | 
											
												
													
														|  | -                    new-created? (nil? last-modified-at)
 |  | 
 | 
											
												
													
														|  | -                    not-changed? (= last-modified-at local-last-modified-at)
 |  | 
 | 
											
												
													
														|  | -                    format (-> (util/get-file-ext path)
 |  | 
 | 
											
												
													
														|  | -                               (config/get-file-format))
 |  | 
 | 
											
												
													
														|  | -                    pending-writes (state/get-write-chan-length)]
 |  | 
 | 
											
												
													
														|  | -              ;; (println {:last-modified-at last-modified-at
 |  | 
 | 
											
												
													
														|  | -              ;;           :local-last-modified-at local-last-modified-at
 |  | 
 | 
											
												
													
														|  | -              ;;           :not-changed? not-changed?
 |  | 
 | 
											
												
													
														|  | -              ;;           :new-created? new-created?
 |  | 
 | 
											
												
													
														|  | -              ;;           :pending-writes pending-writes
 |  | 
 | 
											
												
													
														|  | -              ;;           :local-content local-content
 |  | 
 | 
											
												
													
														|  | -              ;;           :old-content old-content
 |  | 
 | 
											
												
													
														|  | -              ;;           :new? new?})
 |  | 
 | 
											
												
													
														|  | -              (if (and local-content old-content new?
 |  | 
 | 
											
												
													
														|  | -                       (or
 |  | 
 | 
											
												
													
														|  | -                        (> pending-writes 0)
 |  | 
 | 
											
												
													
														|  | -                        not-changed?
 |  | 
 | 
											
												
													
														|  | -                        new-created?))
 |  | 
 | 
											
												
													
														|  | -                (do
 |  | 
 | 
											
												
													
														|  | -                  (p/let [_ (common-handler/verify-permission repo file-handle true)
 |  | 
 | 
											
												
													
														|  | -                          _ (utils/writeFile file-handle content)
 |  | 
 | 
											
												
													
														|  | -                          file (.getFile file-handle)]
 |  | 
 | 
											
												
													
														|  | -                    (when file
 |  | 
 | 
											
												
													
														|  | -                      (nfs-saved-handler repo path file))))
 |  | 
 | 
											
												
													
														|  | -                (do
 |  | 
 | 
											
												
													
														|  | -                  (js/alert (str "The file has been modified in your local disk! File path: " path
 |  | 
 | 
											
												
													
														|  | -                                 ", save your changes and click the refresh button to reload it.")))))
 |  | 
 | 
											
												
													
														|  | -            ;; create file handle
 |  | 
 | 
											
												
													
														|  | -            (->
 |  | 
 | 
											
												
													
														|  | -             (p/let [handle (idb/get-item handle-path)]
 |  | 
 | 
											
												
													
														|  | -               (if handle
 |  | 
 | 
											
												
													
														|  | -                 (do
 |  | 
 | 
											
												
													
														|  | -                   (p/let [_ (common-handler/verify-permission repo handle true)
 |  | 
 | 
											
												
													
														|  | -                           file-handle (.getFileHandle ^js handle basename #js {:create true})
 |  | 
 | 
											
												
													
														|  | -                           _ (idb/set-item! basename-handle-path file-handle)
 |  | 
 | 
											
												
													
														|  | -                           _ (utils/writeFile file-handle content)
 |  | 
 | 
											
												
													
														|  | -                           file (.getFile file-handle)]
 |  | 
 | 
											
												
													
														|  | -                     (when file
 |  | 
 | 
											
												
													
														|  | -                       (nfs-saved-handler repo path file))))
 |  | 
 | 
											
												
													
														|  | -                 (println "Error: directory handle not exists: " handle-path)))
 |  | 
 | 
											
												
													
														|  | -             (p/catch (fn [error]
 |  | 
 | 
											
												
													
														|  | -                        (println "Write local file failed: " {:path path})
 |  | 
 | 
											
												
													
														|  | -                        (js/console.error error)))))))
 |  | 
 | 
											
												
													
														|  | -
 |  | 
 | 
											
												
													
														|  | -      js/window.pfs
 |  | 
 | 
											
												
													
														|  | -      (js/window.pfs.writeFile (str dir "/" path) content)
 |  | 
 | 
											
												
													
														|  | -
 |  | 
 | 
											
												
													
														|  | -      :else
 |  | 
 | 
											
												
													
														|  | -      nil)
 |  | 
 | 
											
												
													
														|  | -    (p/catch (fn [error]
 |  | 
 | 
											
												
													
														|  | -               (log/error :file/write-failed? {:dir dir
 |  | 
 | 
											
												
													
														|  | -                                               :path path
 |  | 
 | 
											
												
													
														|  | -                                               :error error})
 |  | 
 | 
											
												
													
														|  | -               ;; Disable this temporarily
 |  | 
 | 
											
												
													
														|  | -               ;; (js/alert "Current file can't be saved! Please copy its content to your local file system and click the refresh button.")
 |  | 
 | 
											
												
													
														|  | -)))))
 |  | 
 | 
											
												
													
														|  | -
 |  | 
 | 
											
												
													
														|  | -(defn rename
 |  | 
 | 
											
												
													
														|  | 
 |  | +  [dir path]
 | 
											
												
													
														|  | 
 |  | +  (protocol/read-file (get-fs dir) dir path))
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +(defn write-file!
 | 
											
												
													
														|  | 
 |  | +  [repo dir path content opts]
 | 
											
												
													
														|  | 
 |  | +  (->
 | 
											
												
													
														|  | 
 |  | +   (protocol/write-file! (get-fs dir) repo dir path content opts)
 | 
											
												
													
														|  | 
 |  | +   (p/catch (fn [error]
 | 
											
												
													
														|  | 
 |  | +              (log/error :file/write-failed? {:dir dir
 | 
											
												
													
														|  | 
 |  | +                                              :path path
 | 
											
												
													
														|  | 
 |  | +                                              :error error})
 | 
											
												
													
														|  | 
 |  | +              ;; Disable this temporarily
 | 
											
												
													
														|  | 
 |  | +              ;; (js/alert "Current file can't be saved! Please copy its content to your local file system and click the refresh button.")
 | 
											
												
													
														|  | 
 |  | +))))
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +(defn rename!
 | 
											
												
													
														|  |    [repo old-path new-path]
 |  |    [repo old-path new-path]
 | 
											
												
													
														|  |    (cond
 |  |    (cond
 | 
											
												
													
														|  |      ; See https://github.com/isomorphic-git/lightning-fs/issues/41
 |  |      ; See https://github.com/isomorphic-git/lightning-fs/issues/41
 | 
											
												
													
														|  |      (= old-path new-path)
 |  |      (= old-path new-path)
 | 
											
												
													
														|  |      (p/resolved nil)
 |  |      (p/resolved nil)
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | -    (local-db? old-path)
 |  | 
 | 
											
												
													
														|  | -    ;; create new file
 |  | 
 | 
											
												
													
														|  | -    ;; delete old file
 |  | 
 | 
											
												
													
														|  | -    (p/let [[dir basename] (util/get-dir-and-basename old-path)
 |  | 
 | 
											
												
													
														|  | -            [_ new-basename] (util/get-dir-and-basename new-path)
 |  | 
 | 
											
												
													
														|  | -            parts (->> (string/split new-path "/")
 |  | 
 | 
											
												
													
														|  | -                       (remove string/blank?))
 |  | 
 | 
											
												
													
														|  | -            dir (str "/" (first parts))
 |  | 
 | 
											
												
													
														|  | -            new-path (->> (rest parts)
 |  | 
 | 
											
												
													
														|  | -                          (string/join "/"))
 |  | 
 | 
											
												
													
														|  | -            handle (idb/get-item (str "handle" old-path))
 |  | 
 | 
											
												
													
														|  | -            file (.getFile handle)
 |  | 
 | 
											
												
													
														|  | -            content (.text file)
 |  | 
 | 
											
												
													
														|  | -            _ (write-file repo dir new-path content)]
 |  | 
 | 
											
												
													
														|  | -      (unlink old-path nil))
 |  | 
 | 
											
												
													
														|  | -
 |  | 
 | 
											
												
													
														|  |      :else
 |  |      :else
 | 
											
												
													
														|  | -    (js/window.pfs.rename old-path new-path)))
 |  | 
 | 
											
												
													
														|  | 
 |  | +    (protocol/rename! (get-fs old-path) repo old-path new-path)))
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  (defn stat
 |  |  (defn stat
 | 
											
												
													
														|  |    [dir path]
 |  |    [dir path]
 | 
											
										
											
												
													
														|  | @@ -267,32 +82,16 @@
 | 
											
												
													
														|  |                               (subs path 1)
 |  |                               (subs path 1)
 | 
											
												
													
														|  |                               path))
 |  |                               path))
 | 
											
												
													
														|  |                        "")]
 |  |                        "")]
 | 
											
												
													
														|  | -    (cond
 |  | 
 | 
											
												
													
														|  | -      (local-db? dir)
 |  | 
 | 
											
												
													
														|  | -      (if-let [file (get-nfs-file-handle (str "handle/"
 |  | 
 | 
											
												
													
														|  | -                                              (string/replace-first dir "/" "")
 |  | 
 | 
											
												
													
														|  | -                                              append-path))]
 |  | 
 | 
											
												
													
														|  | -        (p/let [file (.getFile file)]
 |  | 
 | 
											
												
													
														|  | -          (let [get-attr #(gobj/get file %)]
 |  | 
 | 
											
												
													
														|  | -            {:file/last-modified-at (get-attr "lastModified")
 |  | 
 | 
											
												
													
														|  | -             :file/size (get-attr "size")
 |  | 
 | 
											
												
													
														|  | -             :file/type (get-attr "type")}))
 |  | 
 | 
											
												
													
														|  | -        (p/rejected "File not exists"))
 |  | 
 | 
											
												
													
														|  | -
 |  | 
 | 
											
												
													
														|  | -      :else
 |  | 
 | 
											
												
													
														|  | -      (do
 |  | 
 | 
											
												
													
														|  | -        (js/window.pfs.stat (str dir append-path))))))
 |  | 
 | 
											
												
													
														|  | 
 |  | +    (protocol/stat (get-fs dir) dir path)))
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  (defn mkdir-if-not-exists
 |  |  (defn mkdir-if-not-exists
 | 
											
												
													
														|  |    [dir]
 |  |    [dir]
 | 
											
												
													
														|  |    (when dir
 |  |    (when dir
 | 
											
												
													
														|  | -    (let [local? (config/local-db? dir)]
 |  | 
 | 
											
												
													
														|  | -      (when (or local? js/window.pfs)
 |  | 
 | 
											
												
													
														|  | -        (util/p-handle
 |  | 
 | 
											
												
													
														|  | -         (stat dir nil)
 |  | 
 | 
											
												
													
														|  | -         (fn [_stat])
 |  | 
 | 
											
												
													
														|  | -         (fn [error]
 |  | 
 | 
											
												
													
														|  | -           (mkdir dir)))))))
 |  | 
 | 
											
												
													
														|  | 
 |  | +    (util/p-handle
 | 
											
												
													
														|  | 
 |  | +     (stat dir nil)
 | 
											
												
													
														|  | 
 |  | +     (fn [_stat])
 | 
											
												
													
														|  | 
 |  | +     (fn [error]
 | 
											
												
													
														|  | 
 |  | +       (mkdir! dir)))))
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  (defn create-if-not-exists
 |  |  (defn create-if-not-exists
 | 
											
												
													
														|  |    ([repo dir path]
 |  |    ([repo dir path]
 | 
											
										
											
												
													
														|  | @@ -306,7 +105,7 @@
 | 
											
												
													
														|  |          true)
 |  |          true)
 | 
											
												
													
														|  |        (p/catch
 |  |        (p/catch
 | 
											
												
													
														|  |         (fn [_error]
 |  |         (fn [_error]
 | 
											
												
													
														|  | -         (p/let [_ (write-file repo dir path initial-content)]
 |  | 
 | 
											
												
													
														|  | 
 |  | +         (p/let [_ (write-file! repo dir path initial-content nil)]
 | 
											
												
													
														|  |             false)))))))
 |  |             false)))))))
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  (defn file-exists?
 |  |  (defn file-exists?
 | 
											
										
											
												
													
														|  | @@ -315,10 +114,3 @@
 | 
											
												
													
														|  |     (stat dir path)
 |  |     (stat dir path)
 | 
											
												
													
														|  |     (fn [_stat] true)
 |  |     (fn [_stat] true)
 | 
											
												
													
														|  |     (fn [_e] false)))
 |  |     (fn [_e] false)))
 | 
											
												
													
														|  | -
 |  | 
 | 
											
												
													
														|  | -(defn check-directory-permission!
 |  | 
 | 
											
												
													
														|  | -  [repo]
 |  | 
 | 
											
												
													
														|  | -  (when (config/local-db? repo)
 |  | 
 | 
											
												
													
														|  | -    (p/let [handle (idb/get-item (str "handle/" repo))]
 |  | 
 | 
											
												
													
														|  | -      (when handle
 |  | 
 | 
											
												
													
														|  | -        (common-handler/verify-permission repo handle true)))))
 |  | 
 |