github.com/emreu/go-swagger@v0.22.1/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 errors "github.com/go-openapi/errors" 10 runtime "github.com/go-openapi/runtime" 11 middleware "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.json 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.JSONConsumer = runtime.JSONConsumer() 36 37 api.UrlformConsumer = runtime.DiscardConsumer 38 39 api.XMLConsumer = runtime.XMLConsumer() 40 41 api.JSONProducer = runtime.JSONProducer() 42 43 api.XMLProducer = runtime.XMLProducer() 44 45 // Applies when the "api_key" header is set 46 api.APIKeyAuth = func(token string) (interface{}, error) { 47 return nil, errors.NotImplemented("api key auth (api_key) api_key from header param [api_key] has not yet been implemented") 48 } 49 api.PetstoreAuthAuth = func(token string, scopes []string) (interface{}, error) { 50 return nil, errors.NotImplemented("oauth2 bearer auth (petstore_auth) has not yet been implemented") 51 } 52 53 // Set your custom authorizer if needed. Default one is security.Authorized() 54 // Expected interface runtime.Authorizer 55 // 56 // Example: 57 // api.APIAuthorizer = security.Authorized() 58 if api.PetAddPetHandler == nil { 59 api.PetAddPetHandler = pet.AddPetHandlerFunc(func(params pet.AddPetParams, principal interface{}) middleware.Responder { 60 return middleware.NotImplemented("operation pet.AddPet has not yet been implemented") 61 }) 62 } 63 if api.UserCreateUserHandler == nil { 64 api.UserCreateUserHandler = user.CreateUserHandlerFunc(func(params user.CreateUserParams) middleware.Responder { 65 return middleware.NotImplemented("operation user.CreateUser has not yet been implemented") 66 }) 67 } 68 if api.UserCreateUsersWithArrayInputHandler == nil { 69 api.UserCreateUsersWithArrayInputHandler = user.CreateUsersWithArrayInputHandlerFunc(func(params user.CreateUsersWithArrayInputParams) middleware.Responder { 70 return middleware.NotImplemented("operation user.CreateUsersWithArrayInput has not yet been implemented") 71 }) 72 } 73 if api.UserCreateUsersWithListInputHandler == nil { 74 api.UserCreateUsersWithListInputHandler = user.CreateUsersWithListInputHandlerFunc(func(params user.CreateUsersWithListInputParams) middleware.Responder { 75 return middleware.NotImplemented("operation user.CreateUsersWithListInput has not yet been implemented") 76 }) 77 } 78 if api.StoreDeleteOrderHandler == nil { 79 api.StoreDeleteOrderHandler = store.DeleteOrderHandlerFunc(func(params store.DeleteOrderParams) middleware.Responder { 80 return middleware.NotImplemented("operation store.DeleteOrder has not yet been implemented") 81 }) 82 } 83 if api.PetDeletePetHandler == nil { 84 api.PetDeletePetHandler = pet.DeletePetHandlerFunc(func(params pet.DeletePetParams, principal interface{}) middleware.Responder { 85 return middleware.NotImplemented("operation pet.DeletePet has not yet been implemented") 86 }) 87 } 88 if api.UserDeleteUserHandler == nil { 89 api.UserDeleteUserHandler = user.DeleteUserHandlerFunc(func(params user.DeleteUserParams) middleware.Responder { 90 return middleware.NotImplemented("operation user.DeleteUser has not yet been implemented") 91 }) 92 } 93 if api.PetFindPetsByStatusHandler == nil { 94 api.PetFindPetsByStatusHandler = pet.FindPetsByStatusHandlerFunc(func(params pet.FindPetsByStatusParams, principal interface{}) middleware.Responder { 95 return middleware.NotImplemented("operation pet.FindPetsByStatus has not yet been implemented") 96 }) 97 } 98 if api.PetFindPetsByTagsHandler == nil { 99 api.PetFindPetsByTagsHandler = pet.FindPetsByTagsHandlerFunc(func(params pet.FindPetsByTagsParams, principal interface{}) middleware.Responder { 100 return middleware.NotImplemented("operation pet.FindPetsByTags has not yet been implemented") 101 }) 102 } 103 if api.StoreGetOrderByIDHandler == nil { 104 api.StoreGetOrderByIDHandler = store.GetOrderByIDHandlerFunc(func(params store.GetOrderByIDParams) middleware.Responder { 105 return middleware.NotImplemented("operation store.GetOrderByID has not yet been implemented") 106 }) 107 } 108 if api.PetGetPetByIDHandler == nil { 109 api.PetGetPetByIDHandler = pet.GetPetByIDHandlerFunc(func(params pet.GetPetByIDParams, principal interface{}) middleware.Responder { 110 return middleware.NotImplemented("operation pet.GetPetByID has not yet been implemented") 111 }) 112 } 113 if api.UserGetUserByNameHandler == nil { 114 api.UserGetUserByNameHandler = user.GetUserByNameHandlerFunc(func(params user.GetUserByNameParams) middleware.Responder { 115 return middleware.NotImplemented("operation user.GetUserByName has not yet been implemented") 116 }) 117 } 118 if api.UserLoginUserHandler == nil { 119 api.UserLoginUserHandler = user.LoginUserHandlerFunc(func(params user.LoginUserParams) middleware.Responder { 120 return middleware.NotImplemented("operation user.LoginUser has not yet been implemented") 121 }) 122 } 123 if api.UserLogoutUserHandler == nil { 124 api.UserLogoutUserHandler = user.LogoutUserHandlerFunc(func(params user.LogoutUserParams) middleware.Responder { 125 return middleware.NotImplemented("operation user.LogoutUser has not yet been implemented") 126 }) 127 } 128 if api.StorePlaceOrderHandler == nil { 129 api.StorePlaceOrderHandler = store.PlaceOrderHandlerFunc(func(params store.PlaceOrderParams) middleware.Responder { 130 return middleware.NotImplemented("operation store.PlaceOrder has not yet been implemented") 131 }) 132 } 133 if api.PetUpdatePetHandler == nil { 134 api.PetUpdatePetHandler = pet.UpdatePetHandlerFunc(func(params pet.UpdatePetParams, principal interface{}) middleware.Responder { 135 return middleware.NotImplemented("operation pet.UpdatePet has not yet been implemented") 136 }) 137 } 138 if api.PetUpdatePetWithFormHandler == nil { 139 api.PetUpdatePetWithFormHandler = pet.UpdatePetWithFormHandlerFunc(func(params pet.UpdatePetWithFormParams, principal interface{}) middleware.Responder { 140 return middleware.NotImplemented("operation pet.UpdatePetWithForm has not yet been implemented") 141 }) 142 } 143 if api.UserUpdateUserHandler == nil { 144 api.UserUpdateUserHandler = user.UpdateUserHandlerFunc(func(params user.UpdateUserParams) middleware.Responder { 145 return middleware.NotImplemented("operation user.UpdateUser has not yet been implemented") 146 }) 147 } 148 149 api.ServerShutdown = func() {} 150 151 return setupGlobalMiddleware(api.Serve(setupMiddlewares)) 152 } 153 154 // The TLS configuration before HTTPS server starts. 155 func configureTLS(tlsConfig *tls.Config) { 156 // Make all necessary changes to the TLS configuration here. 157 } 158 159 // As soon as server is initialized but not run yet, this function will be called. 160 // If you need to modify a config, store server instance to stop it individually later, this is the place. 161 // This function can be called multiple times, depending on the number of serving schemes. 162 // scheme value will be set accordingly: "http", "https" or "unix" 163 func configureServer(s *http.Server, scheme, addr string) { 164 } 165 166 // The middleware configuration is for the handler executors. These do not apply to the swagger.json document. 167 // The middleware executes after routing but before authentication, binding and validation 168 func setupMiddlewares(handler http.Handler) http.Handler { 169 return handler 170 } 171 172 // The middleware configuration happens before anything, this middleware also applies to serving the swagger.json document. 173 // So this is a good place to plug in a panic handling middleware, logging and metrics 174 func setupGlobalMiddleware(handler http.Handler) http.Handler { 175 return handler 176 }