Documentation ¶
Index ¶
- Constants
- Variables
- func GetCapabilitiesFromCluster(ctx context.Context, namespace string, c common.Args, selector labels.Selector) ([]types.Capability, error)
- func GetCapabilityByComponentDefinitionObject(componentDef v1beta1.ComponentDefinition, referenceName string) (*types.Capability, error)
- func GetCapabilityByName(ctx context.Context, c common.Args, capabilityName string, ns string) (*types.Capability, error)
- func GetCapabilityByTraitDefinitionObject(traitDef v1beta1.TraitDefinition) (*types.Capability, error)
- func GetComponentsFromCluster(ctx context.Context, namespace string, c common.Args, selector labels.Selector) ([]types.Capability, []error, error)
- func GetComponentsFromClusterWithValidateOption(ctx context.Context, namespace string, c common.Args, selector labels.Selector, ...) ([]types.Capability, []error, error)
- func GetDescription(annotation map[string]string) string
- func GetInstalledCapabilityWithCapName(capT types.CapType, capName string) (types.Capability, error)
- func GetNamespacedCapabilitiesFromCluster(ctx context.Context, namespace string, c common.Args, selector labels.Selector) ([]types.Capability, error)
- func GetSubDir(dir string, capT types.CapType) string
- func GetTraitsFromCluster(ctx context.Context, namespace string, c common.Args, selector labels.Selector) ([]types.Capability, []error, error)
- func GetTraitsFromClusterWithValidateOption(ctx context.Context, namespace string, c common.Args, selector labels.Selector, ...) ([]types.Capability, []error, error)
- func HandleDefinition(name, crdName string, annotation map[string]string, ...) (types.Capability, error)
- func HandleTemplate(in *runtime.RawExtension, schematic *commontypes.Schematic, name string) (types.Capability, error)
- func LoadAllInstalledCapability(userNamespace string, c common.Args) ([]types.Capability, error)
- func LoadCapabilityByName(name string, userNamespace string, c common.Args) (types.Capability, error)
- func LoadCapabilityFromSyncedCenter(mapper discoverymapper.DiscoveryMapper, dir string) ([]types.Capability, error)
- func LoadInstalledCapabilityWithType(userNamespace string, c common.Args, capT types.CapType) ([]types.Capability, error)
- func ParseAndSyncCapability(mapper discoverymapper.DiscoveryMapper, data []byte) (types.Capability, error)
- func RemoveLegacyTemps(retainedTemps []types.Capability, dir string) int
- func SinkTemp2Local(templates []types.Capability, dir string) int
- func StoreRepos(repos []CapCenterConfig) error
- func WalkParameterSchema(parameters *openapi3.Schema, name string, depth int)
- type BoolType
- type CapCenterConfig
- type CenterClient
- type CommonReference
- type CommonSchema
- type ConsoleReference
- type Content
- type GithubCenter
- type GithubContent
- type GithubRegistry
- type Int64Type
- type ListBucketResult
- type LocalContent
- type LocalRegistry
- type MarkdownReference
- func (ref *MarkdownReference) CreateMarkdown(ctx context.Context, caps []types.Capability, ...) error
- func (ref *MarkdownReference) GenerateReferenceDocs(ctx context.Context, baseRefPath string) error
- func (ref *MarkdownReference) GenerateTerraformCapabilityProperties(capability types.Capability) (string, error)
- type OssContent
- type OssRegistry
- type ParseReference
- type Reference
- type ReferenceParameter
- type ReferenceParameterTable
- type Registry
- type RegistryFile
- type RemoteCapabilities
- type RemoteCapability
- type StringType
Constants ¶
const ( // BaseRefPath is the target path for reference docs BaseRefPath = "docs/en/end-user" // ReferenceSourcePath is the location for source reference ReferenceSourcePath = "hack/references" // ComponentDefinitionTypePath is the URL path for component typed capability ComponentDefinitionTypePath = "components" // WorkloadTypePath is the URL path for workload typed capability WorkloadTypePath = "workload-types" // TraitPath is the URL path for trait typed capability TraitPath = "traits" )
const ( // TerraformWriteConnectionSecretToRefName is the name for Terraform WriteConnectionSecretToRef TerraformWriteConnectionSecretToRefName = "writeConnectionSecretToRef" // TerraformWriteConnectionSecretToRefType is the type for Terraform WriteConnectionSecretToRef TerraformWriteConnectionSecretToRefType = "[writeConnectionSecretToRef](#writeConnectionSecretToRef)" )
const DescriptionUndefined = "description not defined"
DescriptionUndefined indicates the description is not defined
const TypeGithub = "github"
TypeGithub represents github
const TypeLocal = "local"
TypeLocal represents github
const TypeOss = "oss"
TypeOss represent oss
const TypeUnknown = "unknown"
TypeUnknown represents parse failed
Variables ¶
var BaseOpenAPIV3Template = `` /* 198-byte string literal not displayed */
BaseOpenAPIV3Template is Standard OpenAPIV3 Template
var ConfigurationYamlSample = map[string]string{
"annotations": `
apiVersion: core.oam.dev/v1beta1
kind: Application
metadata:
name: myapp
spec:
components:
- name: express-server
type: webservice
properties:
image: crccheck/hello-world
port: 8000
traits:
- type: labels
properties:
"release": "stable"
- type: annotations
properties:
"description": "web application"
`,
"ingress": `
kind: Application
metadata:
name: first-vela-app
spec:
components:
- name: express-server
type: webservice
properties:
image: crccheck/hello-world
port: 8000
traits:
- type: ingress
properties:
domain: testsvc.example.com
http:
"/": 8000
`,
"labels": `
apiVersion: core.oam.dev/v1beta1
kind: Application
metadata:
name: myapp
spec:
components:
- name: express-server
type: webservice
properties:
image: crccheck/hello-world
port: 8000
traits:
- type: labels
properties:
"release": "stable"
- type: annotations
properties:
"description": "web application"
`,
"metrics": `
...
format: "prometheus"
port: 8080
path: "/metrics"
scheme: "http"
enabled: true
`,
"route": `
...
domain: example.com
issuer: tls
rules:
- path: /testapp
rewriteTarget: /
`,
"scaler": `
apiVersion: core.oam.dev/v1beta1
kind: Application
metadata:
name: website
spec:
components:
- name: frontend
type: webservice
properties:
image: nginx
traits:
- type: scaler
properties:
replicas: 2
- type: sidecar
properties:
name: "sidecar-test"
image: "fluentd"
- name: backend
type: worker
properties:
image: busybox
cmd:
- sleep
- '1000'
`,
"sidecar": `
apiVersion: core.oam.dev/v1beta1
kind: Application
metadata:
name: vela-app-with-sidecar
spec:
components:
- name: log-gen-worker
type: worker
properties:
image: busybox
cmd:
- /bin/sh
- -c
- >
i=0;
while true;
do
echo "$i: $(date)" >> /var/log/date.log;
i=$((i+1));
sleep 1;
done
volumes:
- name: varlog
mountPath: /var/log
type: emptyDir
traits:
- type: sidecar
properties:
name: count-log
image: busybox
cmd: [ /bin/sh, -c, 'tail -n+1 -f /var/log/date.log']
volumes:
- name: varlog
path: /var/log
`,
"task": `
apiVersion: core.oam.dev/v1beta1
kind: Application
metadata:
name: app-worker
spec:
components:
- name: mytask
type: task
properties:
image: perl
count: 10
cmd: ["perl", "-Mbignum=bpi", "-wle", "print bpi(2000)"]
`,
"volumes": `
apiVersion: core.oam.dev/v1beta1
kind: Application
metadata:
name: app-worker
spec:
components:
- name: myworker
type: worker
properties:
image: "busybox"
cmd:
- sleep
- "1000"
traits:
- type: aws-ebs-volume
properties:
name: "my-ebs"
mountPath: "/myebs"
volumeID: "my-ebs-id"
`,
"webservice": `
apiVersion: core.oam.dev/v1beta1
kind: Application
metadata:
name: website
spec:
components:
- name: frontend
type: webservice
properties:
image: oamdev/testapp:v1
cmd: ["node", "server.js"]
port: 8080
cpu: "0.1"
env:
- name: FOO
value: bar
- name: FOO
valueFrom:
secretKeyRef:
name: bar
key: bar
`,
"worker": `
apiVersion: core.oam.dev/v1beta1
kind: Application
metadata:
name: app-worker
spec:
components:
- name: myworker
type: worker
properties:
image: "busybox"
cmd:
- sleep
- "1000"
`,
}
ConfigurationYamlSample stores the configuration yaml sample for capabilities
Functions ¶
func GetCapabilitiesFromCluster ¶
func GetCapabilitiesFromCluster(ctx context.Context, namespace string, c common.Args, selector labels.Selector) ([]types.Capability, error)
GetCapabilitiesFromCluster will get capability from K8s cluster
func GetCapabilityByComponentDefinitionObject ¶ added in v1.0.5
func GetCapabilityByComponentDefinitionObject(componentDef v1beta1.ComponentDefinition, referenceName string) (*types.Capability, error)
GetCapabilityByComponentDefinitionObject gets capability by ComponentDefinition object
func GetCapabilityByName ¶ added in v1.0.5
func GetCapabilityByName(ctx context.Context, c common.Args, capabilityName string, ns string) (*types.Capability, error)
GetCapabilityByName gets capability by definition name
func GetCapabilityByTraitDefinitionObject ¶ added in v1.0.5
func GetCapabilityByTraitDefinitionObject(traitDef v1beta1.TraitDefinition) (*types.Capability, error)
GetCapabilityByTraitDefinitionObject gets capability by TraitDefinition object
func GetComponentsFromCluster ¶
func GetComponentsFromCluster(ctx context.Context, namespace string, c common.Args, selector labels.Selector) ([]types.Capability, []error, error)
GetComponentsFromCluster will get capability from K8s cluster
func GetComponentsFromClusterWithValidateOption ¶ added in v1.0.5
func GetComponentsFromClusterWithValidateOption(ctx context.Context, namespace string, c common.Args, selector labels.Selector, validateFlag bool) ([]types.Capability, []error, error)
GetComponentsFromClusterWithValidateOption will get capability from K8s cluster with an option whether to valid Components
func GetDescription ¶
GetDescription get description from annotation
func GetInstalledCapabilityWithCapName ¶
func GetInstalledCapabilityWithCapName(capT types.CapType, capName string) (types.Capability, error)
GetInstalledCapabilityWithCapName will get cap by alias
func GetNamespacedCapabilitiesFromCluster ¶ added in v1.0.5
func GetNamespacedCapabilitiesFromCluster(ctx context.Context, namespace string, c common.Args, selector labels.Selector) ([]types.Capability, error)
GetNamespacedCapabilitiesFromCluster will get capability from K8s cluster in the specified namespace and default namespace If the definition could be found from `namespace`, try to find in namespace `types.DefaultKubeVelaNS`
func GetTraitsFromCluster ¶
func GetTraitsFromCluster(ctx context.Context, namespace string, c common.Args, selector labels.Selector) ([]types.Capability, []error, error)
GetTraitsFromCluster will get capability from K8s cluster
func GetTraitsFromClusterWithValidateOption ¶ added in v1.0.5
func GetTraitsFromClusterWithValidateOption(ctx context.Context, namespace string, c common.Args, selector labels.Selector, validateFlag bool) ([]types.Capability, []error, error)
GetTraitsFromClusterWithValidateOption will get capability from K8s cluster with an option whether to valid Traits
func HandleDefinition ¶
func HandleDefinition(name, crdName string, annotation map[string]string, extension *runtime.RawExtension, tp types.CapType, applyTo []string, schematic *commontypes.Schematic) (types.Capability, error)
HandleDefinition will handle definition to capability
func HandleTemplate ¶
func HandleTemplate(in *runtime.RawExtension, schematic *commontypes.Schematic, name string) (types.Capability, error)
HandleTemplate will handle definition template to capability
func LoadAllInstalledCapability ¶
LoadAllInstalledCapability will list all capability
func LoadCapabilityByName ¶
func LoadCapabilityByName(name string, userNamespace string, c common.Args) (types.Capability, error)
LoadCapabilityByName will load capability from local by name
func LoadCapabilityFromSyncedCenter ¶
func LoadCapabilityFromSyncedCenter(mapper discoverymapper.DiscoveryMapper, dir string) ([]types.Capability, error)
LoadCapabilityFromSyncedCenter will load capability from dir
func LoadInstalledCapabilityWithType ¶
func LoadInstalledCapabilityWithType(userNamespace string, c common.Args, capT types.CapType) ([]types.Capability, error)
LoadInstalledCapabilityWithType will load cap list by type
func ParseAndSyncCapability ¶
func ParseAndSyncCapability(mapper discoverymapper.DiscoveryMapper, data []byte) (types.Capability, error)
ParseAndSyncCapability will convert config from remote center to capability
func RemoveLegacyTemps ¶
func RemoveLegacyTemps(retainedTemps []types.Capability, dir string) int
RemoveLegacyTemps will remove capability definitions under `dir` but not included in `retainedTemps`.
func SinkTemp2Local ¶
func SinkTemp2Local(templates []types.Capability, dir string) int
SinkTemp2Local will sink template to local file
func StoreRepos ¶
func StoreRepos(repos []CapCenterConfig) error
StoreRepos will store cap center repo locally
Types ¶
type CapCenterConfig ¶
type CapCenterConfig struct { Name string `json:"name"` Address string `json:"address"` Token string `json:"token"` }
CapCenterConfig is used to store cap center config in file
func LoadRepos ¶
func LoadRepos() ([]CapCenterConfig, error)
LoadRepos will load all cap center repos TODO(wonderflow): we can make default(built-in) repo configurable, then we should make default inside the answer
type CenterClient ¶
type CenterClient interface {
SyncCapabilityFromCenter() error
}
CenterClient defines an interface for cap center client
func NewCenterClient ¶
func NewCenterClient(ctx context.Context, name, address, token string) (CenterClient, error)
NewCenterClient create a client from type
type CommonReference ¶ added in v1.1.0
type CommonReference struct { Name string Parameters []ReferenceParameter Depth int }
CommonReference contains parameters info of HelmCategory and KubuCategory type capability at present
type CommonSchema ¶ added in v1.1.0
CommonSchema is a struct contains *openapi3.Schema style parameter
type ConsoleReference ¶
type ConsoleReference struct { ParseReference TableName string `json:"tableName"` TableObject *tablewriter.Table `json:"tableObject"` }
ConsoleReference is the struct for capability information in console
func (*ConsoleReference) GenerateCUETemplateProperties ¶ added in v1.0.4
func (ref *ConsoleReference) GenerateCUETemplateProperties(capability *types.Capability) ([]ConsoleReference, error)
GenerateCUETemplateProperties get all properties of a capability
func (*ConsoleReference) GenerateTerraformCapabilityProperties ¶ added in v1.0.4
func (ref *ConsoleReference) GenerateTerraformCapabilityProperties(capability types.Capability) ([]ConsoleReference, error)
GenerateTerraformCapabilityProperties generates Capability properties for Terraform ComponentDefinition in Cli console
type Content ¶ added in v1.1.0
type Content struct { OssContent GithubContent LocalContent }
Content contains different type of content needed when building Registry or GithubCenter
type GithubCenter ¶
type GithubCenter struct {
// contains filtered or unexported fields
}
GithubCenter implementation of cap center
func NewGithubCenter ¶
func NewGithubCenter(ctx context.Context, token, centerName string, r *GithubContent) (*GithubCenter, error)
NewGithubCenter will create client by github center implementation
func (*GithubCenter) SyncCapabilityFromCenter ¶
func (g *GithubCenter) SyncCapabilityFromCenter() error
SyncCapabilityFromCenter will sync capability from github cap center TODO(wonderflow): currently we only sync by create, we also need to delete which not exist remotely.
type GithubContent ¶
type GithubContent struct { Owner string `json:"owner"` Repo string `json:"repo"` Path string `json:"path"` Ref string `json:"ref"` }
GithubContent for cap center
type GithubRegistry ¶ added in v1.1.0
type GithubRegistry struct {
// contains filtered or unexported fields
}
GithubRegistry is Registry's implementation treat github url as resource
func (GithubRegistry) GetCap ¶ added in v1.1.0
func (g GithubRegistry) GetCap(addonName string) (types.Capability, []byte, error)
GetCap return capability object and raw data specified by cap name
func (GithubRegistry) ListCaps ¶ added in v1.1.0
func (g GithubRegistry) ListCaps() ([]types.Capability, error)
ListCaps list all capabilities of registry
type ListBucketResult ¶ added in v1.1.0
ListBucketResult describe a file list from OSS
type LocalContent ¶ added in v1.1.0
type LocalContent struct {
AbsDir string `json:"abs_dir"`
}
LocalContent for local registry
type LocalRegistry ¶ added in v1.1.0
type LocalRegistry struct {
// contains filtered or unexported fields
}
LocalRegistry is Registry's implementation treat local url as resource
func (LocalRegistry) GetCap ¶ added in v1.1.0
func (l LocalRegistry) GetCap(addonName string) (types.Capability, []byte, error)
GetCap return capability object and raw data specified by cap name
func (LocalRegistry) ListCaps ¶ added in v1.1.0
func (l LocalRegistry) ListCaps() ([]types.Capability, error)
ListCaps list all capabilities of registry
type MarkdownReference ¶
type MarkdownReference struct {
ParseReference
}
MarkdownReference is the struct for capability information in
func (*MarkdownReference) CreateMarkdown ¶
func (ref *MarkdownReference) CreateMarkdown(ctx context.Context, caps []types.Capability, baseRefPath, referenceSourcePath string) error
CreateMarkdown creates markdown based on capabilities
func (*MarkdownReference) GenerateReferenceDocs ¶
func (ref *MarkdownReference) GenerateReferenceDocs(ctx context.Context, baseRefPath string) error
GenerateReferenceDocs generates reference docs
func (*MarkdownReference) GenerateTerraformCapabilityProperties ¶ added in v1.0.5
func (ref *MarkdownReference) GenerateTerraformCapabilityProperties(capability types.Capability) (string, error)
GenerateTerraformCapabilityProperties generates Capability properties for Terraform ComponentDefinition in a local website
type OssContent ¶ added in v1.1.0
type OssContent struct {
BucketURL string `json:"bucket_url"`
}
OssContent for oss registry
type OssRegistry ¶ added in v1.1.0
OssRegistry is Registry's implementation treat OSS url as resource
func (OssRegistry) GetCap ¶ added in v1.1.0
func (o OssRegistry) GetCap(addonName string) (types.Capability, []byte, error)
GetCap return capability object and raw data specified by cap name
func (OssRegistry) ListCaps ¶ added in v1.1.0
func (o OssRegistry) ListCaps() ([]types.Capability, error)
ListCaps list all capabilities of registry
type ParseReference ¶
ParseReference is used to include the common function `parseParameter`
func (*ParseReference) GenerateHelmAndKubeProperties ¶ added in v1.1.0
func (ref *ParseReference) GenerateHelmAndKubeProperties(ctx context.Context, capability *types.Capability) ([]CommonReference, []ConsoleReference, error)
GenerateHelmAndKubeProperties get all properties of a Helm/Kube Category type capability
type Reference ¶
type Reference interface {
// contains filtered or unexported methods
}
Reference is the struct for capability information
type ReferenceParameter ¶
type ReferenceParameter struct { types.Parameter `json:",inline,omitempty"` // PrintableType is same to `parameter.Type` which could be printable PrintableType string `json:"printableType"` }
ReferenceParameter is the parameter section of CUE template
type ReferenceParameterTable ¶ added in v1.0.5
type ReferenceParameterTable struct { Name string Parameters []ReferenceParameter Depth *int }
ReferenceParameterTable stores the information of a bunch of ReferenceParameter in a table style
type Registry ¶ added in v1.1.0
type Registry interface { GetCap(addonName string) (types.Capability, []byte, error) ListCaps() ([]types.Capability, error) }
Registry define a registry stores trait & component defs
type RegistryFile ¶ added in v1.1.0
type RegistryFile struct {
// contains filtered or unexported fields
}
RegistryFile describes a file item in registry
type RemoteCapabilities ¶
type RemoteCapabilities []RemoteCapability
RemoteCapabilities is slice of cap center