github.com/josephspurrier/go-swagger@v0.2.1-0.20221129144919-1f672a142a00/examples/composed-auth/restapi/operations/get_orders_for_item.go (about)

     1  // Code generated by go-swagger; DO NOT EDIT.
     2  
     3  package operations
     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  	"github.com/go-swagger/go-swagger/examples/composed-auth/models"
    14  )
    15  
    16  // GetOrdersForItemHandlerFunc turns a function with the right signature into a get orders for item handler
    17  type GetOrdersForItemHandlerFunc func(GetOrdersForItemParams, *models.Principal) middleware.Responder
    18  
    19  // Handle executing the request and returning a response
    20  func (fn GetOrdersForItemHandlerFunc) Handle(params GetOrdersForItemParams, principal *models.Principal) middleware.Responder {
    21  	return fn(params, principal)
    22  }
    23  
    24  // GetOrdersForItemHandler interface for that can handle valid get orders for item params
    25  type GetOrdersForItemHandler interface {
    26  	Handle(GetOrdersForItemParams, *models.Principal) middleware.Responder
    27  }
    28  
    29  // NewGetOrdersForItem creates a new http.Handler for the get orders for item operation
    30  func NewGetOrdersForItem(ctx *middleware.Context, handler GetOrdersForItemHandler) *GetOrdersForItem {
    31  	return &GetOrdersForItem{Context: ctx, Handler: handler}
    32  }
    33  
    34  /*
    35  	GetOrdersForItem swagger:route GET /orders/{itemID} getOrdersForItem
    36  
    37  retrieves all orders for an item
    38  
    39  Only registered resellers should be able to search orders for an item
    40  */
    41  type GetOrdersForItem struct {
    42  	Context *middleware.Context
    43  	Handler GetOrdersForItemHandler
    44  }
    45  
    46  func (o *GetOrdersForItem) ServeHTTP(rw http.ResponseWriter, r *http.Request) {
    47  	route, rCtx, _ := o.Context.RouteInfo(r)
    48  	if rCtx != nil {
    49  		*r = *rCtx
    50  	}
    51  	var Params = NewGetOrdersForItemParams()
    52  	uprinc, aCtx, err := o.Context.Authorize(r, route)
    53  	if err != nil {
    54  		o.Context.Respond(rw, r, route.Produces, route, err)
    55  		return
    56  	}
    57  	if aCtx != nil {
    58  		*r = *aCtx
    59  	}
    60  	var principal *models.Principal
    61  	if uprinc != nil {
    62  		principal = uprinc.(*models.Principal) // this is really a models.Principal, I promise
    63  	}
    64  
    65  	if err := o.Context.BindValidRequest(r, route, &Params); err != nil { // bind params
    66  		o.Context.Respond(rw, r, route.Produces, route, err)
    67  		return
    68  	}
    69  
    70  	res := o.Handler.Handle(Params, principal) // actually handle the request
    71  	o.Context.Respond(rw, r, route.Produces, route, res)
    72  
    73  }