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 }