Tired of implementing this in every project.
// Code generated by go-swagger; DO NOT EDIT.
package main
import (
"github.com/go-openapi/loads"
flags "github.com/jessevdk/go-flags"
"github.com/metajar/hello/restapi"
"github.com/metajar/hello/restapi/operations"
"go.uber.org/zap"
"log"
"net/http"
"os"
"runtime/debug"
"time"
)
// This file was generated by the swagger tool.
// Make sure not to overwrite this file after you generated it because all your edits would be lost!
var logg *zap.SugaredLogger
func main() {
swaggerSpec, err := loads.Embedded(restapi.SwaggerJSON, restapi.FlatSwaggerJSON)
if err != nil {
log.Fatalln(err)
}
api := operations.NewNewAPI(swaggerSpec)
server := restapi.NewServer(api)
defer server.Shutdown()
parser := flags.NewParser(server, flags.Default)
parser.ShortDescription = "new"
parser.LongDescription = swaggerSpec.Spec().Info.Description
server.ConfigureFlags()
for _, optsGroup := range api.CommandLineOptionsGroups {
_, err := parser.AddGroup(optsGroup.ShortDescription, optsGroup.LongDescription, optsGroup.Options)
if err != nil {
log.Fatalln(err)
}
}
if _, err := parser.Parse(); err != nil {
code := 1
if fe, ok := err.(*flags.Error); ok {
if fe.Type == flags.ErrHelp {
code = 0
}
}
os.Exit(code)
}
server.ConfigureAPI()
server.Host = "0.0.0.0"
server.Port = 8080
// Add the middleware to the application for logging purposes.
middleware := LoggingMiddleware(logg)
server.SetHandler(middleware(server.GetHandler()))
if err := server.Serve(); err != nil {
log.Fatalln(err)
}
}