-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathapplication.go
165 lines (126 loc) · 5.44 KB
/
application.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
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
// Copyright 2020 Canonical Ltd.
// Licensed under the AGPLv3, see LICENCE file for details.
package caas
import (
"context"
"github.com/juju/version/v2"
core "k8s.io/api/core/v1"
"github.com/juju/juju/core/constraints"
"github.com/juju/juju/core/devices"
"github.com/juju/juju/core/resources"
"github.com/juju/juju/core/watcher"
"github.com/juju/juju/internal/storage"
)
//go:generate go run go.uber.org/mock/mockgen -package mocks -destination mocks/application_mock.go github.com/juju/juju/caas Application
// Application is for interacting with the CAAS substrate.
type Application interface {
Ensure(config ApplicationConfig) error
Exists() (DeploymentState, error)
Delete() error
Watch() (watcher.NotifyWatcher, error)
WatchReplicas() (watcher.NotifyWatcher, error)
// ApplicationPodSpec returns the pod spec needed to run the application workload.
ApplicationPodSpec(config ApplicationConfig) (*core.PodSpec, error)
// Scale scales the Application's unit to the value specified. Scale must
// be >= 0. Application units will be removed or added to meet the scale
// defined.
Scale(int) error
// Trust sets up the role on the application's service account to
// give full access to the cluster.
Trust(bool) error
State() (ApplicationState, error)
// Units of the application fetched from kubernetes by matching pod labels.
Units() ([]Unit, error)
UnitsToRemove(context.Context, int) ([]string, error)
// Service returns the service associated with the application.
Service() (*Service, error)
ServiceInterface
}
// ServicePort represents service ports mapping from service to units.
type ServicePort struct {
Name string `json:"name"`
Port int `json:"port"`
TargetPort int `json:"target-port"`
Protocol string `json:"protocol"`
}
// ServiceParam defines parameters for an UpdateService request.
type ServiceParam struct {
Type string `json:"type"`
Ports []ServicePort `json:"ports"`
}
// ServiceInterface provides the API to get/set service.
type ServiceInterface interface {
// UpdateService updates the default service with specific service type and port mappings.
UpdateService(ServiceParam) error
UpdatePorts(ports []ServicePort, updateContainerPorts bool) error
}
// ApplicationState represents the application state.
type ApplicationState struct {
DesiredReplicas int
Replicas []string
}
// ApplicationConfig is the config passed to the application units.
type ApplicationConfig struct {
// AgentVersion is the Juju version of the agent image.
AgentVersion version.Number
// AgentImagePath is the docker registry URL for the charm container.
AgentImagePath string
// CharmBaseImagePath is the docker registry URL for the workload containers to run pebble.
CharmBaseImagePath string
// IsPrivateImageRepo indicates if the images repositories are private or not.
// If they are, we need to set the image pull secret.
IsPrivateImageRepo bool
// CharmModifiedVersion is a monotonically incrementing version number
// that represents the version of the charm and resources with regards to
// this application. The CAAS provider will pass this to the uniter worker
// to ensure the container infrastructure matches the charm.
CharmModifiedVersion int
// Containers is the list of containers that make up the container (excluding uniter and init containers).
Containers map[string]ContainerConfig
// ExistingContainers is a list of names for containers which will be added
// to the application pod spec outside the ApplicationPodSpec method.
// These containers will be added to the JUJU_CONTAINER_NAMES env variable
// in the charm container, but we will not create new container specs for
// them, as they are assumed to already exist.
ExistingContainers []string
// IntroductionSecret
IntroductionSecret string
// ControllerAddresses is a comma separated list of controller addresses.
// TODO: Use model-operator service instead for introduction, so controller addresses can change
// without having to update deployed application.
ControllerAddresses string
// ControllerCertBundle is a PEM cert bundle for talking to the Juju controller.
ControllerCertBundle string
// ResourceTags is a set of tags to set on the operator pod.
ResourceTags map[string]string
// Constraints is a set of constraints on
// the pod to create.
Constraints constraints.Value
// Filesystems is a set of parameters for filesystems that should be created.
Filesystems []storage.KubernetesFilesystemParams
// Devices is a set of parameters for Devices that is required.
Devices []devices.KubernetesDeviceParams
// Trust is set to true to give the application cloud access.
Trust bool
// InitialScale is used to provide the initial desired scale of the application.
// After the application is created, InitialScale has no effect.
InitialScale int
// Rootless is true if the application should be run without root priviledges.
Rootless bool
}
// ContainerConfig describes a container that is deployed alonside the uniter/charm container.
type ContainerConfig struct {
// Name of the container.
Name string
// Image used to create the container.
Image resources.DockerImageDetails
// Mounts to storage that are to be provided within this container.
Mounts []MountConfig
}
// MountConfig describes a storage that should be mounted to a container.
type MountConfig struct {
// StorageName is the name of the storage as specified in the charm.
StorageName string
// Path is the mount point inside the container.
Path string
}