summaryrefslogtreecommitdiff
path: root/cmd/podman/generate_kube.go
blob: f63bd431b0daf2e52b9eb575260a071486d4a510 (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
99
100
101
102
103
104
105
106
107
108
109
110
package main

import (
	"fmt"

	"github.com/containers/libpod/cmd/podman/libpodruntime"
	"github.com/containers/libpod/libpod"
	"github.com/containers/libpod/pkg/rootless"
	podmanVersion "github.com/containers/libpod/version"
	"github.com/ghodss/yaml"
	"github.com/pkg/errors"
	"github.com/urfave/cli"
	"k8s.io/api/core/v1"
)

var (
	containerKubeFlags = []cli.Flag{
		cli.BoolFlag{
			Name:  "service, s",
			Usage: "generate YAML for kubernetes service object",
		},
	}
	containerKubeDescription = "Generate Kubernetes Pod YAML"
	containerKubeCommand     = cli.Command{
		Name:                   "kube",
		Usage:                  "Generate Kubernetes pod YAML for a container or pod",
		Description:            containerKubeDescription,
		Flags:                  sortFlags(containerKubeFlags),
		Action:                 generateKubeYAMLCmd,
		ArgsUsage:              "CONTAINER|POD-NAME",
		UseShortOptionHandling: true,
		OnUsageError:           usageErrorHandler,
	}
)

func generateKubeYAMLCmd(c *cli.Context) error {
	var (
		podYAML           *v1.Pod
		container         *libpod.Container
		err               error
		output            []byte
		pod               *libpod.Pod
		marshalledPod     []byte
		marshalledService []byte
		servicePorts      []v1.ServicePort
	)

	if rootless.IsRootless() {
		return errors.Wrapf(libpod.ErrNotImplemented, "rootless users")
	}
	args := c.Args()
	if len(args) > 1 || (len(args) < 1 && !c.Bool("latest")) {
		return errors.Errorf("you must provide one container|pod ID or name or --latest")
	}

	runtime, err := libpodruntime.GetRuntime(c)
	if err != nil {
		return errors.Wrapf(err, "could not get runtime")
	}
	defer runtime.Shutdown(false)

	// Get the container in question
	container, err = runtime.LookupContainer(args[0])
	if err != nil {
		pod, err = runtime.LookupPod(args[0])
		if err != nil {
			return err
		}
		podYAML, servicePorts, err = pod.GenerateForKube()
	} else {
		if len(container.Dependencies()) > 0 {
			return errors.Wrapf(libpod.ErrNotImplemented, "containers with dependencies")
		}
		podYAML, err = container.GenerateForKube()
	}
	if err != nil {
		return err
	}

	if c.Bool("service") {
		serviceYAML := libpod.GenerateKubeServiceFromV1Pod(podYAML, servicePorts)
		marshalledService, err = yaml.Marshal(serviceYAML)
		if err != nil {
			return err
		}
	}
	// Marshall the results
	marshalledPod, err = yaml.Marshal(podYAML)
	if err != nil {
		return err
	}

	header := `# Generation of Kubernetes YAML is still under development!
#
# Save the output of this file and use kubectl create -f to import
# it into Kubernetes.
#
# Created with podman-%s
`
	output = append(output, []byte(fmt.Sprintf(header, podmanVersion.Version))...)
	output = append(output, marshalledPod...)
	if c.Bool("service") {
		output = append(output, []byte("---\n")...)
		output = append(output, marshalledService...)
	}
	// Output the v1.Pod with the v1.Container
	fmt.Println(string(output))

	return nil
}