forked from openshift/installer
/
cluster-network-crds.go
63 lines (52 loc) · 1.51 KB
/
cluster-network-crds.go
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
package openshift
import (
"os"
"path/filepath"
"github.com/openshift/installer/pkg/asset"
"github.com/openshift/installer/pkg/asset/templates/content"
)
const (
netopCRDfilename = "cluster-networkconfig-crd.yaml"
)
var _ asset.WritableAsset = (*NetworkCRDs)(nil)
// NetworkCRDs is the custom resource definitions for the network operator types:
// - NetworkConfig.networkoperator.openshift.io
type NetworkCRDs struct {
FileList []*asset.File
}
// Dependencies returns all of the dependencies directly needed by the asset
func (t *NetworkCRDs) Dependencies() []asset.Asset {
return []asset.Asset{}
}
// Name returns the human-friendly name of the asset.
func (t *NetworkCRDs) Name() string {
return "Network CRDs"
}
// Generate generates the actual files by this asset
func (t *NetworkCRDs) Generate(parents asset.Parents) error {
data, err := content.GetOpenshiftTemplate(netopCRDfilename)
if err != nil {
return err
}
t.FileList = append(t.FileList, &asset.File{
Filename: filepath.Join(content.TemplateDir, netopCRDfilename),
Data: []byte(data),
})
return nil
}
// Files returns the files generated by the asset.
func (t *NetworkCRDs) Files() []*asset.File {
return t.FileList
}
// Load returns the asset from disk.
func (t *NetworkCRDs) Load(f asset.FileFetcher) (bool, error) {
file, err := f.FetchByName(filepath.Join(content.TemplateDir, netopCRDfilename))
if err != nil {
if os.IsNotExist(err) {
return false, nil
}
return false, err
}
t.FileList = append(t.FileList, file)
return true, nil
}