feat: add trace_id to context
This commit is contained in:
		
							
								
								
									
										20
									
								
								ctx.go
									
									
									
									
									
								
							
							
						
						
									
										20
									
								
								ctx.go
									
									
									
									
									
								
							| @@ -2,9 +2,11 @@ package nf | |||||||
|  |  | ||||||
| import ( | import ( | ||||||
| 	"bytes" | 	"bytes" | ||||||
|  | 	"context" | ||||||
| 	"encoding/json" | 	"encoding/json" | ||||||
| 	"errors" | 	"errors" | ||||||
| 	"fmt" | 	"fmt" | ||||||
|  | 	"github.com/google/uuid" | ||||||
| 	"github.com/loveuer/nf/internal/sse" | 	"github.com/loveuer/nf/internal/sse" | ||||||
| 	"io" | 	"io" | ||||||
| 	"mime/multipart" | 	"mime/multipart" | ||||||
| @@ -38,8 +40,18 @@ type Ctx struct { | |||||||
|  |  | ||||||
| func newContext(app *App, writer http.ResponseWriter, request *http.Request) *Ctx { | func newContext(app *App, writer http.ResponseWriter, request *http.Request) *Ctx { | ||||||
|  |  | ||||||
| 	skippedNodes := make([]skippedNode, 0, app.maxSections) | 	var ( | ||||||
| 	v := make(Params, 0, app.maxParams) | 		traceId      string | ||||||
|  | 		skippedNodes = make([]skippedNode, 0, app.maxSections) | ||||||
|  | 		v            = make(Params, 0, app.maxParams) | ||||||
|  | 	) | ||||||
|  |  | ||||||
|  | 	if traceId = request.Header.Get(TraceKey); traceId == "" { | ||||||
|  | 		traceId = uuid.Must(uuid.NewV7()).String() | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	c := context.WithValue(request.Context(), TraceKey, traceId) | ||||||
|  | 	request.WithContext(c) | ||||||
|  |  | ||||||
| 	ctx := &Ctx{ | 	ctx := &Ctx{ | ||||||
| 		lock:       sync.Mutex{}, | 		lock:       sync.Mutex{}, | ||||||
| @@ -112,6 +124,10 @@ func (c *Ctx) Cookies(key string, defaultValue ...string) string { | |||||||
| 	return cookie.Value | 	return cookie.Value | ||||||
| } | } | ||||||
|  |  | ||||||
|  | func (c *Ctx) Context() context.Context { | ||||||
|  | 	return c.Request.Context() | ||||||
|  | } | ||||||
|  |  | ||||||
| func (c *Ctx) Next() error { | func (c *Ctx) Next() error { | ||||||
| 	c.index++ | 	c.index++ | ||||||
|  |  | ||||||
|   | |||||||
							
								
								
									
										9
									
								
								nf.go
									
									
									
									
									
								
							
							
						
						
									
										9
									
								
								nf.go
									
									
									
									
									
								
							| @@ -1,10 +1,11 @@ | |||||||
| package nf | package nf | ||||||
|  |  | ||||||
| const ( | const ( | ||||||
| 	banner = "  _  _     _     ___                 _ \n | \\| |___| |_  | __|__ _  _ _ _  __| |\n | .` / _ \\  _| | _/ _ \\ || | ' \\/ _` |\n |_|\\_\\___/\\__| |_|\\___/\\_,_|_||_\\__,_|\n " | 	banner   = "  _  _     _     ___                 _ \n | \\| |___| |_  | __|__ _  _ _ _  __| |\n | .` / _ \\  _| | _/ _ \\ || | ' \\/ _` |\n |_|\\_\\___/\\__| |_|\\___/\\_,_|_||_\\__,_|\n " | ||||||
| 	_404   = "<!doctype html><html lang=\"en\"><head><meta charset=\"UTF-8\"><meta name=\"viewport\" content=\"width=device-width,user-scalable=no,initial-scale=1,maximum-scale=1,minimum-scale=1\"><meta http-equiv=\"X-UA-Compatible\" content=\"ie=edge\"><title>Not Found</title><style>body{background:#333;margin:0;color:#ccc;display:flex;align-items:center;max-height:100vh;height:100vh;justify-content:center}textarea{min-height:5rem;min-width:20rem;text-align:center;border:none;background:0 0;color:#ccc;resize:none;user-input:none;user-select:none;cursor:default;-webkit-user-select:none;-webkit-touch-callout:none;-moz-user-select:none;-ms-user-select:none;outline:0}</style></head><body><textarea id=\"banner\" readonly=\"readonly\"></textarea><script type=\"text/javascript\">let htmlCodes = [\n    ' _  _     _     ___                 _ ',\n    '| \\\\| |___| |_  | __|__ _  _ _ _  __| |',\n    '| .` / _ \\\\  _| | _/ _ \\\\ || | \\' \\\\/ _` |',\n    '|_|\\\\_\\\\___/\\\\__| |_|\\\\___/\\\\_,_|_||_\\\\__,_|'\n].join('\\n');\ndocument.querySelector('#banner').value = htmlCodes</script></body></html>" | 	_404     = "<!doctype html><html lang=\"en\"><head><meta charset=\"UTF-8\"><meta name=\"viewport\" content=\"width=device-width,user-scalable=no,initial-scale=1,maximum-scale=1,minimum-scale=1\"><meta http-equiv=\"X-UA-Compatible\" content=\"ie=edge\"><title>Not Found</title><style>body{background:#333;margin:0;color:#ccc;display:flex;align-items:center;max-height:100vh;height:100vh;justify-content:center}textarea{min-height:5rem;min-width:20rem;text-align:center;border:none;background:0 0;color:#ccc;resize:none;user-input:none;user-select:none;cursor:default;-webkit-user-select:none;-webkit-touch-callout:none;-moz-user-select:none;-ms-user-select:none;outline:0}</style></head><body><textarea id=\"banner\" readonly=\"readonly\"></textarea><script type=\"text/javascript\">let htmlCodes = [\n    ' _  _     _     ___                 _ ',\n    '| \\\\| |___| |_  | __|__ _  _ _ _  __| |',\n    '| .` / _ \\\\  _| | _/ _ \\\\ || | \\' \\\\/ _` |',\n    '|_|\\\\_\\\\___/\\\\__| |_|\\\\___/\\\\_,_|_||_\\\\__,_|'\n].join('\\n');\ndocument.querySelector('#banner').value = htmlCodes</script></body></html>" | ||||||
| 	_405   = `405 Method Not Allowed` | 	_405     = `405 Method Not Allowed` | ||||||
| 	_500   = `500 Internal Server Error` | 	_500     = `500 Internal Server Error` | ||||||
|  | 	TraceKey = "X-Trace-Id" | ||||||
| ) | ) | ||||||
|  |  | ||||||
| type Map map[string]interface{} | type Map map[string]interface{} | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user