Bare minimum CORS middleware/interceptor for Clojure.
Access-Control-Max-AgeAdd to your deps.edn
{zerg000000/simple-cors {:mvn/version "0.0.8"}}
When use in Ring handler
(require '[simple-cors.ring.middleware :as cors])
(def app (cors/wrap handler {:cors-config {:allowed-request-methods [:post :get]
                                           :allowed-request-headers ["Authorization" "Content-Type"]
                                           :origins ["https://yahoo.com"
                                                     "https://google.com"]
                                           :max-age 300}}))
When use in Reitit
(require '[simple-cors.reitit.interceptor :as cors]
         '[reitit.interceptor.sieppari]
         '[reitit.http :as http])
(def app 
  (let [config {:cors-config {:allowed-request-methods [:post :get]
                              :allowed-request-headers ["Authorization" "Content-Type"]
                              :origins ["https://yahoo.com"
                                        "https://google.com"]
                              :max-age 300}}]
    (http/ring-handler
     (http/router routes
                  {:reitit.http/default-options-endpoint 
                   (cors/default-options-endpoint config)})
     {:executor reitit.interceptor.sieppari/executor
      :interceptors [(cors/cors-interceptor config)]})))
When use in Aleph
(require '[simple-cors.aleph.middleware :as cors])
(def app (cors/wrap handler {:cors-config {:allowed-request-methods [:post :get]
                                           :allowed-request-headers ["Authorization" "Content-Type"]
                                           :origins ["https://yahoo.com"
                                                     "https://google.com"]
                                           :max-age 300}}))
Full config map, you can also see the spec in simple-cors.specs
{:cors-config {:allowed-request-methods [:post :get]
               :allowed-request-headers ["Authorization" "Content-Type"]
               :allow-credentials? true
               :origins ["https://yahoo.com"
                         "https://google.com"]
               :max-age 300
               :exposed-headers ["x-amz-date"]}
 :preflight-forbidden-response {:status 403}
 :preflight-ok-response {:status 200}}
Normally, Static is good and enough
{:cors-config {...
               :origins ["https://whatever.co"]
               ...}}
Some casual user might want CORS matched with any origin
{:cors-config {...
               :origins "*"
               ...}}
The ultimate solution is to provide your own matching function
{:cors-config {...
               :origins #{"https://whatever.co"}
               ...}}
; or
{:cors-config {...
               :origins (fn [origin] (and (str/starts-with? origin "https://")
                                          (str/ends-with? origin ".google.com")))
               ...}}
Support combining multiple CORS config with performance penalty. At most one AnyOrigin in configs, and will act as the last fallback.
{:cors-config [{...
                :origin "*"
                ...}
               {...
                :origin ["http://abc"]
                ...}]}
Since the main idea of CORS is to provide information for a browser to take action. In most of the cases, we can do little on pure server side
Copyright © 2020 Simple CORS
Simple CORS is licensed under the MIT license, available at MIT and also in the LICENSE file.
Can you improve this documentation? These fine people already did:
zerg000000 & Albert LaiEdit on GitHub
cljdoc builds & hosts documentation for Clojure/Script libraries
| Ctrl+k | Jump to recent docs | 
| ← | Move to previous article | 
| → | Move to next article | 
| Ctrl+/ | Jump to the search field |