Fork me on GitHub
#ring-swagger
<
2017-11-27
>
hawari09:11:04

Hello, I've just recently started using clojure, and I'm currently using compojure-api to build an API. When a route is not present in my application, I notice that instead of returning 404 and a message that a resource couldn't be found, the default configuration returns 500 and a html saying that "Response map is nil". Obviously that's not something that I would like to convey to the API user. I found that there's a :invalid-routes-fn key in the api options from the documentation. What the documentation doesn't explain is what kind of function that this key expect, except of it's a 2-arity function. Can somebody helps me on this? I'd really appreciate it.

hawari09:11:59

Wow thanks @ikitommi, works like a charm!

hawari09:11:51

I gotta ask though, when I include compojure-api, does all compojure and ring namespaces available for use?

ikitommi10:11:01

Yes, c-api depends on both Ring & Compojure. With leiningen, you can say lein deps :tree to see the included deps per artefact.

hawari10:11:26

Alright, thanks again @ikitommi!

mgrbyte15:11:08

Wondering if I could use ring-oauth2 as :middleware with compojure-api, or if there's an example someone could point at?

mgrbyte15:11:30

think I might, but not sure about the required ordering

ikitommi15:11:26

I think it should just work? e.g. (api {:middleware [[ring.middleware.oauth2/wrap-oauth2 {...}]]})

mgrbyte15:11:58

I'll let you know! 🙂 :thumbsup:

ikitommi15:11:32

ah, but you might need the cookies from ring-defaults.

mgrbyte15:11:02

and possibly anti-forgery too

ikitommi15:11:52

also, the swagger can be instructed to enforce those for the client (e.g. the swagger-ui).

ikitommi15:11:18

when you get a setup working 😉, would be great to have an example of that in the examples. If there is too much boilerplate, let’s see if that could be reduced with some addons to c-api itself.

petr.mensik22:11:05

I am trying to serve both static content and JSON responses from API however I am struggling with return of correct content type (currently everything is either plain or octet-stream). This is the API configuration

(def app
  (api
   (assoc api-config
          :middleware [[wrap-resource resources-root]
                       [wrap-cors :access-control-allow-origin [#"\\*"] :access-control-allow-methods [:get :post :put :delete :patch]]
                       wrap-reload
                       [wrap-defaults (-> site-defaults
                                          (assoc-in [:not-modified-responses] true)
                                          (assoc-in [:security :anti-forgery] false)
                                          (assoc-in [:security :ssl-redirect] (not (:dev env)))
                                          (assoc-in [:security :hsts] (not (:dev env))))]])
   (context "/auth" []
     api-routes-login
     api-routes-password)

   (context "/api" []
     :header-params [authorization :- String]
     :middleware [[wrap-authentication config/backend]]
     api-routes-calendar ; more routes here
     (undocumented (route/resources "/" {:root resources-root})
                 app-routes
                 not-found-routes)))
Where app-routes are
(defn- get-page
  "Servers HTML page from server"
  ([]
   (get-page "index.html"))
  ([page]
   (content-type (resource-response page {:root resources-root}) "text/html")))

(defroutes app-routes
  (GET "/" [] (get-page))) ;etc
Basically the same configration worked with plan compojure so what am I doing wrong here?