Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/metajar/codgen-zap-middleware

Middleware Wrapper for Zap and Go Swagger
https://github.com/metajar/codgen-zap-middleware

Last synced: 22 days ago
JSON representation

Middleware Wrapper for Zap and Go Swagger

Awesome Lists containing this project

README

        

# codgen-zap-middleware

Tired of implementing this in every project.

### Example Implement Into Generated Code

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

}
```