cdk8s-plus-31 2.0.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.
- package/.backportrc.json +17 -0
- package/.jsii +90235 -0
- package/CODE_OF_CONDUCT.md +3 -0
- package/CONTRIBUTING.md +185 -0
- package/DCO +34 -0
- package/LICENSE +202 -0
- package/NOTICE +1 -0
- package/OWNERS.md +5 -0
- package/README.md +32 -0
- package/SECURITY.md +5 -0
- package/cdk8s.yaml +8 -0
- package/docs/java.md +23855 -0
- package/docs/plus/config-map.md +98 -0
- package/docs/plus/container.md +133 -0
- package/docs/plus/cronjob.md +67 -0
- package/docs/plus/deployment.md +232 -0
- package/docs/plus/horizontal-pod-autoscaler.md +226 -0
- package/docs/plus/ingress.md +68 -0
- package/docs/plus/job.md +48 -0
- package/docs/plus/namespace.md +58 -0
- package/docs/plus/network-policy.md +341 -0
- package/docs/plus/pod.md +455 -0
- package/docs/plus/pv.md +82 -0
- package/docs/plus/pvc.md +77 -0
- package/docs/plus/rbac.md +104 -0
- package/docs/plus/secret.md +32 -0
- package/docs/plus/service-account.md +35 -0
- package/docs/plus/service.md +41 -0
- package/docs/plus/volume.md +38 -0
- package/docs/python.md +26079 -0
- package/docs/typescript.md +19565 -0
- package/git-hooks/README.md +9 -0
- package/git-hooks/prepare-commit-msg +18 -0
- package/git-hooks/setup.sh +10 -0
- package/lib/_action.d.ts +21 -0
- package/lib/_action.js +32 -0
- package/lib/api-resource.d.ts +298 -0
- package/lib/api-resource.js +430 -0
- package/lib/base.d.ts +79 -0
- package/lib/base.js +92 -0
- package/lib/config-map.d.ts +126 -0
- package/lib/config-map.js +159 -0
- package/lib/container.d.ts +1057 -0
- package/lib/container.js +845 -0
- package/lib/cron-job.d.ts +138 -0
- package/lib/cron-job.js +103 -0
- package/lib/daemon-set.d.ts +45 -0
- package/lib/daemon-set.js +55 -0
- package/lib/deployment.d.ts +223 -0
- package/lib/deployment.js +214 -0
- package/lib/handler.d.ts +62 -0
- package/lib/handler.js +54 -0
- package/lib/horizontal-pod-autoscaler.d.ts +500 -0
- package/lib/horizontal-pod-autoscaler.js +569 -0
- package/lib/imports/k8s.d.ts +21534 -0
- package/lib/imports/k8s.js +16496 -0
- package/lib/index.d.ts +26 -0
- package/lib/index.js +39 -0
- package/lib/ingress.d.ts +230 -0
- package/lib/ingress.js +246 -0
- package/lib/job.d.ts +64 -0
- package/lib/job.js +54 -0
- package/lib/namespace.d.ts +128 -0
- package/lib/namespace.js +109 -0
- package/lib/network-policy.d.ts +311 -0
- package/lib/network-policy.js +344 -0
- package/lib/pod.d.ts +1080 -0
- package/lib/pod.js +1139 -0
- package/lib/probe.d.ts +141 -0
- package/lib/probe.js +77 -0
- package/lib/pv.d.ts +375 -0
- package/lib/pv.js +273 -0
- package/lib/pvc.d.ts +163 -0
- package/lib/pvc.js +152 -0
- package/lib/role-binding.d.ts +138 -0
- package/lib/role-binding.js +165 -0
- package/lib/role.d.ts +268 -0
- package/lib/role.js +401 -0
- package/lib/secret.d.ts +195 -0
- package/lib/secret.js +185 -0
- package/lib/service-account.d.ts +83 -0
- package/lib/service-account.js +105 -0
- package/lib/service.d.ts +289 -0
- package/lib/service.js +182 -0
- package/lib/stateful-set.d.ts +169 -0
- package/lib/stateful-set.js +174 -0
- package/lib/utils.d.ts +4 -0
- package/lib/utils.js +34 -0
- package/lib/volume.d.ts +573 -0
- package/lib/volume.js +371 -0
- package/lib/workload.d.ts +121 -0
- package/lib/workload.js +122 -0
- package/node_modules/balanced-match/.github/FUNDING.yml +2 -0
- package/node_modules/balanced-match/LICENSE.md +21 -0
- package/node_modules/balanced-match/README.md +97 -0
- package/node_modules/balanced-match/index.js +62 -0
- package/node_modules/balanced-match/package.json +48 -0
- package/node_modules/concat-map/.travis.yml +4 -0
- package/node_modules/concat-map/LICENSE +18 -0
- package/node_modules/concat-map/README.markdown +62 -0
- package/node_modules/concat-map/example/map.js +6 -0
- package/node_modules/concat-map/index.js +13 -0
- package/node_modules/concat-map/package.json +43 -0
- package/node_modules/concat-map/test/map.js +39 -0
- package/node_modules/minimatch/LICENSE +15 -0
- package/node_modules/minimatch/README.md +230 -0
- package/node_modules/minimatch/minimatch.js +947 -0
- package/node_modules/minimatch/node_modules/brace-expansion/LICENSE +21 -0
- package/node_modules/minimatch/node_modules/brace-expansion/README.md +129 -0
- package/node_modules/minimatch/node_modules/brace-expansion/index.js +201 -0
- package/node_modules/minimatch/node_modules/brace-expansion/package.json +47 -0
- package/node_modules/minimatch/package.json +33 -0
- package/package.json +186 -0
- package/rotate.md +84 -0
|
@@ -0,0 +1,126 @@
|
|
|
1
|
+
import { ApiObject } from 'cdk8s';
|
|
2
|
+
import { Construct } from 'constructs';
|
|
3
|
+
import * as base from './base';
|
|
4
|
+
/**
|
|
5
|
+
* Properties for initialization of `ConfigMap`.
|
|
6
|
+
*/
|
|
7
|
+
export interface ConfigMapProps extends base.ResourceProps {
|
|
8
|
+
/**
|
|
9
|
+
* BinaryData contains the binary data.
|
|
10
|
+
*
|
|
11
|
+
* Each key must consist of alphanumeric characters, '-', '_' or '.'.
|
|
12
|
+
* BinaryData can contain byte sequences that are not in the UTF-8 range. The
|
|
13
|
+
* keys stored in BinaryData must not overlap with the ones in the Data field,
|
|
14
|
+
* this is enforced during validation process.
|
|
15
|
+
*
|
|
16
|
+
* You can also add binary data using `configMap.addBinaryData()`.
|
|
17
|
+
*/
|
|
18
|
+
readonly binaryData?: {
|
|
19
|
+
[key: string]: string;
|
|
20
|
+
};
|
|
21
|
+
/**
|
|
22
|
+
* Data contains the configuration data.
|
|
23
|
+
*
|
|
24
|
+
* Each key must consist of alphanumeric characters, '-', '_' or '.'. Values
|
|
25
|
+
* with non-UTF-8 byte sequences must use the BinaryData field. The keys
|
|
26
|
+
* stored in Data must not overlap with the keys in the BinaryData field, this
|
|
27
|
+
* is enforced during validation process.
|
|
28
|
+
*
|
|
29
|
+
* You can also add data using `configMap.addData()`.
|
|
30
|
+
*/
|
|
31
|
+
readonly data?: {
|
|
32
|
+
[key: string]: string;
|
|
33
|
+
};
|
|
34
|
+
/**
|
|
35
|
+
* If set to true, ensures that data stored in the ConfigMap cannot be updated (only object metadata can be modified).
|
|
36
|
+
* If not set to true, the field can be modified at any time.
|
|
37
|
+
*
|
|
38
|
+
* @default false
|
|
39
|
+
*/
|
|
40
|
+
readonly immutable?: boolean;
|
|
41
|
+
}
|
|
42
|
+
/**
|
|
43
|
+
* Represents a config map.
|
|
44
|
+
*/
|
|
45
|
+
export interface IConfigMap extends base.IResource {
|
|
46
|
+
}
|
|
47
|
+
/**
|
|
48
|
+
* ConfigMap holds configuration data for pods to consume.
|
|
49
|
+
*/
|
|
50
|
+
export declare class ConfigMap extends base.Resource implements IConfigMap {
|
|
51
|
+
/**
|
|
52
|
+
* Represents a ConfigMap created elsewhere.
|
|
53
|
+
*/
|
|
54
|
+
static fromConfigMapName(scope: Construct, id: string, name: string): IConfigMap;
|
|
55
|
+
/**
|
|
56
|
+
* @see base.Resource.apiObject
|
|
57
|
+
*/
|
|
58
|
+
protected readonly apiObject: ApiObject;
|
|
59
|
+
readonly resourceType = "configmaps";
|
|
60
|
+
private readonly _binaryData;
|
|
61
|
+
private readonly _data;
|
|
62
|
+
/**
|
|
63
|
+
* Whether or not this config map is immutable.
|
|
64
|
+
*/
|
|
65
|
+
readonly immutable: boolean;
|
|
66
|
+
constructor(scope: Construct, id: string, props?: ConfigMapProps);
|
|
67
|
+
/**
|
|
68
|
+
* Adds a data entry to the config map.
|
|
69
|
+
* @param key The key
|
|
70
|
+
* @param value The value
|
|
71
|
+
*
|
|
72
|
+
* @throws if there is either a `data` or `binaryData` entry with the same key
|
|
73
|
+
*/
|
|
74
|
+
addData(key: string, value: string): void;
|
|
75
|
+
/**
|
|
76
|
+
* The data associated with this config map.
|
|
77
|
+
*
|
|
78
|
+
* Returns an copy. To add data records, use `addData()` or `addBinaryData()`.
|
|
79
|
+
*/
|
|
80
|
+
get data(): Record<string, string>;
|
|
81
|
+
/**
|
|
82
|
+
* Adds a binary data entry to the config map. BinaryData can contain byte
|
|
83
|
+
* sequences that are not in the UTF-8 range.
|
|
84
|
+
* @param key The key
|
|
85
|
+
* @param value The value
|
|
86
|
+
*
|
|
87
|
+
* @throws if there is either a `data` or `binaryData` entry with the same key
|
|
88
|
+
*/
|
|
89
|
+
addBinaryData(key: string, value: string): void;
|
|
90
|
+
/**
|
|
91
|
+
* The binary data associated with this config map.
|
|
92
|
+
*
|
|
93
|
+
* Returns a copy. To add data records, use `addBinaryData()` or `addData()`.
|
|
94
|
+
*/
|
|
95
|
+
get binaryData(): Record<string, string>;
|
|
96
|
+
/**
|
|
97
|
+
* Adds a file to the ConfigMap.
|
|
98
|
+
* @param localFile The path to the local file
|
|
99
|
+
* @param key The ConfigMap key (default to the file name).
|
|
100
|
+
*/
|
|
101
|
+
addFile(localFile: string, key?: string): void;
|
|
102
|
+
/**
|
|
103
|
+
* Adds a directory to the ConfigMap.
|
|
104
|
+
* @param localDir A path to a local directory
|
|
105
|
+
* @param options Options
|
|
106
|
+
*/
|
|
107
|
+
addDirectory(localDir: string, options?: AddDirectoryOptions): void;
|
|
108
|
+
private verifyKeyAvailable;
|
|
109
|
+
private synthesizeData;
|
|
110
|
+
private synthesizeBinaryData;
|
|
111
|
+
}
|
|
112
|
+
/**
|
|
113
|
+
* Options for `configmap.addDirectory()`
|
|
114
|
+
*/
|
|
115
|
+
export interface AddDirectoryOptions {
|
|
116
|
+
/**
|
|
117
|
+
* A prefix to add to all keys in the config map.
|
|
118
|
+
* @default ""
|
|
119
|
+
*/
|
|
120
|
+
readonly keyPrefix?: string;
|
|
121
|
+
/**
|
|
122
|
+
* Glob patterns to exclude when adding files.
|
|
123
|
+
* @default - include all files
|
|
124
|
+
*/
|
|
125
|
+
readonly exclude?: string[];
|
|
126
|
+
}
|
|
@@ -0,0 +1,159 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var _a;
|
|
3
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
4
|
+
exports.ConfigMap = void 0;
|
|
5
|
+
const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
|
|
6
|
+
const configmap = require("fs");
|
|
7
|
+
const path = require("path");
|
|
8
|
+
const cdk8s_1 = require("cdk8s");
|
|
9
|
+
const constructs_1 = require("constructs");
|
|
10
|
+
const minimatch_1 = require("minimatch");
|
|
11
|
+
const base = require("./base");
|
|
12
|
+
const k8s = require("./imports/k8s");
|
|
13
|
+
const utils_1 = require("./utils");
|
|
14
|
+
class ImportedConfigMap extends constructs_1.Construct {
|
|
15
|
+
constructor(scope, id, name) {
|
|
16
|
+
super(scope, id);
|
|
17
|
+
this.resourceType = 'configmaps';
|
|
18
|
+
this._name = name;
|
|
19
|
+
}
|
|
20
|
+
get name() {
|
|
21
|
+
return this._name;
|
|
22
|
+
}
|
|
23
|
+
get apiVersion() {
|
|
24
|
+
return k8s.KubeConfigMap.GVK.apiVersion;
|
|
25
|
+
}
|
|
26
|
+
get apiGroup() {
|
|
27
|
+
return '';
|
|
28
|
+
}
|
|
29
|
+
get kind() {
|
|
30
|
+
return k8s.KubeConfigMap.GVK.kind;
|
|
31
|
+
}
|
|
32
|
+
get resourceName() {
|
|
33
|
+
return this.name;
|
|
34
|
+
}
|
|
35
|
+
}
|
|
36
|
+
/**
|
|
37
|
+
* ConfigMap holds configuration data for pods to consume.
|
|
38
|
+
*/
|
|
39
|
+
class ConfigMap extends base.Resource {
|
|
40
|
+
constructor(scope, id, props = {}) {
|
|
41
|
+
super(scope, id);
|
|
42
|
+
this.resourceType = 'configmaps';
|
|
43
|
+
this._binaryData = {};
|
|
44
|
+
this._data = {};
|
|
45
|
+
this.immutable = props.immutable ?? false;
|
|
46
|
+
this.apiObject = new k8s.KubeConfigMap(this, 'Resource', {
|
|
47
|
+
metadata: props.metadata,
|
|
48
|
+
// we need lazy here because we filter empty
|
|
49
|
+
data: cdk8s_1.Lazy.any({ produce: () => this.synthesizeData() }),
|
|
50
|
+
binaryData: cdk8s_1.Lazy.any({ produce: () => this.synthesizeBinaryData() }),
|
|
51
|
+
immutable: this.immutable,
|
|
52
|
+
});
|
|
53
|
+
for (const [k, v] of Object.entries(props.data ?? {})) {
|
|
54
|
+
this.addData(k, v);
|
|
55
|
+
}
|
|
56
|
+
for (const [k, v] of Object.entries(props.binaryData ?? {})) {
|
|
57
|
+
this.addBinaryData(k, v);
|
|
58
|
+
}
|
|
59
|
+
}
|
|
60
|
+
/**
|
|
61
|
+
* Represents a ConfigMap created elsewhere.
|
|
62
|
+
*/
|
|
63
|
+
static fromConfigMapName(scope, id, name) {
|
|
64
|
+
return new ImportedConfigMap(scope, id, name);
|
|
65
|
+
}
|
|
66
|
+
/**
|
|
67
|
+
* Adds a data entry to the config map.
|
|
68
|
+
* @param key The key
|
|
69
|
+
* @param value The value
|
|
70
|
+
*
|
|
71
|
+
* @throws if there is either a `data` or `binaryData` entry with the same key
|
|
72
|
+
*/
|
|
73
|
+
addData(key, value) {
|
|
74
|
+
this.verifyKeyAvailable(key);
|
|
75
|
+
this._data[key] = value;
|
|
76
|
+
}
|
|
77
|
+
/**
|
|
78
|
+
* The data associated with this config map.
|
|
79
|
+
*
|
|
80
|
+
* Returns an copy. To add data records, use `addData()` or `addBinaryData()`.
|
|
81
|
+
*/
|
|
82
|
+
get data() {
|
|
83
|
+
return { ...this._data };
|
|
84
|
+
}
|
|
85
|
+
/**
|
|
86
|
+
* Adds a binary data entry to the config map. BinaryData can contain byte
|
|
87
|
+
* sequences that are not in the UTF-8 range.
|
|
88
|
+
* @param key The key
|
|
89
|
+
* @param value The value
|
|
90
|
+
*
|
|
91
|
+
* @throws if there is either a `data` or `binaryData` entry with the same key
|
|
92
|
+
*/
|
|
93
|
+
addBinaryData(key, value) {
|
|
94
|
+
this.verifyKeyAvailable(key);
|
|
95
|
+
this._binaryData[key] = value;
|
|
96
|
+
}
|
|
97
|
+
/**
|
|
98
|
+
* The binary data associated with this config map.
|
|
99
|
+
*
|
|
100
|
+
* Returns a copy. To add data records, use `addBinaryData()` or `addData()`.
|
|
101
|
+
*/
|
|
102
|
+
get binaryData() {
|
|
103
|
+
return { ...this._binaryData };
|
|
104
|
+
}
|
|
105
|
+
/**
|
|
106
|
+
* Adds a file to the ConfigMap.
|
|
107
|
+
* @param localFile The path to the local file
|
|
108
|
+
* @param key The ConfigMap key (default to the file name).
|
|
109
|
+
*/
|
|
110
|
+
addFile(localFile, key) {
|
|
111
|
+
key = key ?? path.basename(localFile);
|
|
112
|
+
const value = configmap.readFileSync(localFile, 'utf-8');
|
|
113
|
+
this.addData(key, value);
|
|
114
|
+
}
|
|
115
|
+
/**
|
|
116
|
+
* Adds a directory to the ConfigMap.
|
|
117
|
+
* @param localDir A path to a local directory
|
|
118
|
+
* @param options Options
|
|
119
|
+
*/
|
|
120
|
+
addDirectory(localDir, options = {}) {
|
|
121
|
+
const exclude = options.exclude ?? [];
|
|
122
|
+
const shouldInclude = (file) => {
|
|
123
|
+
for (const pattern of exclude) {
|
|
124
|
+
const mm = new minimatch_1.Minimatch(pattern);
|
|
125
|
+
if (mm.match(file)) {
|
|
126
|
+
return false;
|
|
127
|
+
}
|
|
128
|
+
}
|
|
129
|
+
return true;
|
|
130
|
+
};
|
|
131
|
+
const keyPrefix = options.keyPrefix ?? '';
|
|
132
|
+
for (const file of configmap.readdirSync(localDir)) {
|
|
133
|
+
const filePath = path.join(localDir, file);
|
|
134
|
+
if (configmap.statSync(filePath).isDirectory()) {
|
|
135
|
+
continue;
|
|
136
|
+
}
|
|
137
|
+
if (!shouldInclude(file)) {
|
|
138
|
+
continue;
|
|
139
|
+
}
|
|
140
|
+
const relativeFilePath = keyPrefix + file;
|
|
141
|
+
this.addFile(filePath, relativeFilePath);
|
|
142
|
+
}
|
|
143
|
+
}
|
|
144
|
+
verifyKeyAvailable(key) {
|
|
145
|
+
if (key in this._data || key in this._binaryData) {
|
|
146
|
+
throw new Error(`unable to add a ConfigMap entry with key "${key}". It is already used`);
|
|
147
|
+
}
|
|
148
|
+
}
|
|
149
|
+
synthesizeData() {
|
|
150
|
+
return utils_1.undefinedIfEmpty(this._data);
|
|
151
|
+
}
|
|
152
|
+
synthesizeBinaryData() {
|
|
153
|
+
return utils_1.undefinedIfEmpty(this._binaryData);
|
|
154
|
+
}
|
|
155
|
+
}
|
|
156
|
+
exports.ConfigMap = ConfigMap;
|
|
157
|
+
_a = JSII_RTTI_SYMBOL_1;
|
|
158
|
+
ConfigMap[_a] = { fqn: "cdk8s-plus-31.ConfigMap", version: "2.0.0" };
|
|
159
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"config-map.js","sourceRoot":"","sources":["../src/config-map.ts"],"names":[],"mappings":"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","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"]}
|