This repository has been archived by the owner on May 1, 2020. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 14
/
types.go
117 lines (105 loc) · 3.86 KB
/
types.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
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
111
112
113
114
115
116
117
/*
Copyright (C) 2018 Synopsys, Inc.
Licensed to the Apache Software Foundation (ASF) under one
or more contributor license agreements. See the NOTICE file
distributed with this work for additional information
regarding copyright ownership. The ASF licenses this file
to you under the Apache License, Version 2.0 (the
"License"); you may not use this file except in compliance
with the License. You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing,
software distributed under the License is distributed on an
"AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
KIND, either express or implied. See the License for the
specific language governing permissions and limitations
under the License.
*/
package api
import (
"github.com/blackducksoftware/horizon/pkg/components"
routev1 "github.com/openshift/api/route/v1"
)
// Route defines the route component
type Route struct {
Namespace string
Name string
Kind string
ServiceName string
PortName string
Labels map[string]string
TLSTerminationType routev1.TLSTerminationType
}
// ComponentList defines the list of components for an app
type ComponentList struct {
ReplicationControllers []*components.ReplicationController
Services []*components.Service
ConfigMaps []*components.ConfigMap
ServiceAccounts []*components.ServiceAccount
ClusterRoleBindings []*components.ClusterRoleBinding
ClusterRoles []*components.ClusterRole
RoleBindings []*components.RoleBinding
Roles []*components.Role
Deployments []*components.Deployment
Secrets []*components.Secret
PersistentVolumeClaims []*components.PersistentVolumeClaim
Routes []*Route
CustomResourceDefinitions []*components.CustomResourceDefinition
}
// GetKubeInterfaces returns a list of kube components as interfaces
func (clist *ComponentList) GetKubeInterfaces() []interface{} {
components := []interface{}{}
for _, rc := range clist.ReplicationControllers {
components = append(components, rc.ReplicationController)
}
for _, svc := range clist.Services {
components = append(components, svc.Service)
}
for _, cm := range clist.ConfigMaps {
components = append(components, cm.ConfigMap)
}
for _, sa := range clist.ServiceAccounts {
components = append(components, sa.ServiceAccount)
}
for _, crb := range clist.ClusterRoleBindings {
components = append(components, crb.ClusterRoleBinding)
}
for _, cr := range clist.ClusterRoles {
components = append(components, cr.ClusterRole)
}
for _, d := range clist.Deployments {
components = append(components, d.Deployment)
}
for _, sec := range clist.Secrets {
components = append(components, sec.Secret)
}
for _, pvc := range clist.PersistentVolumeClaims {
components = append(components, pvc.PersistentVolumeClaim)
}
return components
}
// RegistryConfiguration contains the registry configuration
type RegistryConfiguration struct {
Registry string `json:"registry"`
PullSecrets []string `json:"pullSecrets"`
}
// DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil.
func (in *RegistryConfiguration) DeepCopyInto(out *RegistryConfiguration) {
*out = *in
return
}
// DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new BlackduckSpec.
func (in *RegistryConfiguration) DeepCopy() *RegistryConfiguration {
if in == nil {
return nil
}
out := new(RegistryConfiguration)
in.DeepCopyInto(out)
return out
}
// SecurityContext will contain the specifications of a security contexts
type SecurityContext struct {
FsGroup *int64 `json:"fsGroup"`
RunAsUser *int64 `json:"runAsUser"`
RunAsGroup *int64 `json:"runAsGroup"`
}