mirror of https://github.com/1Panel-dev/1Panel
136 lines
3.6 KiB
Go
136 lines
3.6 KiB
Go
|
package lang
|
||
|
|
||
|
import (
|
||
|
"fmt"
|
||
|
"os"
|
||
|
"path"
|
||
|
"sort"
|
||
|
"strings"
|
||
|
|
||
|
"github.com/1Panel-dev/1Panel/backend/global"
|
||
|
"github.com/1Panel-dev/1Panel/backend/utils/cmd"
|
||
|
"github.com/1Panel-dev/1Panel/backend/utils/files"
|
||
|
)
|
||
|
|
||
|
func Init() {
|
||
|
go initLang()
|
||
|
}
|
||
|
|
||
|
func initLang() {
|
||
|
fileOp := files.NewFileOp()
|
||
|
geoPath := path.Join(global.CONF.System.BaseDir, "1panel/geo/GeoIP.mmdb")
|
||
|
isLangExist := fileOp.Stat("/usr/local/bin/lang/zh.sh")
|
||
|
isGeoExist := fileOp.Stat(geoPath)
|
||
|
if isLangExist && isGeoExist {
|
||
|
return
|
||
|
}
|
||
|
upgradePath := path.Join(global.CONF.System.BaseDir, "1panel/tmp/upgrade")
|
||
|
tmpPath, err := loadRestorePath(upgradePath)
|
||
|
upgradeDir := path.Join(upgradePath, tmpPath, "downloads")
|
||
|
if err != nil || len(tmpPath) == 0 || !fileOp.Stat(upgradeDir) {
|
||
|
if !isLangExist {
|
||
|
downloadLangFromRemote(fileOp)
|
||
|
}
|
||
|
if !isGeoExist {
|
||
|
downloadGeoFromRemote(fileOp, geoPath)
|
||
|
}
|
||
|
return
|
||
|
}
|
||
|
|
||
|
files, _ := os.ReadDir(upgradeDir)
|
||
|
if len(files) == 0 {
|
||
|
tmpPath = "no such file"
|
||
|
} else {
|
||
|
for _, item := range files {
|
||
|
if item.IsDir() && strings.HasPrefix(item.Name(), "1panel-") {
|
||
|
tmpPath = path.Join(upgradePath, tmpPath, "downloads", item.Name())
|
||
|
break
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
if tmpPath == "no such file" || !fileOp.Stat(tmpPath) {
|
||
|
if !isLangExist {
|
||
|
downloadLangFromRemote(fileOp)
|
||
|
}
|
||
|
if !isGeoExist {
|
||
|
downloadGeoFromRemote(fileOp, geoPath)
|
||
|
}
|
||
|
return
|
||
|
}
|
||
|
if !isLangExist {
|
||
|
if !fileOp.Stat(path.Join(tmpPath, "lang")) {
|
||
|
downloadLangFromRemote(fileOp)
|
||
|
return
|
||
|
}
|
||
|
std, err := cmd.Execf("cp -r %s %s", path.Join(tmpPath, "lang"), "/usr/local/bin/")
|
||
|
if err != nil {
|
||
|
global.LOG.Errorf("load lang from package failed, std: %s, err: %v", std, err)
|
||
|
return
|
||
|
}
|
||
|
global.LOG.Info("init lang successful")
|
||
|
}
|
||
|
if !isGeoExist {
|
||
|
if !fileOp.Stat(path.Join(tmpPath, "GeoIP.mmdb")) {
|
||
|
downloadGeoFromRemote(fileOp, geoPath)
|
||
|
return
|
||
|
}
|
||
|
std, err := cmd.Execf("cp %s %s", path.Join(tmpPath, "GeoIP.mmdb"), path.Dir(geoPath))
|
||
|
if err != nil {
|
||
|
global.LOG.Errorf("load geo ip from package failed, std: %s, err: %v", std, err)
|
||
|
return
|
||
|
}
|
||
|
global.LOG.Info("init geo ip successful")
|
||
|
}
|
||
|
}
|
||
|
|
||
|
func loadRestorePath(upgradeDir string) (string, error) {
|
||
|
if _, err := os.Stat(upgradeDir); err != nil && os.IsNotExist(err) {
|
||
|
return "no such file", nil
|
||
|
}
|
||
|
files, err := os.ReadDir(upgradeDir)
|
||
|
if err != nil {
|
||
|
return "", err
|
||
|
}
|
||
|
var folders []string
|
||
|
for _, file := range files {
|
||
|
if file.IsDir() {
|
||
|
folders = append(folders, file.Name())
|
||
|
}
|
||
|
}
|
||
|
if len(folders) == 0 {
|
||
|
return "no such file", nil
|
||
|
}
|
||
|
sort.Slice(folders, func(i, j int) bool {
|
||
|
return folders[i] > folders[j]
|
||
|
})
|
||
|
return folders[0], nil
|
||
|
}
|
||
|
|
||
|
func downloadLangFromRemote(fileOp files.FileOp) {
|
||
|
path := fmt.Sprintf("%s/language/lang.tar.gz", global.CONF.System.RepoUrl)
|
||
|
if err := fileOp.DownloadFileWithProxy(path, "/usr/local/bin/lang.tar.gz"); err != nil {
|
||
|
global.LOG.Errorf("download lang.tar.gz failed, err: %v", err)
|
||
|
return
|
||
|
}
|
||
|
if !fileOp.Stat("/usr/local/bin/lang.tar.gz") {
|
||
|
global.LOG.Error("download lang.tar.gz failed, no such file")
|
||
|
return
|
||
|
}
|
||
|
std, err := cmd.Execf("tar zxvfC %s %s", "/usr/local/bin/lang.tar.gz", "/usr/local/bin/")
|
||
|
if err != nil {
|
||
|
fmt.Printf("decompress lang.tar.gz failed, std: %s, err: %v", std, err)
|
||
|
return
|
||
|
}
|
||
|
_ = os.Remove("/usr/local/bin/lang.tar.gz")
|
||
|
global.LOG.Info("download lang successful")
|
||
|
}
|
||
|
func downloadGeoFromRemote(fileOp files.FileOp, targetPath string) {
|
||
|
_ = os.MkdirAll(path.Dir(targetPath), os.ModePerm)
|
||
|
pathItem := fmt.Sprintf("%s/geo/GeoIP.mmdb", global.CONF.System.RepoUrl)
|
||
|
if err := fileOp.DownloadFileWithProxy(pathItem, targetPath); err != nil {
|
||
|
global.LOG.Errorf("download geo ip failed, err: %v", err)
|
||
|
return
|
||
|
}
|
||
|
global.LOG.Info("download geo ip successful")
|
||
|
}
|