mirror of
https://github.com/MetaCubeX/mihomo.git
synced 2026-03-04 12:57:31 +00:00
chore: cleanup geo internal code
This commit is contained in:
@@ -1,15 +1,9 @@
|
||||
package mmdb
|
||||
|
||||
import (
|
||||
"context"
|
||||
"io"
|
||||
"net/http"
|
||||
"os"
|
||||
"sync"
|
||||
"time"
|
||||
|
||||
mihomoOnce "github.com/metacubex/mihomo/common/once"
|
||||
mihomoHttp "github.com/metacubex/mihomo/component/http"
|
||||
C "github.com/metacubex/mihomo/constant"
|
||||
"github.com/metacubex/mihomo/log"
|
||||
|
||||
@@ -25,26 +19,26 @@ const (
|
||||
)
|
||||
|
||||
var (
|
||||
IPreader IPReader
|
||||
ASNreader ASNReader
|
||||
IPonce sync.Once
|
||||
ASNonce sync.Once
|
||||
ipReader IPReader
|
||||
asnReader ASNReader
|
||||
ipOnce sync.Once
|
||||
asnOnce sync.Once
|
||||
)
|
||||
|
||||
func LoadFromBytes(buffer []byte) {
|
||||
IPonce.Do(func() {
|
||||
ipOnce.Do(func() {
|
||||
mmdb, err := maxminddb.FromBytes(buffer)
|
||||
if err != nil {
|
||||
log.Fatalln("Can't load mmdb: %s", err.Error())
|
||||
}
|
||||
IPreader = IPReader{Reader: mmdb}
|
||||
ipReader = IPReader{Reader: mmdb}
|
||||
switch mmdb.Metadata.DatabaseType {
|
||||
case "sing-geoip":
|
||||
IPreader.databaseType = typeSing
|
||||
ipReader.databaseType = typeSing
|
||||
case "Meta-geoip0":
|
||||
IPreader.databaseType = typeMetaV0
|
||||
ipReader.databaseType = typeMetaV0
|
||||
default:
|
||||
IPreader.databaseType = typeMaxmind
|
||||
ipReader.databaseType = typeMaxmind
|
||||
}
|
||||
})
|
||||
}
|
||||
@@ -58,83 +52,45 @@ func Verify(path string) bool {
|
||||
}
|
||||
|
||||
func IPInstance() IPReader {
|
||||
IPonce.Do(func() {
|
||||
ipOnce.Do(func() {
|
||||
mmdbPath := C.Path.MMDB()
|
||||
log.Infoln("Load MMDB file: %s", mmdbPath)
|
||||
mmdb, err := maxminddb.Open(mmdbPath)
|
||||
if err != nil {
|
||||
log.Fatalln("Can't load MMDB: %s", err.Error())
|
||||
}
|
||||
IPreader = IPReader{Reader: mmdb}
|
||||
ipReader = IPReader{Reader: mmdb}
|
||||
switch mmdb.Metadata.DatabaseType {
|
||||
case "sing-geoip":
|
||||
IPreader.databaseType = typeSing
|
||||
ipReader.databaseType = typeSing
|
||||
case "Meta-geoip0":
|
||||
IPreader.databaseType = typeMetaV0
|
||||
ipReader.databaseType = typeMetaV0
|
||||
default:
|
||||
IPreader.databaseType = typeMaxmind
|
||||
ipReader.databaseType = typeMaxmind
|
||||
}
|
||||
})
|
||||
|
||||
return IPreader
|
||||
}
|
||||
|
||||
func DownloadMMDB(path string) (err error) {
|
||||
ctx, cancel := context.WithTimeout(context.Background(), time.Second*90)
|
||||
defer cancel()
|
||||
resp, err := mihomoHttp.HttpRequest(ctx, C.MmdbUrl, http.MethodGet, http.Header{"User-Agent": {C.UA}}, nil)
|
||||
if err != nil {
|
||||
return
|
||||
}
|
||||
defer resp.Body.Close()
|
||||
|
||||
f, err := os.OpenFile(path, os.O_CREATE|os.O_WRONLY, 0o644)
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
defer f.Close()
|
||||
_, err = io.Copy(f, resp.Body)
|
||||
|
||||
return err
|
||||
return ipReader
|
||||
}
|
||||
|
||||
func ASNInstance() ASNReader {
|
||||
ASNonce.Do(func() {
|
||||
asnOnce.Do(func() {
|
||||
ASNPath := C.Path.ASN()
|
||||
log.Infoln("Load ASN file: %s", ASNPath)
|
||||
asn, err := maxminddb.Open(ASNPath)
|
||||
if err != nil {
|
||||
log.Fatalln("Can't load ASN: %s", err.Error())
|
||||
}
|
||||
ASNreader = ASNReader{Reader: asn}
|
||||
asnReader = ASNReader{Reader: asn}
|
||||
})
|
||||
|
||||
return ASNreader
|
||||
}
|
||||
|
||||
func DownloadASN(path string) (err error) {
|
||||
ctx, cancel := context.WithTimeout(context.Background(), time.Second*90)
|
||||
defer cancel()
|
||||
resp, err := mihomoHttp.HttpRequest(ctx, C.ASNUrl, http.MethodGet, http.Header{"User-Agent": {C.UA}}, nil)
|
||||
if err != nil {
|
||||
return
|
||||
}
|
||||
defer resp.Body.Close()
|
||||
|
||||
f, err := os.OpenFile(path, os.O_CREATE|os.O_WRONLY, 0o644)
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
defer f.Close()
|
||||
_, err = io.Copy(f, resp.Body)
|
||||
|
||||
return err
|
||||
return asnReader
|
||||
}
|
||||
|
||||
func ReloadIP() {
|
||||
mihomoOnce.Reset(&IPonce)
|
||||
mihomoOnce.Reset(&ipOnce)
|
||||
}
|
||||
|
||||
func ReloadASN() {
|
||||
mihomoOnce.Reset(&ASNonce)
|
||||
mihomoOnce.Reset(&asnOnce)
|
||||
}
|
||||
|
||||
@@ -8,11 +8,11 @@ func InstallOverride(override *maxminddb.Reader) {
|
||||
newReader := IPReader{Reader: override}
|
||||
switch override.Metadata.DatabaseType {
|
||||
case "sing-geoip":
|
||||
IPreader.databaseType = typeSing
|
||||
ipReader.databaseType = typeSing
|
||||
case "Meta-geoip0":
|
||||
IPreader.databaseType = typeMetaV0
|
||||
ipReader.databaseType = typeMetaV0
|
||||
default:
|
||||
IPreader.databaseType = typeMaxmind
|
||||
ipReader.databaseType = typeMaxmind
|
||||
}
|
||||
IPreader = newReader
|
||||
ipReader = newReader
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user