// Code generated by go-swagger; DO NOT EDIT. // This file is part of MinIO Console Server // Copyright (c) 2020 MinIO, Inc. // // This program is free software: you can redistribute it and/or modify // it under the terms of the GNU Affero General Public License as published by // the Free Software Foundation, either version 3 of the License, or // (at your option) any later version. // // This program is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the // GNU Affero General Public License for more details. // // You should have received a copy of the GNU Affero General Public License // along with this program. If not, see . // package admin_api // 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/minio/m3/mcs/models" ) // ListGroupsHandlerFunc turns a function with the right signature into a list groups handler type ListGroupsHandlerFunc func(ListGroupsParams, *models.Principal) middleware.Responder // Handle executing the request and returning a response func (fn ListGroupsHandlerFunc) Handle(params ListGroupsParams, principal *models.Principal) middleware.Responder { return fn(params, principal) } // ListGroupsHandler interface for that can handle valid list groups params type ListGroupsHandler interface { Handle(ListGroupsParams, *models.Principal) middleware.Responder } // NewListGroups creates a new http.Handler for the list groups operation func NewListGroups(ctx *middleware.Context, handler ListGroupsHandler) *ListGroups { return &ListGroups{Context: ctx, Handler: handler} } /*ListGroups swagger:route GET /api/v1/groups AdminAPI listGroups List Groups */ type ListGroups struct { Context *middleware.Context Handler ListGroupsHandler } func (o *ListGroups) ServeHTTP(rw http.ResponseWriter, r *http.Request) { route, rCtx, _ := o.Context.RouteInfo(r) if rCtx != nil { r = rCtx } var Params = NewListGroupsParams() 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) }