2023-03-30 08:47:47 +00:00
|
|
|
package service
|
2023-03-31 06:02:28 +00:00
|
|
|
|
|
|
|
import (
|
2023-04-02 08:54:00 +00:00
|
|
|
"fmt"
|
2023-03-31 06:02:28 +00:00
|
|
|
"github.com/1Panel-dev/1Panel/backend/app/model"
|
|
|
|
"github.com/1Panel-dev/1Panel/backend/buserr"
|
|
|
|
"github.com/1Panel-dev/1Panel/backend/constant"
|
2023-04-11 09:08:29 +00:00
|
|
|
"github.com/1Panel-dev/1Panel/backend/global"
|
2023-03-31 06:02:28 +00:00
|
|
|
"github.com/1Panel-dev/1Panel/backend/utils/docker"
|
2023-04-02 08:54:00 +00:00
|
|
|
"github.com/1Panel-dev/1Panel/backend/utils/files"
|
2023-04-17 06:04:22 +00:00
|
|
|
"github.com/docker/cli/cli/command"
|
2023-04-02 08:54:00 +00:00
|
|
|
"github.com/subosito/gotenv"
|
2023-04-17 06:04:22 +00:00
|
|
|
"os"
|
2023-04-02 08:54:00 +00:00
|
|
|
"path"
|
|
|
|
"strings"
|
2023-03-31 06:02:28 +00:00
|
|
|
)
|
|
|
|
|
2023-04-13 06:42:34 +00:00
|
|
|
func buildRuntime(runtime *model.Runtime, service *docker.ComposeService, oldImageID string) {
|
2023-03-31 06:02:28 +00:00
|
|
|
err := service.ComposeBuild()
|
|
|
|
if err != nil {
|
|
|
|
runtime.Status = constant.RuntimeError
|
|
|
|
runtime.Message = buserr.New(constant.ErrImageBuildErr).Error() + ":" + err.Error()
|
|
|
|
} else {
|
|
|
|
runtime.Status = constant.RuntimeNormal
|
2023-04-13 06:42:34 +00:00
|
|
|
if oldImageID != "" {
|
2023-04-11 09:08:29 +00:00
|
|
|
client, err := docker.NewClient()
|
|
|
|
if err == nil {
|
2023-04-13 06:42:34 +00:00
|
|
|
newImageID, err := client.GetImageIDByName(runtime.Image)
|
|
|
|
if err == nil && newImageID != oldImageID {
|
|
|
|
global.LOG.Infof("delete imageID [%s] ", oldImageID)
|
|
|
|
if err := client.DeleteImage(oldImageID); err != nil {
|
|
|
|
global.LOG.Errorf("delete imageID [%s] error %v", oldImageID, err)
|
|
|
|
} else {
|
|
|
|
global.LOG.Infof("delete old image success")
|
|
|
|
}
|
2023-04-11 09:08:29 +00:00
|
|
|
}
|
|
|
|
} else {
|
2023-04-13 06:42:34 +00:00
|
|
|
global.LOG.Errorf("delete imageID [%s] error %v", oldImageID, err)
|
2023-04-11 09:08:29 +00:00
|
|
|
}
|
|
|
|
}
|
2023-03-31 06:02:28 +00:00
|
|
|
}
|
|
|
|
_ = runtimeRepo.Save(runtime)
|
|
|
|
}
|
2023-04-02 08:54:00 +00:00
|
|
|
|
|
|
|
func handleParams(image, runtimeType, runtimeDir string, params map[string]interface{}) (composeContent []byte, envContent []byte, forms []byte, err error) {
|
|
|
|
fileOp := files.NewFileOp()
|
|
|
|
composeContent, err = fileOp.GetContent(path.Join(runtimeDir, "docker-compose.yml"))
|
|
|
|
if err != nil {
|
|
|
|
return
|
|
|
|
}
|
|
|
|
env, err := gotenv.Read(path.Join(runtimeDir, ".env"))
|
|
|
|
if err != nil {
|
|
|
|
return
|
|
|
|
}
|
|
|
|
forms, err = fileOp.GetContent(path.Join(runtimeDir, "config.json"))
|
|
|
|
if err != nil {
|
|
|
|
return
|
|
|
|
}
|
|
|
|
params["IMAGE_NAME"] = image
|
|
|
|
if runtimeType == constant.RuntimePHP {
|
|
|
|
if extends, ok := params["PHP_EXTENSIONS"]; ok {
|
|
|
|
if extendsArray, ok := extends.([]interface{}); ok {
|
|
|
|
strArray := make([]string, len(extendsArray))
|
|
|
|
for i, v := range extendsArray {
|
|
|
|
strArray[i] = fmt.Sprintf("%v", v)
|
|
|
|
}
|
|
|
|
params["PHP_EXTENSIONS"] = strings.Join(strArray, ",")
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
newMap := make(map[string]string)
|
|
|
|
handleMap(params, newMap)
|
|
|
|
for k, v := range newMap {
|
|
|
|
env[k] = v
|
|
|
|
}
|
|
|
|
envStr, err := gotenv.Marshal(env)
|
|
|
|
if err != nil {
|
|
|
|
return
|
|
|
|
}
|
|
|
|
if err = gotenv.Write(env, path.Join(runtimeDir, ".env")); err != nil {
|
|
|
|
return
|
|
|
|
}
|
|
|
|
envContent = []byte(envStr)
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
2023-04-09 14:32:12 +00:00
|
|
|
func getComposeService(name, runtimeDir string, composeFile, env []byte, skipNormalization bool) (*docker.ComposeService, error) {
|
|
|
|
project, err := docker.GetComposeProject(name, runtimeDir, composeFile, env, skipNormalization)
|
2023-04-02 08:54:00 +00:00
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
2023-04-17 06:04:22 +00:00
|
|
|
logPath := path.Join(runtimeDir, "build.log")
|
|
|
|
fileOp := files.NewFileOp()
|
|
|
|
if fileOp.Stat(logPath) {
|
|
|
|
_ = fileOp.DeleteFile(logPath)
|
|
|
|
}
|
|
|
|
file, err := os.Create(logPath)
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
composeService, err := docker.NewComposeService(command.WithOutputStream(file))
|
2023-04-02 08:54:00 +00:00
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
composeService.SetProject(project)
|
|
|
|
return composeService, nil
|
|
|
|
}
|