(ns publishing "Basic script for publishing from CLI" (:require ["fs" :as fs] ["path" :as node-path] [clojure.edn :as edn] [datascript.core :as d] [logseq.db.common.sqlite-cli :as sqlite-cli] [logseq.db.sqlite.util :as sqlite-util] [logseq.graph-parser.cli :as gp-cli] [logseq.publishing :as publishing] [nbb.core :as nbb])) (defn- get-db [graph-dir] (let [{:keys [conn]} (gp-cli/parse-graph graph-dir {:verbose false})] @conn)) (defn- publish-file-graph [static-dir graph-dir output-path options] (let [repo-config (-> (node-path/join graph-dir "logseq" "config.edn") fs/readFileSync str edn/read-string)] (publishing/export (get-db graph-dir) static-dir graph-dir output-path (merge options {:repo (node-path/basename graph-dir) :repo-config repo-config :ui/theme "dark" :ui/radix-color :purple})))) (defn- publish-db-graph [static-dir graph-dir output-path opts] (let [db-name (node-path/basename graph-dir) conn (sqlite-cli/open-db! (node-path/dirname graph-dir) db-name) repo-config (-> (d/q '[:find ?content :where [?b :file/path "logseq/config.edn"] [?b :file/content ?content]] @conn) ffirst edn/read-string)] (publishing/export @conn static-dir graph-dir output-path (merge opts {:repo (str sqlite-util/db-version-prefix db-name) :repo-config repo-config :db-graph? true :ui/theme "dark" :ui/radix-color :cyan})))) (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 -main [args] (when (< (count args) 3) (println "Usage: $0 STATIC-DIR GRAPH-DIR OUT-DIR") (js/process.exit 1)) (let [[static-dir graph-dir output-path] (map resolve-path args) options {:dev? (contains? (set args) "--dev")}] (if (sqlite-cli/db-graph-directory? graph-dir) (publish-db-graph static-dir graph-dir output-path options) (publish-file-graph static-dir graph-dir output-path options)))) (when (= nbb/*file* (nbb/invoked-file)) (-main *command-line-args*))