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  }