Files
logseq/deps/publishing/script/publishing.cljs
2026-01-22 13:19:57 -05:00

46 lines
1.8 KiB
Clojure

(ns publishing
"Basic script for publishing from CLI"
(:require ["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.publishing :as publishing]
[nbb.core :as nbb]))
(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")}]
(publish-db-graph static-dir graph-dir output-path options)))
(when (= nbb/*file* (nbb/invoked-file))
(-main *command-line-args*))