zabov/01.killfile.go

160 lines
2.8 KiB
Go
Raw Normal View History

2020-10-08 15:14:07 -05:00
package main
import (
"fmt"
"strings"
)
type killfileItem struct {
Kdomain string
Ksource string
Kconfigs stringarray
2020-10-08 15:14:07 -05:00
}
var bKillChannel chan killfileItem
var bWhiteListChannel chan killfileItem
2020-10-08 15:14:07 -05:00
func init() {
bKillChannel = make(chan killfileItem, 1024)
bWhiteListChannel = make(chan killfileItem, 1024)
2020-10-08 15:14:07 -05:00
fmt.Println("Initializing kill channel engine.")
go bWriteKillThread()
go bWriteWhiteListThread()
2020-10-08 15:14:07 -05:00
}
func bWriteKillThread() {
2020-10-08 15:14:07 -05:00
for item := range bKillChannel {
2020-10-08 15:14:07 -05:00
alreadyInSomeDB := false
for _, config := range item.Kconfigs {
if !alreadyInSomeDB {
alreadyInSomeDB = domainInKillfile(item.Kdomain, config)
}
writeInKillfile(item.Kdomain, item.Ksource, config)
}
if !alreadyInSomeDB {
incrementStats("BL domains from "+item.Ksource, 1)
incrementStats("TOTAL", 1)
}
2020-10-08 15:14:07 -05:00
}
}
//DomainKill stores a domain name inside the killfile
func DomainKill(s, durl string, configs stringarray) {
2020-10-08 15:14:07 -05:00
if len(s) > 2 {
s = strings.ToLower(s)
var k killfileItem
k.Kdomain = s
k.Ksource = durl
k.Kconfigs = configs
2020-10-08 15:14:07 -05:00
bKillChannel <- k
2020-10-08 15:14:07 -05:00
}
}
func writeInKillfile(key, value string, config string) {
2020-10-08 15:14:07 -05:00
stK := []byte(key)
stV := []byte(value)
MyZabovKDB := MyZabovKDBs[config]
2020-10-08 15:14:07 -05:00
err := MyZabovKDB.Put(stK, stV, nil)
if err != nil {
fmt.Println("Cannot write to Killfile DB: ", err.Error())
}
}
func domainInKillfile(domain string, config string) bool {
2020-10-08 15:14:07 -05:00
s := strings.ToLower(domain)
MyZabovKDB := MyZabovKDBs[config]
2020-10-08 15:14:07 -05:00
has, err := MyZabovKDB.Has([]byte(s), nil)
if err != nil {
fmt.Println("Cannot read from Killfile DB: ", err.Error())
}
return has
}
func bWriteWhiteListThread() {
for item := range bWhiteListChannel {
alreadyInSomeDB := false
for _, config := range item.Kconfigs {
if !alreadyInSomeDB {
alreadyInSomeDB = domainInWhiteListfile(item.Kdomain, config)
}
writeInWhiteListfile(item.Kdomain, item.Ksource, config)
}
if !alreadyInSomeDB {
incrementStats("WL domains from "+item.Ksource, 1)
incrementStats("WL TOTAL", 1)
}
}
}
//DomainWhiteList stores a domain name inside the killfile
func DomainWhiteList(s, durl string, configs stringarray) {
if len(s) > 2 {
s = strings.ToLower(s)
var k killfileItem
k.Kdomain = s
k.Ksource = durl
k.Kconfigs = configs
bWhiteListChannel <- k
}
}
func writeInWhiteListfile(key, value string, config string) {
stK := []byte(key)
stV := []byte(value)
MyZabovWLDB := MyZabovWLDBs[config]
err := MyZabovWLDB.Put(stK, stV, nil)
if err != nil {
fmt.Println("Cannot write to Whitelist DB: ", err.Error())
}
}
func domainInWhiteListfile(domain string, config string) bool {
s := strings.ToLower(domain)
MyZabovWLDB := MyZabovWLDBs[config]
has, err := MyZabovWLDB.Has([]byte(s), nil)
if err != nil {
fmt.Println("Cannot read from Whitelist DB: ", err.Error())
}
return has
}