github.com/rzurga/go-swagger@v0.28.1-0.20211109195225-5d1f453ffa3a/examples/generated/restapi/configure_petstore.go (about)

     1  // This file is safe to edit. Once it exists it will not be overwritten
     2  
     3  package restapi
     4  
     5  import (
     6  	"crypto/tls"
     7  	"net/http"
     8  
     9  	"github.com/go-openapi/errors"
    10  	"github.com/go-openapi/runtime"
    11  	"github.com/go-openapi/runtime/middleware"
    12  
    13  	"github.com/go-swagger/go-swagger/examples/generated/restapi/operations"
    14  	"github.com/go-swagger/go-swagger/examples/generated/restapi/operations/pet"
    15  	"github.com/go-swagger/go-swagger/examples/generated/restapi/operations/store"
    16  	"github.com/go-swagger/go-swagger/examples/generated/restapi/operations/user"
    17  )
    18  
    19  //go:generate swagger generate server --target ../../generated --name Petstore --spec ../swagger-petstore.json --principal interface{}
    20  
    21  func configureFlags(api *operations.PetstoreAPI) {
    22  	// api.CommandLineOptionsGroups = []swag.CommandLineOptionsGroup{ ... }
    23  }
    24  
    25  func configureAPI(api *operations.PetstoreAPI) http.Handler {
    26  	// configure the api here
    27  	api.ServeError = errors.ServeError
    28  
    29  	// Set your custom logger if needed. Default one is log.Printf
    30  	// Expected interface func(string, ...interface{})
    31  	//
    32  	// Example:
    33  	// api.Logger = log.Printf
    34  
    35  	api.UseSwaggerUI()
    36  	// To continue using redoc as your UI, uncomment the following line
    37  	// api.UseRedoc()
    38  
    39  	api.JSONConsumer = runtime.JSONConsumer()
    40  	api.UrlformConsumer = runtime.DiscardConsumer
    41  	api.XMLConsumer = runtime.XMLConsumer()
    42  
    43  	api.JSONProducer = runtime.JSONProducer()
    44  	api.XMLProducer = runtime.XMLProducer()
    45  
    46  	// Applies when the "api_key" header is set
    47  	if api.APIKeyAuth == nil {
    48  		api.APIKeyAuth = func(token string) (interface{}, error) {
    49  			return nil, errors.NotImplemented("api key auth (api_key) api_key from header param [api_key] has not yet been implemented")
    50  		}
    51  	}
    52  	if api.PetstoreAuthAuth == nil {
    53  		api.PetstoreAuthAuth = func(token string, scopes []string) (interface{}, error) {
    54  			return nil, errors.NotImplemented("oauth2 bearer auth (petstore_auth) has not yet been implemented")
    55  		}
    56  	}
    57  
    58  	// Set your custom authorizer if needed. Default one is security.Authorized()
    59  	// Expected interface runtime.Authorizer
    60  	//
    61  	// Example:
    62  	// api.APIAuthorizer = security.Authorized()
    63  	// You may change here the memory limit for this multipart form parser. Below is the default (32 MB).
    64  	// pet.UpdatePetWithFormMaxParseMemory = 32 << 20
    65  
    66  	if api.PetAddPetHandler == nil {
    67  		api.PetAddPetHandler = pet.AddPetHandlerFunc(func(params pet.AddPetParams, principal interface{}) middleware.Responder {
    68  			return middleware.NotImplemented("operation pet.AddPet has not yet been implemented")
    69  		})
    70  	}
    71  	if api.UserCreateUserHandler == nil {
    72  		api.UserCreateUserHandler = user.CreateUserHandlerFunc(func(params user.CreateUserParams) middleware.Responder {
    73  			return middleware.NotImplemented("operation user.CreateUser has not yet been implemented")
    74  		})
    75  	}
    76  	if api.UserCreateUsersWithArrayInputHandler == nil {
    77  		api.UserCreateUsersWithArrayInputHandler = user.CreateUsersWithArrayInputHandlerFunc(func(params user.CreateUsersWithArrayInputParams) middleware.Responder {
    78  			return middleware.NotImplemented("operation user.CreateUsersWithArrayInput has not yet been implemented")
    79  		})
    80  	}
    81  	if api.UserCreateUsersWithListInputHandler == nil {
    82  		api.UserCreateUsersWithListInputHandler = user.CreateUsersWithListInputHandlerFunc(func(params user.CreateUsersWithListInputParams) middleware.Responder {
    83  			return middleware.NotImplemented("operation user.CreateUsersWithListInput has not yet been implemented")
    84  		})
    85  	}
    86  	if api.StoreDeleteOrderHandler == nil {
    87  		api.StoreDeleteOrderHandler = store.DeleteOrderHandlerFunc(func(params store.DeleteOrderParams) middleware.Responder {
    88  			return middleware.NotImplemented("operation store.DeleteOrder has not yet been implemented")
    89  		})
    90  	}
    91  	if api.PetDeletePetHandler == nil {
    92  		api.PetDeletePetHandler = pet.DeletePetHandlerFunc(func(params pet.DeletePetParams, principal interface{}) middleware.Responder {
    93  			return middleware.NotImplemented("operation pet.DeletePet has not yet been implemented")
    94  		})
    95  	}
    96  	if api.UserDeleteUserHandler == nil {
    97  		api.UserDeleteUserHandler = user.DeleteUserHandlerFunc(func(params user.DeleteUserParams) middleware.Responder {
    98  			return middleware.NotImplemented("operation user.DeleteUser has not yet been implemented")
    99  		})
   100  	}
   101  	if api.PetFindPetsByStatusHandler == nil {
   102  		api.PetFindPetsByStatusHandler = pet.FindPetsByStatusHandlerFunc(func(params pet.FindPetsByStatusParams, principal interface{}) middleware.Responder {
   103  			return middleware.NotImplemented("operation pet.FindPetsByStatus has not yet been implemented")
   104  		})
   105  	}
   106  	if api.PetFindPetsByTagsHandler == nil {
   107  		api.PetFindPetsByTagsHandler = pet.FindPetsByTagsHandlerFunc(func(params pet.FindPetsByTagsParams, principal interface{}) middleware.Responder {
   108  			return middleware.NotImplemented("operation pet.FindPetsByTags has not yet been implemented")
   109  		})
   110  	}
   111  	if api.StoreGetOrderByIDHandler == nil {
   112  		api.StoreGetOrderByIDHandler = store.GetOrderByIDHandlerFunc(func(params store.GetOrderByIDParams) middleware.Responder {
   113  			return middleware.NotImplemented("operation store.GetOrderByID has not yet been implemented")
   114  		})
   115  	}
   116  	if api.PetGetPetByIDHandler == nil {
   117  		api.PetGetPetByIDHandler = pet.GetPetByIDHandlerFunc(func(params pet.GetPetByIDParams, principal interface{}) middleware.Responder {
   118  			return middleware.NotImplemented("operation pet.GetPetByID has not yet been implemented")
   119  		})
   120  	}
   121  	if api.UserGetUserByNameHandler == nil {
   122  		api.UserGetUserByNameHandler = user.GetUserByNameHandlerFunc(func(params user.GetUserByNameParams) middleware.Responder {
   123  			return middleware.NotImplemented("operation user.GetUserByName has not yet been implemented")
   124  		})
   125  	}
   126  	if api.UserLoginUserHandler == nil {
   127  		api.UserLoginUserHandler = user.LoginUserHandlerFunc(func(params user.LoginUserParams) middleware.Responder {
   128  			return middleware.NotImplemented("operation user.LoginUser has not yet been implemented")
   129  		})
   130  	}
   131  	if api.UserLogoutUserHandler == nil {
   132  		api.UserLogoutUserHandler = user.LogoutUserHandlerFunc(func(params user.LogoutUserParams) middleware.Responder {
   133  			return middleware.NotImplemented("operation user.LogoutUser has not yet been implemented")
   134  		})
   135  	}
   136  	if api.StorePlaceOrderHandler == nil {
   137  		api.StorePlaceOrderHandler = store.PlaceOrderHandlerFunc(func(params store.PlaceOrderParams) middleware.Responder {
   138  			return middleware.NotImplemented("operation store.PlaceOrder has not yet been implemented")
   139  		})
   140  	}
   141  	if api.PetUpdatePetHandler == nil {
   142  		api.PetUpdatePetHandler = pet.UpdatePetHandlerFunc(func(params pet.UpdatePetParams, principal interface{}) middleware.Responder {
   143  			return middleware.NotImplemented("operation pet.UpdatePet has not yet been implemented")
   144  		})
   145  	}
   146  	if api.PetUpdatePetWithFormHandler == nil {
   147  		api.PetUpdatePetWithFormHandler = pet.UpdatePetWithFormHandlerFunc(func(params pet.UpdatePetWithFormParams, principal interface{}) middleware.Responder {
   148  			return middleware.NotImplemented("operation pet.UpdatePetWithForm has not yet been implemented")
   149  		})
   150  	}
   151  	if api.UserUpdateUserHandler == nil {
   152  		api.UserUpdateUserHandler = user.UpdateUserHandlerFunc(func(params user.UpdateUserParams) middleware.Responder {
   153  			return middleware.NotImplemented("operation user.UpdateUser has not yet been implemented")
   154  		})
   155  	}
   156  
   157  	api.PreServerShutdown = func() {}
   158  
   159  	api.ServerShutdown = func() {}
   160  
   161  	return setupGlobalMiddleware(api.Serve(setupMiddlewares))
   162  }
   163  
   164  // The TLS configuration before HTTPS server starts.
   165  func configureTLS(tlsConfig *tls.Config) {
   166  	// Make all necessary changes to the TLS configuration here.
   167  }
   168  
   169  // As soon as server is initialized but not run yet, this function will be called.
   170  // If you need to modify a config, store server instance to stop it individually later, this is the place.
   171  // This function can be called multiple times, depending on the number of serving schemes.
   172  // scheme value will be set accordingly: "http", "https" or "unix".
   173  func configureServer(s *http.Server, scheme, addr string) {
   174  }
   175  
   176  // The middleware configuration is for the handler executors. These do not apply to the swagger.json document.
   177  // The middleware executes after routing but before authentication, binding and validation.
   178  func setupMiddlewares(handler http.Handler) http.Handler {
   179  	return handler
   180  }
   181  
   182  // The middleware configuration happens before anything, this middleware also applies to serving the swagger.json document.
   183  // So this is a good place to plug in a panic handling middleware, logging and metrics.
   184  func setupGlobalMiddleware(handler http.Handler) http.Handler {
   185  	return handler
   186  }