aboutsummaryrefslogtreecommitdiff
path: root/backend/api/ip.go
diff options
context:
space:
mode:
authorRyan Mehri <[email protected]>2020-05-09 21:17:40 -0600
committerGitHub <[email protected]>2020-05-09 21:17:40 -0600
commit14e120bc3fa4da442af0063c1a00852e67fbc6a2 (patch)
tree9258832576f9c1bcad6126cf76ef8f7f6a128e82 /backend/api/ip.go
parentMerge pull request #3 from jackyzha0/doc-expiry (diff)
parentfolder refactor (diff)
downloadctrl-v-14e120bc3fa4da442af0063c1a00852e67fbc6a2.tar.xz
ctrl-v-14e120bc3fa4da442af0063c1a00852e67fbc6a2.zip
Merge pull request #4 from jackyzha0/folder-refactor
folder refactor
Diffstat (limited to 'backend/api/ip.go')
-rw-r--r--backend/api/ip.go37
1 files changed, 37 insertions, 0 deletions
diff --git a/backend/api/ip.go b/backend/api/ip.go
new file mode 100644
index 0000000..0d135b3
--- /dev/null
+++ b/backend/api/ip.go
@@ -0,0 +1,37 @@
+package api
+
+import (
+ "net"
+ "net/http"
+ "strings"
+)
+
+func getIP(r *http.Request) (s string) {
+ // Get IP from the X-REAL-IP header
+ ip := r.Header.Get("X-REAL-IP")
+ netIP := net.ParseIP(ip)
+ if netIP != nil {
+ return ip
+ }
+
+ // Get IP from X-FORWARDED-FOR header
+ ips := r.Header.Get("X-FORWARDED-FOR")
+ splitIps := strings.Split(ips, ",")
+ for _, ip := range splitIps {
+ netIP := net.ParseIP(ip)
+ if netIP != nil {
+ return ip
+ }
+ }
+
+ // Get IP from RemoteAddr
+ ip, _, err := net.SplitHostPort(r.RemoteAddr)
+ if err != nil {
+ return
+ }
+ netIP = net.ParseIP(ip)
+ if netIP != nil {
+ return
+ }
+ return
+}