22 lines
		
	
	
		
			499 B
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			22 lines
		
	
	
		
			499 B
		
	
	
	
		
			Go
		
	
	
	
	
	
package middleware
 | 
						|
 | 
						|
import (
 | 
						|
	"GoWeb/security"
 | 
						|
	"log/slog"
 | 
						|
	"net/http"
 | 
						|
)
 | 
						|
 | 
						|
// Csrf validates the CSRF token and returns the handler function if it succeeded
 | 
						|
func Csrf(f func(w http.ResponseWriter, r *http.Request)) func(w http.ResponseWriter, r *http.Request) {
 | 
						|
	return func(w http.ResponseWriter, r *http.Request) {
 | 
						|
		_, err := security.VerifyCsrfToken(r)
 | 
						|
		if err != nil {
 | 
						|
			slog.Info("error verifying csrf token")
 | 
						|
			http.Error(w, "Forbidden", http.StatusForbidden)
 | 
						|
			return
 | 
						|
		}
 | 
						|
 | 
						|
		f(w, r)
 | 
						|
	}
 | 
						|
}
 |