cdk8s-plus-32 2.4.13 → 2.5.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -4248,6 +4248,18 @@ new StatefulSet(scope: Construct, id: string, props: StatefulSetProps)
4248
4248
 
4249
4249
  #### Methods <a name="Methods"></a>
4250
4250
 
4251
+ ##### `addVolumeClaimTemplate` <a name="cdk8s-plus-32.StatefulSet.addVolumeClaimTemplate"></a>
4252
+
4253
+ ```typescript
4254
+ public addVolumeClaimTemplate(template: PersistentVolumeClaimTemplateProps)
4255
+ ```
4256
+
4257
+ ###### `template`<sup>Required</sup> <a name="cdk8s-plus-32.StatefulSet.parameter.template"></a>
4258
+
4259
+ - *Type:* [`cdk8s-plus-32.PersistentVolumeClaimTemplateProps`](#cdk8s-plus-32.PersistentVolumeClaimTemplateProps)
4260
+
4261
+ ---
4262
+
4251
4263
  ##### `markHasAutoscaler` <a name="cdk8s-plus-32.StatefulSet.markHasAutoscaler"></a>
4252
4264
 
4253
4265
  ```typescript
@@ -4345,6 +4357,16 @@ If this is a target of an autoscaler.
4345
4357
 
4346
4358
  ---
4347
4359
 
4360
+ ##### `volumeClaimTemplates`<sup>Optional</sup> <a name="cdk8s-plus-32.StatefulSet.property.volumeClaimTemplates"></a>
4361
+
4362
+ ```typescript
4363
+ public readonly volumeClaimTemplates: PersistentVolumeClaimTemplateProps[];
4364
+ ```
4365
+
4366
+ - *Type:* [`cdk8s-plus-32.PersistentVolumeClaimTemplateProps`](#cdk8s-plus-32.PersistentVolumeClaimTemplateProps)[]
4367
+
4368
+ ---
4369
+
4348
4370
 
4349
4371
  ### TlsSecret <a name="cdk8s-plus-32.TlsSecret"></a>
4350
4372
 
@@ -4742,6 +4764,32 @@ Volume.fromHostPath(scope: Construct, id: string, name: string, options: HostPat
4742
4764
 
4743
4765
  ---
4744
4766
 
4767
+ ##### `fromName` <a name="cdk8s-plus-32.Volume.fromName"></a>
4768
+
4769
+ ```typescript
4770
+ import { Volume } from 'cdk8s-plus-32'
4771
+
4772
+ Volume.fromName(scope: Construct, id: string, name: string)
4773
+ ```
4774
+
4775
+ ###### `scope`<sup>Required</sup> <a name="cdk8s-plus-32.Volume.parameter.scope"></a>
4776
+
4777
+ - *Type:* [`constructs.Construct`](#constructs.Construct)
4778
+
4779
+ ---
4780
+
4781
+ ###### `id`<sup>Required</sup> <a name="cdk8s-plus-32.Volume.parameter.id"></a>
4782
+
4783
+ - *Type:* `string`
4784
+
4785
+ ---
4786
+
4787
+ ###### `name`<sup>Required</sup> <a name="cdk8s-plus-32.Volume.parameter.name"></a>
4788
+
4789
+ - *Type:* `string`
4790
+
4791
+ ---
4792
+
4745
4793
  ##### `fromNfs` <a name="cdk8s-plus-32.Volume.fromNfs"></a>
4746
4794
 
4747
4795
  ```typescript
@@ -11569,6 +11617,132 @@ Defines what type of volume is required by the claim.
11569
11617
 
11570
11618
  ---
11571
11619
 
11620
+ ### PersistentVolumeClaimTemplateProps <a name="cdk8s-plus-32.PersistentVolumeClaimTemplateProps"></a>
11621
+
11622
+ A PersistentVolumeClaim template for StatefulSets.
11623
+
11624
+ #### Initializer <a name="[object Object].Initializer"></a>
11625
+
11626
+ ```typescript
11627
+ import { PersistentVolumeClaimTemplateProps } from 'cdk8s-plus-32'
11628
+
11629
+ const persistentVolumeClaimTemplateProps: PersistentVolumeClaimTemplateProps = { ... }
11630
+ ```
11631
+
11632
+ ##### `metadata`<sup>Optional</sup> <a name="cdk8s-plus-32.PersistentVolumeClaimTemplateProps.property.metadata"></a>
11633
+
11634
+ ```typescript
11635
+ public readonly metadata: ApiObjectMetadata;
11636
+ ```
11637
+
11638
+ - *Type:* [`cdk8s.ApiObjectMetadata`](#cdk8s.ApiObjectMetadata)
11639
+
11640
+ Metadata that all persisted resources must have, which includes all objects users must create.
11641
+
11642
+ ---
11643
+
11644
+ ##### `accessModes`<sup>Optional</sup> <a name="cdk8s-plus-32.PersistentVolumeClaimTemplateProps.property.accessModes"></a>
11645
+
11646
+ ```typescript
11647
+ public readonly accessModes: PersistentVolumeAccessMode[];
11648
+ ```
11649
+
11650
+ - *Type:* [`cdk8s-plus-32.PersistentVolumeAccessMode`](#cdk8s-plus-32.PersistentVolumeAccessMode)[]
11651
+ - *Default:* No access modes requirement.
11652
+
11653
+ Contains the access modes the volume should support.
11654
+
11655
+ > https://kubernetes.io/docs/concepts/storage/persistent-volumes#access-modes-1
11656
+
11657
+ ---
11658
+
11659
+ ##### `storage`<sup>Optional</sup> <a name="cdk8s-plus-32.PersistentVolumeClaimTemplateProps.property.storage"></a>
11660
+
11661
+ ```typescript
11662
+ public readonly storage: Size;
11663
+ ```
11664
+
11665
+ - *Type:* [`cdk8s.Size`](#cdk8s.Size)
11666
+ - *Default:* No storage requirement.
11667
+
11668
+ Minimum storage size the volume should have.
11669
+
11670
+ > https://kubernetes.io/docs/concepts/storage/persistent-volumes#resources
11671
+
11672
+ ---
11673
+
11674
+ ##### `storageClassName`<sup>Optional</sup> <a name="cdk8s-plus-32.PersistentVolumeClaimTemplateProps.property.storageClassName"></a>
11675
+
11676
+ ```typescript
11677
+ public readonly storageClassName: string;
11678
+ ```
11679
+
11680
+ - *Type:* `string`
11681
+ - *Default:* Not set.
11682
+
11683
+ Name of the StorageClass required by the claim. When this property is not set, the behavior is as follows:.
11684
+
11685
+ If the admission plugin is turned on, the storage class marked as default will be used.
11686
+ - If the admission plugin is turned off, the pvc can only be bound to volumes without a storage class.
11687
+
11688
+ > https://kubernetes.io/docs/concepts/storage/persistent-volumes#class-1
11689
+
11690
+ ---
11691
+
11692
+ ##### `volume`<sup>Optional</sup> <a name="cdk8s-plus-32.PersistentVolumeClaimTemplateProps.property.volume"></a>
11693
+
11694
+ ```typescript
11695
+ public readonly volume: IPersistentVolume;
11696
+ ```
11697
+
11698
+ - *Type:* [`cdk8s-plus-32.IPersistentVolume`](#cdk8s-plus-32.IPersistentVolume)
11699
+ - *Default:* No specific volume binding.
11700
+
11701
+ The PersistentVolume backing this claim.
11702
+
11703
+ The control plane still checks that storage class, access modes,
11704
+ and requested storage size on the volume are valid.
11705
+
11706
+ Note that in order to guarantee a proper binding, the volume should
11707
+ also define a `claimRef` referring to this claim. Otherwise, the volume may be
11708
+ claimed be other pvc's before it gets a chance to bind to this one.
11709
+
11710
+ If the volume is managed (i.e not imported), you can use `pv.claim()` to easily
11711
+ create a bi-directional bounded claim.
11712
+
11713
+ > https://kubernetes.io/docs/concepts/storage/persistent-volumes/#binding.
11714
+
11715
+ ---
11716
+
11717
+ ##### `volumeMode`<sup>Optional</sup> <a name="cdk8s-plus-32.PersistentVolumeClaimTemplateProps.property.volumeMode"></a>
11718
+
11719
+ ```typescript
11720
+ public readonly volumeMode: PersistentVolumeMode;
11721
+ ```
11722
+
11723
+ - *Type:* [`cdk8s-plus-32.PersistentVolumeMode`](#cdk8s-plus-32.PersistentVolumeMode)
11724
+ - *Default:* VolumeMode.FILE_SYSTEM
11725
+
11726
+ Defines what type of volume is required by the claim.
11727
+
11728
+ ---
11729
+
11730
+ ##### `name`<sup>Required</sup> <a name="cdk8s-plus-32.PersistentVolumeClaimTemplateProps.property.name"></a>
11731
+
11732
+ ```typescript
11733
+ public readonly name: string;
11734
+ ```
11735
+
11736
+ - *Type:* `string`
11737
+
11738
+ The name of the claim that the StatefulSet controller will create for each pod.
11739
+
11740
+ This will be used to name the created PVC in the format <claim-name>-<pod-name>
11741
+
11742
+ This name should match the name of a volume mount in one of the containers.
11743
+
11744
+ ---
11745
+
11572
11746
  ### PersistentVolumeClaimVolumeOptions <a name="cdk8s-plus-32.PersistentVolumeClaimVolumeOptions"></a>
11573
11747
 
11574
11748
  Options for a PersistentVolumeClaim-based volume.
@@ -14022,6 +14196,24 @@ Indicates the StatefulSetUpdateStrategy that will be employed to update Pods in
14022
14196
 
14023
14197
  ---
14024
14198
 
14199
+ ##### `volumeClaimTemplates`<sup>Optional</sup> <a name="cdk8s-plus-32.StatefulSetProps.property.volumeClaimTemplates"></a>
14200
+
14201
+ ```typescript
14202
+ public readonly volumeClaimTemplates: PersistentVolumeClaimTemplateProps[];
14203
+ ```
14204
+
14205
+ - *Type:* [`cdk8s-plus-32.PersistentVolumeClaimTemplateProps`](#cdk8s-plus-32.PersistentVolumeClaimTemplateProps)[]
14206
+ - *Default:* No volume claim templates will be created.
14207
+
14208
+ A list of PersistentVolumeClaim templates that will be created for each pod in the StatefulSet.
14209
+
14210
+ The StatefulSet controller creates a PVC and a PV for each template based on the pod's ordinal index,
14211
+ ensuring stable storage across pod restarts and rescheduling.
14212
+
14213
+ Each claim in this list must have at least one matching (by name) volumeMount in one of the containers.
14214
+
14215
+ ---
14216
+
14025
14217
  ### StatefulSetUpdateStrategyRollingUpdateOptions <a name="cdk8s-plus-32.StatefulSetUpdateStrategyRollingUpdateOptions"></a>
14026
14218
 
14027
14219
  Options for `StatefulSetUpdateStrategy.rollingUpdate`.
@@ -27,7 +27,7 @@ class ApiResource {
27
27
  }
28
28
  exports.ApiResource = ApiResource;
29
29
  _a = JSII_RTTI_SYMBOL_1;
30
- ApiResource[_a] = { fqn: "cdk8s-plus-32.ApiResource", version: "2.4.13" };
30
+ ApiResource[_a] = { fqn: "cdk8s-plus-32.ApiResource", version: "2.5.0" };
31
31
  /**
32
32
  * API resource information for Binding.
33
33
  */
@@ -426,5 +426,5 @@ class NonApiResource {
426
426
  }
427
427
  exports.NonApiResource = NonApiResource;
428
428
  _b = JSII_RTTI_SYMBOL_1;
429
- NonApiResource[_b] = { fqn: "cdk8s-plus-32.NonApiResource", version: "2.4.13" };
429
+ NonApiResource[_b] = { fqn: "cdk8s-plus-32.NonApiResource", version: "2.5.0" };
430
430
  //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"api-resource.js","sourceRoot":"","sources":["../src/api-resource.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * Represents a resource or collection of resources.\n */\nexport interface IApiResource {\n  /**\n   * The group portion of the API version (e.g. `authorization.k8s.io`).\n   */\n  readonly apiGroup: string;\n\n  /**\n   * The name of a resource type as it appears in the relevant API endpoint.\n   * @example - \"pods\" or \"pods/log\"\n   * @see https://kubernetes.io/docs/reference/access-authn-authz/rbac/#referring-to-resources\n   */\n  readonly resourceType: string;\n\n  /**\n   * The unique, namespace-global, name of an object inside the Kubernetes cluster.\n   *\n   * If this is omitted, the ApiResource should represent all objects of the given type.\n   */\n  readonly resourceName?: string;\n}\n/**\n * An API Endpoint can either be a resource descriptor (e.g /pods)\n * or a non resource url (e.g /healthz). It must be one or the other, and not both.\n */\nexport interface IApiEndpoint {\n\n  /**\n   * Return the IApiResource this object represents.\n   */\n  asApiResource(): IApiResource | undefined;\n\n  /**\n   * Return the non resource url this object represents.\n   */\n  asNonApiResource(): string | undefined;\n\n}\n\n/**\n * Options for `ApiResource`.\n */\nexport interface ApiResourceOptions {\n  /**\n   * The group portion of the API version (e.g. `authorization.k8s.io`).\n   */\n  readonly apiGroup: string;\n\n  /**\n   * The name of the resource type as it appears in the relevant API endpoint.\n   * @example - \"pods\" or \"pods/log\"\n   * @see https://kubernetes.io/docs/reference/access-authn-authz/rbac/#referring-to-resources\n   */\n  readonly resourceType: string;\n}\n\n/**\n * Represents information about an API resource type.\n */\nexport class ApiResource implements IApiResource, IApiEndpoint {\n  /**\n   * API resource information for Binding.\n   */\n  public static readonly BINDINGS = new ApiResource({\n    apiGroup: '',\n    resourceType: 'bindings',\n  });\n\n  /**\n   * API resource information for ComponentStatus.\n   */\n  public static readonly COMPONENT_STATUSES = new ApiResource({\n    apiGroup: '',\n    resourceType: 'componentstatuses',\n  });\n\n  /**\n   * API resource information for ConfigMap.\n   */\n  public static readonly CONFIG_MAPS = new ApiResource({\n    apiGroup: '',\n    resourceType: 'configmaps',\n  });\n\n  /**\n   * API resource information for Endpoints.\n   */\n  public static readonly ENDPOINTS = new ApiResource({\n    apiGroup: '',\n    resourceType: 'endpoints',\n  });\n\n  /**\n   * API resource information for Event.\n   */\n  public static readonly EVENTS = new ApiResource({\n    apiGroup: '',\n    resourceType: 'events',\n  });\n\n  /**\n   * API resource information for LimitRange.\n   */\n  public static readonly LIMIT_RANGES = new ApiResource({\n    apiGroup: '',\n    resourceType: 'limitranges',\n  });\n\n  /**\n   * API resource information for Namespace.\n   */\n  public static readonly NAMESPACES = new ApiResource({\n    apiGroup: '',\n    resourceType: 'namespaces',\n  });\n\n  /**\n   * API resource information for Node.\n   */\n  public static readonly NODES = new ApiResource({\n    apiGroup: '',\n    resourceType: 'nodes',\n  });\n\n  /**\n   * API resource information for PersistentVolumeClaim.\n   */\n  public static readonly PERSISTENT_VOLUME_CLAIMS = new ApiResource({\n    apiGroup: '',\n    resourceType: 'persistentvolumeclaims',\n  });\n\n  /**\n   * API resource information for PersistentVolume.\n   */\n  public static readonly PERSISTENT_VOLUMES = new ApiResource({\n    apiGroup: '',\n    resourceType: 'persistentvolumes',\n  });\n\n  /**\n   * API resource information for Pod.\n   */\n  public static readonly PODS = new ApiResource({\n    apiGroup: '',\n    resourceType: 'pods',\n  });\n\n  /**\n   * API resource information for PodTemplate.\n   */\n  public static readonly POD_TEMPLATES = new ApiResource({\n    apiGroup: '',\n    resourceType: 'podtemplates',\n  });\n\n  /**\n   * API resource information for ReplicationController.\n   */\n  public static readonly REPLICATION_CONTROLLERS = new ApiResource({\n    apiGroup: '',\n    resourceType: 'replicationcontrollers',\n  });\n\n  /**\n   * API resource information for ResourceQuota.\n   */\n  public static readonly RESOURCE_QUOTAS = new ApiResource({\n    apiGroup: '',\n    resourceType: 'resourcequotas',\n  });\n\n  /**\n   * API resource information for Secret.\n   */\n  public static readonly SECRETS = new ApiResource({\n    apiGroup: '',\n    resourceType: 'secrets',\n  });\n\n  /**\n   * API resource information for ServiceAccount.\n   */\n  public static readonly SERVICE_ACCOUNTS = new ApiResource({\n    apiGroup: '',\n    resourceType: 'serviceaccounts',\n  });\n\n  /**\n   * API resource information for Service.\n   */\n  public static readonly SERVICES = new ApiResource({\n    apiGroup: '',\n    resourceType: 'services',\n  });\n\n  /**\n   * API resource information for MutatingWebhookConfiguration.\n   */\n  public static readonly MUTATING_WEBHOOK_CONFIGURATIONS = new ApiResource({\n    apiGroup: 'admissionregistration.k8s.io',\n    resourceType: 'mutatingwebhookconfigurations',\n  });\n\n  /**\n   * API resource information for ValidatingWebhookConfiguration.\n   */\n  public static readonly VALIDATING_WEBHOOK_CONFIGURATIONS = new ApiResource({\n    apiGroup: 'admissionregistration.k8s.io',\n    resourceType: 'validatingwebhookconfigurations',\n  });\n\n  /**\n   * API resource information for CustomResourceDefinition.\n   */\n  public static readonly CUSTOM_RESOURCE_DEFINITIONS = new ApiResource({\n    apiGroup: 'apiextensions.k8s.io',\n    resourceType: 'customresourcedefinitions',\n  });\n\n  /**\n   * API resource information for APIService.\n   */\n  public static readonly API_SERVICES = new ApiResource({\n    apiGroup: 'apiregistration.k8s.io',\n    resourceType: 'apiservices',\n  });\n\n  /**\n   * API resource information for ControllerRevision.\n   */\n  public static readonly CONTROLLER_REVISIONS = new ApiResource({\n    apiGroup: 'apps',\n    resourceType: 'controllerrevisions',\n  });\n\n  /**\n   * API resource information for DaemonSet.\n   */\n  public static readonly DAEMON_SETS = new ApiResource({\n    apiGroup: 'apps',\n    resourceType: 'daemonsets',\n  });\n\n  /**\n   * API resource information for Deployment.\n   */\n  public static readonly DEPLOYMENTS = new ApiResource({\n    apiGroup: 'apps',\n    resourceType: 'deployments',\n  });\n\n  /**\n   * API resource information for ReplicaSet.\n   */\n  public static readonly REPLICA_SETS = new ApiResource({\n    apiGroup: 'apps',\n    resourceType: 'replicasets',\n  });\n\n  /**\n   * API resource information for StatefulSet.\n   */\n  public static readonly STATEFUL_SETS = new ApiResource({\n    apiGroup: 'apps',\n    resourceType: 'statefulsets',\n  });\n\n  /**\n   * API resource information for TokenReview.\n   */\n  public static readonly TOKEN_REVIEWS = new ApiResource({\n    apiGroup: 'authentication.k8s.io',\n    resourceType: 'tokenreviews',\n  });\n\n  /**\n   * API resource information for LocalSubjectAccessReview.\n   */\n  public static readonly LOCAL_SUBJECT_ACCESS_REVIEWS = new ApiResource({\n    apiGroup: 'authorization.k8s.io',\n    resourceType: 'localsubjectaccessreviews',\n  });\n\n  /**\n   * API resource information for SelfSubjectAccessReview.\n   */\n  public static readonly SELF_SUBJECT_ACCESS_REVIEWS = new ApiResource({\n    apiGroup: 'authorization.k8s.io',\n    resourceType: 'selfsubjectaccessreviews',\n  });\n\n  /**\n   * API resource information for SelfSubjectRulesReview.\n   */\n  public static readonly SELF_SUBJECT_RULES_REVIEWS = new ApiResource({\n    apiGroup: 'authorization.k8s.io',\n    resourceType: 'selfsubjectrulesreviews',\n  });\n\n  /**\n   * API resource information for SubjectAccessReview.\n   */\n  public static readonly SUBJECT_ACCESS_REVIEWS = new ApiResource({\n    apiGroup: 'authorization.k8s.io',\n    resourceType: 'subjectaccessreviews',\n  });\n\n  /**\n   * API resource information for HorizontalPodAutoscaler.\n   */\n  public static readonly HORIZONTAL_POD_AUTOSCALERS = new ApiResource({\n    apiGroup: 'autoscaling',\n    resourceType: 'horizontalpodautoscalers',\n  });\n\n  /**\n   * API resource information for CronJob.\n   */\n  public static readonly CRON_JOBS = new ApiResource({\n    apiGroup: 'batch',\n    resourceType: 'cronjobs',\n  });\n\n  /**\n   * API resource information for Job.\n   */\n  public static readonly JOBS = new ApiResource({\n    apiGroup: 'batch',\n    resourceType: 'jobs',\n  });\n\n  /**\n   * API resource information for CertificateSigningRequest.\n   */\n  public static readonly CERTIFICATE_SIGNING_REQUESTS = new ApiResource({\n    apiGroup: 'certificates.k8s.io',\n    resourceType: 'certificatesigningrequests',\n  });\n\n  /**\n   * API resource information for Lease.\n   */\n  public static readonly LEASES = new ApiResource({\n    apiGroup: 'coordination.k8s.io',\n    resourceType: 'leases',\n  });\n\n  /**\n   * API resource information for EndpointSlice.\n   */\n  public static readonly ENDPOINT_SLICES = new ApiResource({\n    apiGroup: 'discovery.k8s.io',\n    resourceType: 'endpointslices',\n  });\n\n  /**\n   * API resource information for FlowSchema.\n   */\n  public static readonly FLOW_SCHEMAS = new ApiResource({\n    apiGroup: 'flowcontrol.apiserver.k8s.io',\n    resourceType: 'flowschemas',\n  });\n\n  /**\n   * API resource information for PriorityLevelConfiguration.\n   */\n  public static readonly PRIORITY_LEVEL_CONFIGURATIONS = new ApiResource({\n    apiGroup: 'flowcontrol.apiserver.k8s.io',\n    resourceType: 'prioritylevelconfigurations',\n  });\n\n  /**\n   * API resource information for IngressClass.\n   */\n  public static readonly INGRESS_CLASSES = new ApiResource({\n    apiGroup: 'networking.k8s.io',\n    resourceType: 'ingressclasses',\n  });\n\n  /**\n   * API resource information for Ingress.\n   */\n  public static readonly INGRESSES = new ApiResource({\n    apiGroup: 'networking.k8s.io',\n    resourceType: 'ingresses',\n  });\n\n  /**\n   * API resource information for NetworkPolicy.\n   */\n  public static readonly NETWORK_POLICIES = new ApiResource({\n    apiGroup: 'networking.k8s.io',\n    resourceType: 'networkpolicies',\n  });\n\n  /**\n   * API resource information for RuntimeClass.\n   */\n  public static readonly RUNTIME_CLASSES = new ApiResource({\n    apiGroup: 'node.k8s.io',\n    resourceType: 'runtimeclasses',\n  });\n\n  /**\n   * API resource information for PodDisruptionBudget.\n   */\n  public static readonly POD_DISRUPTION_BUDGETS = new ApiResource({\n    apiGroup: 'policy',\n    resourceType: 'poddisruptionbudgets',\n  });\n\n  /**\n   * API resource information for ClusterRoleBinding.\n   */\n  public static readonly CLUSTER_ROLE_BINDINGS = new ApiResource({\n    apiGroup: 'rbac.authorization.k8s.io',\n    resourceType: 'clusterrolebindings',\n  });\n\n  /**\n   * API resource information for ClusterRole.\n   */\n  public static readonly CLUSTER_ROLES = new ApiResource({\n    apiGroup: 'rbac.authorization.k8s.io',\n    resourceType: 'clusterroles',\n  });\n\n  /**\n   * API resource information for RoleBinding.\n   */\n  public static readonly ROLE_BINDINGS = new ApiResource({\n    apiGroup: 'rbac.authorization.k8s.io',\n    resourceType: 'rolebindings',\n  });\n\n  /**\n   * API resource information for Role.\n   */\n  public static readonly ROLES = new ApiResource({\n    apiGroup: 'rbac.authorization.k8s.io',\n    resourceType: 'roles',\n  });\n\n  /**\n   * API resource information for PriorityClass.\n   */\n  public static readonly PRIORITY_CLASSES = new ApiResource({\n    apiGroup: 'scheduling.k8s.io',\n    resourceType: 'priorityclasses',\n  });\n\n  /**\n   * API resource information for CSIDriver.\n   */\n  public static readonly CSI_DRIVERS = new ApiResource({\n    apiGroup: 'storage.k8s.io',\n    resourceType: 'csidrivers',\n  });\n\n  /**\n   * API resource information for CSINode.\n   */\n  public static readonly CSI_NODES = new ApiResource({\n    apiGroup: 'storage.k8s.io',\n    resourceType: 'csinodes',\n  });\n\n  /**\n   * API resource information for CSIStorageCapacity.\n   */\n  public static readonly CSI_STORAGE_CAPACITIES = new ApiResource({\n    apiGroup: 'storage.k8s.io',\n    resourceType: 'csistoragecapacities',\n  });\n\n  /**\n   * API resource information for StorageClass.\n   */\n  public static readonly STORAGE_CLASSES = new ApiResource({\n    apiGroup: 'storage.k8s.io',\n    resourceType: 'storageclasses',\n  });\n\n  /**\n   * API resource information for VolumeAttachment.\n   */\n  public static readonly VOLUME_ATTACHMENTS = new ApiResource({\n    apiGroup: 'storage.k8s.io',\n    resourceType: 'volumeattachments',\n  });\n\n  /**\n   * API resource information for a custom resource type.\n   */\n  public static custom(options: ApiResourceOptions): ApiResource {\n    return new ApiResource(options);\n  };\n\n  /**\n   * The group portion of the API version (e.g. `authorization.k8s.io`).\n   */\n  public readonly apiGroup: string;\n\n  /**\n   * The name of the resource type as it appears in the relevant API endpoint.\n   * @example - \"pods\" or \"pods/log\"\n   * @see https://kubernetes.io/docs/reference/access-authn-authz/rbac/#referring-to-resources\n   */\n  public readonly resourceType: string;\n\n  private constructor(options: ApiResourceOptions) {\n    this.apiGroup = options.apiGroup;\n    this.resourceType = options.resourceType;\n  }\n\n  public asApiResource(): IApiResource | undefined {\n    return this;\n  }\n\n  public asNonApiResource(): string | undefined {\n    return undefined;\n  }\n}\n\n/**\n * Factory for creating non api resources.\n */\nexport class NonApiResource implements IApiEndpoint {\n\n  public static of(url: string): NonApiResource {\n    return new NonApiResource(url);\n  }\n\n  private constructor(private readonly nonResourceUrl: string) {};\n\n  public asApiResource(): IApiResource | undefined {\n    return undefined;\n  }\n\n  public asNonApiResource(): string | undefined {\n\n    return this.nonResourceUrl;\n  }\n}"]}
package/lib/base.js CHANGED
@@ -52,7 +52,7 @@ class Resource extends constructs_1.Construct {
52
52
  }
53
53
  exports.Resource = Resource;
54
54
  _a = JSII_RTTI_SYMBOL_1;
55
- Resource[_a] = { fqn: "cdk8s-plus-32.Resource", version: "2.4.13" };
55
+ Resource[_a] = { fqn: "cdk8s-plus-32.Resource", version: "2.5.0" };
56
56
  /**
57
57
  * Controls permissions for operations on resources.
58
58
  */
@@ -85,7 +85,7 @@ class ResourcePermissions {
85
85
  }
86
86
  exports.ResourcePermissions = ResourcePermissions;
87
87
  _b = JSII_RTTI_SYMBOL_1;
88
- ResourcePermissions[_b] = { fqn: "cdk8s-plus-32.ResourcePermissions", version: "2.4.13" };
88
+ ResourcePermissions[_b] = { fqn: "cdk8s-plus-32.ResourcePermissions", version: "2.5.0" };
89
89
  // meh, avoiding errors due to circular imports...
90
90
  const r = require("./role");
91
91
  const utils_1 = require("./utils");
package/lib/config-map.js CHANGED
@@ -155,5 +155,5 @@ class ConfigMap extends base.Resource {
155
155
  }
156
156
  exports.ConfigMap = ConfigMap;
157
157
  _a = JSII_RTTI_SYMBOL_1;
158
- ConfigMap[_a] = { fqn: "cdk8s-plus-32.ConfigMap", version: "2.4.13" };
158
+ ConfigMap[_a] = { fqn: "cdk8s-plus-32.ConfigMap", version: "2.5.0" };
159
159
  //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"config-map.js","sourceRoot":"","sources":["../src/config-map.ts"],"names":[],"mappings":";;;;;AAAA,gCAAgC;AAChC,6BAA6B;AAC7B,iCAAwC;AACxC,2CAAuC;AACvC,yCAAsC;AACtC,+BAA+B;AAC/B,qCAAqC;AACrC,mCAA2C;AA+C3C,MAAM,iBAAkB,SAAQ,sBAAS;IAMvC,YAAY,KAAgB,EAAE,EAAU,EAAE,IAAY;QACpD,KAAK,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC;QAHH,iBAAY,GAAG,YAAY,CAAC;QAI1C,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC;IACpB,CAAC;IAED,IAAW,IAAI;QACb,OAAO,IAAI,CAAC,KAAK,CAAC;IACpB,CAAC;IAED,IAAW,UAAU;QACnB,OAAO,GAAG,CAAC,aAAa,CAAC,GAAG,CAAC,UAAU,CAAC;IAC1C,CAAC;IAED,IAAW,QAAQ;QACjB,OAAO,EAAE,CAAC;IACZ,CAAC;IAED,IAAW,IAAI;QACb,OAAO,GAAG,CAAC,aAAa,CAAC,GAAG,CAAC,IAAI,CAAC;IACpC,CAAC;IAED,IAAW,YAAY;QACrB,OAAO,IAAI,CAAC,IAAI,CAAC;IACnB,CAAC;CAEF;AAED;;GAEG;AACH,MAAa,SAAU,SAAQ,IAAI,CAAC,QAAQ;IAE1C;;OAEG;IACI,MAAM,CAAC,iBAAiB,CAAC,KAAgB,EAAE,EAAU,EAAE,IAAY;QACxE,OAAO,IAAI,iBAAiB,CAAC,KAAK,EAAE,EAAE,EAAE,IAAI,CAAC,CAAC;IAChD,CAAC;IAiBD,YAAmB,KAAgB,EAAE,EAAU,EAAE,QAAwB,EAAG;QAC1E,KAAK,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC;QAXH,iBAAY,GAAG,YAAY,CAAC;QAE3B,gBAAW,GAA8B,EAAG,CAAC;QAC7C,UAAK,GAA8B,EAAG,CAAC;QAUtD,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC,SAAS,IAAI,KAAK,CAAC;QAC1C,IAAI,CAAC,SAAS,GAAG,IAAI,GAAG,CAAC,aAAa,CAAC,IAAI,EAAE,UAAU,EAAE;YACvD,QAAQ,EAAE,KAAK,CAAC,QAAQ;YAExB,4CAA4C;YAC5C,IAAI,EAAE,YAAI,CAAC,GAAG,CAAC,EAAE,OAAO,EAAE,GAAG,EAAE,CAAC,IAAI,CAAC,cAAc,EAAE,EAAE,CAAC;YACxD,UAAU,EAAE,YAAI,CAAC,GAAG,CAAC,EAAE,OAAO,EAAE,GAAG,EAAE,CAAC,IAAI,CAAC,oBAAoB,EAAE,EAAE,CAAC;YACpE,SAAS,EAAE,IAAI,CAAC,SAAS;SAC1B,CAAC,CAAC;QAEH,KAAK,MAAM,CAAC,CAAC,EAAE,CAAC,CAAC,IAAI,MAAM,CAAC,OAAO,CAAC,KAAK,CAAC,IAAI,IAAI,EAAG,CAAC,EAAE,CAAC;YACvD,IAAI,CAAC,OAAO,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;QACrB,CAAC;QAED,KAAK,MAAM,CAAC,CAAC,EAAE,CAAC,CAAC,IAAI,MAAM,CAAC,OAAO,CAAC,KAAK,CAAC,UAAU,IAAI,EAAG,CAAC,EAAE,CAAC;YAC7D,IAAI,CAAC,aAAa,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;QAC3B,CAAC;IAEH,CAAC;IAED;;;;;;OAMG;IACI,OAAO,CAAC,GAAW,EAAE,KAAa;QACvC,IAAI,CAAC,kBAAkB,CAAC,GAAG,CAAC,CAAC;QAE7B,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,GAAG,KAAK,CAAC;IAC1B,CAAC;IAED;;;;OAIG;IACH,IAAW,IAAI;QACb,OAAO,EAAE,GAAG,IAAI,CAAC,KAAK,EAAE,CAAC;IAC3B,CAAC;IAED;;;;;;;OAOG;IACI,aAAa,CAAC,GAAW,EAAE,KAAa;QAC7C,IAAI,CAAC,kBAAkB,CAAC,GAAG,CAAC,CAAC;QAE7B,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,GAAG,KAAK,CAAC;IAChC,CAAC;IAED;;;;OAIG;IACH,IAAW,UAAU;QACnB,OAAO,EAAE,GAAG,IAAI,CAAC,WAAW,EAAE,CAAC;IACjC,CAAC;IAED;;;;OAIG;IACI,OAAO,CAAC,SAAiB,EAAE,GAAY;QAC5C,GAAG,GAAG,GAAG,IAAI,IAAI,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC;QACtC,MAAM,KAAK,GAAG,SAAS,CAAC,YAAY,CAAC,SAAS,EAAE,OAAO,CAAC,CAAC;QAEzD,IAAI,CAAC,OAAO,CAAC,GAAG,EAAE,KAAK,CAAC,CAAC;IAC3B,CAAC;IAED;;;;OAIG;IACI,YAAY,CAAC,QAAgB,EAAE,UAA+B,EAAG;QACtE,MAAM,OAAO,GAAG,OAAO,CAAC,OAAO,IAAI,EAAE,CAAC;QACtC,MAAM,aAAa,GAAG,CAAC,IAAY,EAAE,EAAE;YACrC,KAAK,MAAM,OAAO,IAAI,OAAO,EAAE,CAAC;gBAC9B,MAAM,EAAE,GAAG,IAAI,qBAAS,CAAC,OAAO,CAAC,CAAC;gBAClC,IAAI,EAAE,CAAC,KAAK,CAAC,IAAI,CAAC,EAAE,CAAC;oBACnB,OAAO,KAAK,CAAC;gBACf,CAAC;YACH,CAAC;YACD,OAAO,IAAI,CAAC;QACd,CAAC,CAAC;QAEF,MAAM,SAAS,GAAG,OAAO,CAAC,SAAS,IAAI,EAAE,CAAC;QAC1C,KAAK,MAAM,IAAI,IAAI,SAAS,CAAC,WAAW,CAAC,QAAQ,CAAC,EAAE,CAAC;YAEnD,MAAM,QAAQ,GAAG,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE,IAAI,CAAC,CAAC;YAE3C,IAAI,SAAS,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAC,WAAW,EAAE,EAAE,CAAC;gBAC/C,SAAS;YACX,CAAC;YAED,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,EAAE,CAAC;gBACzB,SAAS;YACX,CAAC;YAED,MAAM,gBAAgB,GAAG,SAAS,GAAG,IAAI,CAAC;YAC1C,IAAI,CAAC,OAAO,CAAC,QAAQ,EAAE,gBAAgB,CAAC,CAAC;QAC3C,CAAC;IACH,CAAC;IAEO,kBAAkB,CAAC,GAAW;QACpC,IAAI,GAAG,IAAI,IAAI,CAAC,KAAK,IAAI,GAAG,IAAI,IAAI,CAAC,WAAW,EAAE,CAAC;YACjD,MAAM,IAAI,KAAK,CAAC,6CAA6C,GAAG,uBAAuB,CAAC,CAAC;QAC3F,CAAC;IACH,CAAC;IAEO,cAAc;QACpB,OAAO,IAAA,wBAAgB,EAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IACtC,CAAC;IAEO,oBAAoB;QAC1B,OAAO,IAAA,wBAAgB,EAAC,IAAI,CAAC,WAAW,CAAC,CAAC;IAC5C,CAAC;;AAvJH,8BAwJC","sourcesContent":["import * as configmap from 'fs';\nimport * as path from 'path';\nimport { ApiObject, Lazy } from 'cdk8s';\nimport { Construct } from 'constructs';\nimport { Minimatch } from 'minimatch';\nimport * as base from './base';\nimport * as k8s from './imports/k8s';\nimport { undefinedIfEmpty } from './utils';\n\n/**\n * Properties for initialization of `ConfigMap`.\n */\nexport interface ConfigMapProps extends base.ResourceProps {\n  /**\n   * BinaryData contains the binary data.\n   *\n   * Each key must consist of alphanumeric characters, '-', '_' or '.'.\n   * BinaryData can contain byte sequences that are not in the UTF-8 range. The\n   * keys stored in BinaryData must not overlap with the ones in the Data field,\n   * this is enforced during validation process.\n   *\n   * You can also add binary data using `configMap.addBinaryData()`.\n   */\n  readonly binaryData?: { [key: string]: string };\n\n  /**\n   * Data contains the configuration data.\n   *\n   * Each key must consist of alphanumeric characters, '-', '_' or '.'. Values\n   * with non-UTF-8 byte sequences must use the BinaryData field. The keys\n   * stored in Data must not overlap with the keys in the BinaryData field, this\n   * is enforced during validation process.\n   *\n   * You can also add data using `configMap.addData()`.\n   */\n  readonly data?: { [key: string]: string };\n\n  /**\n   * If set to true, ensures that data stored in the ConfigMap cannot be updated (only object metadata can be modified).\n   * If not set to true, the field can be modified at any time.\n   *\n   * @default false\n   */\n  readonly immutable?: boolean;\n\n}\n\n/**\n * Represents a config map.\n */\nexport interface IConfigMap extends base.IResource {\n\n}\n\nclass ImportedConfigMap extends Construct implements IConfigMap {\n\n  private readonly _name: string;\n\n  public readonly resourceType = 'configmaps';\n\n  constructor(scope: Construct, id: string, name: string) {\n    super(scope, id);\n    this._name = name;\n  }\n\n  public get name(): string {\n    return this._name;\n  }\n\n  public get apiVersion(): string {\n    return k8s.KubeConfigMap.GVK.apiVersion;\n  }\n\n  public get apiGroup(): string {\n    return '';\n  }\n\n  public get kind(): string {\n    return k8s.KubeConfigMap.GVK.kind;\n  }\n\n  public get resourceName(): string {\n    return this.name;\n  }\n\n}\n\n/**\n * ConfigMap holds configuration data for pods to consume.\n */\nexport class ConfigMap extends base.Resource implements IConfigMap {\n\n  /**\n   * Represents a ConfigMap created elsewhere.\n   */\n  public static fromConfigMapName(scope: Construct, id: string, name: string): IConfigMap {\n    return new ImportedConfigMap(scope, id, name);\n  }\n\n  /**\n   * @see base.Resource.apiObject\n   */\n  protected readonly apiObject: ApiObject;\n\n  public readonly resourceType = 'configmaps';\n\n  private readonly _binaryData: { [key: string]: string } = { };\n  private readonly _data: { [key: string]: string } = { };\n\n  /**\n   * Whether or not this config map is immutable.\n   */\n  public readonly immutable: boolean;\n\n  public constructor(scope: Construct, id: string, props: ConfigMapProps = { }) {\n    super(scope, id);\n\n    this.immutable = props.immutable ?? false;\n    this.apiObject = new k8s.KubeConfigMap(this, 'Resource', {\n      metadata: props.metadata,\n\n      // we need lazy here because we filter empty\n      data: Lazy.any({ produce: () => this.synthesizeData() }),\n      binaryData: Lazy.any({ produce: () => this.synthesizeBinaryData() }),\n      immutable: this.immutable,\n    });\n\n    for (const [k, v] of Object.entries(props.data ?? { })) {\n      this.addData(k, v);\n    }\n\n    for (const [k, v] of Object.entries(props.binaryData ?? { })) {\n      this.addBinaryData(k, v);\n    }\n\n  }\n\n  /**\n   * Adds a data entry to the config map.\n   * @param key The key\n   * @param value The value\n   *\n   * @throws if there is either a `data` or `binaryData` entry with the same key\n   */\n  public addData(key: string, value: string) {\n    this.verifyKeyAvailable(key);\n\n    this._data[key] = value;\n  }\n\n  /**\n   * The data associated with this config map.\n   *\n   * Returns an copy. To add data records, use `addData()` or `addBinaryData()`.\n   */\n  public get data(): Record<string, string> {\n    return { ...this._data };\n  }\n\n  /**\n   * Adds a binary data entry to the config map. BinaryData can contain byte\n   * sequences that are not in the UTF-8 range.\n   * @param key The key\n   * @param value The value\n   *\n   * @throws if there is either a `data` or `binaryData` entry with the same key\n   */\n  public addBinaryData(key: string, value: string) {\n    this.verifyKeyAvailable(key);\n\n    this._binaryData[key] = value;\n  }\n\n  /**\n   * The binary data associated with this config map.\n   *\n   * Returns a copy. To add data records, use `addBinaryData()` or `addData()`.\n   */\n  public get binaryData(): Record<string, string> {\n    return { ...this._binaryData };\n  }\n\n  /**\n   * Adds a file to the ConfigMap.\n   * @param localFile The path to the local file\n   * @param key The ConfigMap key (default to the file name).\n   */\n  public addFile(localFile: string, key?: string) {\n    key = key ?? path.basename(localFile);\n    const value = configmap.readFileSync(localFile, 'utf-8');\n\n    this.addData(key, value);\n  }\n\n  /**\n   * Adds a directory to the ConfigMap.\n   * @param localDir A path to a local directory\n   * @param options Options\n   */\n  public addDirectory(localDir: string, options: AddDirectoryOptions = { }) {\n    const exclude = options.exclude ?? [];\n    const shouldInclude = (file: string) => {\n      for (const pattern of exclude) {\n        const mm = new Minimatch(pattern);\n        if (mm.match(file)) {\n          return false;\n        }\n      }\n      return true;\n    };\n\n    const keyPrefix = options.keyPrefix ?? '';\n    for (const file of configmap.readdirSync(localDir)) {\n\n      const filePath = path.join(localDir, file);\n\n      if (configmap.statSync(filePath).isDirectory()) {\n        continue;\n      }\n\n      if (!shouldInclude(file)) {\n        continue;\n      }\n\n      const relativeFilePath = keyPrefix + file;\n      this.addFile(filePath, relativeFilePath);\n    }\n  }\n\n  private verifyKeyAvailable(key: string) {\n    if (key in this._data || key in this._binaryData) {\n      throw new Error(`unable to add a ConfigMap entry with key \"${key}\". It is already used`);\n    }\n  }\n\n  private synthesizeData() {\n    return undefinedIfEmpty(this._data);\n  }\n\n  private synthesizeBinaryData() {\n    return undefinedIfEmpty(this._binaryData);\n  }\n}\n\n/**\n * Options for `configmap.addDirectory()`\n */\nexport interface AddDirectoryOptions {\n  /**\n   * A prefix to add to all keys in the config map.\n   * @default \"\"\n   */\n  readonly keyPrefix?: string;\n\n  /**\n   * Glob patterns to exclude when adding files.\n   * @default - include all files\n   */\n  readonly exclude?: string[];\n}\n"]}
package/lib/container.js CHANGED
@@ -250,7 +250,7 @@ class ContainerSecurityContext {
250
250
  }
251
251
  exports.ContainerSecurityContext = ContainerSecurityContext;
252
252
  _a = JSII_RTTI_SYMBOL_1;
253
- ContainerSecurityContext[_a] = { fqn: "cdk8s-plus-32.ContainerSecurityContext", version: "2.4.13" };
253
+ ContainerSecurityContext[_a] = { fqn: "cdk8s-plus-32.ContainerSecurityContext", version: "2.5.0" };
254
254
  var EnvFieldPaths;
255
255
  (function (EnvFieldPaths) {
256
256
  /**
@@ -425,7 +425,7 @@ class EnvValue {
425
425
  }
426
426
  exports.EnvValue = EnvValue;
427
427
  _b = JSII_RTTI_SYMBOL_1;
428
- EnvValue[_b] = { fqn: "cdk8s-plus-32.EnvValue", version: "2.4.13" };
428
+ EnvValue[_b] = { fqn: "cdk8s-plus-32.EnvValue", version: "2.5.0" };
429
429
  var ImagePullPolicy;
430
430
  (function (ImagePullPolicy) {
431
431
  /**
@@ -659,7 +659,7 @@ class Container {
659
659
  }
660
660
  exports.Container = Container;
661
661
  _c = JSII_RTTI_SYMBOL_1;
662
- Container[_c] = { fqn: "cdk8s-plus-32.Container", version: "2.4.13" };
662
+ Container[_c] = { fqn: "cdk8s-plus-32.Container", version: "2.5.0" };
663
663
  var MountPropagation;
664
664
  (function (MountPropagation) {
665
665
  /**
@@ -725,7 +725,7 @@ class Cpu {
725
725
  }
726
726
  exports.Cpu = Cpu;
727
727
  _d = JSII_RTTI_SYMBOL_1;
728
- Cpu[_d] = { fqn: "cdk8s-plus-32.Cpu", version: "2.4.13" };
728
+ Cpu[_d] = { fqn: "cdk8s-plus-32.Cpu", version: "2.5.0" };
729
729
  /**
730
730
  * A collection of env variables defined in other resources.
731
731
  */
@@ -753,7 +753,7 @@ class EnvFrom {
753
753
  }
754
754
  exports.EnvFrom = EnvFrom;
755
755
  _e = JSII_RTTI_SYMBOL_1;
756
- EnvFrom[_e] = { fqn: "cdk8s-plus-32.EnvFrom", version: "2.4.13" };
756
+ EnvFrom[_e] = { fqn: "cdk8s-plus-32.EnvFrom", version: "2.5.0" };
757
757
  function extractContainerPorts(selector) {
758
758
  if (!selector) {
759
759
  return [];
@@ -841,5 +841,5 @@ class Env {
841
841
  }
842
842
  exports.Env = Env;
843
843
  _f = JSII_RTTI_SYMBOL_1;
844
- Env[_f] = { fqn: "cdk8s-plus-32.Env", version: "2.4.13" };
844
+ Env[_f] = { fqn: "cdk8s-plus-32.Env", version: "2.5.0" };
845
845
  //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"container.js","sourceRoot":"","sources":["../src/container.ts"],"names":[],"mappings":"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","sourcesContent":["import { Size } from 'cdk8s';\nimport * as configmap from './config-map';\nimport * as handler from './handler';\nimport * as k8s from './imports/k8s';\nimport * as probe from './probe';\nimport * as secret from './secret';\nimport { undefinedIfEmpty } from './utils';\nimport * as volume from './volume';\n\n/**\n * Capability - complete list of POSIX capabilities\n */\nexport enum Capability {\n  /**\n   * ALL\n   */\n  ALL = 'ALL',\n  /**\n   * CAP_AUDIT_CONTROL\n   */\n  AUDIT_CONTROL = 'AUDIT_CONTROL',\n  /**\n   * CAP_AUDIT_READ\n   */\n  AUDIT_READ = 'AUDIT_READ',\n  /**\n   * CAP_AUDIT_WRITE\n   */\n  AUDIT_WRITE = 'AUDIT_WRITE',\n  /**\n   * CAP_BLOCK_SUSPEND\n   */\n  BLOCK_SUSPEND = 'BLOCK_SUSPEND',\n  /**\n   * CAP_BPF\n   */\n  BPF = 'BPF',\n  /**\n   * CAP_CHECKPOINT_RESTORE\n   */\n  CHECKPOINT_RESTORE = 'CHECKPOINT_RESTORE',\n  /**\n   * CAP_CHOWN\n   */\n  CHOWN = 'CHOWN',\n  /**\n   * CAP_DAC_OVERRIDE\n   */\n  DAC_OVERRIDE = 'DAC_OVERRIDE',\n  /**\n   * CAP_DAC_READ_SEARCH\n   */\n  DAC_READ_SEARCH = 'DAC_READ_SEARCH',\n  /**\n   * CAP_FOWNER\n   */\n  FOWNER = 'FOWNER',\n  /**\n   * CAP_FSETID\n   */\n  FSETID = 'FSETID',\n  /**\n   * CAP_IPC_LOCK\n   */\n  IPC_LOCK = 'IPC_LOCK',\n  /**\n   * CAP_IPC_OWNER\n   */\n  IPC_OWNER = 'IPC_OWNER',\n  /**\n   * CAP_KILL\n   */\n  KILL = 'KILL',\n  /**\n   * CAP_LEASE\n   */\n  LEASE = 'LEASE',\n  /**\n   * CAP_LINUX_IMMUTABLE\n   */\n  LINUX_IMMUTABLE = 'LINUX_IMMUTABLE',\n  /**\n   * CAP_MAC_ADMIN\n   */\n  MAC_ADMIN = 'MAC_ADMIN',\n  /**\n   * CAP_MAC_OVERRIDE\n   */\n  MAC_OVERRIDE = 'MAC_OVERRIDE',\n  /**\n   * CAP_MKNOD\n   */\n  MKNOD = 'MKNOD',\n  /**\n   * CAP_NET_ADMIN\n   */\n  NET_ADMIN = 'NET_ADMIN',\n  /**\n   * CAP_NET_BIND_SERVICE\n   */\n  NET_BIND_SERVICE = 'NET_BIND_SERVICE',\n  /**\n   * CAP_NET_BROADCAST\n   */\n  NET_BROADCAST = 'NET_BROADCAST',\n  /**\n   * CAP_NET_RAW\n   */\n  NET_RAW = 'NET_RAW',\n  /**\n   * CAP_PERFMON\n   */\n  PERFMON = 'PERFMON',\n  /**\n   * CAP_SETGID\n   */\n  SETGID = 'SETGID',\n  /**\n   * CAP_SETFCAP\n   */\n  SETFCAP = 'SETFCAP',\n  /**\n   * CAP_SETPCAP\n   */\n  SETPCAP = 'SETPCAP',\n  /**\n   * CAP_SETUID\n   */\n  SETUID = 'SETUID',\n  /**\n   * CAP_SYS_ADMIN\n   */\n  SYS_ADMIN = 'SYS_ADMIN',\n  /**\n   * CAP_SYS_BOOT\n   */\n  SYS_BOOT = 'SYS_BOOT',\n  /**\n   * CAP_SYS_CHROOT\n   */\n  SYS_CHROOT = 'SYS_CHROOT',\n  /**\n   * CAP_SYS_MODULE\n   */\n  SYS_MODULE = 'SYS_MODULE',\n  /**\n   * CAP_SYS_NICE\n   */\n  SYS_NICE = 'SYS_NICE',\n  /**\n   * CAP_SYS_PACCT\n   */\n  SYS_PACCT = 'SYS_PACCT',\n  /**\n   * CAP_SYS_PTRACE\n   */\n  SYS_PTRACE = 'SYS_PTRACE',\n  /**\n   * CAP_SYS_RAWIO\n   */\n  SYS_RAWIO = 'SYS_RAWIO',\n  /**\n   * CAP_SYS_RESOURCE\n   */\n  SYS_RESOURCE = 'SYS_RESOURCE',\n  /**\n   * CAP_SYS_TIME\n   */\n  SYS_TIME = 'SYS_TIME',\n  /**\n   * CAP_SYS_TTY_CONFIG\n   */\n  SYS_TTY_CONFIG = 'SYS_TTY_CONFIG',\n  /**\n   * CAP_SYSLOG\n   */\n  SYSLOG = 'SYSLOG',\n  /**\n   * CAP_WAKE_ALARM\n   */\n  WAKE_ALARM = 'WAKE_ALARM',\n}\n\nexport enum SeccompProfileType {\n  /**\n  * A profile defined in a file on the node should be used\n  */\n  LOCALHOST = 'Localhost',\n  /**\n  * The container runtime default profile should be used\n  */\n  RUNTIME_DEFAULT = 'RuntimeDefault',\n  /**\n  * No profile should be applied\n  */\n  UNCONFINED = 'Unconfined',\n}\n\nexport interface SeccompProfile {\n  /**\n   * localhostProfile indicates a profile defined in a file on the node should be used.\n   * The profile must be preconfigured on the node to work. Must be a descending path,\n   * relative to the kubelet's configured seccomp profile location.\n   * Must only be set if type is \"Localhost\".\n   *\n   * @default - empty string\n   */\n  readonly localhostProfile?: string;\n  /**\n   * Indicates which kind of seccomp profile will be applied\n   */\n  readonly type: SeccompProfileType;\n}\n\nexport interface ContainerSecutiryContextCapabilities {\n  /**\n   * Added capabilities\n   */\n  readonly add?: Capability[];\n\n  /**\n   * Removed capabilities\n   */\n  readonly drop?: Capability[];\n}\n\n/**\n * Properties for `ContainerSecurityContext`\n */\nexport interface ContainerSecurityContextProps {\n\n  /**\n    * The UID to run the entrypoint of the container process.\n    *\n    * @default - 25000. An arbitrary number bigger than 9999 is selected here.\n    * This is so that the container is blocked to access host files even if\n    * somehow it manages to get access to host file system.\n    */\n  readonly user?: number;\n\n  /**\n    * The GID to run the entrypoint of the container process.\n    *\n    * @default - 26000. An arbitrary number bigger than 9999 is selected here.\n    * This is so that the container is blocked to access host files even if\n    * somehow it manages to get access to host file system.\n    */\n  readonly group?: number;\n\n  /**\n    * Indicates that the container must run as a non-root user.\n    * If true, the Kubelet will validate the image at runtime to ensure that it does\n    * not run as UID 0 (root) and fail to start the container if it does.\n    *\n    * @default true\n    */\n  readonly ensureNonRoot?: boolean;\n\n  /**\n   * Run container in privileged mode. Processes in privileged containers are essentially equivalent to root on the host.\n   *\n   * @default false\n   */\n  readonly privileged?: boolean;\n\n  /**\n   * Whether this container has a read-only root filesystem.\n   *\n   * @default true\n   */\n  readonly readOnlyRootFilesystem?: boolean;\n\n  /**\n   * Whether a process can gain more privileges than its parent process.\n   *\n   * @default false\n   */\n  readonly allowPrivilegeEscalation?: boolean;\n\n  /**\n   * POSIX capabilities for running containers\n   *\n   * @default none\n   */\n  readonly capabilities?: ContainerSecutiryContextCapabilities;\n\n  /**\n  * Container's seccomp profile settings. Only one profile source may be set\n  *\n  * @default none\n  */\n  readonly seccompProfile?: SeccompProfile;\n}\n\n/**\n * Represents a network port in a single container.\n */\nexport interface ContainerPort {\n\n  /**\n   * Number of port to expose on the pod's IP address. This must be a valid port number, 0 < x < 65536.\n   */\n  readonly number: number;\n\n  /**\n   * What host IP to bind the external port to.\n   *\n   * @default - 127.0.0.1.\n   */\n  readonly hostIp?: string;\n\n  /**\n   * Number of port to expose on the host. If specified, this must be a valid port number, 0 < x < 65536.\n   * Most containers do not need this.\n   *\n   * @default - auto generated by kubernetes and might change on restarts.\n   */\n  readonly hostPort?: number;\n\n  /**\n   * If specified, this must be an IANA_SVC_NAME and unique within the pod.\n   * Each named port in a pod must have a unique name.\n   * Name for the port that can be referred to by services.\n   *\n   * @default - port is not named.\n   */\n  readonly name?: string;\n\n  /**\n   * Protocol for port. Must be UDP, TCP, or SCTP. Defaults to \"TCP\".\n   *\n   * @default Protocol.TCP\n   */\n  readonly protocol?: Protocol;\n\n}\n\n/**\n * Network protocols.\n */\nexport enum Protocol {\n\n  /**\n   * TCP.\n   */\n  TCP = 'TCP',\n\n  /**\n   * UDP.\n   */\n  UDP = 'UDP',\n\n  /**\n   * SCTP.\n   */\n  SCTP = 'SCTP',\n}\n\n\n/**\n * Container security attributes and settings.\n */\nexport class ContainerSecurityContext {\n\n  public readonly ensureNonRoot: boolean;\n  public readonly privileged: boolean;\n  public readonly readOnlyRootFilesystem: boolean;\n  public readonly user?: number;\n  public readonly group?: number;\n  public readonly allowPrivilegeEscalation?: boolean;\n  public readonly capabilities?: ContainerSecutiryContextCapabilities;\n  public readonly seccompProfile?: SeccompProfile;\n\n  constructor(props: ContainerSecurityContextProps = {}) {\n    if (props.seccompProfile?.localhostProfile && props.seccompProfile.type != SeccompProfileType.LOCALHOST) {\n      throw new Error('localhostProfile must only be set if type is \"Localhost\"');\n    }\n    this.ensureNonRoot = props.ensureNonRoot ?? true;\n    this.privileged = props.privileged ?? false;\n    this.readOnlyRootFilesystem = props.readOnlyRootFilesystem ?? true;\n    this.user = props.user;\n    this.group = props.group;\n    this.allowPrivilegeEscalation = props.allowPrivilegeEscalation ?? false;\n    this.capabilities = props.capabilities;\n    this.seccompProfile = props.seccompProfile;\n  }\n\n  /**\n   * @internal\n   */\n  public _toKube(): k8s.SecurityContext {\n    return {\n      runAsGroup: this.group,\n      runAsUser: this.user,\n      runAsNonRoot: this.ensureNonRoot,\n      privileged: this.privileged,\n      readOnlyRootFilesystem: this.readOnlyRootFilesystem,\n      allowPrivilegeEscalation: this.allowPrivilegeEscalation,\n      capabilities: this.capabilities,\n      seccompProfile: this.seccompProfile,\n    };\n  }\n\n}\n\nexport enum EnvFieldPaths {\n  /**\n   * The name of the pod.\n   */\n  POD_NAME = 'metadata.name',\n\n  /**\n   * The namespace of the pod.\n   */\n  POD_NAMESPACE = 'metadata.namespace',\n\n  /**\n   * The uid of the pod.\n   */\n  POD_UID = 'metadata.uid',\n\n  /**\n   * The labels of the pod.\n   */\n  POD_LABEL = 'metadata.labels',\n\n  /**\n   * The annotations of the pod.\n   */\n  POD_ANNOTATION = 'metadata.annotations',\n\n  /**\n   * The ipAddress of the pod.\n   */\n  POD_IP = 'status.podIP',\n\n  /**\n   * The service account name of the pod.\n   */\n  SERVICE_ACCOUNT_NAME = 'spec.serviceAccountName',\n\n  /**\n   * The name of the node.\n   */\n  NODE_NAME = 'spec.nodeName',\n\n  /**\n   * The ipAddress of the node.\n   */\n  NODE_IP = 'status.hostIP',\n\n  /**\n   * The ipAddresess of the pod.\n   */\n  POD_IPS = 'status.podIPs',\n}\n\nexport enum ResourceFieldPaths {\n  /**\n   * CPU limit of the container.\n   */\n  CPU_LIMIT = 'limits.cpu',\n\n  /**\n   * Memory limit of the container.\n   */\n  MEMORY_LIMIT = 'limits.memory',\n\n  /**\n   * CPU request of the container.\n   */\n  CPU_REQUEST = 'requests.cpu',\n\n  /**\n   * Memory request of the container.\n   */\n  MEMORY_REQUEST = 'requests.memory',\n\n  /**\n   * Ephemeral storage limit of the container.\n   */\n  STORAGE_LIMIT = 'limits.ephemeral-storage',\n\n  /**\n   * Ephemeral storage request of the container.\n   */\n  STORAGE_REQUEST = 'requests.ephemeral-storage',\n}\n\n/**\n * Options to specify an envionment variable value from a ConfigMap key.\n */\nexport interface EnvValueFromConfigMapOptions {\n\n  /**\n   * Specify whether the ConfigMap or its key must be defined.\n   *\n   * @default false\n   */\n  readonly optional?: boolean;\n}\n\n/**\n * Options to specify an environment variable value from a Secret.\n */\nexport interface EnvValueFromSecretOptions {\n\n  /**\n   * Specify whether the Secret or its key must be defined.\n   *\n   * @default false\n   */\n  readonly optional?: boolean;\n\n}\n\n/**\n * Options to specify an environment variable value from the process environment.\n */\nexport interface EnvValueFromProcessOptions {\n\n  /**\n   * Specify whether the key must exist in the environment.\n   * If this is set to true, and the key does not exist, an error will thrown.\n   *\n   * @default false\n   */\n  readonly required?: boolean;\n}\n\n/**\n * Options to specify an environment variable value from a field reference.\n */\nexport interface EnvValueFromFieldRefOptions {\n  /**\n   * Version of the schema the FieldPath is written in terms of.\n   */\n  readonly apiVersion?: string;\n\n  /**\n   * The key to select the pod label or annotation.\n   */\n  readonly key?: string;\n}\n\n/**\n * Options to specify an environment variable value from a resource.\n */\nexport interface EnvValueFromResourceOptions {\n  /**\n   * The container to select the value from.\n   */\n  readonly container?: Container;\n\n  /**\n   * The output format of the exposed resource.\n   */\n  readonly divisor?: string;\n}\n\n/**\n * Utility class for creating reading env values from various sources.\n */\nexport class EnvValue {\n\n  /**\n   * Create a value by reading a specific key inside a config map.\n   *\n   * @param configMap - The config map.\n   * @param key - The key to extract the value from.\n   * @param options - Additional options.\n   */\n  public static fromConfigMap(configMap: configmap.IConfigMap, key: string, options: EnvValueFromConfigMapOptions = {}): EnvValue {\n\n    const source: k8s.EnvVarSource = {\n      configMapKeyRef: {\n        name: configMap.name,\n        key,\n        optional: options.optional,\n      },\n    };\n    return new EnvValue(undefined, source);\n  }\n\n  /**\n   * Defines an environment value from a secret JSON value.\n   *\n   * @param secretValue The secret value (secrent + key)\n   * @param options Additional options\n   */\n  public static fromSecretValue(secretValue: secret.SecretValue, options: EnvValueFromSecretOptions = {}): EnvValue {\n    const source: k8s.EnvVarSource = {\n      secretKeyRef: {\n        name: secretValue.secret.name,\n        key: secretValue.key,\n        optional: options.optional,\n      },\n    };\n\n    return new EnvValue(undefined, source);\n  }\n\n  /**\n   * Create a value from the given argument.\n   *\n   * @param value - The value.\n   */\n  public static fromValue(value: string): EnvValue {\n    return new EnvValue(value);\n  }\n\n  /**\n   *\n   * Create a value from a field reference.\n   *\n   * @param fieldPath: The field reference.\n   * @param options: Additional options.\n   */\n  public static fromFieldRef(fieldPath: EnvFieldPaths, options: EnvValueFromFieldRefOptions = {}): EnvValue {\n    let needsKey: boolean = false;\n\n    if (fieldPath === EnvFieldPaths.POD_LABEL || fieldPath === EnvFieldPaths.POD_ANNOTATION) {\n      needsKey = true;\n    }\n\n    if (needsKey && options.key === undefined) {\n      throw new Error(`${fieldPath} requires a key`);\n    }\n\n    const source: k8s.EnvVarSource = {\n      fieldRef: {\n        fieldPath: (`${fieldPath}` + (needsKey ? `['${options.key}']` : '')),\n        ...(options.apiVersion ? { apiVersion: options.apiVersion } : {}),\n      },\n    };\n\n    return new EnvValue(undefined, source);\n  }\n\n  /**\n   * Create a value from a resource.\n   *\n   * @param resource: Resource to select the value from.\n   * @param options: Additional options.\n   */\n  public static fromResource(resource: ResourceFieldPaths, options: EnvValueFromResourceOptions = {}): EnvValue {\n    const source: k8s.EnvVarSource = {\n      resourceFieldRef: {\n        resource: `${resource}`,\n        ... (options.divisor ? { divisor: k8s.IntOrString.fromString(options.divisor) } : {}),\n        ... (options.container ? { containerName: options.container.name } : {}),\n      },\n    };\n\n    return new EnvValue(undefined, source);\n  }\n\n  /**\n   * Create a value from a key in the current process environment.\n   *\n   * @param key - The key to read.\n   * @param options - Additional options.\n   */\n  public static fromProcess(key: string, options: EnvValueFromProcessOptions = {}): EnvValue {\n\n    const value = process.env[key];\n\n    if (options.required && !value) {\n      throw new Error(`Missing ${key} env variable`);\n    }\n\n    return EnvValue.fromValue(value!);\n  }\n\n  private constructor(public readonly value?: any, public readonly valueFrom?: any) { }\n}\n\nexport enum ImagePullPolicy {\n  /**\n   * Every time the kubelet launches a container, the kubelet queries the container image registry\n   * to resolve the name to an image digest. If the kubelet has a container image with that exact\n   * digest cached locally, the kubelet uses its cached image; otherwise, the kubelet downloads\n   * (pulls) the image with the resolved digest, and uses that image to launch the container.\n   *\n   * Default is Always if ImagePullPolicy is omitted and either the image tag is :latest or\n   * the image tag is omitted.\n   */\n  ALWAYS = 'Always',\n\n  /**\n   * The image is pulled only if it is not already present locally.\n   *\n   * Default is IfNotPresent if ImagePullPolicy is omitted and the image tag is present but\n   * not :latest\n   */\n  IF_NOT_PRESENT = 'IfNotPresent',\n\n  /**\n   * The image is assumed to exist locally. No attempt is made to pull the image.\n   */\n  NEVER = 'Never',\n}\n\n/**\n * Container lifecycle properties.\n */\nexport interface ContainerLifecycle {\n\n  /**\n   * This hook is executed immediately after a container is created. However,\n   * there is no guarantee that the hook will execute before the container ENTRYPOINT.\n   *\n   * @default - No post start handler.\n   */\n  readonly postStart?: handler.Handler;\n\n  /**\n   * This hook is called immediately before a container is terminated due to an API request or management\n   * event such as a liveness/startup probe failure, preemption, resource contention and others.\n   * A call to the PreStop hook fails if the container is already in a terminated or completed state\n   * and the hook must complete before the TERM signal to stop the container can be sent.\n   * The Pod's termination grace period countdown begins before the PreStop hook is executed,\n   * so regardless of the outcome of the handler, the container will eventually terminate\n   * within the Pod's termination grace period. No parameters are passed to the handler.\n   *\n   * @see https://kubernetes.io/docs/concepts/workloads/pods/pod-lifecycle/#pod-termination\n   *\n   * @default - No pre stop handler.\n   */\n  readonly preStop?: handler.Handler;\n\n}\n\n/**\n * RestartPolicy defines the restart behavior of individual containers in a pod.\n * This field may only be set for init containers, and the only allowed value is \"Always\".\n * For non-init containers or when this field is not specified,\n * the restart behavior is defined by the Pod's restart policy and the container type.\n * Setting the RestartPolicy as \"Always\" for the init container will have the following effect:\n * this init container will be continually restarted on exit until all regular containers have terminated.\n * Once all regular containers have completed, all init containers with restartPolicy \"Always\" will be shut down.\n * This lifecycle differs from normal init containers and is often referred to as a \"sidecar\" container.\n *\n * @see https://kubernetes.io/docs/concepts/workloads/pods/sidecar-containers/\n */\nexport enum ContainerRestartPolicy {\n\n  /**\n   * If an init container is created with its restartPolicy set to Always,\n   * it will start and remain running during the entire life of the Pod.\n   * For regular containers, this is ignored by Kubernetes.\n   */\n  ALWAYS = 'Always',\n}\n/**\n * Properties for creating a container.\n */\nexport interface ContainerProps extends ContainerOpts {\n\n  /**\n   * Docker image name.\n   */\n  readonly image: string;\n}\n\n/**\n * Optional properties of a container.\n */\nexport interface ContainerOpts {\n  /**\n   * Name of the container specified as a DNS_LABEL. Each container in a pod must have a unique name (DNS_LABEL). Cannot be updated.\n   *\n   * @default 'main'\n   */\n  readonly name?: string;\n\n  /**\n   * @deprecated - use `portNumber`.\n   */\n  readonly port?: number;\n\n  /**\n   * Number of port to expose on the pod's IP address. This must be a valid port number, 0 < x < 65536.\n   *\n   * This is a convinience property if all you need a single TCP numbered port.\n   * In case more advanced configuartion is required, use the `ports` property.\n   *\n   * This port is added to the list of ports mentioned in the `ports` property.\n   *\n   * @default - Only the ports mentiond in the `ports` property are exposed.\n   */\n  readonly portNumber?: number;\n\n  /**\n   * List of ports to expose from this container.\n   *\n   * @default - Only the port mentioned in the `portNumber` property is exposed.\n   */\n  readonly ports?: ContainerPort[];\n\n  /**\n   * Entrypoint array. Not executed within a shell. The docker image's ENTRYPOINT is used if this is not provided. Variable references $(VAR_NAME) are expanded using the container's environment.\n   * If a variable cannot be resolved, the reference in the input string will be unchanged. The $(VAR_NAME) syntax can be escaped with a double $$, ie: $$(VAR_NAME).\n   * Escaped references will never be expanded, regardless of whether the variable exists or not. Cannot be updated.\n   * More info: https://kubernetes.io/docs/tasks/inject-data-application/define-command-argument-container/#running-a-command-in-a-shell\n   *\n   * @default - The docker image's ENTRYPOINT.\n   */\n  readonly command?: string[];\n\n  /**\n   * Arguments to the entrypoint. The docker image's CMD is used if `command` is\n   * not provided.\n   *\n   * Variable references $(VAR_NAME) are expanded using the container's\n   * environment. If a variable cannot be resolved, the reference in the input\n   * string will be unchanged. The $(VAR_NAME) syntax can be escaped with a\n   * double $$, ie: $$(VAR_NAME). Escaped references will never be expanded,\n   * regardless of whether the variable exists or not.\n   *\n   * Cannot be updated.\n   *\n   * @see https://kubernetes.io/docs/tasks/inject-data-application/define-command-argument-container/#running-a-command-in-a-shell\n   * @default []\n   */\n  readonly args?: string[];\n\n  /**\n   * Container's working directory. If not specified, the container runtime's default will be used, which might be configured in the container image. Cannot be updated.\n   *\n   * @default - The container runtime's default.\n   */\n  readonly workingDir?: string;\n\n  /**\n   * Environment variables to set in the container.\n   *\n   * @default - No environment variables.\n   */\n  readonly envVariables?: { [name: string]: EnvValue };\n\n  /**\n   * List of sources to populate environment variables in the container.\n   * When a key exists in multiple sources, the value associated with\n   * the last source will take precedence. Values defined by the `envVariables` property\n   * with a duplicate key will take precedence.\n   *\n   * @default - No sources.\n   */\n  readonly envFrom?: EnvFrom[];\n\n  /**\n   * Pod volumes to mount into the container's filesystem. Cannot be updated.\n   */\n  readonly volumeMounts?: VolumeMount[];\n\n  /**\n   * Image pull policy for this container\n   * @default ImagePullPolicy.ALWAYS\n   */\n  readonly imagePullPolicy?: ImagePullPolicy;\n\n  /**\n   * Determines when the container is ready to serve traffic.\n   *\n   * @default - no readiness probe is defined\n   */\n  readonly readiness?: probe.Probe;\n\n  /**\n   * Periodic probe of container liveness. Container will be restarted if the probe fails.\n   *\n   * @default - no liveness probe is defined\n   */\n  readonly liveness?: probe.Probe;\n\n  /**\n   * StartupProbe indicates that the Pod has successfully initialized.\n   * If specified, no other probes are executed until this completes successfully\n   *\n   * @default - If a port is provided, then knocks on that port\n   * to determine when the container is ready for readiness and\n   * liveness probe checks.\n   * Otherwise, no startup probe is defined.\n   */\n  readonly startup?: probe.Probe;\n\n  /**\n   * Describes actions that the management system should take in response to container lifecycle events.\n   */\n  readonly lifecycle?: ContainerLifecycle;\n\n  /**\n   * Compute resources (CPU and memory requests and limits) required by the container\n   * @see https://kubernetes.io/docs/concepts/configuration/manage-resources-containers/\n   *\n   * @default\n   *    cpu:\n   *      request: 1000 millis\n   *      limit: 1500 millis\n   *    memory:\n   *      request: 512 mebibytes\n   *      limit: 2048 mebibytes\n   */\n  readonly resources?: ContainerResources;\n\n  /**\n   * SecurityContext defines the security options the container should be run with.\n   * If set, the fields override equivalent fields of the pod's security context.\n   *\n   * @see https://kubernetes.io/docs/tasks/configure-pod-container/security-context/\n   * @default\n   *\n   *   ensureNonRoot: true\n   *   privileged: false\n   *   readOnlyRootFilesystem: true\n   *   allowPrivilegeEscalation: false\n   *   user: 25000\n   *   group: 26000\n   */\n  readonly securityContext?: ContainerSecurityContextProps;\n\n  /**\n   * Kubelet will start init containers with restartPolicy=Always in the order with other init containers,\n   * but instead of waiting for its completion, it will wait for the container startup completion\n   * Currently, only accepted value is Always\n   * @see https://kubernetes.io/docs/concepts/workloads/pods/sidecar-containers/\n   * @default - no restart policy is defined and the pod restart policy is applied\n   */\n  readonly restartPolicy?: ContainerRestartPolicy;\n}\n\n/**\n * A single application container that you want to run within a pod.\n */\nexport class Container {\n\n  /**\n   * The port number that was configured for this container.\n   * If undefined, either the container doesn't expose a port, or its\n   * port configuration is stored in the `ports` field.\n   */\n  public readonly portNumber?: number;\n\n  /**\n   * Volume mounts configured for this container.\n   */\n  public readonly mounts: VolumeMount[];\n\n  /**\n   * Image pull policy for this container\n   */\n  public readonly imagePullPolicy: ImagePullPolicy;\n\n  /**\n   * The container image.\n   */\n  public readonly image: string;\n\n  /**\n   * The name of the container.\n   */\n  public readonly name: string;\n\n  /**\n   * The working directory inside the container.\n   */\n  public readonly workingDir?: string;\n\n  /**\n   * Compute resources (CPU and memory requests and limits) required by the container\n   * @see https://kubernetes.io/docs/concepts/configuration/manage-resources-containers/\n   */\n  public readonly resources?: ContainerResources;\n\n  /**\n   * The security context of the container.\n   */\n  public readonly securityContext: ContainerSecurityContext;\n\n  /**\n   * The environment of the container.\n   */\n  public readonly env: Env;\n\n  /**\n   * The restart policy of the container.\n   */\n  public readonly restartPolicy?: ContainerRestartPolicy;\n\n  private readonly _command?: readonly string[];\n  private readonly _args?: readonly string[];\n  private readonly _ports: ContainerPort[] = [];\n  private readonly _readiness?: probe.Probe;\n  private readonly _liveness?: probe.Probe;\n  private readonly _startup?: probe.Probe;\n  private readonly _lifecycle?: ContainerLifecycle;\n\n  constructor(props: ContainerProps) {\n    if (props instanceof Container) {\n      throw new Error('Attempted to construct a container from a Container object.');\n    }\n\n    const defaultResourceSpec: ContainerResources = {\n      cpu: {\n        request: Cpu.millis(1000),\n        limit: Cpu.millis(1500),\n      },\n      memory: {\n        request: Size.mebibytes(512),\n        limit: Size.mebibytes(2048),\n      },\n    };\n\n    if (props.port && props.portNumber) {\n      throw new Error('Either \\'port\\' or \\'portNumber\\' is allowed. Use \\'portNumber\\' since \\'port\\' is deprecated');\n    }\n\n    const portNumber = props.portNumber ?? props.port;\n    const defaultProbeConfiguration: probe.Probe = probe.Probe.fromTcpSocket({ port: portNumber });\n\n    this.name = props.name ?? 'main';\n    this.image = props.image;\n    this.portNumber = portNumber;\n    this._command = props.command;\n    this._args = props.args;\n    this._readiness = props.readiness;\n    this._liveness = props.liveness;\n    this._startup = props.startup ?? (this.portNumber ? defaultProbeConfiguration : undefined);\n    this._lifecycle = props.lifecycle;\n    this.resources = props.resources ?? defaultResourceSpec;\n    this.workingDir = props.workingDir;\n    this.mounts = props.volumeMounts ?? [];\n    this.imagePullPolicy = props.imagePullPolicy ?? ImagePullPolicy.ALWAYS;\n    this.securityContext = new ContainerSecurityContext(props.securityContext);\n    this.env = new Env(props.envFrom ?? [], props.envVariables ?? {});\n    this.restartPolicy = props.restartPolicy;\n\n    if (this.portNumber) {\n      this.addPort({\n        number: this.portNumber,\n      });\n    }\n\n    for (const port of props.ports ?? []) {\n      this.addPort(port);\n    }\n  }\n\n  /**\n   * @deprecated - use `portNumber`.\n   */\n  public get port(): number | undefined {\n    return this.portNumber;\n  }\n\n  /**\n   * Ports exposed by this containers.\n   * Returns a copy, use `addPort` to modify.\n   */\n  public get ports(): ContainerPort[] {\n    return [...this._ports];\n  }\n\n  /**\n   * Entrypoint array (the command to execute when the container starts).\n   * @returns a copy of the entrypoint array, cannot be modified\n   */\n  public get command(): string[] | undefined {\n    return this._command ? [...this._command] : undefined;\n  }\n\n  /**\n   * Arguments to the entrypoint.\n   *\n   * @returns a copy of the arguments array, cannot be modified.\n   */\n  public get args(): string[] | undefined {\n    return this._args ? [...this._args] : undefined;\n  }\n\n  /**\n   * Mount a volume to a specific path so that it is accessible by the container.\n   * Every pod that is configured to use this container will autmoatically have access to the volume.\n   *\n   * @param path - The desired path in the container.\n   * @param storage - The storage to mount.\n   */\n  public mount(path: string, storage: volume.IStorage, options: MountOptions = {}) {\n    this.mounts.push({ path, volume: storage.asVolume(), ...options });\n  }\n\n  /**\n   * Add a port to expose from this container.\n   */\n  public addPort(port: ContainerPort) {\n\n    const names = this._ports.map(p => p.name).filter(x => x);\n    const numberProtocols = this._ports.map(p => `${p.number}/${p.protocol || Protocol.TCP}`);\n\n    if (port.name && names.includes(port.name)) {\n      throw new Error(`Port with name ${port.name} already exists`);\n    }\n\n    const protocol = `${port.number}/${port.protocol || Protocol.TCP}`;\n    if (numberProtocols.includes(protocol)) {\n      throw new Error(`Port with number ${port.number} and protocol ${port.protocol || Protocol.TCP} already exists`);\n    }\n\n    this._ports.push(port);\n  }\n\n  /**\n   * @internal\n   */\n  public _toKube(): k8s.Container {\n    const volumeMounts: k8s.VolumeMount[] = [];\n\n    for (const mount of this.mounts) {\n      volumeMounts.push({\n        name: mount.volume.name,\n        mountPath: mount.path,\n        readOnly: mount.readOnly,\n        mountPropagation: mount.propagation,\n        subPath: mount.subPath,\n        subPathExpr: mount.subPathExpr,\n      });\n    }\n\n    const ports = new Array<k8s.ContainerPort>();\n\n    for (const port of this.ports) {\n      ports.push({\n        containerPort: port.number,\n        protocol: port.protocol?.toString(),\n        name: port.name,\n        hostPort: port.hostPort,\n        hostIp: port.hostIp,\n      });\n    }\n\n    // Resource requests and limits\n    const cpuLimit = this.resources?.cpu?.limit?.amount;\n    const cpuRequest = this.resources?.cpu?.request?.amount;\n    const memoryLimit = this.resources?.memory?.limit;\n    const memoryRequest = this.resources?.memory?.request;\n    const ephemeralStorageLimit = this.resources?.ephemeralStorage?.limit;\n    const ephemeralStorageRequest = this.resources?.ephemeralStorage?.request;\n\n    const limits: { [key: string]: k8s.Quantity } = {};\n    const requests: { [key: string]: k8s.Quantity } = {};\n\n    if (cpuLimit) {\n      limits.cpu = k8s.Quantity.fromString(cpuLimit);\n    }\n    if (memoryLimit) {\n      limits.memory = k8s.Quantity.fromString(memoryLimit.toMebibytes().toString() + 'Mi');\n    }\n    if (ephemeralStorageLimit) {\n      limits['ephemeral-storage'] = k8s.Quantity.fromString(ephemeralStorageLimit.toGibibytes().toString() + 'Gi');\n    }\n    if (cpuRequest) {\n      requests.cpu = k8s.Quantity.fromString(cpuRequest);\n    }\n    if (memoryRequest) {\n      requests.memory = k8s.Quantity.fromString(memoryRequest.toMebibytes().toString() + 'Mi');\n    }\n    if (ephemeralStorageRequest) {\n      requests['ephemeral-storage'] = k8s.Quantity.fromString(ephemeralStorageRequest.toGibibytes().toString() + 'Gi');\n    }\n\n    let resourceRequirements: k8s.ResourceRequirements | undefined = undefined;\n    if (Object.keys(limits).length > 0 || Object.keys(requests).length > 0) {\n      resourceRequirements = {\n        limits: undefinedIfEmpty(limits),\n        requests: undefinedIfEmpty(requests),\n      };\n    }\n\n    const env = this.env._toKube();\n\n    return {\n      name: this.name,\n      image: this.image,\n      imagePullPolicy: this.imagePullPolicy,\n      ports: undefinedIfEmpty(ports),\n      volumeMounts: undefinedIfEmpty(volumeMounts),\n      command: this.command,\n      args: this.args,\n      workingDir: this.workingDir,\n      env: env.variables,\n      envFrom: env.from,\n      readinessProbe: this._readiness?._toKube(this),\n      livenessProbe: this._liveness?._toKube(this),\n      startupProbe: this._startup?._toKube(this),\n      lifecycle: this._lifecycle ? {\n        postStart: this._lifecycle.postStart?._toKube(this),\n        preStop: this._lifecycle.preStop?._toKube(this),\n      } : undefined,\n      resources: resourceRequirements,\n      restartPolicy: this.restartPolicy,\n      securityContext: this.securityContext._toKube(),\n    };\n  }\n}\n\n/**\n * Options for mounts.\n */\nexport interface MountOptions {\n  /**\n   * Determines how mounts are propagated from the host to container and the\n   * other way around. When not set, MountPropagationNone is used.\n   *\n   * Mount propagation allows for sharing volumes mounted by a Container to\n   * other Containers in the same Pod, or even to other Pods on the same node.\n   *\n   * @default MountPropagation.NONE\n   */\n  readonly propagation?: MountPropagation;\n\n  /**\n   * Mounted read-only if true, read-write otherwise (false or unspecified).\n   * Defaults to false.\n   *\n   * @default false\n   */\n  readonly readOnly?: boolean;\n\n  /**\n   * Path within the volume from which the container's volume should be mounted.).\n   *\n   * @default \"\" the volume's root\n   */\n  readonly subPath?: string;\n\n  /**\n   * Expanded path within the volume from which the container's volume should be\n   * mounted. Behaves similarly to SubPath but environment variable references\n   * $(VAR_NAME) are expanded using the container's environment. Defaults to \"\"\n   * (volume's root).\n   *\n   * `subPathExpr` and `subPath` are mutually exclusive.\n   *\n   * @default \"\" volume's root.\n   */\n  readonly subPathExpr?: string;\n}\n\n/**\n * Mount a volume from the pod to the container.\n */\nexport interface VolumeMount extends MountOptions {\n  /**\n   * The volume to mount.\n   */\n  readonly volume: volume.Volume;\n\n  /**\n   * Path within the container at which the volume should be mounted. Must not\n   * contain ':'.\n   */\n  readonly path: string;\n}\n\nexport enum MountPropagation {\n  /**\n   * This volume mount will not receive any subsequent mounts that are mounted\n   * to this volume or any of its subdirectories by the host. In similar\n   * fashion, no mounts created by the Container will be visible on the host.\n   *\n   * This is the default mode.\n   *\n   * This mode is equal to `private` mount propagation as described in the Linux\n   * kernel documentation\n   */\n  NONE = 'None',\n\n  /**\n   * This volume mount will receive all subsequent mounts that are mounted to\n   * this volume or any of its subdirectories.\n   *\n   * In other words, if the host mounts anything inside the volume mount, the\n   * Container will see it mounted there.\n   *\n   * Similarly, if any Pod with Bidirectional mount propagation to the same\n   * volume mounts anything there, the Container with HostToContainer mount\n   * propagation will see it.\n   *\n   * This mode is equal to `rslave` mount propagation as described in the Linux\n   * kernel documentation\n   */\n  HOST_TO_CONTAINER = 'HostToContainer',\n\n  /**\n   * This volume mount behaves the same the HostToContainer mount. In addition,\n   * all volume mounts created by the Container will be propagated back to the\n   * host and to all Containers of all Pods that use the same volume\n   *\n   * A typical use case for this mode is a Pod with a FlexVolume or CSI driver\n   * or a Pod that needs to mount something on the host using a hostPath volume.\n   *\n   * This mode is equal to `rshared` mount propagation as described in the Linux\n   * kernel documentation\n   *\n   * Caution: Bidirectional mount propagation can be dangerous. It can damage\n   * the host operating system and therefore it is allowed only in privileged\n   * Containers. Familiarity with Linux kernel behavior is strongly recommended.\n   * In addition, any volume mounts created by Containers in Pods must be\n   * destroyed (unmounted) by the Containers on termination.\n   *\n   */\n  BIDIRECTIONAL = 'Bidirectional',\n}\n\n/**\n * CPU and memory compute resources\n */\nexport interface ContainerResources {\n  readonly cpu?: CpuResources;\n  readonly memory?: MemoryResources;\n  readonly ephemeralStorage?: EphemeralStorageResources;\n}\n\n/**\n * CPU request and limit\n */\nexport interface CpuResources {\n  readonly request?: Cpu;\n  readonly limit?: Cpu;\n}\n\n/**\n * Represents the amount of CPU.\n * The amount can be passed as millis or units.\n */\nexport class Cpu {\n  static millis(amount: number): Cpu {\n    return new Cpu(amount + 'm');\n  }\n  static units(amount: number): Cpu {\n    return new Cpu(amount.toString());\n  }\n  amount: string;\n  private constructor(amount: string) {\n    this.amount = amount;\n  }\n}\n\n/**\n * Memory request and limit\n */\nexport interface MemoryResources {\n  readonly request?: Size;\n  readonly limit?: Size;\n}\n\n/**\n * Emphemeral storage request and limit\n */\nexport interface EphemeralStorageResources {\n  readonly request?: Size;\n  readonly limit?: Size;\n}\n\n/**\n * A collection of env variables defined in other resources.\n */\nexport class EnvFrom {\n\n  constructor(\n    private readonly configMap?: configmap.IConfigMap,\n    private readonly prefix?: string,\n    private readonly sec?: secret.ISecret) { };\n\n  /**\n   * @internal\n   */\n  public _toKube(): k8s.EnvFromSource {\n    return {\n      configMapRef: this.configMap ? {\n        name: this.configMap.name,\n      } : undefined,\n      secretRef: this.sec ? {\n        name: this.sec.name,\n      } : undefined,\n      prefix: this.prefix,\n    };\n  }\n\n}\n\nexport function extractContainerPorts(selector?: any): ContainerPort[] {\n\n  if (!selector) { return []; }\n\n  // we don't use instanceof intentionally since it can create\n  // cyclic import problems.\n  const containers: Container[] = (selector as any).containers ?? [];\n\n  return containers.flatMap(c => c.ports);\n}\n\n/**\n * Container environment variables.\n */\nexport class Env {\n\n  /**\n   * Selects a ConfigMap to populate the environment variables with.\n   * The contents of the target ConfigMap's Data field will represent\n   * the key-value pairs as environment variables.\n   */\n  public static fromConfigMap(configMap: configmap.IConfigMap, prefix?: string): EnvFrom {\n    return new EnvFrom(configMap, prefix, undefined);\n  }\n\n  /**\n   * Selects a Secret to populate the environment variables with.\n   * The contents of the target Secret's Data field will represent\n   * the key-value pairs as environment variables.\n   */\n  public static fromSecret(secr: secret.ISecret): EnvFrom {\n    return new EnvFrom(undefined, undefined, secr);\n  }\n\n  private readonly _sources: EnvFrom[];\n  private readonly _variables: { [key: string]: EnvValue };\n\n  public constructor(sources: EnvFrom[], variables: { [name: string]: EnvValue }) {\n    this._sources = sources;\n    this._variables = variables;\n  }\n\n  /**\n   * Add a single variable by name and value.\n   * The variable value can come from various dynamic sources such a secrets of config maps.\n   * Use `EnvValue.fromXXX` to select sources.\n   */\n  public addVariable(name: string, value: EnvValue) {\n    this._variables[name] = value;\n  }\n\n  /**\n   * The environment variables for this container.\n   * Returns a copy. To add environment variables use `container.env.addVariable()`.\n   */\n  public get variables(): { [name: string]: EnvValue } {\n    return { ...this._variables };\n  }\n\n  /**\n   * Add a collection of variables by copying from another source.\n   * Use `Env.fromXXX` functions to select sources.\n   */\n  public copyFrom(from: EnvFrom) {\n    this._sources.push(from);\n  }\n\n  /**\n   * The list of sources used to populate the container environment,\n   * in addition to the `variables`.\n   *\n   * Returns a copy. To add a source use `container.env.copyFrom()`.\n   */\n  public get sources(): EnvFrom[] {\n    return [...this._sources];\n  }\n\n  private renderEnv(env: { [name: string]: EnvValue }): k8s.EnvVar[] {\n    const result = new Array<k8s.EnvVar>();\n    for (const [name, v] of Object.entries(env)) {\n      result.push({\n        name,\n        value: v.value,\n        valueFrom: v.valueFrom,\n      });\n    }\n    return result;\n  }\n\n  /**\n   * @internal\n   */\n  public _toKube(): { variables?: k8s.EnvVar[]; from?: k8s.EnvFromSource[] } {\n    return {\n      from: undefinedIfEmpty(this._sources.map(s => s._toKube())),\n      variables: undefinedIfEmpty(this.renderEnv(this._variables)),\n    };\n  }\n}\n"]}
package/lib/cron-job.js CHANGED
@@ -99,5 +99,5 @@ class CronJob extends workload.Workload {
99
99
  }
100
100
  exports.CronJob = CronJob;
101
101
  _a = JSII_RTTI_SYMBOL_1;
102
- CronJob[_a] = { fqn: "cdk8s-plus-32.CronJob", version: "2.4.13" };
102
+ CronJob[_a] = { fqn: "cdk8s-plus-32.CronJob", version: "2.5.0" };
103
103
  //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cron-job.js","sourceRoot":"","sources":["../src/cron-job.ts"],"names":[],"mappings":"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","sourcesContent":["import { ApiObject, Duration, Lazy, Cron } from 'cdk8s';\nimport { Construct } from 'constructs';\nimport * as k8s from './imports/k8s';\nimport { JobProps } from './job';\nimport { RestartPolicy } from './pod';\nimport * as workload from './workload';\n\n/**\n * Concurrency policy for CronJobs.\n */\nexport enum ConcurrencyPolicy {\n  /**\n   * This policy allows to run job concurrently.\n   */\n  ALLOW = 'Allow',\n  /**\n   * This policy does not allow to run job concurrently. It does not let a new job to be scheduled if the previous one is not finished yet.\n   */\n  FORBID = 'Forbid',\n  /**\n   * This policy replaces the currently running job if a new job is being scheduled.\n   */\n  REPLACE = 'Replace',\n}\n\n/**\n * Properties for `CronJob`.\n */\nexport interface CronJobProps extends JobProps {\n  /**\n   * Specifies the time in which the job would run again. This is defined as a cron expression in the CronJob resource.\n   */\n  readonly schedule: Cron;\n\n  /**\n   * Specifies the timezone for the job. This helps aligining the schedule to follow the specified timezone.\n   *\n   * @see {@link https://en.wikipedia.org/wiki/List_of_tz_database_time_zones} for list of valid timezone values.\n   *\n   * @default - Timezone of kube-controller-manager process.\n   */\n  readonly timeZone?: string;\n\n  /**\n   * Specifies the concurrency policy for the job.\n   *\n   * @default ConcurrencyPolicy.Forbid\n   */\n  readonly concurrencyPolicy?: ConcurrencyPolicy;\n\n  /**\n   * Kubernetes attempts to start cron jobs at its schedule time, but this is not guaranteed. This deadline specifies\n   * how much time can pass after a schedule point, for which kubernetes can still start the job.\n   * For example, if this is set to 100 seconds, kubernetes is allowed to start the job at a maximum 100 seconds after\n   * the scheduled time.\n   *\n   * Note that the Kubernetes CronJobController checks for things every 10 seconds, for this reason, a deadline below 10\n   * seconds is not allowed, as it may cause your job to never be scheduled.\n   *\n   * In addition, kubernetes will stop scheduling jobs if more than 100 schedules were missed (for any reason).\n   * This property also controls what time interval should kubernetes consider when counting for missed schedules.\n   *\n   * For example, suppose a CronJob is set to schedule a new Job every one minute beginning at 08:30:00,\n   * and its `startingDeadline` field is not set. If the CronJob controller happens to be down from 08:29:00 to 10:21:00,\n   * the job will not start as the number of missed jobs which missed their schedule is greater than 100.\n   * However, if `startingDeadline` is set to 200 seconds, kubernetes will only count 3 missed schedules, and thus\n   * start a new execution at 10:22:00.\n   *\n   * @default Duration.seconds(10)\n   */\n  readonly startingDeadline?: Duration;\n\n  /**\n   * Specifies if the cron job should be suspended. Only applies to future executions, current ones are remained untouched.\n   *\n   * @default false\n   */\n  readonly suspend?: boolean;\n\n  /**\n   * Specifies the number of successful jobs history retained. This would retain the Job and the associated Pod resource and can be useful for debugging.\n   *\n   * @default 3\n   */\n  readonly successfulJobsRetained?: number;\n\n  /**\n   * Specifies the number of failed jobs history retained. This would retain the Job and the associated Pod resource and can be useful for debugging.\n   *\n   * @default 1\n   */\n  readonly failedJobsRetained?: number;\n}\n\n/**\n * A CronJob is responsible for creating a Job and scheduling it based on provided cron schedule. This helps running Jobs in a recurring manner.\n */\nexport class CronJob extends workload.Workload {\n  /**\n   * The schedule this cron job is scheduled to run in.\n   */\n  public readonly schedule: Cron;\n\n  /**\n   * The timezone which this cron job would follow to schedule jobs.\n   */\n  public readonly timeZone?: string;\n\n  /**\n   * The policy used by this cron job to determine the concurrency mode in which to schedule jobs.\n   */\n  public readonly concurrencyPolicy: string;\n\n  /**\n   * The time by which the running cron job needs to schedule the next job execution. The job is considered as failed if it misses this deadline.\n   */\n  public readonly startingDeadline: Duration;\n\n  /**\n   * Whether or not the cron job is currently suspended or not.\n   */\n  public readonly suspend: boolean;\n\n  /**\n   * The number of successful jobs retained by this cron job.\n   */\n  public readonly successfulJobsRetained: number;\n\n  /**\n   * The number of failed jobs retained by this cron job.\n   */\n  public readonly failedJobsRetained: number;\n\n  /**\n   * The properties of the recurring `Job` that this cronjob will schedule.\n   */\n  private readonly jobProperties: JobProps;\n\n  /**\n   * @see base.Resource.apiObject\n   */\n  protected readonly apiObject: ApiObject;\n\n  /**\n   * Represents the resource type.\n   */\n  public readonly resourceType = 'cronjob';\n\n  constructor(scope: Construct, id: string, props: CronJobProps) {\n    super(scope, id, {\n      restartPolicy: RestartPolicy.NEVER,\n      select: false,\n      ...props,\n    });\n\n    this.apiObject = new k8s.KubeCronJob(this, 'Resource', {\n      metadata: props.metadata,\n      spec: Lazy.any({ produce: () => this._toKube() }),\n    });\n\n    if (props.startingDeadline != undefined && props.startingDeadline.toSeconds() < 10) {\n      throw new Error(`The 'startingDeadline' property cannot be less than 10 seconds since the Kubernetes CronJobController checks things every 10 seconds and hence the CronJob may not be scheduled. The value passed is: ${props.startingDeadline}`);\n    }\n\n    if (props.ttlAfterFinished != undefined && (props.successfulJobsRetained != undefined || props.failedJobsRetained != undefined)) {\n      throw new Error('The \\'ttlAfterFinished\\' property cannot be set if \\'successfulJobsRetained\\' property or \\'failedJobsRetained\\' property is set. This would cause the retention of jobs to not work properly since it would delete the job based on its value.');\n    }\n\n    if (this.isolate) {\n      this.connections.isolate();\n    }\n\n    this.schedule = props.schedule;\n    this.timeZone = props.timeZone;\n    this.concurrencyPolicy = props.concurrencyPolicy ?? ConcurrencyPolicy.FORBID;\n    this.startingDeadline = props.startingDeadline ?? Duration.seconds(10);\n    this.suspend = props.suspend ?? false;\n    this.successfulJobsRetained = props.successfulJobsRetained ?? 3;\n    this.failedJobsRetained = props.failedJobsRetained ?? 1;\n    this.jobProperties = {\n      activeDeadline: props.activeDeadline,\n      backoffLimit: props.backoffLimit,\n      ttlAfterFinished: props.ttlAfterFinished,\n    };\n  }\n\n  /**\n   * @internal\n   */\n  public _toKube(): k8s.CronJobSpec {\n    return {\n      concurrencyPolicy: this.concurrencyPolicy,\n      failedJobsHistoryLimit: this.failedJobsRetained,\n      jobTemplate: {\n        spec: this._toJobSpec(),\n      },\n      schedule: this.schedule.expressionString,\n      startingDeadlineSeconds: this.startingDeadline.toSeconds(),\n      successfulJobsHistoryLimit: this.successfulJobsRetained,\n      suspend: this.suspend,\n      timeZone: this.timeZone,\n    };\n  }\n\n  /**\n   * Returns the job spec.\n   */\n  private _toJobSpec(): k8s.JobSpec {\n    return {\n      template: {\n        metadata: this.podMetadata.toJson(),\n        spec: this._toPodSpec(),\n      },\n      activeDeadlineSeconds: this.jobProperties.activeDeadline?.toSeconds(),\n      backoffLimit: this.jobProperties.backoffLimit,\n      ttlSecondsAfterFinished: this.jobProperties.ttlAfterFinished?.toSeconds(),\n    };\n  }\n}"]}