Compare commits
	
		
			9 Commits
		
	
	
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| 5273ff7600 | |||
| caa69c3629 | |||
| 0ff5f0aa28 | |||
| d5cb1e48ed | |||
| 1c2d3f541f | |||
| ec62ad436f | |||
| 8d0ef0f002 | |||
| d78550672e | |||
| 1d629f6db8 | 
| @@ -38,8 +38,18 @@ printf "package goext\n\nconst GoextVersion = \"%s\"\n\nconst GoextVersionTimest | |||||||
|  |  | ||||||
| git add --verbose . | git add --verbose . | ||||||
|  |  | ||||||
|  | echo -n "Insert option commit message: " | ||||||
|  |  | ||||||
|  | read commitMessage | ||||||
|  |  | ||||||
| msg="v${next_ver}" | msg="v${next_ver}" | ||||||
|  |  | ||||||
|  |  | ||||||
|  | if [[ "$commitMessage" != "" ]]; then | ||||||
|  |   msg="${msg} ${commitMessage}" | ||||||
|  | fi | ||||||
|  |  | ||||||
|  |  | ||||||
| if [ $# -gt 0 ]; then | if [ $# -gt 0 ]; then | ||||||
|   msg="$1" |   msg="$1" | ||||||
| fi | fi | ||||||
|   | |||||||
							
								
								
									
										59
									
								
								ginext/appContext.go
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										59
									
								
								ginext/appContext.go
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,59 @@ | |||||||
|  | package ginext | ||||||
|  |  | ||||||
|  | import ( | ||||||
|  | 	"context" | ||||||
|  | 	"github.com/gin-gonic/gin" | ||||||
|  | 	"time" | ||||||
|  | ) | ||||||
|  |  | ||||||
|  | type AppContext struct { | ||||||
|  | 	inner      context.Context | ||||||
|  | 	cancelFunc context.CancelFunc | ||||||
|  | 	cancelled  bool | ||||||
|  | 	GinContext *gin.Context | ||||||
|  | } | ||||||
|  |  | ||||||
|  | func CreateAppContext(g *gin.Context, innerCtx context.Context, cancelFn context.CancelFunc) *AppContext { | ||||||
|  | 	return &AppContext{ | ||||||
|  | 		inner:      innerCtx, | ||||||
|  | 		cancelFunc: cancelFn, | ||||||
|  | 		cancelled:  false, | ||||||
|  | 		GinContext: g, | ||||||
|  | 	} | ||||||
|  | } | ||||||
|  |  | ||||||
|  | func (ac *AppContext) Deadline() (deadline time.Time, ok bool) { | ||||||
|  | 	return ac.inner.Deadline() | ||||||
|  | } | ||||||
|  |  | ||||||
|  | func (ac *AppContext) Done() <-chan struct{} { | ||||||
|  | 	return ac.inner.Done() | ||||||
|  | } | ||||||
|  |  | ||||||
|  | func (ac *AppContext) Err() error { | ||||||
|  | 	return ac.inner.Err() | ||||||
|  | } | ||||||
|  |  | ||||||
|  | func (ac *AppContext) Value(key any) any { | ||||||
|  | 	return ac.inner.Value(key) | ||||||
|  | } | ||||||
|  |  | ||||||
|  | func (ac *AppContext) Cancel() { | ||||||
|  | 	ac.cancelled = true | ||||||
|  | 	ac.cancelFunc() | ||||||
|  | } | ||||||
|  |  | ||||||
|  | func (ac *AppContext) RequestURI() string { | ||||||
|  | 	if ac.GinContext != nil && ac.GinContext.Request != nil { | ||||||
|  | 		return ac.GinContext.Request.Method + " :: " + ac.GinContext.Request.RequestURI | ||||||
|  | 	} else { | ||||||
|  | 		return "" | ||||||
|  | 	} | ||||||
|  | } | ||||||
|  |  | ||||||
|  | func (ac *AppContext) FinishSuccess(res HTTPResponse) HTTPResponse { | ||||||
|  | 	if ac.cancelled { | ||||||
|  | 		panic("Cannot finish a cancelled request") | ||||||
|  | 	} | ||||||
|  | 	return res | ||||||
|  | } | ||||||
| @@ -1,4 +1,4 @@ | |||||||
| package apierr | package commonApiErr | ||||||
| 
 | 
 | ||||||
| type APIErrorCode struct { | type APIErrorCode struct { | ||||||
| 	HTTPStatusCode int | 	HTTPStatusCode int | ||||||
| @@ -1,24 +1,23 @@ | |||||||
| package ginext | package ginext | ||||||
|  |  | ||||||
| import ( | import ( | ||||||
| 	"github.com/gin-gonic/gin" |  | ||||||
| 	"net/http" | 	"net/http" | ||||||
| ) | ) | ||||||
|  |  | ||||||
| func RedirectFound(newuri string) gin.HandlerFunc { | func RedirectFound(newuri string) WHandlerFunc { | ||||||
| 	return func(g *gin.Context) { | 	return func(pctx PreContext) HTTPResponse { | ||||||
| 		g.Redirect(http.StatusFound, newuri) | 		return Redirect(http.StatusFound, newuri) | ||||||
| 	} | 	} | ||||||
| } | } | ||||||
|  |  | ||||||
| func RedirectTemporary(newuri string) gin.HandlerFunc { | func RedirectTemporary(newuri string) WHandlerFunc { | ||||||
| 	return func(g *gin.Context) { | 	return func(pctx PreContext) HTTPResponse { | ||||||
| 		g.Redirect(http.StatusTemporaryRedirect, newuri) | 		return Redirect(http.StatusTemporaryRedirect, newuri) | ||||||
| 	} | 	} | ||||||
| } | } | ||||||
|  |  | ||||||
| func RedirectPermanent(newuri string) gin.HandlerFunc { | func RedirectPermanent(newuri string) WHandlerFunc { | ||||||
| 	return func(g *gin.Context) { | 	return func(pctx PreContext) HTTPResponse { | ||||||
| 		g.Redirect(http.StatusPermanentRedirect, newuri) | 		return Redirect(http.StatusPermanentRedirect, newuri) | ||||||
| 	} | 	} | ||||||
| } | } | ||||||
|   | |||||||
| @@ -1,6 +1,10 @@ | |||||||
| package ginext | package ginext | ||||||
|  |  | ||||||
| import "github.com/gin-gonic/gin" | import ( | ||||||
|  | 	"github.com/gin-gonic/gin" | ||||||
|  | 	"net/http" | ||||||
|  | 	"time" | ||||||
|  | ) | ||||||
|  |  | ||||||
| type GinWrapper struct { | type GinWrapper struct { | ||||||
| 	engine          *gin.Engine | 	engine          *gin.Engine | ||||||
| @@ -9,9 +13,10 @@ type GinWrapper struct { | |||||||
| 	allowCors       bool | 	allowCors       bool | ||||||
| 	ginDebug        bool | 	ginDebug        bool | ||||||
| 	returnRawErrors bool | 	returnRawErrors bool | ||||||
|  | 	requestTimeout  time.Duration | ||||||
| } | } | ||||||
|  |  | ||||||
| func NewEngine(allowCors bool, ginDebug bool, returnRawErrors bool) *GinWrapper { | func NewEngine(allowCors bool, ginDebug bool, returnRawErrors bool, timeout time.Duration) *GinWrapper { | ||||||
| 	engine := gin.New() | 	engine := gin.New() | ||||||
|  |  | ||||||
| 	wrapper := &GinWrapper{ | 	wrapper := &GinWrapper{ | ||||||
| @@ -20,6 +25,7 @@ func NewEngine(allowCors bool, ginDebug bool, returnRawErrors bool) *GinWrapper | |||||||
| 		allowCors:       allowCors, | 		allowCors:       allowCors, | ||||||
| 		ginDebug:        ginDebug, | 		ginDebug:        ginDebug, | ||||||
| 		returnRawErrors: returnRawErrors, | 		returnRawErrors: returnRawErrors, | ||||||
|  | 		requestTimeout:  timeout, | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	engine.RedirectFixedPath = false | 	engine.RedirectFixedPath = false | ||||||
| @@ -40,3 +46,7 @@ func NewEngine(allowCors bool, ginDebug bool, returnRawErrors bool) *GinWrapper | |||||||
|  |  | ||||||
| 	return wrapper | 	return wrapper | ||||||
| } | } | ||||||
|  |  | ||||||
|  | func (w *GinWrapper) ServeHTTP(writer http.ResponseWriter, request *http.Request) { | ||||||
|  | 	w.engine.ServeHTTP(writer, request) | ||||||
|  | } | ||||||
|   | |||||||
| @@ -5,11 +5,9 @@ import ( | |||||||
| 	"fmt" | 	"fmt" | ||||||
| 	"github.com/gin-gonic/gin" | 	"github.com/gin-gonic/gin" | ||||||
| 	"github.com/rs/zerolog/log" | 	"github.com/rs/zerolog/log" | ||||||
| 	"gogs.mikescher.com/BlackForestBytes/goext/ginext/apierr" |  | ||||||
| 	"runtime/debug" |  | ||||||
| ) | ) | ||||||
|  |  | ||||||
| type WHandlerFunc func(*gin.Context) HTTPResponse | type WHandlerFunc func(PreContext) HTTPResponse | ||||||
|  |  | ||||||
| func Wrap(w *GinWrapper, fn WHandlerFunc) gin.HandlerFunc { | func Wrap(w *GinWrapper, fn WHandlerFunc) gin.HandlerFunc { | ||||||
|  |  | ||||||
| @@ -19,14 +17,14 @@ func Wrap(w *GinWrapper, fn WHandlerFunc) gin.HandlerFunc { | |||||||
|  |  | ||||||
| 		reqctx := g.Request.Context() | 		reqctx := g.Request.Context() | ||||||
|  |  | ||||||
| 		wrap, stackTrace, panicObj := callPanicSafe(fn, g) | 		wrap, stackTrace, panicObj := callPanicSafe(fn, PreContext{wrapper: w, ginCtx: g}) | ||||||
| 		if panicObj != nil { | 		if panicObj != nil { | ||||||
| 			fmt.Printf("\n======== ======== STACKTRACE ======== ========\n%s\n======== ======== ======== ========\n\n", stackTrace) | 			fmt.Printf("\n======== ======== STACKTRACE ======== ========\n%s\n======== ======== ======== ========\n\n", stackTrace) | ||||||
| 			log.Error(). | 			log.Error(). | ||||||
| 				Interface("panicObj", panicObj). | 				Interface("panicObj", panicObj). | ||||||
| 				Str("trace", stackTrace). | 				Str("trace", stackTrace). | ||||||
| 				Msg("Panic occured (in gin handler)") | 				Msg("Panic occured (in gin handler)") | ||||||
| 			wrap = APIError(g, apierr.Panic, "A panic occured in the HTTP handler", errors.New(fmt.Sprintf("%+v", panicObj))) | 			wrap = APIError(g, commonApiErr.Panic, "A panic occured in the HTTP handler", errors.New(fmt.Sprintf("%+v", panicObj))) | ||||||
| 		} | 		} | ||||||
|  |  | ||||||
| 		if g.Writer.Written() { | 		if g.Writer.Written() { | ||||||
| @@ -38,16 +36,3 @@ func Wrap(w *GinWrapper, fn WHandlerFunc) gin.HandlerFunc { | |||||||
| 		} | 		} | ||||||
| 	} | 	} | ||||||
| } | } | ||||||
|  |  | ||||||
| func callPanicSafe(fn WHandlerFunc, g *gin.Context) (res HTTPResponse, stackTrace string, panicObj any) { |  | ||||||
| 	defer func() { |  | ||||||
| 		if rec := recover(); rec != nil { |  | ||||||
| 			res = nil |  | ||||||
| 			stackTrace = string(debug.Stack()) |  | ||||||
| 			panicObj = rec |  | ||||||
| 		} |  | ||||||
| 	}() |  | ||||||
|  |  | ||||||
| 	res = fn(g) |  | ||||||
| 	return res, "", nil |  | ||||||
| } |  | ||||||
|   | |||||||
							
								
								
									
										90
									
								
								ginext/preContext.go
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										90
									
								
								ginext/preContext.go
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,90 @@ | |||||||
|  | package ginext | ||||||
|  |  | ||||||
|  | import ( | ||||||
|  | 	"context" | ||||||
|  | 	"github.com/gin-gonic/gin" | ||||||
|  | 	"github.com/gin-gonic/gin/binding" | ||||||
|  | 	"gogs.mikescher.com/BlackForestBytes/goext/langext" | ||||||
|  | 	"runtime/debug" | ||||||
|  | ) | ||||||
|  |  | ||||||
|  | type PreContext struct { | ||||||
|  | 	ginCtx  *gin.Context | ||||||
|  | 	wrapper *GinWrapper | ||||||
|  | 	uri     any | ||||||
|  | 	query   any | ||||||
|  | 	body    any | ||||||
|  | 	form    any | ||||||
|  | } | ||||||
|  |  | ||||||
|  | func (pctx *PreContext) URI(uri any) *PreContext { | ||||||
|  | 	pctx.uri = uri | ||||||
|  | 	return pctx | ||||||
|  | } | ||||||
|  |  | ||||||
|  | func (pctx *PreContext) Query(query any) *PreContext { | ||||||
|  | 	pctx.query = query | ||||||
|  | 	return pctx | ||||||
|  | } | ||||||
|  |  | ||||||
|  | func (pctx *PreContext) Body(body any) *PreContext { | ||||||
|  | 	pctx.body = body | ||||||
|  | 	return pctx | ||||||
|  | } | ||||||
|  |  | ||||||
|  | func (pctx *PreContext) Form(form any) *PreContext { | ||||||
|  | 	pctx.form = form | ||||||
|  | 	return pctx | ||||||
|  | } | ||||||
|  |  | ||||||
|  | func (pctx PreContext) Start() (*AppContext, *gin.Context, *HTTPResponse) { | ||||||
|  | 	if pctx.uri != nil { | ||||||
|  | 		if err := pctx.ginCtx.ShouldBindUri(pctx.uri); err != nil { | ||||||
|  | 			return nil, nil, langext.Ptr(APIError(pctx.ginCtx, commonApiErr.BindFailURI, "Failed to read uri", err)) | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	if pctx.query != nil { | ||||||
|  | 		if err := pctx.ginCtx.ShouldBindQuery(pctx.query); err != nil { | ||||||
|  | 			return nil, nil, langext.Ptr(APIError(pctx.ginCtx, commonApiErr.BindFailQuery, "Failed to read query", err)) | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	if pctx.body != nil { | ||||||
|  | 		if pctx.ginCtx.ContentType() == "application/json" { | ||||||
|  | 			if err := pctx.ginCtx.ShouldBindJSON(pctx.body); err != nil { | ||||||
|  | 				return nil, nil, langext.Ptr(APIError(pctx.ginCtx, commonApiErr.BindFailJSON, "Failed to read body", err)) | ||||||
|  | 			} | ||||||
|  | 		} else { | ||||||
|  | 			return nil, nil, langext.Ptr(APIError(pctx.ginCtx, commonApiErr.BindFailJSON, "missing JSON body", nil)) | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	if pctx.form != nil { | ||||||
|  | 		if pctx.ginCtx.ContentType() == "multipart/form-data" { | ||||||
|  | 			if err := pctx.ginCtx.ShouldBindWith(pctx.form, binding.Form); err != nil { | ||||||
|  | 				return nil, nil, langext.Ptr(APIError(pctx.ginCtx, commonApiErr.BindFailFormData, "Failed to read multipart-form", err)) | ||||||
|  | 			} | ||||||
|  | 		} else { | ||||||
|  | 			return nil, nil, langext.Ptr(APIError(pctx.ginCtx, commonApiErr.BindFailJSON, "missing form body", nil)) | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	ictx, cancel := context.WithTimeout(context.Background(), pctx.wrapper.requestTimeout) | ||||||
|  | 	actx := CreateAppContext(pctx.ginCtx, ictx, cancel) | ||||||
|  |  | ||||||
|  | 	return actx, pctx.ginCtx, nil | ||||||
|  | } | ||||||
|  |  | ||||||
|  | func callPanicSafe(fn WHandlerFunc, pctx PreContext) (res HTTPResponse, stackTrace string, panicObj any) { | ||||||
|  | 	defer func() { | ||||||
|  | 		if rec := recover(); rec != nil { | ||||||
|  | 			res = nil | ||||||
|  | 			stackTrace = string(debug.Stack()) | ||||||
|  | 			panicObj = rec | ||||||
|  | 		} | ||||||
|  | 	}() | ||||||
|  |  | ||||||
|  | 	res = fn(pctx) | ||||||
|  | 	return res, "", nil | ||||||
|  | } | ||||||
| @@ -4,7 +4,6 @@ import ( | |||||||
| 	"fmt" | 	"fmt" | ||||||
| 	"github.com/gin-gonic/gin" | 	"github.com/gin-gonic/gin" | ||||||
| 	"github.com/rs/zerolog/log" | 	"github.com/rs/zerolog/log" | ||||||
| 	"gogs.mikescher.com/BlackForestBytes/goext/ginext/apierr" |  | ||||||
| 	json "gogs.mikescher.com/BlackForestBytes/goext/gojson" | 	json "gogs.mikescher.com/BlackForestBytes/goext/gojson" | ||||||
| 	"gogs.mikescher.com/BlackForestBytes/goext/langext" | 	"gogs.mikescher.com/BlackForestBytes/goext/langext" | ||||||
| 	"runtime/debug" | 	"runtime/debug" | ||||||
| @@ -66,6 +65,15 @@ func (j fileHTTPResponse) Write(g *gin.Context) { | |||||||
| 	g.File(j.filepath) | 	g.File(j.filepath) | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | type redirectHTTPResponse struct { | ||||||
|  | 	statusCode int | ||||||
|  | 	url        string | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | func (j redirectHTTPResponse) Write(g *gin.Context) { | ||||||
|  | 	g.Redirect(j.statusCode, j.url) | ||||||
|  | } | ||||||
|  | 
 | ||||||
| func Status(sc int) HTTPResponse { | func Status(sc int) HTTPResponse { | ||||||
| 	return &emptyHTTPResponse{statusCode: sc} | 	return &emptyHTTPResponse{statusCode: sc} | ||||||
| } | } | ||||||
| @@ -90,15 +98,19 @@ func Download(mimetype string, filepath string, filename string) HTTPResponse { | |||||||
| 	return &fileHTTPResponse{mimetype: mimetype, filepath: filepath, filename: &filename} | 	return &fileHTTPResponse{mimetype: mimetype, filepath: filepath, filename: &filename} | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| func APIError(g *gin.Context, errcode apierr.APIErrorCode, msg string, e error) HTTPResponse { | func Redirect(sc int, newURL string) HTTPResponse { | ||||||
|  | 	return &redirectHTTPResponse{statusCode: sc, url: newURL} | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | func APIError(g *gin.Context, errcode commonApiErr.APIErrorCode, msg string, e error) HTTPResponse { | ||||||
| 	return createApiError(g, errcode, msg, e) | 	return createApiError(g, errcode, msg, e) | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| func NotImplemented(g *gin.Context) HTTPResponse { | func NotImplemented(g *gin.Context) HTTPResponse { | ||||||
| 	return createApiError(g, apierr.NotImplemented, "", nil) | 	return createApiError(g, commonApiErr.NotImplemented, "", nil) | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| func createApiError(g *gin.Context, errcode apierr.APIErrorCode, msg string, e error) HTTPResponse { | func createApiError(g *gin.Context, errcode commonApiErr.APIErrorCode, msg string, e error) HTTPResponse { | ||||||
| 	reqUri := "" | 	reqUri := "" | ||||||
| 	if g != nil && g.Request != nil { | 	if g != nil && g.Request != nil { | ||||||
| 		reqUri = g.Request.Method + " :: " + g.Request.RequestURI | 		reqUri = g.Request.Method + " :: " + g.Request.RequestURI | ||||||
| @@ -5,6 +5,12 @@ import ( | |||||||
| 	"net/http" | 	"net/http" | ||||||
| ) | ) | ||||||
|  |  | ||||||
|  | var anyMethods = []string{ | ||||||
|  | 	http.MethodGet, http.MethodPost, http.MethodPut, http.MethodPatch, | ||||||
|  | 	http.MethodHead, http.MethodOptions, http.MethodDelete, http.MethodConnect, | ||||||
|  | 	http.MethodTrace, | ||||||
|  | } | ||||||
|  |  | ||||||
| type GinRoutesWrapper struct { | type GinRoutesWrapper struct { | ||||||
| 	wrapper *GinWrapper | 	wrapper *GinWrapper | ||||||
| 	routes  gin.IRouter | 	routes  gin.IRouter | ||||||
| @@ -13,7 +19,7 @@ type GinRoutesWrapper struct { | |||||||
| type GinRouteBuilder struct { | type GinRouteBuilder struct { | ||||||
| 	routes *GinRoutesWrapper | 	routes *GinRoutesWrapper | ||||||
|  |  | ||||||
| 	method   string | 	methods  []string | ||||||
| 	relPath  string | 	relPath  string | ||||||
| 	handlers []gin.HandlerFunc | 	handlers []gin.HandlerFunc | ||||||
| } | } | ||||||
| @@ -27,42 +33,53 @@ func (w *GinRoutesWrapper) Group(relativePath string) *GinRoutesWrapper { | |||||||
| } | } | ||||||
|  |  | ||||||
| func (w *GinRoutesWrapper) GET(relativePath string) *GinRouteBuilder { | func (w *GinRoutesWrapper) GET(relativePath string) *GinRouteBuilder { | ||||||
| 	return &GinRouteBuilder{routes: w, method: http.MethodGet, relPath: relativePath, handlers: make([]gin.HandlerFunc, 0)} | 	return &GinRouteBuilder{routes: w, methods: []string{http.MethodGet}, relPath: relativePath, handlers: make([]gin.HandlerFunc, 0)} | ||||||
| } | } | ||||||
|  |  | ||||||
| func (w *GinRoutesWrapper) POST(relativePath string) *GinRouteBuilder { | func (w *GinRoutesWrapper) POST(relativePath string) *GinRouteBuilder { | ||||||
| 	return &GinRouteBuilder{routes: w, method: http.MethodPost, relPath: relativePath, handlers: make([]gin.HandlerFunc, 0)} | 	return &GinRouteBuilder{routes: w, methods: []string{http.MethodPost}, relPath: relativePath, handlers: make([]gin.HandlerFunc, 0)} | ||||||
| } | } | ||||||
|  |  | ||||||
| func (w *GinRoutesWrapper) DELETE(relativePath string) *GinRouteBuilder { | func (w *GinRoutesWrapper) DELETE(relativePath string) *GinRouteBuilder { | ||||||
| 	return &GinRouteBuilder{routes: w, method: http.MethodDelete, relPath: relativePath, handlers: make([]gin.HandlerFunc, 0)} | 	return &GinRouteBuilder{routes: w, methods: []string{http.MethodDelete}, relPath: relativePath, handlers: make([]gin.HandlerFunc, 0)} | ||||||
| } | } | ||||||
|  |  | ||||||
| func (w *GinRoutesWrapper) PATCH(relativePath string) *GinRouteBuilder { | func (w *GinRoutesWrapper) PATCH(relativePath string) *GinRouteBuilder { | ||||||
| 	return &GinRouteBuilder{routes: w, method: http.MethodPatch, relPath: relativePath, handlers: make([]gin.HandlerFunc, 0)} | 	return &GinRouteBuilder{routes: w, methods: []string{http.MethodPatch}, relPath: relativePath, handlers: make([]gin.HandlerFunc, 0)} | ||||||
| } | } | ||||||
|  |  | ||||||
| func (w *GinRoutesWrapper) PUT(relativePath string) *GinRouteBuilder { | func (w *GinRoutesWrapper) PUT(relativePath string) *GinRouteBuilder { | ||||||
| 	return &GinRouteBuilder{routes: w, method: http.MethodPut, relPath: relativePath, handlers: make([]gin.HandlerFunc, 0)} | 	return &GinRouteBuilder{routes: w, methods: []string{http.MethodPut}, relPath: relativePath, handlers: make([]gin.HandlerFunc, 0)} | ||||||
| } | } | ||||||
|  |  | ||||||
| func (w *GinRoutesWrapper) OPTIONS(relativePath string) *GinRouteBuilder { | func (w *GinRoutesWrapper) OPTIONS(relativePath string) *GinRouteBuilder { | ||||||
| 	return &GinRouteBuilder{routes: w, method: http.MethodOptions, relPath: relativePath, handlers: make([]gin.HandlerFunc, 0)} | 	return &GinRouteBuilder{routes: w, methods: []string{http.MethodOptions}, relPath: relativePath, handlers: make([]gin.HandlerFunc, 0)} | ||||||
| } | } | ||||||
|  |  | ||||||
| func (w *GinRoutesWrapper) HEAD(relativePath string) *GinRouteBuilder { | func (w *GinRoutesWrapper) HEAD(relativePath string) *GinRouteBuilder { | ||||||
| 	return &GinRouteBuilder{routes: w, method: http.MethodHead, relPath: relativePath, handlers: make([]gin.HandlerFunc, 0)} | 	return &GinRouteBuilder{routes: w, methods: []string{http.MethodHead}, relPath: relativePath, handlers: make([]gin.HandlerFunc, 0)} | ||||||
| } | } | ||||||
|  |  | ||||||
| func (w *GinRoutesWrapper) COUNT(relativePath string) *GinRouteBuilder { | func (w *GinRoutesWrapper) COUNT(relativePath string) *GinRouteBuilder { | ||||||
| 	return &GinRouteBuilder{routes: w, method: "COUNT", relPath: relativePath, handlers: make([]gin.HandlerFunc, 0)} | 	return &GinRouteBuilder{routes: w, methods: []string{"COUNT"}, relPath: relativePath, handlers: make([]gin.HandlerFunc, 0)} | ||||||
| } | } | ||||||
|  |  | ||||||
| func (w *GinRouteBuilder) Use(middleware gin.HandlerFunc) *GinRouteBuilder { | func (w *GinRoutesWrapper) Any(relativePath string) *GinRouteBuilder { | ||||||
| 	w.handlers = append(w.handlers, middleware) | 	return &GinRouteBuilder{routes: w, methods: anyMethods, relPath: relativePath, handlers: make([]gin.HandlerFunc, 0)} | ||||||
|  | } | ||||||
|  |  | ||||||
|  | func (w *GinRouteBuilder) Use(middleware ...gin.HandlerFunc) *GinRouteBuilder { | ||||||
|  | 	w.handlers = append(w.handlers, middleware...) | ||||||
| 	return w | 	return w | ||||||
| } | } | ||||||
|  |  | ||||||
| func (w *GinRouteBuilder) Handle(handler WHandlerFunc) { | func (w *GinRouteBuilder) Handle(handler WHandlerFunc) { | ||||||
| 	w.handlers = append(w.handlers, Wrap(w.routes.wrapper, handler)) | 	w.handlers = append(w.handlers, Wrap(w.routes.wrapper, handler)) | ||||||
| 	w.routes.routes.Handle(w.method, w.relPath, w.handlers...) | 	for _, m := range w.methods { | ||||||
|  | 		w.routes.routes.Handle(m, w.relPath, w.handlers...) | ||||||
|  | 	} | ||||||
|  | } | ||||||
|  |  | ||||||
|  | func (w *GinWrapper) NoRoute(handler WHandlerFunc) { | ||||||
|  | 	w.engine.NoRoute(Wrap(w, handler)) | ||||||
| } | } | ||||||
|   | |||||||
| @@ -1,5 +1,5 @@ | |||||||
| package goext | package goext | ||||||
|  |  | ||||||
| const GoextVersion = "0.0.172" | const GoextVersion = "0.0.181" | ||||||
|  |  | ||||||
| const GoextVersionTimestamp = "2023-07-18T14:40:10+0200" | const GoextVersionTimestamp = "2023-07-19T11:26:02+0200" | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user