mirror of
https://github.com/Ernous/TorrServerJellyfin.git
synced 2025-12-19 21:46:11 +05:00
add white/black ip list
This commit is contained in:
129
server/web/blocker/blocker.go
Normal file
129
server/web/blocker/blocker.go
Normal file
@@ -0,0 +1,129 @@
|
||||
package blocker
|
||||
|
||||
import (
|
||||
"bufio"
|
||||
"bytes"
|
||||
"errors"
|
||||
"io/ioutil"
|
||||
"net"
|
||||
"net/http"
|
||||
"path/filepath"
|
||||
"strings"
|
||||
|
||||
"server/log"
|
||||
"server/settings"
|
||||
|
||||
"github.com/anacrolix/torrent/iplist"
|
||||
"github.com/gin-gonic/gin"
|
||||
)
|
||||
|
||||
func Blocker() gin.HandlerFunc {
|
||||
emptyFN := func(c *gin.Context) {
|
||||
c.Next()
|
||||
}
|
||||
|
||||
name := filepath.Join(settings.Path, "bip.txt")
|
||||
buf, err := ioutil.ReadFile(name)
|
||||
if err != nil {
|
||||
return emptyFN
|
||||
}
|
||||
blackIpList := scanBuf(buf)
|
||||
|
||||
name = filepath.Join(settings.Path, "wip.txt")
|
||||
buf, err = ioutil.ReadFile(name)
|
||||
if err != nil {
|
||||
return emptyFN
|
||||
}
|
||||
whiteIpList := scanBuf(buf)
|
||||
if blackIpList.NumRanges() == 0 {
|
||||
return emptyFN
|
||||
}
|
||||
|
||||
if blackIpList.NumRanges() == 0 && whiteIpList.NumRanges() == 0 {
|
||||
return emptyFN
|
||||
}
|
||||
|
||||
return func(c *gin.Context) {
|
||||
arr := strings.Split(c.Request.RemoteAddr, ":")
|
||||
if len(arr) > 0 {
|
||||
ip := net.ParseIP(arr[0])
|
||||
minifyIP(&ip)
|
||||
if whiteIpList.NumRanges() > 0 {
|
||||
if _, ok := whiteIpList.Lookup(ip); !ok {
|
||||
log.TLogln("Block ip, not in white list", ip.String())
|
||||
c.String(http.StatusTeapot, "Banned")
|
||||
c.Abort()
|
||||
return
|
||||
}
|
||||
}
|
||||
if blackIpList.NumRanges() > 0 {
|
||||
if r, ok := blackIpList.Lookup(ip); ok {
|
||||
log.TLogln("Block ip, in black list:", ip.String(), "in range", r.Description, ":", r.First, "-", r.Last)
|
||||
c.String(http.StatusTeapot, "Banned")
|
||||
c.Abort()
|
||||
return
|
||||
}
|
||||
}
|
||||
}
|
||||
c.Next()
|
||||
}
|
||||
}
|
||||
|
||||
func scanBuf(buf []byte) iplist.Ranger {
|
||||
scanner := bufio.NewScanner(strings.NewReader(string(buf)))
|
||||
var ranges []iplist.Range
|
||||
for scanner.Scan() {
|
||||
r, ok, err := parseLine(scanner.Bytes())
|
||||
if err != nil {
|
||||
log.TLogln("Error scan ip list:", err)
|
||||
return iplist.New(nil)
|
||||
}
|
||||
if ok {
|
||||
ranges = append(ranges, r)
|
||||
}
|
||||
}
|
||||
err := scanner.Err()
|
||||
if err != nil {
|
||||
log.TLogln("Error scan ip list:", err)
|
||||
}
|
||||
if len(ranges) > 0 {
|
||||
return iplist.New(ranges)
|
||||
}
|
||||
return iplist.New(nil)
|
||||
}
|
||||
|
||||
func parseLine(l []byte) (r iplist.Range, ok bool, err error) {
|
||||
l = bytes.TrimSpace(l)
|
||||
if len(l) == 0 || bytes.HasPrefix(l, []byte("#")) {
|
||||
return
|
||||
}
|
||||
colon := bytes.LastIndexAny(l, ":")
|
||||
hyphen := bytes.IndexByte(l[colon+1:], '-')
|
||||
hyphen += colon + 1
|
||||
if colon >= 0 {
|
||||
r.Description = string(l[:colon])
|
||||
}
|
||||
if hyphen-(colon+1) >= 0 {
|
||||
r.First = net.ParseIP(string(l[colon+1 : hyphen]))
|
||||
minifyIP(&r.First)
|
||||
r.Last = net.ParseIP(string(l[hyphen+1:]))
|
||||
minifyIP(&r.Last)
|
||||
} else {
|
||||
r.First = net.ParseIP(string(l[colon+1:]))
|
||||
minifyIP(&r.First)
|
||||
r.Last = r.First
|
||||
}
|
||||
if r.First == nil || r.Last == nil || len(r.First) != len(r.Last) {
|
||||
err = errors.New("bad IP range")
|
||||
return
|
||||
}
|
||||
ok = true
|
||||
return
|
||||
}
|
||||
|
||||
func minifyIP(ip *net.IP) {
|
||||
v4 := ip.To4()
|
||||
if v4 != nil {
|
||||
*ip = append(make([]byte, 0, 4), v4...)
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user