// Copyright 2021 The Casdoor Authors. All Rights Reserved. // // Licensed under the Apache License, Version 2.0 (the "License"); // you may not use this file except in compliance with the License. // You may obtain a copy of the License at // // http://www.apache.org/licenses/LICENSE-2.0 // // Unless required by applicable law or agreed to in writing, software // distributed under the License is distributed on an "AS IS" BASIS, // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. // See the License for the specific language governing permissions and // limitations under the License. package util import ( "fmt" "net/http" "strings" "github.com/beego/beego/context" "github.com/beego/beego/logs" ) func GetIPInfo(clientIP string) string { if clientIP == "" { return "" } ips := strings.Split(clientIP, ",") res := "" for i := range ips { ip := strings.TrimSpace(ips[i]) // desc := GetDescFromIP(ip) ipstr := fmt.Sprintf("%s: %s", ip, "") if i != len(ips)-1 { res += ipstr + " -> " } else { res += ipstr } } return res } func GetIPFromRequest(req *http.Request) string { clientIP := req.Header.Get("x-forwarded-for") if clientIP == "" { ipPort := strings.Split(req.RemoteAddr, ":") if len(ipPort) >= 1 && len(ipPort) <= 2 { clientIP = ipPort[0] } else if len(ipPort) > 2 { idx := strings.LastIndex(req.RemoteAddr, ":") clientIP = req.RemoteAddr[0:idx] clientIP = strings.TrimLeft(clientIP, "[") clientIP = strings.TrimRight(clientIP, "]") } } return GetIPInfo(clientIP) } func LogInfo(ctx *context.Context, f string, v ...interface{}) { ipString := fmt.Sprintf("(%s) ", GetIPFromRequest(ctx.Request)) logs.Info(ipString+f, v...) } func LogWarning(ctx *context.Context, f string, v ...interface{}) { ipString := fmt.Sprintf("(%s) ", GetIPFromRequest(ctx.Request)) logs.Warning(ipString+f, v...) }