github.com/rzurga/go-swagger@v0.28.1-0.20211109195225-5d1f453ffa3a/examples/auto-configure/restapi/operations/todos/destroy_one.go (about) 1 // Code generated by go-swagger; DO NOT EDIT. 2 3 package todos 4 5 // This file was generated by the swagger tool. 6 // Editing this file might prove futile when you re-run the generate command 7 8 import ( 9 "net/http" 10 11 "github.com/go-openapi/runtime/middleware" 12 ) 13 14 // DestroyOneHandlerFunc turns a function with the right signature into a destroy one handler 15 type DestroyOneHandlerFunc func(DestroyOneParams, interface{}) middleware.Responder 16 17 // Handle executing the request and returning a response 18 func (fn DestroyOneHandlerFunc) Handle(params DestroyOneParams, principal interface{}) middleware.Responder { 19 return fn(params, principal) 20 } 21 22 // DestroyOneHandler interface for that can handle valid destroy one params 23 type DestroyOneHandler interface { 24 Handle(DestroyOneParams, interface{}) middleware.Responder 25 } 26 27 // NewDestroyOne creates a new http.Handler for the destroy one operation 28 func NewDestroyOne(ctx *middleware.Context, handler DestroyOneHandler) *DestroyOne { 29 return &DestroyOne{Context: ctx, Handler: handler} 30 } 31 32 /* DestroyOne swagger:route DELETE /{id} todos destroyOne 33 34 DestroyOne destroy one API 35 36 */ 37 type DestroyOne struct { 38 Context *middleware.Context 39 Handler DestroyOneHandler 40 } 41 42 func (o *DestroyOne) ServeHTTP(rw http.ResponseWriter, r *http.Request) { 43 route, rCtx, _ := o.Context.RouteInfo(r) 44 if rCtx != nil { 45 r = rCtx 46 } 47 var Params = NewDestroyOneParams() 48 uprinc, aCtx, err := o.Context.Authorize(r, route) 49 if err != nil { 50 o.Context.Respond(rw, r, route.Produces, route, err) 51 return 52 } 53 if aCtx != nil { 54 r = aCtx 55 } 56 var principal interface{} 57 if uprinc != nil { 58 principal = uprinc.(interface{}) // this is really a interface{}, I promise 59 } 60 61 if err := o.Context.BindValidRequest(r, route, &Params); err != nil { // bind params 62 o.Context.Respond(rw, r, route.Produces, route, err) 63 return 64 } 65 66 res := o.Handler.Handle(Params, principal) // actually handle the request 67 o.Context.Respond(rw, r, route.Produces, route, res) 68 69 }