Skip to content

Commit

Permalink
Merge pull request #23 from holyjak/feat/auto-request-pathom-errors
Browse files Browse the repository at this point in the history
EQL transform to add ::p/errors
  • Loading branch information
awkay authored Sep 19, 2021
2 parents f7d9795 + 4c5bebe commit 7536793
Show file tree
Hide file tree
Showing 2 changed files with 15 additions and 2 deletions.
3 changes: 3 additions & 0 deletions .gitignore
Original file line number Diff line number Diff line change
Expand Up @@ -60,3 +60,6 @@ docs/.jekyll-metadata
.shadow-cljs
resources/public/workspaces/*
!resources/public/workspaces/index.html
.calva/
.lsp/.cache/
.clj-kondo/.cache/
14 changes: 12 additions & 2 deletions src/main/app/application.cljs
Original file line number Diff line number Diff line change
Expand Up @@ -2,20 +2,30 @@
(:require
[com.fulcrologic.fulcro.networking.http-remote :as net]
[com.fulcrologic.fulcro.application :as app]
[com.fulcrologic.fulcro.components :as comp]))
[com.fulcrologic.fulcro.components :as comp]
[edn-query-language.core :as eql]))

(def secured-request-middleware
;; The CSRF token is embedded via server_components/html.clj
(->
(net/wrap-csrf-token (or js/fulcro_network_csrf_token "TOKEN-NOT-IN-HTML!"))
(net/wrap-fulcro-request)))

(defn global-eql-transform
"As the default transform but also asking that any Pathom errors during load! are returned,
so that they can be inspected e.g. in `:remote-error?`"
[ast]
(cond-> (app/default-global-eql-transform ast)
(-> ast :type #{:root})
(update :children conj (eql/expr->ast :com.wsscode.pathom.core/errors))))

(defonce SPA (app/fulcro-app
{;; This ensures your client can talk to a CSRF-protected server.
;; See middleware.clj to see how the token is embedded into the HTML
:remotes {:remote (net/fulcro-http-remote
{:url "/api"
:request-middleware secured-request-middleware})}}))
:request-middleware secured-request-middleware})}
:global-eql-transform global-eql-transform}))

(comment
(-> SPA (::app/runtime-atom) deref ::app/indexes))

0 comments on commit 7536793

Please sign in to comment.