// Code generated by go-swagger; DO NOT EDIT. package operations // This file was generated by the swagger tool. // Editing this file might prove futile when you re-run the generate command import ( "net/http" "github.com/go-openapi/runtime/middleware" "github.com/nspcc-dev/neofs-rest-gw/gen/models" ) // PutStorageGroupHandlerFunc turns a function with the right signature into a put storage group handler type PutStorageGroupHandlerFunc func(PutStorageGroupParams, *models.Principal) middleware.Responder // Handle executing the request and returning a response func (fn PutStorageGroupHandlerFunc) Handle(params PutStorageGroupParams, principal *models.Principal) middleware.Responder { return fn(params, principal) } // PutStorageGroupHandler interface for that can handle valid put storage group params type PutStorageGroupHandler interface { Handle(PutStorageGroupParams, *models.Principal) middleware.Responder } // NewPutStorageGroup creates a new http.Handler for the put storage group operation func NewPutStorageGroup(ctx *middleware.Context, handler PutStorageGroupHandler) *PutStorageGroup { return &PutStorageGroup{Context: ctx, Handler: handler} } /* PutStorageGroup swagger:route PUT /containers/{containerId}/storagegroups putStorageGroup Create a new storage group in container. */ type PutStorageGroup struct { Context *middleware.Context Handler PutStorageGroupHandler } func (o *PutStorageGroup) ServeHTTP(rw http.ResponseWriter, r *http.Request) { route, rCtx, _ := o.Context.RouteInfo(r) if rCtx != nil { *r = *rCtx } var Params = NewPutStorageGroupParams() uprinc, aCtx, err := o.Context.Authorize(r, route) if err != nil { o.Context.Respond(rw, r, route.Produces, route, err) return } if aCtx != nil { *r = *aCtx } var principal *models.Principal if uprinc != nil { principal = uprinc.(*models.Principal) // this is really a models.Principal, I promise } if err := o.Context.BindValidRequest(r, route, &Params); err != nil { // bind params o.Context.Respond(rw, r, route.Produces, route, err) return } res := o.Handler.Handle(Params, principal) // actually handle the request o.Context.Respond(rw, r, route.Produces, route, res) }