summaryrefslogtreecommitdiff
path: root/pkg/api/handlers/libpod/generate.go
blob: 7e08dd4a8475caeecd39283bfce7c76779c3c755 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
package libpod

import (
	"net/http"

	"github.com/containers/podman/v4/libpod"
	"github.com/containers/podman/v4/pkg/api/handlers/utils"
	api "github.com/containers/podman/v4/pkg/api/types"
	"github.com/containers/podman/v4/pkg/domain/entities"
	"github.com/containers/podman/v4/pkg/domain/infra/abi"
	"github.com/containers/podman/v4/pkg/util"
	"github.com/gorilla/schema"
	"github.com/pkg/errors"
)

func GenerateSystemd(w http.ResponseWriter, r *http.Request) {
	runtime := r.Context().Value(api.RuntimeKey).(*libpod.Runtime)
	decoder := r.Context().Value(api.DecoderKey).(*schema.Decoder)
	query := struct {
		Name             bool     `schema:"useName"`
		New              bool     `schema:"new"`
		NoHeader         bool     `schema:"noHeader"`
		TemplateUnitFile bool     `schema:"templateUnitFile"`
		RestartPolicy    *string  `schema:"restartPolicy"`
		RestartSec       uint     `schema:"restartSec"`
		StopTimeout      uint     `schema:"stopTimeout"`
		StartTimeout     uint     `schema:"startTimeout"`
		ContainerPrefix  string   `schema:"containerPrefix"`
		PodPrefix        string   `schema:"podPrefix"`
		Separator        string   `schema:"separator"`
		Wants            []string `schema:"wants"`
		After            []string `schema:"after"`
		Requires         []string `schema:"requires"`
	}{
		StartTimeout:    0,
		StopTimeout:     util.DefaultContainerConfig().Engine.StopTimeout,
		ContainerPrefix: "container",
		PodPrefix:       "pod",
		Separator:       "-",
	}

	if err := decoder.Decode(&query, r.URL.Query()); err != nil {
		utils.Error(w, http.StatusBadRequest, errors.Wrapf(err, "failed to parse parameters for %s", r.URL.String()))
		return
	}

	containerEngine := abi.ContainerEngine{Libpod: runtime}
	options := entities.GenerateSystemdOptions{
		Name:             query.Name,
		New:              query.New,
		NoHeader:         query.NoHeader,
		TemplateUnitFile: query.TemplateUnitFile,
		RestartPolicy:    query.RestartPolicy,
		StartTimeout:     &query.StartTimeout,
		StopTimeout:      &query.StopTimeout,
		ContainerPrefix:  query.ContainerPrefix,
		PodPrefix:        query.PodPrefix,
		Separator:        query.Separator,
		RestartSec:       &query.RestartSec,
		Wants:            query.Wants,
		After:            query.After,
		Requires:         query.Requires,
	}

	report, err := containerEngine.GenerateSystemd(r.Context(), utils.GetName(r), options)
	if err != nil {
		utils.Error(w, http.StatusInternalServerError, errors.Wrap(err, "error generating systemd units"))
		return
	}

	utils.WriteResponse(w, http.StatusOK, report.Units)
}

func GenerateKube(w http.ResponseWriter, r *http.Request) {
	runtime := r.Context().Value(api.RuntimeKey).(*libpod.Runtime)
	decoder := r.Context().Value(api.DecoderKey).(*schema.Decoder)
	query := struct {
		Names   []string `schema:"names"`
		Service bool     `schema:"service"`
	}{
		// Defaults would go here.
	}

	if err := decoder.Decode(&query, r.URL.Query()); err != nil {
		utils.Error(w, http.StatusBadRequest, errors.Wrapf(err, "failed to parse parameters for %s", r.URL.String()))
		return
	}

	containerEngine := abi.ContainerEngine{Libpod: runtime}
	options := entities.GenerateKubeOptions{Service: query.Service}
	report, err := containerEngine.GenerateKube(r.Context(), query.Names, options)
	if err != nil {
		utils.Error(w, http.StatusInternalServerError, errors.Wrap(err, "error generating YAML"))
		return
	}

	utils.WriteResponse(w, http.StatusOK, report.Reader)
}