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 GetNamespacedCapabilitiesFromCluster(ctx context.Context, namespace string, c common.Args, selector labels.Selector) ([]types.Capability, error)
- 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, labels 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 LoadInstalledCapabilityWithType(userNamespace string, c common.Args, capT types.CapType) ([]types.Capability, error)
- func WalkParameterSchema(parameters *openapi3.Schema, name string, depth int)
- type BoolType
- type CommonReference
- type CommonSchema
- type ConsoleReference
- type Int64Type
- 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 ParseReference
- type Reference
- type ReferenceParameter
- type ReferenceParameterTable
- 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 DescriptionUndefined = "description not defined"
DescriptionUndefined indicates the description is not defined
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 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, labels 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 LoadInstalledCapabilityWithType ¶
func LoadInstalledCapabilityWithType(userNamespace string, c common.Args, capT types.CapType) ([]types.Capability, error)
LoadInstalledCapabilityWithType will load cap list by type
Types ¶
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 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 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