mirror of
https://github.com/daeuniverse/dae.git
synced 2025-07-07 00:42:22 +07:00
optimize: assets finder
This commit is contained in:
@ -7,15 +7,17 @@ package assets
|
|||||||
|
|
||||||
import (
|
import (
|
||||||
"errors"
|
"errors"
|
||||||
|
"fmt"
|
||||||
"github.com/adrg/xdg"
|
"github.com/adrg/xdg"
|
||||||
|
"github.com/sirupsen/logrus"
|
||||||
"io/fs"
|
"io/fs"
|
||||||
"os"
|
"os"
|
||||||
"path/filepath"
|
"path/filepath"
|
||||||
"runtime"
|
"runtime"
|
||||||
|
"strings"
|
||||||
)
|
)
|
||||||
|
|
||||||
func GetLocationAsset(filename string) (path string, err error) {
|
func GetLocationAsset(log *logrus.Logger, filename string) (path string, err error) {
|
||||||
// FIXME:
|
|
||||||
folder := "dae"
|
folder := "dae"
|
||||||
location := os.Getenv("DAE_LOCATION_ASSET")
|
location := os.Getenv("DAE_LOCATION_ASSET")
|
||||||
// check if DAE_LOCATION_ASSET is set
|
// check if DAE_LOCATION_ASSET is set
|
||||||
@ -32,41 +34,45 @@ func GetLocationAsset(filename string) (path string, err error) {
|
|||||||
filepath.Join("/usr/share", folder, filename),
|
filepath.Join("/usr/share", folder, filename),
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
|
searchDirs := make([]string, len(searchPaths))
|
||||||
|
for i := range searchDirs {
|
||||||
|
searchDirs[i] = filepath.Dir(searchPaths[i])
|
||||||
|
}
|
||||||
|
log.Debugf(`Search "%v" in [%v]`, filename, strings.Join(searchDirs, ", "))
|
||||||
for _, searchPath := range searchPaths {
|
for _, searchPath := range searchPaths {
|
||||||
if _, err = os.Stat(searchPath); err != nil && errors.Is(err, fs.ErrNotExist) {
|
if _, err = os.Stat(searchPath); err != nil && errors.Is(err, fs.ErrNotExist) {
|
||||||
continue
|
continue
|
||||||
}
|
}
|
||||||
|
log.Debugf(`Found "%v" at %v`, filename, searchPath)
|
||||||
// return the first path that exists
|
// return the first path that exists
|
||||||
return searchPath, nil
|
return searchPath, nil
|
||||||
}
|
}
|
||||||
// or download asset into DAE_LOCATION_ASSET
|
return "", fmt.Errorf("%v: %w in [%v]", filename, os.ErrNotExist, strings.Join(searchDirs, ", "))
|
||||||
return searchPaths[0], nil
|
|
||||||
} else {
|
} else {
|
||||||
if runtime.GOOS != "windows" {
|
if runtime.GOOS != "windows" {
|
||||||
// search XDG data directories on non windows platform
|
// search XDG data directories on non windows platform
|
||||||
// symlink all assets into XDG_RUNTIME_DIR
|
searchDirs := append([]string{xdg.DataHome}, xdg.DataDirs...)
|
||||||
|
for i := range searchDirs {
|
||||||
|
searchDirs[i] = filepath.Join(searchDirs[i], folder)
|
||||||
|
}
|
||||||
|
log.Debugf(`Search "%v" in [%v]`, filename, strings.Join(searchDirs, ", "))
|
||||||
relpath := filepath.Join(folder, filename)
|
relpath := filepath.Join(folder, filename)
|
||||||
fullpath, err := xdg.SearchDataFile(relpath)
|
fullpath, err := xdg.SearchDataFile(relpath)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
fullpath, err = xdg.DataFile(relpath)
|
return "", fmt.Errorf("%v: %w in [%v]", filename, os.ErrNotExist, strings.Join(searchDirs, ", "))
|
||||||
if err != nil {
|
|
||||||
return "", err
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
runtimepath, err := xdg.RuntimeFile(filepath.Join(folder, filename))
|
log.Debugf(`Found "%v" at %v`, filename, fullpath)
|
||||||
if err != nil {
|
return fullpath, nil
|
||||||
return "", err
|
|
||||||
}
|
|
||||||
os.Remove(runtimepath)
|
|
||||||
err = os.Symlink(fullpath, runtimepath)
|
|
||||||
if err != nil {
|
|
||||||
return "", err
|
|
||||||
}
|
|
||||||
return fullpath, err
|
|
||||||
} else {
|
} else {
|
||||||
// fallback to the old behavior of using only config dir on Windows
|
// fallback to the old behavior of using only current dir on Windows
|
||||||
// FIXME: conf.GetEnvironmentConfig().Config
|
path := filepath.Join("./", filename)
|
||||||
return filepath.Join("./", filename), nil
|
if absPath, e := filepath.Abs(path); e == nil {
|
||||||
|
path = absPath
|
||||||
|
}
|
||||||
|
if _, err := os.Stat(path); errors.Is(err, os.ErrNotExist) {
|
||||||
|
return "", fmt.Errorf("%v: %w in %v", filename, os.ErrNotExist, path)
|
||||||
|
}
|
||||||
|
return path, nil
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -222,7 +222,7 @@ retryLoadBpf:
|
|||||||
&routing.MergeAndSortRulesOptimizer{},
|
&routing.MergeAndSortRulesOptimizer{},
|
||||||
&routing.DeduplicateParamsOptimizer{},
|
&routing.DeduplicateParamsOptimizer{},
|
||||||
); err != nil {
|
); err != nil {
|
||||||
return nil, fmt.Errorf("ApplyRulesOptimizers error: \n %w", err)
|
return nil, fmt.Errorf("ApplyRulesOptimizers error:\n%w", err)
|
||||||
}
|
}
|
||||||
if log.IsLevelEnabled(logrus.DebugLevel) {
|
if log.IsLevelEnabled(logrus.DebugLevel) {
|
||||||
var debugBuilder strings.Builder
|
var debugBuilder strings.Builder
|
||||||
|
@ -154,7 +154,7 @@ func (o *DatReaderOptimizer) loadGeoSite(filename string, code string) (params [
|
|||||||
if !strings.HasSuffix(filename, ".dat") {
|
if !strings.HasSuffix(filename, ".dat") {
|
||||||
filename += ".dat"
|
filename += ".dat"
|
||||||
}
|
}
|
||||||
filePath, err := assets.GetLocationAsset(filename)
|
filePath, err := assets.GetLocationAsset(o.Logger, filename)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
o.Logger.Debugf("Failed to read geosite \"%v:%v\": %v", filename, code, err)
|
o.Logger.Debugf("Failed to read geosite \"%v:%v\": %v", filename, code, err)
|
||||||
return nil, err
|
return nil, err
|
||||||
@ -199,7 +199,7 @@ func (o *DatReaderOptimizer) loadGeoIp(filename string, code string) (params []*
|
|||||||
if !strings.HasSuffix(filename, ".dat") {
|
if !strings.HasSuffix(filename, ".dat") {
|
||||||
filename += ".dat"
|
filename += ".dat"
|
||||||
}
|
}
|
||||||
filePath, err := assets.GetLocationAsset(filename)
|
filePath, err := assets.GetLocationAsset(o.Logger, filename)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
o.Logger.Debugf("Failed to read geoip \"%v:%v\": %v", filename, code, err)
|
o.Logger.Debugf("Failed to read geoip \"%v:%v\": %v", filename, code, err)
|
||||||
return nil, err
|
return nil, err
|
||||||
|
Reference in New Issue
Block a user