35 lines
1.0 KiB
Go
35 lines
1.0 KiB
Go
|
|
package controller
|
||
|
|
|
||
|
|
import (
|
||
|
|
"net/http"
|
||
|
|
"net/http/httptest"
|
||
|
|
"testing"
|
||
|
|
|
||
|
|
"github.com/gin-gonic/gin"
|
||
|
|
)
|
||
|
|
|
||
|
|
func TestGetRemoteIpIgnoresForwardedHeadersFromUntrustedRemote(t *testing.T) {
|
||
|
|
gin.SetMode(gin.TestMode)
|
||
|
|
c, _ := gin.CreateTestContext(httptest.NewRecorder())
|
||
|
|
c.Request = httptest.NewRequest(http.MethodGet, "/", nil)
|
||
|
|
c.Request.RemoteAddr = "203.0.113.10:12345"
|
||
|
|
c.Request.Header.Set("X-Real-IP", "198.51.100.9")
|
||
|
|
c.Request.Header.Set("X-Forwarded-For", "198.51.100.8")
|
||
|
|
|
||
|
|
if got := getRemoteIp(c); got != "203.0.113.10" {
|
||
|
|
t.Fatalf("remote IP = %q, want request remote address", got)
|
||
|
|
}
|
||
|
|
}
|
||
|
|
|
||
|
|
func TestGetRemoteIpHonorsForwardedHeadersFromTrustedLoopbackProxy(t *testing.T) {
|
||
|
|
gin.SetMode(gin.TestMode)
|
||
|
|
c, _ := gin.CreateTestContext(httptest.NewRecorder())
|
||
|
|
c.Request = httptest.NewRequest(http.MethodGet, "/", nil)
|
||
|
|
c.Request.RemoteAddr = "127.0.0.1:12345"
|
||
|
|
c.Request.Header.Set("X-Forwarded-For", "198.51.100.8, 127.0.0.1")
|
||
|
|
|
||
|
|
if got := getRemoteIp(c); got != "198.51.100.8" {
|
||
|
|
t.Fatalf("remote IP = %q, want forwarded client IP", got)
|
||
|
|
}
|
||
|
|
}
|