Skip to content

metajar/codgen-zap-middleware

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

2 Commits
 
 
 
 
 
 
 
 

Repository files navigation

codgen-zap-middleware

Tired of implementing this in every project.

Example Implement Into Generated Code

// 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)
	}

}

About

Middleware Wrapper for Zap and Go Swagger

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages