Documentation ¶
Index ¶
- func ApiVersionComment(gvk schema.GroupVersionKind) string
- func DotnetClient(swagger map[string]interface{}, templateDir string) (inputsts, outputsts string, groups map[string]string, err error)
- func NodeJSClient(swagger map[string]interface{}, templateDir string) (inputsts, outputsts, indexts, yamlts, packagejson string, ...)
- func PulumiComment(kind string) string
- func PythonClient(swagger map[string]interface{}, templateDir string, ...) error
- type GroupConfig
- type GroupTS
- type KindConfig
- func (kc *KindConfig) APIVersion() string
- func (kc *KindConfig) AdditionalSecretOutputs() []string
- func (kc *KindConfig) Aliases() []string
- func (kc *KindConfig) Comment() string
- func (kc *KindConfig) IsNested() bool
- func (kc *KindConfig) Kind() string
- func (kc *KindConfig) OptionalInputProperties() []*Property
- func (kc *KindConfig) Properties() []*Property
- func (kc *KindConfig) PulumiComment() string
- func (kc *KindConfig) RawAPIVersion() string
- func (kc *KindConfig) RequiredInputProperties() []*Property
- func (kc *KindConfig) TypeGuard() string
- func (kc *KindConfig) URNAPIVersion() string
- type Property
- func (p *Property) Comment() string
- func (p *Property) DefaultValue() string
- func (p *Property) DotnetIsListOrMap() bool
- func (p *Property) DotnetVarName() string
- func (p *Property) InputsAPIType() string
- func (p *Property) IsLast() bool
- func (p *Property) LanguageName() string
- func (p *Property) Name() string
- func (p *Property) OutputsAPIType() string
- func (p *Property) ProviderType() string
- func (p *Property) PythonConstructorComment() string
- type VersionConfig
- func (vc *VersionConfig) APIVersion() string
- func (vc *VersionConfig) HasTopLevelKinds() bool
- func (vc *VersionConfig) Kinds() []*KindConfig
- func (vc *VersionConfig) ListTopLevelKindsAndAliases() []*KindConfig
- func (vc *VersionConfig) RawAPIVersion() string
- func (vc *VersionConfig) TopLevelKinds() []*KindConfig
- func (vc *VersionConfig) TopLevelKindsAndAliases() []*KindConfig
- func (vc *VersionConfig) Version() string
- type VersionTS
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
func ApiVersionComment ¶ added in v1.0.1
func ApiVersionComment(gvk schema.GroupVersionKind) string
func DotnetClient ¶ added in v1.3.2
func DotnetClient( swagger map[string]interface{}, templateDir string, ) (inputsts, outputsts string, groups map[string]string, err error)
DotnetClient will generate a Pulumi Kubernetes provider client SDK for .NET.
func NodeJSClient ¶
func NodeJSClient(swagger map[string]interface{}, templateDir string, ) (inputsts, outputsts, indexts, yamlts, packagejson string, groupsts map[string]*GroupTS, err error)
NodeJSClient will generate a Pulumi Kubernetes provider client SDK for nodejs.
func PulumiComment ¶ added in v1.2.0
PulumiComment adds additional information to the docs generated automatically from the OpenAPI specs. This includes information about Pulumi's await behavior, deprecation information, etc.
func PythonClient ¶ added in v0.18.0
func PythonClient( swagger map[string]interface{}, templateDir string, rootInit func(initPy string) error, groupInit func(group, initPy string) error, customResource func(crPy string) error, versionInit func(group, version, initPy string) error, kindFile func(group, version, kind, kindPy string) error, casingFile func(casingPy string) error, yamlFile func(yamlPy string) error, ) error
PythonClient will generate a Pulumi Kubernetes provider client SDK for nodejs.
Types ¶
type GroupConfig ¶
type GroupConfig struct {
// contains filtered or unexported fields
}
GroupConfig represents a Kubernetes API group (e.g., core, apps, extensions, etc.)
func (*GroupConfig) Group ¶
func (gc *GroupConfig) Group() string
Group returns the name of the group (e.g., `core` for core, etc.)
func (*GroupConfig) HasTopLevelKinds ¶ added in v1.4.0
func (gc *GroupConfig) HasTopLevelKinds() bool
HasTopLevelKinds returns true if this group has top-level kinds.
func (*GroupConfig) Versions ¶
func (gc *GroupConfig) Versions() []*VersionConfig
Versions returns the set of version for some Kubernetes API group. For example, the `apps` group has `v1beta1`, `v1beta2`, and `v1`.
type KindConfig ¶
type KindConfig struct {
// contains filtered or unexported fields
}
KindConfig represents a Kubernetes API kind (e.g., the `Deployment` type in `apps/v1beta1/Deployment`).
func (*KindConfig) APIVersion ¶
func (kc *KindConfig) APIVersion() string
APIVersion returns the fully-qualified apiVersion (e.g., `storage.k8s.io/v1` for storage, etc.)
func (*KindConfig) AdditionalSecretOutputs ¶ added in v1.2.0
func (kc *KindConfig) AdditionalSecretOutputs() []string
AdditionalSecretOutputs returns the list of strings to set as additionalSecretOutputs on some Kubernetes API kind.
func (*KindConfig) Aliases ¶ added in v1.2.0
func (kc *KindConfig) Aliases() []string
Aliases returns the list of aliases for a Kubernetes API kind.
func (*KindConfig) Comment ¶
func (kc *KindConfig) Comment() string
Comment returns the comments associated with some Kubernetes API kind.
func (*KindConfig) IsNested ¶ added in v1.4.0
func (kc *KindConfig) IsNested() bool
IsNested returns true if this is a nested kind.
func (*KindConfig) Kind ¶
func (kc *KindConfig) Kind() string
Kind returns the name of the Kubernetes API kind (e.g., `Deployment` for `apps/v1beta1/Deployment`).
func (*KindConfig) OptionalInputProperties ¶ added in v1.0.0
func (kc *KindConfig) OptionalInputProperties() []*Property
OptionalInputProperties returns the list of properties that are optional input properties on some Kubernetes API kind (i.e., things that we will want to provide, like `thing.metadata`, etc.).
func (*KindConfig) Properties ¶
func (kc *KindConfig) Properties() []*Property
Properties returns the list of properties that exist on some Kubernetes API kind (i.e., things that we will want to `.` into, like `thing.apiVersion`, `thing.kind`, `thing.metadata`, etc.).
func (*KindConfig) PulumiComment ¶ added in v1.2.0
func (kc *KindConfig) PulumiComment() string
PulumiComment returns the await logic documentation associated with some Kubernetes API kind.
func (*KindConfig) RawAPIVersion ¶ added in v0.15.0
func (kc *KindConfig) RawAPIVersion() string
RawAPIVersion returns the "raw" apiVersion (e.g., `v1` rather than `core/v1`).
func (*KindConfig) RequiredInputProperties ¶ added in v1.0.0
func (kc *KindConfig) RequiredInputProperties() []*Property
RequiredInputProperties returns the list of properties that are required input properties on some Kubernetes API kind (i.e., things that we will want to provide, like `thing.metadata`, etc.).
func (*KindConfig) TypeGuard ¶ added in v0.15.0
func (kc *KindConfig) TypeGuard() string
TypeGuard returns the text of a TypeScript type guard for the given kind.
func (*KindConfig) URNAPIVersion ¶ added in v0.18.0
func (kc *KindConfig) URNAPIVersion() string
URNAPIVersion returns API version that can be used in a URN (e.g., using the backwards-compatible alias `apiextensions` instead of `apiextensions.k8s.io`).
type Property ¶
type Property struct {
// contains filtered or unexported fields
}
Property represents a property we want to expose on a Kubernetes API kind (i.e., things that we will want to `.` into, like `thing.apiVersion`, `thing.kind`, `thing.metadata`, etc.).
func (*Property) DefaultValue ¶
DefaultValue returns the type of the property.
func (*Property) DotnetIsListOrMap ¶ added in v1.3.2
DotnetIsListOrMap returns whether the property type is a List or map
func (*Property) DotnetVarName ¶ added in v1.3.2
DotnetVarName returns a variable name safe to use in .NET (e.g. `@namespace` instead of `namespace`)
func (*Property) InputsAPIType ¶ added in v1.4.0
InputsAPIType returns the type of the property for the inputs API.
func (*Property) IsLast ¶ added in v1.3.2
IsLast returns whether the property is the last in the list of properties.
func (*Property) LanguageName ¶ added in v0.18.0
LanguageName returns the name of the property.
func (*Property) OutputsAPIType ¶ added in v1.4.0
OutputsAPIType returns the type of the property for the outputs API.
func (*Property) ProviderType ¶ added in v1.4.0
ProviderType returns the type of the property for the provider API.
func (*Property) PythonConstructorComment ¶ added in v1.0.0
PythonConstructorComment returns the comments associated with some property, formatted for Python constructor documentation.
type VersionConfig ¶
type VersionConfig struct {
// contains filtered or unexported fields
}
VersionConfig represents a version of a Kubernetes API group (e.g., the `apps` group has `v1beta1`, `v1beta2`, and `v1`.)
func (*VersionConfig) APIVersion ¶
func (vc *VersionConfig) APIVersion() string
APIVersion returns the fully-qualified apiVersion (e.g., `storage.k8s.io/v1` for storage, etc.)
func (*VersionConfig) HasTopLevelKinds ¶ added in v1.4.0
func (vc *VersionConfig) HasTopLevelKinds() bool
HasTopLevelKinds returns true if this group has top-level kinds.
func (*VersionConfig) Kinds ¶
func (vc *VersionConfig) Kinds() []*KindConfig
Kinds returns the set of kinds in some Kubernetes API group/version combination (e.g., `apps/v1beta1` has the `Deployment` kind, etc.).
func (*VersionConfig) ListTopLevelKindsAndAliases ¶ added in v1.4.0
func (vc *VersionConfig) ListTopLevelKindsAndAliases() []*KindConfig
ListTopLevelKindsAndAliases will return all known `Kind`s that are lists, or aliases of lists. These `Kind`s are not instantiated by the API server, and we must "flatten" them client-side to get an accurate view of what resource operations we need to perform.
func (*VersionConfig) RawAPIVersion ¶ added in v0.15.0
func (vc *VersionConfig) RawAPIVersion() string
RawAPIVersion returns the "raw" apiVersion (e.g., `v1` rather than `core/v1`).
func (*VersionConfig) TopLevelKinds ¶ added in v1.4.0
func (vc *VersionConfig) TopLevelKinds() []*KindConfig
TopLevelKinds returns the set of kinds that are not nested.
func (*VersionConfig) TopLevelKindsAndAliases ¶ added in v1.4.0
func (vc *VersionConfig) TopLevelKindsAndAliases() []*KindConfig
TopLevelKindsAndAliases will produce a list of kinds, including aliases (e.g., both `apiregistration` and `apiregistration.k8s.io`).
func (*VersionConfig) Version ¶
func (vc *VersionConfig) Version() string
Version returns the name of the version (e.g., `apps/v1beta1` would return `v1beta1`).