github.com/johnlanni/go-swagger@v0.19.0/examples/generated/restapi/operations/pet/update_pet.go (about)

     1  // Code generated by go-swagger; DO NOT EDIT.
     2  
     3  package pet
     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  	middleware "github.com/go-openapi/runtime/middleware"
    12  )
    13  
    14  // UpdatePetHandlerFunc turns a function with the right signature into a update pet handler
    15  type UpdatePetHandlerFunc func(UpdatePetParams, interface{}) middleware.Responder
    16  
    17  // Handle executing the request and returning a response
    18  func (fn UpdatePetHandlerFunc) Handle(params UpdatePetParams, principal interface{}) middleware.Responder {
    19  	return fn(params, principal)
    20  }
    21  
    22  // UpdatePetHandler interface for that can handle valid update pet params
    23  type UpdatePetHandler interface {
    24  	Handle(UpdatePetParams, interface{}) middleware.Responder
    25  }
    26  
    27  // NewUpdatePet creates a new http.Handler for the update pet operation
    28  func NewUpdatePet(ctx *middleware.Context, handler UpdatePetHandler) *UpdatePet {
    29  	return &UpdatePet{Context: ctx, Handler: handler}
    30  }
    31  
    32  /*UpdatePet swagger:route PUT /pets pet updatePet
    33  
    34  Update an existing pet
    35  
    36  */
    37  type UpdatePet struct {
    38  	Context *middleware.Context
    39  	Handler UpdatePetHandler
    40  }
    41  
    42  func (o *UpdatePet) 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 = NewUpdatePetParams()
    48  
    49  	uprinc, aCtx, err := o.Context.Authorize(r, route)
    50  	if err != nil {
    51  		o.Context.Respond(rw, r, route.Produces, route, err)
    52  		return
    53  	}
    54  	if aCtx != nil {
    55  		r = aCtx
    56  	}
    57  	var principal interface{}
    58  	if uprinc != nil {
    59  		principal = uprinc
    60  	}
    61  
    62  	if err := o.Context.BindValidRequest(r, route, &Params); err != nil { // bind params
    63  		o.Context.Respond(rw, r, route.Produces, route, err)
    64  		return
    65  	}
    66  
    67  	res := o.Handler.Handle(Params, principal) // actually handle the request
    68  
    69  	o.Context.Respond(rw, r, route.Produces, route, res)
    70  
    71  }