1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071 |
- (ns export-graph
- "A script that exports a graph to a sqlite.build EDN file"
- (:require ["fs" :as fs]
- ["os" :as os]
- ["path" :as node-path]
- [babashka.cli :as cli]
- [clojure.edn :as edn]
- [clojure.pprint :as pprint]
- [clojure.string :as string]
- [logseq.db.sqlite.cli :as sqlite-cli]
- [logseq.db.sqlite.export :as sqlite-export]
- [nbb.core :as nbb]))
- (defn- resolve-path
- "If relative path, resolve with $ORIGINAL_PWD"
- [path]
- (if (node-path/isAbsolute path)
- path
- (node-path/join (or js/process.env.ORIGINAL_PWD ".") path)))
- (defn- get-dir-and-db-name
- "Gets dir and db name for use with open-db! Works for relative and absolute paths and
- defaults to ~/logseq/graphs/ when no '/' present in name"
- [graph-dir]
- (if (string/includes? graph-dir "/")
- (let [resolve-path' #(if (node-path/isAbsolute %) %
- ;; $ORIGINAL_PWD used by bb tasks to correct current dir
- (node-path/join (or js/process.env.ORIGINAL_PWD ".") %))]
- ((juxt node-path/dirname node-path/basename) (resolve-path' graph-dir)))
- [(node-path/join (os/homedir) "logseq" "graphs") graph-dir]))
- (def spec
- "Options spec"
- {:help {:alias :h
- :desc "Print help"}
- :include-timestamps? {:alias :t
- :desc "Include timestamps in export"}
- :file {:alias :f
- :desc "Saves edn to file"}
- :catch-validation-errors? {:alias :c
- :desc "Catch validation errors for dev"}
- :exclude-namespaces {:alias :e
- :coerce #{}
- :desc "Namespaces to exclude from properties and classes"}
- :exclude-built-in-pages? {:alias :b
- :desc "Exclude built-in pages"}
- :exclude-files? {:alias :F
- :desc "Exclude :file/path files"}})
- (defn -main [args]
- (let [{options :opts args' :args} (cli/parse-args args {:spec spec})
- graph-dir (first args')
- _ (when (or (nil? graph-dir) (:help options))
- (println (str "Usage: $0 GRAPH-NAME [& ARGS] [OPTIONS]\nOptions:\n"
- (cli/format-opts {:spec spec})))
- (js/process.exit 1))
- [dir db-name] (get-dir-and-db-name graph-dir)
- conn (sqlite-cli/open-db! dir db-name)
- export-options (dissoc options :file)
- export-map (sqlite-export/build-export @conn {:export-type :graph :graph-options export-options})]
- (if (:file options)
- (do
- (println "Exported" (count (:properties export-map)) "properties,"
- (count (:properties export-map)) "classes and"
- (count (:pages-and-blocks export-map)) "pages")
- (fs/writeFileSync (resolve-path (:file options))
- (with-out-str (pprint/pprint export-map))))
- (pprint/pprint export-map))))
- (when (= nbb/*file* (nbb/invoked-file))
- (-main *command-line-args*))
|