Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
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
- Host: GitHub
- URL: https://github.com/metajar/codgen-zap-middleware
- Owner: metajar
- Created: 2020-12-05T12:12:47.000Z (almost 4 years ago)
- Default Branch: master
- Last Pushed: 2020-12-05T12:23:14.000Z (almost 4 years ago)
- Last Synced: 2024-03-11T13:31:38.002Z (8 months ago)
- Language: Go
- Size: 3.91 KB
- Stars: 1
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
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.SugaredLoggerfunc 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)
}}
```