mirror of
https://github.com/ipfs/kubo.git
synced 2025-06-19 18:05:32 +08:00
p2p/net/filter: Guard with a mutex
Callers assume this is safe to call whenever, let's make it so. License: MIT Signed-off-by: Tommi Virtanen <tv@eagain.net>
This commit is contained in:
@ -3,12 +3,14 @@ package filter
|
|||||||
import (
|
import (
|
||||||
"net"
|
"net"
|
||||||
"strings"
|
"strings"
|
||||||
|
"sync"
|
||||||
|
|
||||||
ma "github.com/ipfs/go-ipfs/Godeps/_workspace/src/github.com/jbenet/go-multiaddr"
|
ma "github.com/ipfs/go-ipfs/Godeps/_workspace/src/github.com/jbenet/go-multiaddr"
|
||||||
manet "github.com/ipfs/go-ipfs/Godeps/_workspace/src/github.com/jbenet/go-multiaddr-net"
|
manet "github.com/ipfs/go-ipfs/Godeps/_workspace/src/github.com/jbenet/go-multiaddr-net"
|
||||||
)
|
)
|
||||||
|
|
||||||
type Filters struct {
|
type Filters struct {
|
||||||
|
mu sync.RWMutex
|
||||||
filters map[string]*net.IPNet
|
filters map[string]*net.IPNet
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -19,6 +21,8 @@ func NewFilters() *Filters {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func (fs *Filters) AddDialFilter(f *net.IPNet) {
|
func (fs *Filters) AddDialFilter(f *net.IPNet) {
|
||||||
|
fs.mu.Lock()
|
||||||
|
defer fs.mu.Unlock()
|
||||||
fs.filters[f.String()] = f
|
fs.filters[f.String()] = f
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -31,6 +35,8 @@ func (f *Filters) AddrBlocked(a ma.Multiaddr) bool {
|
|||||||
|
|
||||||
ipstr := strings.Split(addr, ":")[0]
|
ipstr := strings.Split(addr, ":")[0]
|
||||||
ip := net.ParseIP(ipstr)
|
ip := net.ParseIP(ipstr)
|
||||||
|
f.mu.RLock()
|
||||||
|
defer f.mu.RUnlock()
|
||||||
for _, ft := range f.filters {
|
for _, ft := range f.filters {
|
||||||
if ft.Contains(ip) {
|
if ft.Contains(ip) {
|
||||||
return true
|
return true
|
||||||
@ -41,6 +47,8 @@ func (f *Filters) AddrBlocked(a ma.Multiaddr) bool {
|
|||||||
|
|
||||||
func (f *Filters) Filters() []*net.IPNet {
|
func (f *Filters) Filters() []*net.IPNet {
|
||||||
var out []*net.IPNet
|
var out []*net.IPNet
|
||||||
|
f.mu.RLock()
|
||||||
|
defer f.mu.RUnlock()
|
||||||
for _, ff := range f.filters {
|
for _, ff := range f.filters {
|
||||||
out = append(out, ff)
|
out = append(out, ff)
|
||||||
}
|
}
|
||||||
@ -48,5 +56,7 @@ func (f *Filters) Filters() []*net.IPNet {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func (f *Filters) Remove(ff *net.IPNet) {
|
func (f *Filters) Remove(ff *net.IPNet) {
|
||||||
|
f.mu.Lock()
|
||||||
|
defer f.mu.Unlock()
|
||||||
delete(f.filters, ff.String())
|
delete(f.filters, ff.String())
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user