mirror of
https://github.com/therootcompany/golib.git
synced 2026-04-24 20:58:00 +00:00
feat: add Blacklist type to check-ip-blacklist to test ergonomics
This commit is contained in:
parent
73b033c3e1
commit
4b0f943bd7
72
net/ipcohort/cmd/check-ip-blacklist/blacklist.go
Normal file
72
net/ipcohort/cmd/check-ip-blacklist/blacklist.go
Normal file
@ -0,0 +1,72 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
import (
|
||||||
|
"context"
|
||||||
|
"fmt"
|
||||||
|
"os"
|
||||||
|
"path/filepath"
|
||||||
|
"sync/atomic"
|
||||||
|
"time"
|
||||||
|
|
||||||
|
"github.com/therootcompany/golib/net/gitshallow"
|
||||||
|
"github.com/therootcompany/golib/net/ipcohort"
|
||||||
|
)
|
||||||
|
|
||||||
|
type Blacklist struct {
|
||||||
|
atomic.Pointer[ipcohort.Cohort]
|
||||||
|
path string
|
||||||
|
repo *gitshallow.Repo // nil if file-only
|
||||||
|
}
|
||||||
|
|
||||||
|
func NewBlacklist(path string) *Blacklist {
|
||||||
|
return &Blacklist{path: path}
|
||||||
|
}
|
||||||
|
|
||||||
|
func NewGitBlacklist(gitURL, path string) *Blacklist {
|
||||||
|
repo := gitshallow.New(gitURL, filepath.Dir(path), 1, "")
|
||||||
|
b := &Blacklist{path: path, repo: repo}
|
||||||
|
repo.Register(b.reload)
|
||||||
|
return b
|
||||||
|
}
|
||||||
|
|
||||||
|
func (b *Blacklist) Init(lightGC bool) error {
|
||||||
|
if b.repo != nil {
|
||||||
|
return b.repo.Init(lightGC)
|
||||||
|
}
|
||||||
|
return b.reload()
|
||||||
|
}
|
||||||
|
|
||||||
|
func (b *Blacklist) Run(ctx context.Context, lightGC bool) {
|
||||||
|
ticker := time.NewTicker(47 * time.Minute)
|
||||||
|
defer ticker.Stop()
|
||||||
|
|
||||||
|
for {
|
||||||
|
select {
|
||||||
|
case <-ticker.C:
|
||||||
|
if updated, err := b.repo.Sync(lightGC); err != nil {
|
||||||
|
fmt.Fprintf(os.Stderr, "error: blacklist sync: %v\n", err)
|
||||||
|
} else if updated {
|
||||||
|
fmt.Fprintf(os.Stderr, "blacklist: reloaded %d entries\n", b.Size())
|
||||||
|
}
|
||||||
|
case <-ctx.Done():
|
||||||
|
return
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func (b *Blacklist) Contains(ipStr string) bool {
|
||||||
|
return b.Load().Contains(ipStr)
|
||||||
|
}
|
||||||
|
|
||||||
|
func (b *Blacklist) Size() int {
|
||||||
|
return b.Load().Size()
|
||||||
|
}
|
||||||
|
|
||||||
|
func (b *Blacklist) reload() error {
|
||||||
|
c, err := ipcohort.LoadFile(b.path)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
b.Store(c)
|
||||||
|
return nil
|
||||||
|
}
|
||||||
@ -3,11 +3,6 @@ package main
|
|||||||
import (
|
import (
|
||||||
"fmt"
|
"fmt"
|
||||||
"os"
|
"os"
|
||||||
"path/filepath"
|
|
||||||
"sync/atomic"
|
|
||||||
|
|
||||||
"github.com/therootcompany/golib/net/gitshallow"
|
|
||||||
"github.com/therootcompany/golib/net/ipcohort"
|
|
||||||
)
|
)
|
||||||
|
|
||||||
func main() {
|
func main() {
|
||||||
@ -23,38 +18,21 @@ func main() {
|
|||||||
gitURL = os.Args[3]
|
gitURL = os.Args[3]
|
||||||
}
|
}
|
||||||
|
|
||||||
var cohort atomic.Pointer[ipcohort.Cohort]
|
var bl *Blacklist
|
||||||
|
|
||||||
load := func() error {
|
|
||||||
c, err := ipcohort.LoadFile(dataPath)
|
|
||||||
if err != nil {
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
cohort.Store(c)
|
|
||||||
return nil
|
|
||||||
}
|
|
||||||
|
|
||||||
if gitURL != "" {
|
if gitURL != "" {
|
||||||
repoDir := filepath.Dir(dataPath)
|
bl = NewGitBlacklist(gitURL, dataPath)
|
||||||
repo := gitshallow.New(gitURL, repoDir, 1, "")
|
|
||||||
repo.Register(load)
|
|
||||||
fmt.Fprintf(os.Stderr, "Syncing %q ...\n", repoDir)
|
|
||||||
if err := repo.Init(false); err != nil {
|
|
||||||
fmt.Fprintf(os.Stderr, "error: git sync: %v\n", err)
|
|
||||||
os.Exit(1)
|
|
||||||
}
|
|
||||||
} else {
|
} else {
|
||||||
fmt.Fprintf(os.Stderr, "Loading %q ...\n", dataPath)
|
bl = NewBlacklist(dataPath)
|
||||||
if err := load(); err != nil {
|
|
||||||
fmt.Fprintf(os.Stderr, "error: load: %v\n", err)
|
|
||||||
os.Exit(1)
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
c := cohort.Load()
|
if err := bl.Init(false); err != nil {
|
||||||
fmt.Fprintf(os.Stderr, "Loaded %d entries\n", c.Size())
|
fmt.Fprintf(os.Stderr, "error: %v\n", err)
|
||||||
|
os.Exit(1)
|
||||||
|
}
|
||||||
|
|
||||||
if c.Contains(ipStr) {
|
fmt.Fprintf(os.Stderr, "Loaded %d entries\n", bl.Size())
|
||||||
|
|
||||||
|
if bl.Contains(ipStr) {
|
||||||
fmt.Printf("%s is BLOCKED\n", ipStr)
|
fmt.Printf("%s is BLOCKED\n", ipStr)
|
||||||
os.Exit(1)
|
os.Exit(1)
|
||||||
}
|
}
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user