2020-12-14 17:32:32 +00:00
|
|
|
// Copyright © 2020 Ettore Di Giacinto <mudler@gentoo.org>
|
|
|
|
//
|
|
|
|
// This program is free software; you can redistribute it and/or modify
|
|
|
|
// it under the terms of the GNU General Public License as published by
|
|
|
|
// the Free Software Foundation; either version 2 of the License, or
|
|
|
|
// (at your option) any later version.
|
|
|
|
//
|
|
|
|
// This program is distributed in the hope that it will be useful,
|
|
|
|
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
// GNU General Public License for more details.
|
|
|
|
//
|
|
|
|
// You should have received a copy of the GNU General Public License along
|
|
|
|
// with this program; if not, see <http://www.gnu.org/licenses/>.
|
|
|
|
|
|
|
|
package backend
|
|
|
|
|
|
|
|
import (
|
2021-02-01 18:10:16 +00:00
|
|
|
"fmt"
|
|
|
|
"os/exec"
|
|
|
|
|
2021-01-18 16:58:32 +00:00
|
|
|
"github.com/mudler/luet/pkg/compiler"
|
2021-02-01 18:10:16 +00:00
|
|
|
"github.com/mudler/luet/pkg/config"
|
|
|
|
|
|
|
|
"github.com/google/go-containerregistry/pkg/crane"
|
|
|
|
"github.com/pkg/errors"
|
2021-01-18 16:58:32 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
const (
|
|
|
|
ImgBackend = "img"
|
|
|
|
DockerBackend = "docker"
|
2020-12-14 17:32:32 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
func imageAvailable(image string) bool {
|
|
|
|
_, err := crane.Digest(image)
|
|
|
|
return err == nil
|
|
|
|
}
|
2021-01-18 16:58:32 +00:00
|
|
|
|
|
|
|
func NewBackend(s string) compiler.CompilerBackend {
|
|
|
|
var compilerBackend compiler.CompilerBackend
|
|
|
|
|
|
|
|
switch s {
|
|
|
|
case ImgBackend:
|
|
|
|
compilerBackend = NewSimpleImgBackend()
|
|
|
|
case DockerBackend:
|
|
|
|
compilerBackend = NewSimpleDockerBackend()
|
|
|
|
}
|
|
|
|
return compilerBackend
|
|
|
|
}
|
2021-02-01 18:10:16 +00:00
|
|
|
|
|
|
|
func runCommand(cmd *exec.Cmd) (string, error) {
|
|
|
|
ans := ""
|
|
|
|
writer := NewBackendWriter(!config.LuetCfg.GetGeneral().ShowBuildOutput)
|
|
|
|
|
|
|
|
cmd.Stdout = writer
|
|
|
|
cmd.Stderr = writer
|
|
|
|
|
|
|
|
err := cmd.Start()
|
|
|
|
if err != nil {
|
|
|
|
return "", errors.Wrap(err, "Failed starting build")
|
|
|
|
}
|
|
|
|
|
|
|
|
err = cmd.Wait()
|
|
|
|
if err != nil {
|
|
|
|
return "", errors.Wrap(err, "Failed waiting for building command")
|
|
|
|
}
|
|
|
|
|
|
|
|
res := cmd.ProcessState.ExitCode()
|
|
|
|
if res != 0 {
|
|
|
|
errMsg := fmt.Sprintf("Failed building image (exiting with %d)", res)
|
|
|
|
if !config.LuetCfg.GetGeneral().ShowBuildOutput {
|
|
|
|
errMsg = fmt.Sprintf("Failed building image (exiting with %d): %s",
|
|
|
|
res, writer.GetCombinedOutput())
|
|
|
|
}
|
|
|
|
|
|
|
|
return "", errors.Wrap(err, errMsg)
|
|
|
|
}
|
|
|
|
|
2021-02-13 08:28:54 +00:00
|
|
|
if !config.LuetCfg.GetGeneral().ShowBuildOutput {
|
2021-02-01 18:10:16 +00:00
|
|
|
ans = writer.GetCombinedOutput()
|
|
|
|
}
|
|
|
|
|
|
|
|
return ans, nil
|
|
|
|
}
|