mirror of https://github.com/helm/helm
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
171 lines
6.0 KiB
171 lines
6.0 KiB
/*
|
|
Copyright 2015 The Kubernetes Authors All rights reserved.
|
|
Licensed 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 common
|
|
|
|
import (
|
|
"time"
|
|
)
|
|
|
|
// SchemaImport represents an import as declared in a schema file.
|
|
type SchemaImport struct {
|
|
Path string `json:"path"`
|
|
Name string `json:"name"`
|
|
}
|
|
|
|
// Schema is a partial DM schema. We only need access to the imports object at this level.
|
|
type Schema struct {
|
|
Imports []SchemaImport `json:"imports"`
|
|
}
|
|
|
|
// Repository manages storage for all Deployment Manager entities, as well as
|
|
// the common operations to store, access and manage them.
|
|
type Repository interface {
|
|
// Deployments.
|
|
ListDeployments() ([]Deployment, error)
|
|
GetDeployment(name string) (*Deployment, error)
|
|
GetValidDeployment(name string) (*Deployment, error)
|
|
CreateDeployment(name string) (*Deployment, error)
|
|
DeleteDeployment(name string, forget bool) (*Deployment, error)
|
|
SetDeploymentStatus(name string, status DeploymentStatus) error
|
|
|
|
// Manifests.
|
|
AddManifest(deploymentName string, manifest *Manifest) error
|
|
ListManifests(deploymentName string) (map[string]*Manifest, error)
|
|
GetManifest(deploymentName string, manifestName string) (*Manifest, error)
|
|
GetLatestManifest(deploymentName string) (*Manifest, error)
|
|
|
|
// Types.
|
|
ListTypes() []string
|
|
GetTypeInstances(typeName string) []*TypeInstance
|
|
ClearTypeInstances(deploymentName string)
|
|
SetTypeInstances(deploymentName string, instances map[string][]*TypeInstance)
|
|
}
|
|
|
|
// Deployment defines a deployment that describes
|
|
// the creation, modification and/or deletion of a set of resources.
|
|
type Deployment struct {
|
|
Name string `json:"name"`
|
|
ID int `json:"id"`
|
|
CreatedAt time.Time `json:"createdAt,omitempty"`
|
|
DeployedAt time.Time `json:"deployedAt,omitempty"`
|
|
ModifiedAt time.Time `json:"modifiedAt,omitempty"`
|
|
DeletedAt time.Time `json:"deletedAt,omitempty"`
|
|
Status DeploymentStatus `json:"status,omitempty"`
|
|
LatestManifest string `json:"latestManifest,omitEmpty"`
|
|
}
|
|
|
|
// NewDeployment creates a new deployment.
|
|
func NewDeployment(name string) *Deployment {
|
|
return &Deployment{Name: name, CreatedAt: time.Now(), Status: CreatedStatus}
|
|
}
|
|
|
|
// DeploymentStatus is an enumeration type for the status of a deployment.
|
|
type DeploymentStatus string
|
|
|
|
// These constants implement the DeploymentStatus enumeration type.
|
|
const (
|
|
CreatedStatus DeploymentStatus = "Created"
|
|
DeletedStatus DeploymentStatus = "Deleted"
|
|
DeployedStatus DeploymentStatus = "Deployed"
|
|
FailedStatus DeploymentStatus = "Failed"
|
|
ModifiedStatus DeploymentStatus = "Modified"
|
|
)
|
|
|
|
func (s DeploymentStatus) String() string {
|
|
return string(s)
|
|
}
|
|
|
|
// LayoutResource defines the structure of resources in the manifest layout.
|
|
type LayoutResource struct {
|
|
Resource
|
|
Layout
|
|
}
|
|
|
|
// Layout defines the structure of a layout as returned from expansion.
|
|
type Layout struct {
|
|
Resources []*LayoutResource `json:"resources,omitempty"`
|
|
}
|
|
|
|
// Manifest contains the input configuration for a deployment, the fully
|
|
// expanded configuration, and the layout structure of the manifest.
|
|
//
|
|
type Manifest struct {
|
|
Deployment string `json:"deployment,omitempty"`
|
|
Name string `json:"name,omitempty"`
|
|
InputConfig *Template `json:"inputConfig,omitempty"`
|
|
ExpandedConfig *Configuration `json:"expandedConfig,omitempty"`
|
|
Layout *Layout `json:"layout,omitempty"`
|
|
}
|
|
|
|
// Template describes a set of resources to be deployed.
|
|
// Manager expands a Template into a Configuration, which
|
|
// describes the set in a form that can be instantiated.
|
|
type Template struct {
|
|
Name string `json:"name"`
|
|
Content string `json:"content"`
|
|
Imports []*ImportFile `json:"imports"`
|
|
}
|
|
|
|
// ImportFile describes a base64 encoded file imported by a Template.
|
|
type ImportFile struct {
|
|
Name string `json:"name,omitempty"`
|
|
Path string `json:"path",omitempty` // Actual URL for the file
|
|
Content string `json:"content"`
|
|
}
|
|
|
|
// Configuration describes a set of resources in a form
|
|
// that can be instantiated.
|
|
type Configuration struct {
|
|
Resources []*Resource `json:"resources"`
|
|
}
|
|
|
|
// ResourceStatus is an enumeration type for the status of a resource.
|
|
type ResourceStatus string
|
|
|
|
// These constants implement the resourceStatus enumeration type.
|
|
const (
|
|
Created ResourceStatus = "Created"
|
|
Failed ResourceStatus = "Failed"
|
|
Aborted ResourceStatus = "Aborted"
|
|
)
|
|
|
|
// ResourceState describes the state of a resource.
|
|
// Status is set during resource creation and is a terminal state.
|
|
type ResourceState struct {
|
|
Status ResourceStatus `json:"status,omitempty"`
|
|
SelfLink string `json:"selflink,omitempty"`
|
|
Errors []string `json:"errors,omitempty"`
|
|
}
|
|
|
|
// Resource describes a resource in a configuration. A resource has
|
|
// a name, a type and a set of properties. The name and type are used
|
|
// to identify the resource in Kubernetes. The properties are passed
|
|
// to Kubernetes as the resource configuration.
|
|
type Resource struct {
|
|
Name string `json:"name"`
|
|
Type string `json:"type"`
|
|
Properties map[string]interface{} `json:"properties,omitempty"`
|
|
State *ResourceState `json:"state,omitempty"`
|
|
}
|
|
|
|
// TypeInstance defines the metadata for an instantiation of a template type
|
|
// in a deployment.
|
|
type TypeInstance struct {
|
|
Name string `json:"name"` // instance name
|
|
Type string `json:"type"` // instance type
|
|
Deployment string `json:"deployment"` // deployment name
|
|
Manifest string `json:"manifest"` // manifest name
|
|
Path string `json:"path"` // JSON path within manifest
|
|
}
|