f506d6ce49
* fix bug * updata UI * 0.3.2 ### Added - [Files] Files can now be selected multiple files and downloaded, deleted, moved, etc. - [Apps] Support to modify the application opening address.([#204](https://github.com/IceWhaleTech/CasaOS/issues/204)) ### Changed - [Apps] Hide the display of non-essential environment variables in the application. - [System] Network, disk, cpu, memory, etc. information is modified to be pushed via socket. - [System] Optimize opening speed.([#214](https://github.com/IceWhaleTech/CasaOS/issues/214)) ### Fixed - [System] Fixed the problem that sync data cannot submit the device ID ([#68](https://github.com/IceWhaleTech/CasaOS/issues/68)) - [Files] Fixed the code editor center alignment display problem.([#210](https://github.com/IceWhaleTech/CasaOS/issues/210)) - [Files] Fixed the problem of wrong name when downloading files.([#240](https://github.com/IceWhaleTech/CasaOS/issues/240)) - [System] Fixed the network display as a negative number problem.([#224](https://github.com/IceWhaleTech/CasaOS/issues/224)) * Modify log help class * Fix some bugs in 0.3.2 * Solve the operation file queue problem * Exclude web folders * update UI * add cancel file operate * Update UI * Merge sockets to transfer data * Conflict Resolution * Update send data interval * Update UI * fixed bug - Fix the problem of application opening failure on non-80 ports - Modify port failure problem - Modify environment variables disappearing problem * update version function * Fix version update issues * fixed bug - [System] Fixed the issue of widgets displaying wrongly on mobile devices. - [App] Fix the problem of application opening failure on non-80 ports ([#283](https://github.com/IceWhaleTech/CasaOS/issues/283) [#280](https://github.com/IceWhaleTech/CasaOS/issues/280)) - [System] Modify port failure problem ([#282](https://github.com/IceWhaleTech/CasaOS/issues/282)) - [App]Modify environment variables disappearing problem([#284](https://github.com/IceWhaleTech/CasaOS/issues/284)) - [System]Fix no update alert([#278](https://github.com/IceWhaleTech/CasaOS/issues/278)) - [System] Fixed some bugs of application cpu usage and memory staging([#272]https://github.com/IceWhaleTech/CasaOS/issues/272) * update UI * Update CHANGELOG.md * update app service * update ui * Fix application installation host mode error * update ui * Update UI
297 lines
8.4 KiB
Go
297 lines
8.4 KiB
Go
package route
|
||
|
||
import (
|
||
"encoding/xml"
|
||
"fmt"
|
||
"path/filepath"
|
||
"runtime"
|
||
"strconv"
|
||
"strings"
|
||
"time"
|
||
|
||
"github.com/IceWhaleTech/CasaOS/model"
|
||
"github.com/IceWhaleTech/CasaOS/model/system_app"
|
||
"github.com/IceWhaleTech/CasaOS/pkg/config"
|
||
"github.com/IceWhaleTech/CasaOS/pkg/utils/command"
|
||
"github.com/IceWhaleTech/CasaOS/pkg/utils/env_helper"
|
||
"github.com/IceWhaleTech/CasaOS/pkg/utils/file"
|
||
"github.com/IceWhaleTech/CasaOS/pkg/utils/port"
|
||
"github.com/IceWhaleTech/CasaOS/service"
|
||
model2 "github.com/IceWhaleTech/CasaOS/service/model"
|
||
uuid "github.com/satori/go.uuid"
|
||
)
|
||
|
||
func InitFunction() {
|
||
go checkSystemApp()
|
||
Update2_3()
|
||
CheckSerialDiskMount()
|
||
|
||
CheckToken2_11()
|
||
ImportApplications()
|
||
ChangeAPIUrl()
|
||
InitSystemApplication()
|
||
|
||
}
|
||
|
||
var syncIsExistence = false
|
||
|
||
func installSyncthing(appId string) {
|
||
|
||
var appInfo model.ServerAppList
|
||
m := model.CustomizationPostData{}
|
||
var dockerImage string
|
||
var dockerImageVersion string
|
||
appInfo = service.MyService.Casa().GetServerAppInfo(appId, "system", "us_en")
|
||
dockerImage = appInfo.Image
|
||
dockerImageVersion = appInfo.ImageVersion
|
||
|
||
if len(appInfo.ImageVersion) == 0 {
|
||
dockerImageVersion = "latest"
|
||
}
|
||
|
||
if appInfo.NetworkModel != "host" {
|
||
for i := 0; i < len(appInfo.Ports); i++ {
|
||
if p, _ := strconv.Atoi(appInfo.Ports[i].ContainerPort); port.IsPortAvailable(p, appInfo.Ports[i].Protocol) {
|
||
appInfo.Ports[i].CommendPort = strconv.Itoa(p)
|
||
} else {
|
||
if appInfo.Ports[i].Protocol == "tcp" {
|
||
if p, err := port.GetAvailablePort("tcp"); err == nil {
|
||
appInfo.Ports[i].CommendPort = strconv.Itoa(p)
|
||
}
|
||
} else if appInfo.Ports[i].Protocol == "upd" {
|
||
if p, err := port.GetAvailablePort("udp"); err == nil {
|
||
appInfo.Ports[i].CommendPort = strconv.Itoa(p)
|
||
}
|
||
}
|
||
}
|
||
|
||
if appInfo.Ports[i].Type == 0 {
|
||
appInfo.PortMap = appInfo.Ports[i].CommendPort
|
||
}
|
||
}
|
||
}
|
||
|
||
for i := 0; i < len(appInfo.Devices); i++ {
|
||
if !file.CheckNotExist(appInfo.Devices[i].ContainerPath) {
|
||
appInfo.Devices[i].Path = appInfo.Devices[i].ContainerPath
|
||
}
|
||
}
|
||
if len(appInfo.Tip) > 0 {
|
||
appInfo.Tip = env_helper.ReplaceStringDefaultENV(appInfo.Tip)
|
||
}
|
||
|
||
appInfo.MaxMemory = service.MyService.System().GetMemInfo().Total >> 20
|
||
|
||
id := uuid.NewV4().String()
|
||
|
||
// step:下载镜像
|
||
err := service.MyService.Docker().DockerPullImage(dockerImage+":"+dockerImageVersion, "", "")
|
||
if err != nil {
|
||
//pull image error
|
||
fmt.Println("pull image error", err, dockerImage, dockerImageVersion)
|
||
return
|
||
}
|
||
for !service.MyService.Docker().IsExistImage(dockerImage + ":" + dockerImageVersion) {
|
||
time.Sleep(time.Second)
|
||
}
|
||
|
||
m.CpuShares = 50
|
||
m.Envs = appInfo.Envs
|
||
m.Memory = int64(appInfo.MaxMemory)
|
||
m.Origin = "system"
|
||
m.PortMap = appInfo.PortMap
|
||
m.Ports = appInfo.Ports
|
||
m.Restart = "always"
|
||
m.Volumes = appInfo.Volumes
|
||
m.NetworkModel = appInfo.NetworkModel
|
||
m.Label = id
|
||
m.CustomId = id
|
||
containerId, err := service.MyService.Docker().DockerContainerCreate(dockerImage+":"+dockerImageVersion, m)
|
||
if err != nil {
|
||
fmt.Println("container create error", err)
|
||
// create container error
|
||
return
|
||
}
|
||
|
||
//step:start container
|
||
err = service.MyService.Docker().DockerContainerStart(containerId)
|
||
if err != nil {
|
||
//start container error
|
||
return
|
||
}
|
||
|
||
checkSystemApp()
|
||
}
|
||
|
||
// check if the system application is installed
|
||
func checkSystemApp() {
|
||
list := service.MyService.App().GetSystemAppList()
|
||
for _, v := range list {
|
||
info, err := service.MyService.Docker().DockerContainerInfo(v.ID)
|
||
if err != nil {
|
||
continue
|
||
}
|
||
if strings.Contains(info.Config.Image, "linuxserver/syncthing") {
|
||
if v.State != "running" {
|
||
//step:start container
|
||
service.MyService.Docker().DockerContainerStart(v.ID)
|
||
}
|
||
syncIsExistence = true
|
||
if config.SystemConfigInfo.SyncPort != v.Labels["web"] {
|
||
config.SystemConfigInfo.SyncPort = v.Labels["web"]
|
||
}
|
||
|
||
path := ""
|
||
for _, i := range info.Mounts {
|
||
if i.Destination == "/config" {
|
||
path = i.Source
|
||
break
|
||
}
|
||
}
|
||
content := file.ReadFullFile(filepath.Join(path, "config.xml"))
|
||
syncConfig := &system_app.SyncConfig{}
|
||
xml.Unmarshal(content, &syncConfig)
|
||
config.SystemConfigInfo.SyncKey = syncConfig.Key
|
||
break
|
||
}
|
||
}
|
||
if !syncIsExistence {
|
||
installSyncthing("74")
|
||
}
|
||
}
|
||
func CheckSerialDiskMount() {
|
||
// check mount point
|
||
dbList := service.MyService.Disk().GetSerialAll()
|
||
|
||
list := service.MyService.Disk().LSBLK(true)
|
||
mountPoint := make(map[string]string, len(dbList))
|
||
//remount
|
||
for _, v := range dbList {
|
||
mountPoint[v.UUID] = v.MountPoint
|
||
}
|
||
for _, v := range list {
|
||
command.ExecEnabledSMART(v.Path)
|
||
if v.Children != nil {
|
||
for _, h := range v.Children {
|
||
if len(h.MountPoint) == 0 && len(v.Children) == 1 && h.FsType == "ext4" {
|
||
if m, ok := mountPoint[h.UUID]; ok {
|
||
//mount point check
|
||
volume := m
|
||
if !file.CheckNotExist(m) {
|
||
for i := 0; file.CheckNotExist(volume); i++ {
|
||
volume = m + strconv.Itoa(i+1)
|
||
}
|
||
}
|
||
service.MyService.Disk().MountDisk(h.Path, volume)
|
||
if volume != m {
|
||
ms := model2.SerialDisk{}
|
||
ms.UUID = v.UUID
|
||
ms.MountPoint = volume
|
||
service.MyService.Disk().UpdateMountPoint(ms)
|
||
}
|
||
|
||
}
|
||
}
|
||
}
|
||
}
|
||
}
|
||
service.MyService.Disk().RemoveLSBLKCache()
|
||
command.OnlyExec("source " + config.AppInfo.ProjectPath + "/shell/helper.sh ;AutoRemoveUnuseDir")
|
||
}
|
||
func Update2_3() {
|
||
command.OnlyExec("source " + config.AppInfo.ProjectPath + "/shell/assist.sh")
|
||
|
||
}
|
||
func CheckToken2_11() {
|
||
if len(config.ServerInfo.Token) == 0 {
|
||
token := uuid.NewV4().String
|
||
config.ServerInfo.Token = token()
|
||
config.Cfg.Section("server").Key("Token").SetValue(token())
|
||
config.Cfg.SaveTo(config.SystemConfigInfo.ConfigPath)
|
||
}
|
||
if len(config.AppInfo.RootPath) == 0 {
|
||
config.Cfg.Section("app").Key("RootPath").SetValue("/casaOS")
|
||
config.AppInfo.RootPath = "/casaOS"
|
||
config.Cfg.SaveTo(config.SystemConfigInfo.ConfigPath)
|
||
}
|
||
// if len(config.ServerInfo.Handshake) == 0 {
|
||
// config.Cfg.Section("app").Key("RootPath").SetValue("/casaOS")
|
||
// config.AppInfo.RootPath = "/casaOS"
|
||
// config.Cfg.SaveTo(config.SystemConfigInfo.ConfigPath)
|
||
// }
|
||
sysType := runtime.GOOS
|
||
if len(config.FileSettingInfo.DownloadDir) == 0 {
|
||
downloadPath := "/DATA/Downloads"
|
||
if sysType == "windows" {
|
||
downloadPath = "C:\\CasaOS\\DATA\\Downloads"
|
||
}
|
||
if sysType == "darwin" {
|
||
downloadPath = "./CasaOS/DATA/Downloads"
|
||
}
|
||
config.Cfg.Section("file").Key("DownloadDir").SetValue(downloadPath)
|
||
config.FileSettingInfo.DownloadDir = downloadPath
|
||
file.IsNotExistMkDir(config.FileSettingInfo.DownloadDir)
|
||
config.Cfg.SaveTo(config.SystemConfigInfo.ConfigPath)
|
||
}
|
||
|
||
if len(config.UserInfo.Description) == 0 {
|
||
config.Cfg.Section("user").Key("Description").SetValue("nothing")
|
||
config.UserInfo.Description = "nothing"
|
||
config.Cfg.SaveTo(config.SystemConfigInfo.ConfigPath)
|
||
}
|
||
if len(config.ServerInfo.Handshake) == 0 {
|
||
config.Cfg.Section("server").Key("Handshake").SetValue("socket.casaos.io")
|
||
config.ServerInfo.Handshake = "socket.casaos.io"
|
||
config.Cfg.SaveTo(config.SystemConfigInfo.ConfigPath)
|
||
}
|
||
|
||
if service.MyService.ZiMa().GetSysInfo().KernelArch == "aarch64" && config.ServerInfo.USBAutoMount != "True" && strings.Contains(service.MyService.ZiMa().GetDeviceTree(), "Raspberry Pi") {
|
||
service.MyService.System().UpdateUSBAutoMount("False")
|
||
service.MyService.System().ExecUSBAutoMountShell("False")
|
||
}
|
||
|
||
// str := []string{}
|
||
// str = append(str, "ddd")
|
||
// str = append(str, "aaa")
|
||
// ddd := strings.Join(str, "|")
|
||
// config.Cfg.Section("file").Key("ShareDir").SetValue(ddd)
|
||
|
||
// config.Cfg.SaveTo(config.SystemConfigInfo.ConfigPath)
|
||
|
||
}
|
||
|
||
func ImportApplications() {
|
||
service.MyService.App().ImportApplications(true)
|
||
}
|
||
|
||
// 0.3.1
|
||
func ChangeAPIUrl() {
|
||
|
||
newAPIUrl := "https://api.casaos.io/casaos-api"
|
||
if config.ServerInfo.ServerApi == "https://api.casaos.zimaboard.com" {
|
||
config.ServerInfo.ServerApi = newAPIUrl
|
||
config.Cfg.Section("server").Key("ServerApi").SetValue(newAPIUrl)
|
||
config.Cfg.SaveTo(config.SystemConfigInfo.ConfigPath)
|
||
}
|
||
|
||
}
|
||
|
||
// 0.3.1
|
||
func InitSystemApplication() {
|
||
list := service.MyService.App().GetApplicationList()
|
||
if len(list) != 2 {
|
||
application := model2.ApplicationModel{}
|
||
application.Name = "Files"
|
||
application.Icon = "/ui/img/Files.svg"
|
||
application.Type = "system"
|
||
application.Order = 0
|
||
service.MyService.App().CreateApplication(application)
|
||
|
||
application.Name = "CasaConnect"
|
||
application.Icon = "/ui/img/CasaConnect.svg"
|
||
application.Type = "system"
|
||
application.Order = 0
|
||
|
||
service.MyService.App().CreateApplication(application)
|
||
}
|
||
}
|