(ns my-app.websocket-server
(:require
[com.fulcrologic.fulcro.server.api-middleware :refer [not-found-handler]]
[com.fulcrologic.fulcro.networking.websockets :as fws]
[com.fulcrologic.fulcro.networking.websocket-protocols :as fwsp]
[immutant.web :as web]
[ring.middleware.content-type :refer [wrap-content-type]]
[ring.middleware.not-modified :refer [wrap-not-modified]]
[ring.middleware.resource :refer [wrap-resource]]
[ring.middleware.params :refer [wrap-params]]
[ring.middleware.keyword-params :refer [wrap-keyword-params]]
[ring.util.response :refer [response file-response resource-response]]
[taoensso.sente.server-adapters.immutant :refer [get-sch-adapter]]))
(def server (atom nil))
(def ws (atom nil))
(defn query-parser
""
[env query]
;; call out to something like a pathom parser. See Fulcro Developers Guide.
;; (note that the ring request, which you may want e.g. for session information, is under :request)
)
(defn http-server []
(let [websockets (fws/start! (fws/make-websockets
query-parser
{:http-server-adapter (get-sch-adapter)
:parser-accepts-env? true
;; See Sente for CSRF instructions. If you are using ring-defaults,
;; you will likely want {:csrf-token-fn :anti-forgery-token} here.
:sente-options {:csrf-token-fn nil}}))
middleware (-> not-found-handler
(fws/wrap-api websockets)
wrap-keyword-params
wrap-params
(wrap-resource "public")
wrap-content-type
wrap-not-modified)
result (web/run middleware {:host "0.0.0.0"
:port 3000})]
(reset! ws websockets)
(reset! server
(fn []
(fws/stop! websockets)
(web/stop result)))))
(comment
;; start the server
(http-server)
;; stop the server
(@server)
;; send a push event
(fwsp/push @ws some-client-id :x {:greeting "hello"}))