UNPKG

@pulumi/kubernetes

Version:

[![Actions Status](https://github.com/pulumi/pulumi-kubernetes/workflows/main/badge.svg)](https://github.com/pulumi/pulumi-kubernetes/actions) [![Slack](http://www.pulumi.com/images/docs/badges/slack.svg)](https://slack.pulumi.com) [![NPM version](https:/

128 lines (127 loc) 7.7 kB
import * as pulumi from "@pulumi/pulumi"; import * as inputs from "../../types/input"; import * as outputs from "../../types/output"; /** * Patch resources are used to modify existing Kubernetes resources by using * Server-Side Apply updates. The name of the resource must be specified, but all other properties are optional. More than * one patch may be applied to the same resource, and a random FieldManager name will be used for each Patch resource. * Conflicts will result in an error by default, but can be forced using the "pulumi.com/patchForce" annotation. See the * [Server-Side Apply Docs](https://www.pulumi.com/registry/packages/kubernetes/how-to-guides/managing-resources-with-server-side-apply/) for * additional information about using Server-Side Apply to manage Kubernetes resources with Pulumi. * StorageClass describes the parameters for a class of storage for which PersistentVolumes can be dynamically provisioned. * * StorageClasses are non-namespaced; the name of the storage class according to etcd is in ObjectMeta.Name. */ export declare class StorageClassPatch extends pulumi.CustomResource { /** * Get an existing StorageClassPatch resource's state with the given name, ID, and optional extra * properties used to qualify the lookup. * * @param name The _unique_ name of the resulting resource. * @param id The _unique_ provider ID of the resource to lookup. * @param opts Optional settings to control the behavior of the CustomResource. */ static get(name: string, id: pulumi.Input<pulumi.ID>, opts?: pulumi.CustomResourceOptions): StorageClassPatch; /** * Returns true if the given object is an instance of StorageClassPatch. This is designed to work even * when multiple copies of the Pulumi SDK have been loaded into the same process. */ static isInstance(obj: any): obj is StorageClassPatch; /** * allowVolumeExpansion shows whether the storage class allow volume expand. */ readonly allowVolumeExpansion: pulumi.Output<boolean>; /** * allowedTopologies restrict the node topologies where volumes can be dynamically provisioned. Each volume plugin defines its own supported topology specifications. An empty TopologySelectorTerm list means there is no topology restriction. This field is only honored by servers that enable the VolumeScheduling feature. */ readonly allowedTopologies: pulumi.Output<outputs.core.v1.TopologySelectorTermPatch[]>; /** * APIVersion defines the versioned schema of this representation of an object. Servers should convert recognized schemas to the latest internal value, and may reject unrecognized values. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources */ readonly apiVersion: pulumi.Output<"storage.k8s.io/v1">; /** * Kind is a string value representing the REST resource this object represents. Servers may infer this from the endpoint the client submits requests to. Cannot be updated. In CamelCase. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds */ readonly kind: pulumi.Output<"StorageClass">; /** * Standard object's metadata. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#metadata */ readonly metadata: pulumi.Output<outputs.meta.v1.ObjectMetaPatch>; /** * mountOptions controls the mountOptions for dynamically provisioned PersistentVolumes of this storage class. e.g. ["ro", "soft"]. Not validated - mount of the PVs will simply fail if one is invalid. */ readonly mountOptions: pulumi.Output<string[]>; /** * parameters holds the parameters for the provisioner that should create volumes of this storage class. */ readonly parameters: pulumi.Output<{ [key: string]: string; }>; /** * provisioner indicates the type of the provisioner. */ readonly provisioner: pulumi.Output<string>; /** * reclaimPolicy controls the reclaimPolicy for dynamically provisioned PersistentVolumes of this storage class. Defaults to Delete. */ readonly reclaimPolicy: pulumi.Output<string>; /** * volumeBindingMode indicates how PersistentVolumeClaims should be provisioned and bound. When unset, VolumeBindingImmediate is used. This field is only honored by servers that enable the VolumeScheduling feature. */ readonly volumeBindingMode: pulumi.Output<string>; /** * Create a StorageClassPatch resource with the given unique name, arguments, and options. * * @param name The _unique_ name of the resource. * @param args The arguments to use to populate this resource's properties. * @param opts A bag of options that control this resource's behavior. */ constructor(name: string, args?: StorageClassPatchArgs, opts?: pulumi.CustomResourceOptions); } /** * The set of arguments for constructing a StorageClassPatch resource. */ export interface StorageClassPatchArgs { /** * allowVolumeExpansion shows whether the storage class allow volume expand. */ allowVolumeExpansion?: pulumi.Input<boolean>; /** * allowedTopologies restrict the node topologies where volumes can be dynamically provisioned. Each volume plugin defines its own supported topology specifications. An empty TopologySelectorTerm list means there is no topology restriction. This field is only honored by servers that enable the VolumeScheduling feature. */ allowedTopologies?: pulumi.Input<pulumi.Input<inputs.core.v1.TopologySelectorTermPatch>[]>; /** * APIVersion defines the versioned schema of this representation of an object. Servers should convert recognized schemas to the latest internal value, and may reject unrecognized values. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources */ apiVersion?: pulumi.Input<"storage.k8s.io/v1">; /** * Kind is a string value representing the REST resource this object represents. Servers may infer this from the endpoint the client submits requests to. Cannot be updated. In CamelCase. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds */ kind?: pulumi.Input<"StorageClass">; /** * Standard object's metadata. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#metadata */ metadata?: pulumi.Input<inputs.meta.v1.ObjectMetaPatch>; /** * mountOptions controls the mountOptions for dynamically provisioned PersistentVolumes of this storage class. e.g. ["ro", "soft"]. Not validated - mount of the PVs will simply fail if one is invalid. */ mountOptions?: pulumi.Input<pulumi.Input<string>[]>; /** * parameters holds the parameters for the provisioner that should create volumes of this storage class. */ parameters?: pulumi.Input<{ [key: string]: pulumi.Input<string>; }>; /** * provisioner indicates the type of the provisioner. */ provisioner?: pulumi.Input<string>; /** * reclaimPolicy controls the reclaimPolicy for dynamically provisioned PersistentVolumes of this storage class. Defaults to Delete. */ reclaimPolicy?: pulumi.Input<string>; /** * volumeBindingMode indicates how PersistentVolumeClaims should be provisioned and bound. When unset, VolumeBindingImmediate is used. This field is only honored by servers that enable the VolumeScheduling feature. */ volumeBindingMode?: pulumi.Input<string>; }