com.pulumi.kubernetes.yaml.v2.kotlin.ConfigFile.kt Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of pulumi-kubernetes-kotlin Show documentation
Show all versions of pulumi-kubernetes-kotlin Show documentation
Build cloud applications and infrastructure by combining the safety and reliability of infrastructure as code with the power of the Kotlin programming language.
The newest version!
@file:Suppress("NAME_SHADOWING", "DEPRECATION")
package com.pulumi.kubernetes.yaml.v2.kotlin
import com.pulumi.core.Output
import com.pulumi.kotlin.KotlinComponentResource
import com.pulumi.kotlin.PulumiTagMarker
import com.pulumi.kotlin.ResourceMapper
import com.pulumi.kotlin.options.ComponentResourceOptions
import com.pulumi.kotlin.options.ComponentResourceOptionsBuilder
import com.pulumi.resources.Resource
import kotlin.Any
import kotlin.Boolean
import kotlin.String
import kotlin.Suppress
import kotlin.Unit
import kotlin.collections.List
/**
* Builder for [ConfigFile].
*/
@PulumiTagMarker
public class ConfigFileResourceBuilder internal constructor() {
public var name: String? = null
public var args: ConfigFileArgs = ConfigFileArgs()
public var opts: ComponentResourceOptions = ComponentResourceOptions()
/**
* @param name The _unique_ name of the resulting resource.
*/
public fun name(`value`: String) {
this.name = value
}
/**
* @param block The arguments to use to populate this resource's properties.
*/
public suspend fun args(block: suspend ConfigFileArgsBuilder.() -> Unit) {
val builder = ConfigFileArgsBuilder()
block(builder)
this.args = builder.build()
}
/**
* @param block A bag of options that control this resource's behavior.
*/
public suspend fun opts(block: suspend ComponentResourceOptionsBuilder.() -> Unit) {
this.opts = com.pulumi.kotlin.options.ComponentResourceOptions.opts(block)
}
internal fun build(): ConfigFile {
val builtJavaResource = com.pulumi.kubernetes.yaml.v2.ConfigFile(
this.name,
this.args.toJava(),
this.opts.toJava(),
)
return ConfigFile(builtJavaResource)
}
}
/**
* ConfigFile creates a set of Kubernetes resources from a remote or on-disk Kubernetes YAML file.
* (If you have in-memory YAML a ConfigGroup may be more appropriate.)
* ## Dependency ordering
* Sometimes resources must be applied in a specific order. For example, a namespace resource must be
* created before any namespaced resources, or a Custom Resource Definition (CRD) must be pre-installed.
* Pulumi uses heuristics to determine which order to apply and delete objects within the ConfigFile. Pulumi also
* waits for each object to be fully reconciled, unless `skipAwait` is enabled.
* ### Explicit Dependency Ordering
* Pulumi supports the `config.kubernetes.io/depends-on` annotation to declare an explicit dependency on a given resource.
* The annotation accepts a list of resource references, delimited by commas.
* Note that references to resources outside the ConfigFile aren't supported.
* **Resource reference**
* A resource reference is a string that uniquely identifies a resource.
* It consists of the group, kind, name, and optionally the namespace, delimited by forward slashes.
* | Resource Scope | Format |
* | :--------------- | :--------------------------------------------- |
* | namespace-scoped | `/namespaces///` |
* | cluster-scoped | `//` |
* For resources in the “core” group, the empty string is used instead (for example: `/namespaces/test/Pod/pod-a`).
* ### Ordering across ConfigFiles
* The `dependsOn` resource option creates a list of explicit dependencies between Pulumi resources.
* Use it on another resource to make it dependent on the ConfigFile and to wait for the resources within
* the group to be deployed.
* A best practice is to deploy each application using its own ConfigFile, especially when that application
* installs custom resource definitions.
* {{% examples %}}
* ## Example Usage
* {{% example %}}
* ### Local File
* ```yaml
* name: example
* runtime: yaml
* resources:
* example:
* type: kubernetes:yaml/v2:ConfigFile
* properties:
* file: ./manifest.yaml
* ```
* ```typescript
* import * as pulumi from "@pulumi/pulumi";
* import * as k8s from "@pulumi/kubernetes";
* const example = new k8s.yaml.v2.ConfigFile("example", {
* files: ["./manifest.yaml"],
* });
* ```
* ```python
* import pulumi
* from pulumi_kubernetes.yaml.v2 import ConfigFile
* example = ConfigFile(
* "example",
* file="./manifest.yaml"
* )
* ```
* ```csharp
* using Pulumi;
* using Pulumi.Kubernetes.Types.Inputs.Yaml.V2;
* using Pulumi.Kubernetes.Yaml.V2;
* using System.Collections.Generic;
* return await Deployment.RunAsync(() =>
* {
* var example = new ConfigFile("example", new ConfigFileArgs
* {
* File = "./manifest.yaml"
* });
* });
* ```
* ```go
* package main
* import (
* yamlv2 "github.com/pulumi/pulumi-kubernetes/sdk/v4/go/kubernetes/yaml/v2"
* "github.com/pulumi/pulumi/sdk/v3/go/pulumi"
* )
* func main() {
* pulumi.Run(func(ctx *pulumi.Context) error {
* _, err := yamlv2.NewConfigFile(ctx, "example", &yamlv2.ConfigFileArgs{
* File: pulumi.String("manifest.yaml"),
* })
* if err != nil {
* return err
* }
* return nil
* })
* }
* ```
* ```java
* package myproject;
* import com.pulumi.Pulumi;
* import com.pulumi.kubernetes.yaml.v2.ConfigFile;
* import com.pulumi.kubernetes.yaml.v2.ConfigFileArgs;
* public class App {
* public static void main(String[] args) {
* Pulumi.run(ctx -> {
* var example = new ConfigFile("example", ConfigFileArgs.builder()
* .file("./manifest.yaml")
* .build());
* });
* }
* }
* ```
* {{% /example %}}
* {% /examples %}}
*/
public class ConfigFile internal constructor(
override val javaResource: com.pulumi.kubernetes.yaml.v2.ConfigFile,
) : KotlinComponentResource(javaResource, ConfigFileMapper) {
/**
* Resources created by the ConfigFile.
*/
public val resources: Output>?
get() = javaResource.resources().applyValue({ args0 ->
args0.map({ args0 ->
args0.map({ args0 ->
args0
})
}).orElse(null)
})
}
public object ConfigFileMapper : ResourceMapper {
override fun supportsMappingOfType(javaResource: Resource): Boolean =
com.pulumi.kubernetes.yaml.v2.ConfigFile::class == javaResource::class
override fun map(javaResource: Resource): ConfigFile = ConfigFile(
javaResource as
com.pulumi.kubernetes.yaml.v2.ConfigFile,
)
}
/**
* @see [ConfigFile].
* @param name The _unique_ name of the resulting resource.
* @param block Builder for [ConfigFile].
*/
public suspend fun configFile(name: String, block: suspend ConfigFileResourceBuilder.() -> Unit): ConfigFile {
val builder = ConfigFileResourceBuilder()
builder.name(name)
block(builder)
return builder.build()
}
/**
* @see [ConfigFile].
* @param name The _unique_ name of the resulting resource.
*/
public fun configFile(name: String): ConfigFile {
val builder = ConfigFileResourceBuilder()
builder.name(name)
return builder.build()
}
© 2015 - 2024 Weber Informatics LLC | Privacy Policy