log101-dot-dev-services/middleware/middleware.go

49 lines
1.0 KiB
Go
Raw Permalink Normal View History

2024-05-30 15:42:33 +00:00
package middleware
import (
"net/netip"
"github.com/gin-gonic/gin"
)
// AnonymizeIPMiddleware masks the last segment of IPv4 addresses
// and the last 80 bits of IPv6 addresses.
func AnonymizeIPMiddleware() gin.HandlerFunc {
return func(c *gin.Context) {
ip := c.ClientIP()
anonymizedIP := anonymizeIP(ip)
c.Request.RemoteAddr = anonymizedIP
c.Next()
}
}
// anonymizeIP masks the last segment of IPv4 addresses
// and the last 80 bits of IPv6 addresses.
func anonymizeIP(ip string) string {
parsedIP, err := netip.ParseAddr(ip)
if err != nil {
// If there's an error parsing the IP, return the original IP
return ip
}
if parsedIP.Is4() {
// Mask the last octet for IPv4
ipPrefix, err := parsedIP.Prefix(24)
if err != nil {
return ip
}
2024-06-13 10:56:27 +00:00
return ipPrefix.Masked().Addr().String()
2024-05-30 15:42:33 +00:00
} else if parsedIP.Is6() {
// Mask the last 80 bits for IPv6
ipPrefix, err := parsedIP.Prefix(48)
if err != nil {
return ip
}
2024-06-13 10:56:27 +00:00
return ipPrefix.Masked().Addr().String()
2024-05-30 15:42:33 +00:00
}
// If it's neither IPv4 nor IPv6, return the original IP
return ip
}