mirror of
https://github.com/metosin/reitit.git
synced 2026-02-07 12:23:12 +00:00
Merge pull request #140 from metosin/spec-ring-swagger
Spec ring swagger
This commit is contained in:
commit
5cfcd0a3c9
7 changed files with 148 additions and 6 deletions
11
examples/ring-spec-swagger/.gitignore
vendored
Normal file
11
examples/ring-spec-swagger/.gitignore
vendored
Normal file
|
|
@ -0,0 +1,11 @@
|
||||||
|
/target
|
||||||
|
/classes
|
||||||
|
/checkouts
|
||||||
|
pom.xml
|
||||||
|
pom.xml.asc
|
||||||
|
*.jar
|
||||||
|
*.class
|
||||||
|
/.lein-*
|
||||||
|
/.nrepl-port
|
||||||
|
.hgignore
|
||||||
|
.hg/
|
||||||
23
examples/ring-spec-swagger/README.md
Normal file
23
examples/ring-spec-swagger/README.md
Normal file
|
|
@ -0,0 +1,23 @@
|
||||||
|
# reitit-ring, clojure.spec, swagger
|
||||||
|
|
||||||
|
## Usage
|
||||||
|
|
||||||
|
```clj
|
||||||
|
> lein repl
|
||||||
|
(start)
|
||||||
|
```
|
||||||
|
|
||||||
|
To test the endpoints using [httpie](https://httpie.org/):
|
||||||
|
|
||||||
|
```bash
|
||||||
|
http GET :3000/math/plus x==1 y==20
|
||||||
|
http POST :3000/math/spec/plus x:=1 y:=20
|
||||||
|
|
||||||
|
http GET :3000/swagger.json
|
||||||
|
```
|
||||||
|
|
||||||
|
<img src="https://raw.githubusercontent.com/metosin/reitit/master/examples/ring-spec-swagger/swagger.png" />
|
||||||
|
|
||||||
|
## License
|
||||||
|
|
||||||
|
Copyright © 2017-2018 Metosin Oy
|
||||||
6
examples/ring-spec-swagger/project.clj
Normal file
6
examples/ring-spec-swagger/project.clj
Normal file
|
|
@ -0,0 +1,6 @@
|
||||||
|
(defproject ring-example "0.1.0-SNAPSHOT"
|
||||||
|
:description "Reitit Ring App with Swagger"
|
||||||
|
:dependencies [[org.clojure/clojure "1.9.0"]
|
||||||
|
[ring "1.6.3"]
|
||||||
|
[metosin/reitit "0.2.1"]]
|
||||||
|
:repl-options {:init-ns example.server})
|
||||||
BIN
examples/ring-spec-swagger/resources/reitit.png
Normal file
BIN
examples/ring-spec-swagger/resources/reitit.png
Normal file
Binary file not shown.
|
After Width: | Height: | Size: 494 KiB |
105
examples/ring-spec-swagger/src/example/server.clj
Normal file
105
examples/ring-spec-swagger/src/example/server.clj
Normal file
|
|
@ -0,0 +1,105 @@
|
||||||
|
(ns example.server
|
||||||
|
(:require [reitit.ring :as ring]
|
||||||
|
[reitit.swagger :as swagger]
|
||||||
|
[reitit.swagger-ui :as swagger-ui]
|
||||||
|
[reitit.ring.coercion :as coercion]
|
||||||
|
[reitit.coercion.spec]
|
||||||
|
[reitit.ring.middleware.muuntaja :as muuntaja]
|
||||||
|
[reitit.ring.middleware.exception :as exception]
|
||||||
|
[reitit.ring.middleware.multipart :as multipart]
|
||||||
|
[ring.middleware.params :as params]
|
||||||
|
[ring.adapter.jetty :as jetty]
|
||||||
|
[muuntaja.core :as m]
|
||||||
|
[clojure.spec.alpha :as s]
|
||||||
|
[spec-tools.spec :as spec]
|
||||||
|
[clojure.java.io :as io]))
|
||||||
|
|
||||||
|
(s/def ::file multipart/temp-file-part)
|
||||||
|
(s/def ::file-params (s/keys :req-un [::file]))
|
||||||
|
|
||||||
|
(s/def ::name spec/string?)
|
||||||
|
(s/def ::size spec/int?)
|
||||||
|
(s/def ::file-response (s/keys :req-un [::name ::size]))
|
||||||
|
|
||||||
|
(s/def ::x spec/int?)
|
||||||
|
(s/def ::y spec/int?)
|
||||||
|
(s/def ::total spec/int?)
|
||||||
|
(s/def ::math-request (s/keys :req-un [::x ::y]))
|
||||||
|
(s/def ::math-response (s/keys :req-un [::total]))
|
||||||
|
|
||||||
|
(def app
|
||||||
|
(ring/ring-handler
|
||||||
|
(ring/router
|
||||||
|
[["/swagger.json"
|
||||||
|
{:get {:no-doc true
|
||||||
|
:swagger {:info {:title "my-api"}}
|
||||||
|
:handler (swagger/create-swagger-handler)}}]
|
||||||
|
|
||||||
|
["/files"
|
||||||
|
{:swagger {:tags ["files"]}}
|
||||||
|
|
||||||
|
["/upload"
|
||||||
|
{:post {:summary "upload a file"
|
||||||
|
:parameters {:multipart ::file-params}
|
||||||
|
:responses {200 {:body ::file-response}}
|
||||||
|
:handler (fn [{{{:keys [file]} :multipart} :parameters}]
|
||||||
|
{:status 200
|
||||||
|
:body {:name (:filename file)
|
||||||
|
:size (:size file)}})}}]
|
||||||
|
|
||||||
|
["/download"
|
||||||
|
{:get {:summary "downloads a file"
|
||||||
|
:swagger {:produces ["image/png"]}
|
||||||
|
:handler (fn [_]
|
||||||
|
{:status 200
|
||||||
|
:headers {"Content-Type" "image/png"}
|
||||||
|
:body (io/input-stream
|
||||||
|
(io/resource "reitit.png"))})}}]]
|
||||||
|
|
||||||
|
["/math"
|
||||||
|
{:swagger {:tags ["math"]}}
|
||||||
|
|
||||||
|
["/plus"
|
||||||
|
{:get {:summary "plus with spec query parameters"
|
||||||
|
:parameters {:query ::math-request}
|
||||||
|
:responses {200 {:body ::math-response}}
|
||||||
|
:handler (fn [{{{:keys [x y]} :query} :parameters}]
|
||||||
|
{:status 200
|
||||||
|
:body {:total (+ x y)}})}
|
||||||
|
:post {:summary "plus with spec body parameters"
|
||||||
|
:parameters {:body ::math-request}
|
||||||
|
:responses {200 {:body ::math-response}}
|
||||||
|
:handler (fn [{{{:keys [x y]} :body} :parameters}]
|
||||||
|
{:status 200
|
||||||
|
:body {:total (+ x y)}})}}]]]
|
||||||
|
|
||||||
|
{:data {:coercion reitit.coercion.spec/coercion
|
||||||
|
:muuntaja m/instance
|
||||||
|
:middleware [;; query-params & form-params
|
||||||
|
params/wrap-params
|
||||||
|
;; content-negotiation
|
||||||
|
muuntaja/format-negotiate-middleware
|
||||||
|
;; encoding response body
|
||||||
|
muuntaja/format-response-middleware
|
||||||
|
;; exception handling
|
||||||
|
exception/exception-middleware
|
||||||
|
;; decoding request body
|
||||||
|
muuntaja/format-request-middleware
|
||||||
|
;; coercing response bodys
|
||||||
|
coercion/coerce-response-middleware
|
||||||
|
;; coercing request parameters
|
||||||
|
coercion/coerce-request-middleware
|
||||||
|
;; multipart
|
||||||
|
multipart/multipart-middleware]}})
|
||||||
|
(ring/routes
|
||||||
|
(swagger-ui/create-swagger-ui-handler
|
||||||
|
{:path "/"
|
||||||
|
:config {:validatorUrl nil}})
|
||||||
|
(ring/create-default-handler))))
|
||||||
|
|
||||||
|
(defn start []
|
||||||
|
(jetty/run-jetty #'app {:port 3000, :join? false})
|
||||||
|
(println "server running in port 3000"))
|
||||||
|
|
||||||
|
(comment
|
||||||
|
(start))
|
||||||
BIN
examples/ring-spec-swagger/swagger.png
Normal file
BIN
examples/ring-spec-swagger/swagger.png
Normal file
Binary file not shown.
|
After Width: | Height: | Size: 228 KiB |
|
|
@ -10,15 +10,12 @@
|
||||||
To test the endpoints using [httpie](https://httpie.org/):
|
To test the endpoints using [httpie](https://httpie.org/):
|
||||||
|
|
||||||
```bash
|
```bash
|
||||||
http GET :3000/api/schema/plus x==1 y==20
|
http GET :3000/math/plus x==1 y==20
|
||||||
http GET :3000/api/spec/plus x==1 y==20
|
http POST :3000/math/spec/plus x:=1 y:=20
|
||||||
|
|
||||||
http GET :3000/api/swagger.json
|
http GET :3000/swagger.json
|
||||||
```
|
```
|
||||||
|
|
||||||
* swagger.json: http://localhost:3000/api/swagger.json
|
|
||||||
* swagger-ui: http://localhost:3000/api-docs/
|
|
||||||
|
|
||||||
<img src="https://raw.githubusercontent.com/metosin/reitit/master/examples/ring-swagger/swagger.png" />
|
<img src="https://raw.githubusercontent.com/metosin/reitit/master/examples/ring-swagger/swagger.png" />
|
||||||
|
|
||||||
## License
|
## License
|
||||||
|
|
|
||||||
Loading…
Reference in a new issue