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.
Files changed (114) hide show
  1. package/.backportrc.json +17 -0
  2. package/.jsii +90235 -0
  3. package/CODE_OF_CONDUCT.md +3 -0
  4. package/CONTRIBUTING.md +185 -0
  5. package/DCO +34 -0
  6. package/LICENSE +202 -0
  7. package/NOTICE +1 -0
  8. package/OWNERS.md +5 -0
  9. package/README.md +32 -0
  10. package/SECURITY.md +5 -0
  11. package/cdk8s.yaml +8 -0
  12. package/docs/java.md +23855 -0
  13. package/docs/plus/config-map.md +98 -0
  14. package/docs/plus/container.md +133 -0
  15. package/docs/plus/cronjob.md +67 -0
  16. package/docs/plus/deployment.md +232 -0
  17. package/docs/plus/horizontal-pod-autoscaler.md +226 -0
  18. package/docs/plus/ingress.md +68 -0
  19. package/docs/plus/job.md +48 -0
  20. package/docs/plus/namespace.md +58 -0
  21. package/docs/plus/network-policy.md +341 -0
  22. package/docs/plus/pod.md +455 -0
  23. package/docs/plus/pv.md +82 -0
  24. package/docs/plus/pvc.md +77 -0
  25. package/docs/plus/rbac.md +104 -0
  26. package/docs/plus/secret.md +32 -0
  27. package/docs/plus/service-account.md +35 -0
  28. package/docs/plus/service.md +41 -0
  29. package/docs/plus/volume.md +38 -0
  30. package/docs/python.md +26079 -0
  31. package/docs/typescript.md +19565 -0
  32. package/git-hooks/README.md +9 -0
  33. package/git-hooks/prepare-commit-msg +18 -0
  34. package/git-hooks/setup.sh +10 -0
  35. package/lib/_action.d.ts +21 -0
  36. package/lib/_action.js +32 -0
  37. package/lib/api-resource.d.ts +298 -0
  38. package/lib/api-resource.js +430 -0
  39. package/lib/base.d.ts +79 -0
  40. package/lib/base.js +92 -0
  41. package/lib/config-map.d.ts +126 -0
  42. package/lib/config-map.js +159 -0
  43. package/lib/container.d.ts +1057 -0
  44. package/lib/container.js +845 -0
  45. package/lib/cron-job.d.ts +138 -0
  46. package/lib/cron-job.js +103 -0
  47. package/lib/daemon-set.d.ts +45 -0
  48. package/lib/daemon-set.js +55 -0
  49. package/lib/deployment.d.ts +223 -0
  50. package/lib/deployment.js +214 -0
  51. package/lib/handler.d.ts +62 -0
  52. package/lib/handler.js +54 -0
  53. package/lib/horizontal-pod-autoscaler.d.ts +500 -0
  54. package/lib/horizontal-pod-autoscaler.js +569 -0
  55. package/lib/imports/k8s.d.ts +21534 -0
  56. package/lib/imports/k8s.js +16496 -0
  57. package/lib/index.d.ts +26 -0
  58. package/lib/index.js +39 -0
  59. package/lib/ingress.d.ts +230 -0
  60. package/lib/ingress.js +246 -0
  61. package/lib/job.d.ts +64 -0
  62. package/lib/job.js +54 -0
  63. package/lib/namespace.d.ts +128 -0
  64. package/lib/namespace.js +109 -0
  65. package/lib/network-policy.d.ts +311 -0
  66. package/lib/network-policy.js +344 -0
  67. package/lib/pod.d.ts +1080 -0
  68. package/lib/pod.js +1139 -0
  69. package/lib/probe.d.ts +141 -0
  70. package/lib/probe.js +77 -0
  71. package/lib/pv.d.ts +375 -0
  72. package/lib/pv.js +273 -0
  73. package/lib/pvc.d.ts +163 -0
  74. package/lib/pvc.js +152 -0
  75. package/lib/role-binding.d.ts +138 -0
  76. package/lib/role-binding.js +165 -0
  77. package/lib/role.d.ts +268 -0
  78. package/lib/role.js +401 -0
  79. package/lib/secret.d.ts +195 -0
  80. package/lib/secret.js +185 -0
  81. package/lib/service-account.d.ts +83 -0
  82. package/lib/service-account.js +105 -0
  83. package/lib/service.d.ts +289 -0
  84. package/lib/service.js +182 -0
  85. package/lib/stateful-set.d.ts +169 -0
  86. package/lib/stateful-set.js +174 -0
  87. package/lib/utils.d.ts +4 -0
  88. package/lib/utils.js +34 -0
  89. package/lib/volume.d.ts +573 -0
  90. package/lib/volume.js +371 -0
  91. package/lib/workload.d.ts +121 -0
  92. package/lib/workload.js +122 -0
  93. package/node_modules/balanced-match/.github/FUNDING.yml +2 -0
  94. package/node_modules/balanced-match/LICENSE.md +21 -0
  95. package/node_modules/balanced-match/README.md +97 -0
  96. package/node_modules/balanced-match/index.js +62 -0
  97. package/node_modules/balanced-match/package.json +48 -0
  98. package/node_modules/concat-map/.travis.yml +4 -0
  99. package/node_modules/concat-map/LICENSE +18 -0
  100. package/node_modules/concat-map/README.markdown +62 -0
  101. package/node_modules/concat-map/example/map.js +6 -0
  102. package/node_modules/concat-map/index.js +13 -0
  103. package/node_modules/concat-map/package.json +43 -0
  104. package/node_modules/concat-map/test/map.js +39 -0
  105. package/node_modules/minimatch/LICENSE +15 -0
  106. package/node_modules/minimatch/README.md +230 -0
  107. package/node_modules/minimatch/minimatch.js +947 -0
  108. package/node_modules/minimatch/node_modules/brace-expansion/LICENSE +21 -0
  109. package/node_modules/minimatch/node_modules/brace-expansion/README.md +129 -0
  110. package/node_modules/minimatch/node_modules/brace-expansion/index.js +201 -0
  111. package/node_modules/minimatch/node_modules/brace-expansion/package.json +47 -0
  112. package/node_modules/minimatch/package.json +33 -0
  113. package/package.json +186 -0
  114. package/rotate.md +84 -0
package/lib/probe.d.ts ADDED
@@ -0,0 +1,141 @@
1
+ import { Duration } from 'cdk8s';
2
+ import * as container from './container';
3
+ import * as k8s from './imports/k8s';
4
+ /**
5
+ * Probe options.
6
+ */
7
+ export interface ProbeOptions {
8
+ /**
9
+ * Minimum consecutive failures for the probe to be considered failed after
10
+ * having succeeded.
11
+ *
12
+ * Defaults to 3. Minimum value is 1.
13
+ *
14
+ * @default 3
15
+ */
16
+ readonly failureThreshold?: number;
17
+ /**
18
+ * Number of seconds after the container has started before liveness probes
19
+ * are initiated.
20
+ *
21
+ * @see https://kubernetes.io/docs/concepts/workloads/pods/pod-lifecycle#container-probes
22
+ * @default - immediate
23
+ */
24
+ readonly initialDelaySeconds?: Duration;
25
+ /**
26
+ * How often (in seconds) to perform the probe.
27
+ *
28
+ * Default to 10 seconds. Minimum value is 1.
29
+ *
30
+ * @default Duration.seconds(10) Minimum value is 1.
31
+ */
32
+ readonly periodSeconds?: Duration;
33
+ /**
34
+ * Minimum consecutive successes for the probe to be considered successful
35
+ * after having failed. Defaults to 1.
36
+ *
37
+ * Must be 1 for liveness and startup. Minimum value is 1.
38
+ *
39
+ * @default 1 Must be 1 for liveness and startup. Minimum value is 1.
40
+ */
41
+ readonly successThreshold?: number;
42
+ /**
43
+ * Number of seconds after which the probe times out.
44
+ *
45
+ * Defaults to 1 second. Minimum value is 1.
46
+ *
47
+ * @see https://kubernetes.io/docs/concepts/workloads/pods/pod-lifecycle#container-probes
48
+ * @default Duration.seconds(1)
49
+ */
50
+ readonly timeoutSeconds?: Duration;
51
+ }
52
+ export declare enum ConnectionScheme {
53
+ /**
54
+ * Use HTTP request for connecting to host.
55
+ */
56
+ HTTP = "HTTP",
57
+ /**
58
+ * Use HTTPS request for connecting to host.
59
+ */
60
+ HTTPS = "HTTPS"
61
+ }
62
+ /**
63
+ * Options for `Probe.fromHttpGet()`.
64
+ */
65
+ export interface HttpGetProbeOptions extends ProbeOptions {
66
+ /**
67
+ * The TCP port to use when sending the GET request.
68
+ *
69
+ * @default - defaults to `container.port`.
70
+ */
71
+ readonly port?: number;
72
+ /**
73
+ * Scheme to use for connecting to the host (HTTP or HTTPS).
74
+ *
75
+ * @default ConnectionScheme.HTTP
76
+ */
77
+ readonly scheme?: ConnectionScheme;
78
+ /**
79
+ * The host name to connect to on the container.
80
+ *
81
+ * @default - defaults to the pod IP
82
+ */
83
+ readonly host?: string;
84
+ }
85
+ /**
86
+ * Options for `Probe.fromCommand()`.
87
+ */
88
+ export interface CommandProbeOptions extends ProbeOptions {
89
+ }
90
+ /**
91
+ * Options for `Probe.fromTcpSocket()`.
92
+ */
93
+ export interface TcpSocketProbeOptions extends ProbeOptions {
94
+ /**
95
+ * The TCP port to connect to on the container.
96
+ *
97
+ * @default - defaults to `container.port`.
98
+ */
99
+ readonly port?: number;
100
+ /**
101
+ * The host name to connect to on the container.
102
+ *
103
+ * @default - defaults to the pod IP
104
+ */
105
+ readonly host?: string;
106
+ }
107
+ /**
108
+ * Probe describes a health check to be performed against a container to
109
+ * determine whether it is alive or ready to receive traffic.
110
+ */
111
+ export declare class Probe {
112
+ private readonly probeOptions;
113
+ private readonly tcpSocketOptions?;
114
+ private readonly commandOptions?;
115
+ private readonly httpGetOptions?;
116
+ /**
117
+ * Defines a probe based on an HTTP GET request to the IP address of the container.
118
+ *
119
+ * @param path The URL path to hit
120
+ * @param options Options
121
+ */
122
+ static fromHttpGet(path: string, options?: HttpGetProbeOptions): Probe;
123
+ /**
124
+ * Defines a probe based on a command which is executed within the container.
125
+ *
126
+ * @param command The command to execute
127
+ * @param options Options
128
+ */
129
+ static fromCommand(command: string[], options?: CommandProbeOptions): Probe;
130
+ /**
131
+ * Defines a probe based opening a connection to a TCP socket on the container.
132
+ *
133
+ * @param options Options
134
+ */
135
+ static fromTcpSocket(options?: TcpSocketProbeOptions): Probe;
136
+ private constructor();
137
+ /**
138
+ * @internal
139
+ */
140
+ _toKube(cont: container.Container): k8s.Probe;
141
+ }
package/lib/probe.js ADDED
@@ -0,0 +1,77 @@
1
+ "use strict";
2
+ var _a;
3
+ Object.defineProperty(exports, "__esModule", { value: true });
4
+ exports.Probe = exports.ConnectionScheme = void 0;
5
+ const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
6
+ const _action = require("./_action");
7
+ var ConnectionScheme;
8
+ (function (ConnectionScheme) {
9
+ /**
10
+ * Use HTTP request for connecting to host.
11
+ */
12
+ ConnectionScheme["HTTP"] = "HTTP";
13
+ /**
14
+ * Use HTTPS request for connecting to host.
15
+ */
16
+ ConnectionScheme["HTTPS"] = "HTTPS";
17
+ })(ConnectionScheme = exports.ConnectionScheme || (exports.ConnectionScheme = {}));
18
+ /**
19
+ * Probe describes a health check to be performed against a container to
20
+ * determine whether it is alive or ready to receive traffic.
21
+ */
22
+ class Probe {
23
+ constructor(probeOptions, tcpSocketOptions, commandOptions, httpGetOptions) {
24
+ this.probeOptions = probeOptions;
25
+ this.tcpSocketOptions = tcpSocketOptions;
26
+ this.commandOptions = commandOptions;
27
+ this.httpGetOptions = httpGetOptions;
28
+ }
29
+ /**
30
+ * Defines a probe based on an HTTP GET request to the IP address of the container.
31
+ *
32
+ * @param path The URL path to hit
33
+ * @param options Options
34
+ */
35
+ static fromHttpGet(path, options = {}) {
36
+ return new Probe(options, undefined, undefined, { path, ...options });
37
+ }
38
+ /**
39
+ * Defines a probe based on a command which is executed within the container.
40
+ *
41
+ * @param command The command to execute
42
+ * @param options Options
43
+ */
44
+ static fromCommand(command, options = {}) {
45
+ return new Probe(options, undefined, { command, ...options }, undefined);
46
+ }
47
+ /**
48
+ * Defines a probe based opening a connection to a TCP socket on the container.
49
+ *
50
+ * @param options Options
51
+ */
52
+ static fromTcpSocket(options = {}) {
53
+ return new Probe(options, options, undefined, undefined);
54
+ }
55
+ /**
56
+ * @internal
57
+ */
58
+ _toKube(cont) {
59
+ const exec = this.commandOptions ? _action.Action.fromCommand(this.commandOptions.command) : undefined;
60
+ const httpGet = this.httpGetOptions ? _action.Action.fromHttpGet(cont, this.httpGetOptions.path, this.httpGetOptions) : undefined;
61
+ const tcpSocket = this.tcpSocketOptions ? _action.Action.fromTcpSocket(cont, this.tcpSocketOptions) : undefined;
62
+ return {
63
+ failureThreshold: this.probeOptions.failureThreshold ?? 3,
64
+ initialDelaySeconds: this.probeOptions.initialDelaySeconds ? this.probeOptions.initialDelaySeconds.toSeconds() : undefined,
65
+ periodSeconds: this.probeOptions.periodSeconds ? this.probeOptions.periodSeconds.toSeconds() : undefined,
66
+ successThreshold: this.probeOptions.successThreshold,
67
+ timeoutSeconds: this.probeOptions.timeoutSeconds ? this.probeOptions.timeoutSeconds.toSeconds() : undefined,
68
+ exec: exec,
69
+ httpGet,
70
+ tcpSocket,
71
+ };
72
+ }
73
+ }
74
+ exports.Probe = Probe;
75
+ _a = JSII_RTTI_SYMBOL_1;
76
+ Probe[_a] = { fqn: "cdk8s-plus-31.Probe", version: "2.0.0" };
77
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"probe.js","sourceRoot":"","sources":["../src/probe.ts"],"names":[],"mappings":";;;;;AACA,qCAAqC;AAyDrC,IAAY,gBAUX;AAVD,WAAY,gBAAgB;IAC1B;;OAEG;IACH,iCAAa,CAAA;IAEb;;OAEG;IACH,mCAAe,CAAA;AACjB,CAAC,EAVW,gBAAgB,GAAhB,wBAAgB,KAAhB,wBAAgB,QAU3B;AAsDD;;;GAGG;AACH,MAAa,KAAK;IA+BhB,YACmB,YAA0B,EAC1B,gBAAwC,EACxC,cAAqD,EACrD,cAAuD;QAHvD,iBAAY,GAAZ,YAAY,CAAc;QAC1B,qBAAgB,GAAhB,gBAAgB,CAAwB;QACxC,mBAAc,GAAd,cAAc,CAAuC;QACrD,mBAAc,GAAd,cAAc,CAAyC;IAAG,CAAC;IAjC9E;;;;;OAKG;IACI,MAAM,CAAC,WAAW,CAAC,IAAY,EAAE,UAA+B,EAAE;QACvE,OAAO,IAAI,KAAK,CAAC,OAAO,EAAE,SAAS,EAAE,SAAS,EAAE,EAAE,IAAI,EAAE,GAAG,OAAO,EAAE,CAAC,CAAC;IACxE,CAAC;IAED;;;;;OAKG;IACI,MAAM,CAAC,WAAW,CAAC,OAAiB,EAAE,UAA+B,EAAE;QAC5E,OAAO,IAAI,KAAK,CAAC,OAAO,EAAE,SAAS,EAAE,EAAE,OAAO,EAAE,GAAG,OAAO,EAAE,EAAE,SAAS,CAAC,CAAC;IAC3E,CAAC;IAED;;;;OAIG;IACI,MAAM,CAAC,aAAa,CAAC,UAAiC,EAAE;QAC7D,OAAO,IAAI,KAAK,CAAC,OAAO,EAAE,OAAO,EAAE,SAAS,EAAE,SAAS,CAAC,CAAC;IAC3D,CAAC;IAQD;;OAEG;IACI,OAAO,CAAC,IAAyB;QAEtC,MAAM,IAAI,GAAG,IAAI,CAAC,cAAc,CAAC,CAAC,CAAC,OAAO,CAAC,MAAM,CAAC,WAAW,CAAC,IAAI,CAAC,cAAc,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC;QACvG,MAAM,OAAO,GAAG,IAAI,CAAC,cAAc,CAAC,CAAC,CAAC,OAAO,CAAC,MAAM,CAAC,WAAW,CAAC,IAAI,EAAE,IAAI,CAAC,cAAc,CAAC,IAAI,EAAE,IAAI,CAAC,cAAc,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC;QAClI,MAAM,SAAS,GAAG,IAAI,CAAC,gBAAgB,CAAC,CAAC,CAAC,OAAO,CAAC,MAAM,CAAC,aAAa,CAAC,IAAI,EAAE,IAAI,CAAC,gBAAgB,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC;QAEhH,OAAO;YACL,gBAAgB,EAAE,IAAI,CAAC,YAAY,CAAC,gBAAgB,IAAI,CAAC;YACzD,mBAAmB,EAAE,IAAI,CAAC,YAAY,CAAC,mBAAmB,CAAC,CAAC,CAAC,IAAI,CAAC,YAAY,CAAC,mBAAmB,CAAC,SAAS,EAAE,CAAC,CAAC,CAAC,SAAS;YAC1H,aAAa,EAAE,IAAI,CAAC,YAAY,CAAC,aAAa,CAAC,CAAC,CAAC,IAAI,CAAC,YAAY,CAAC,aAAa,CAAC,SAAS,EAAE,CAAC,CAAC,CAAC,SAAS;YACxG,gBAAgB,EAAE,IAAI,CAAC,YAAY,CAAC,gBAAgB;YACpD,cAAc,EAAE,IAAI,CAAC,YAAY,CAAC,cAAc,CAAC,CAAC,CAAC,IAAI,CAAC,YAAY,CAAC,cAAc,CAAC,SAAS,EAAE,CAAC,CAAC,CAAC,SAAS;YAC3G,IAAI,EAAE,IAAI;YACV,OAAO;YACP,SAAS;SACV,CAAC;IACJ,CAAC;;AAxDH,sBAyDC","sourcesContent":["import { Duration } from 'cdk8s';\nimport * as _action from './_action';\nimport * as container from './container';\nimport * as k8s from './imports/k8s';\n\n/**\n * Probe options.\n */\nexport interface ProbeOptions {\n  /**\n   * Minimum consecutive failures for the probe to be considered failed after\n   * having succeeded.\n   *\n   * Defaults to 3. Minimum value is 1.\n   *\n   * @default 3\n   */\n  readonly failureThreshold?: number;\n\n  /**\n   * Number of seconds after the container has started before liveness probes\n   * are initiated.\n   *\n   * @see https://kubernetes.io/docs/concepts/workloads/pods/pod-lifecycle#container-probes\n   * @default - immediate\n   */\n  readonly initialDelaySeconds?: Duration;\n\n  /**\n   * How often (in seconds) to perform the probe.\n   *\n   * Default to 10 seconds. Minimum value is 1.\n   *\n   * @default Duration.seconds(10) Minimum value is 1.\n   */\n  readonly periodSeconds?: Duration;\n\n  /**\n   * Minimum consecutive successes for the probe to be considered successful\n   * after having failed. Defaults to 1.\n   *\n   * Must be 1 for liveness and startup. Minimum value is 1.\n   *\n   * @default 1 Must be 1 for liveness and startup. Minimum value is 1.\n   */\n  readonly successThreshold?: number;\n\n  /**\n   * Number of seconds after which the probe times out.\n   *\n   * Defaults to 1 second. Minimum value is 1.\n   *\n   * @see https://kubernetes.io/docs/concepts/workloads/pods/pod-lifecycle#container-probes\n   * @default Duration.seconds(1)\n   */\n  readonly timeoutSeconds?: Duration;\n}\n\nexport enum ConnectionScheme {\n  /**\n   * Use HTTP request for connecting to host.\n   */\n  HTTP = 'HTTP',\n\n  /**\n   * Use HTTPS request for connecting to host.\n   */\n  HTTPS = 'HTTPS'\n}\n\n/**\n * Options for `Probe.fromHttpGet()`.\n */\nexport interface HttpGetProbeOptions extends ProbeOptions {\n  /**\n   * The TCP port to use when sending the GET request.\n   *\n   * @default - defaults to `container.port`.\n   */\n  readonly port?: number;\n\n  /**\n   *  Scheme to use for connecting to the host (HTTP or HTTPS).\n   *\n   *  @default ConnectionScheme.HTTP\n   */\n  readonly scheme?: ConnectionScheme;\n\n  /**\n   * The host name to connect to on the container.\n   *\n   * @default - defaults to the pod IP\n   */\n  readonly host?: string;\n}\n\n/**\n * Options for `Probe.fromCommand()`.\n */\nexport interface CommandProbeOptions extends ProbeOptions {\n\n}\n\n/**\n * Options for `Probe.fromTcpSocket()`.\n */\nexport interface TcpSocketProbeOptions extends ProbeOptions {\n  /**\n   * The TCP port to connect to on the container.\n   *\n   * @default - defaults to `container.port`.\n   */\n  readonly port?: number;\n\n  /**\n   * The host name to connect to on the container.\n   *\n   * @default - defaults to the pod IP\n   */\n  readonly host?: string;\n}\n\n/**\n * Probe describes a health check to be performed against a container to\n * determine whether it is alive or ready to receive traffic.\n */\nexport class Probe {\n\n  /**\n   * Defines a probe based on an HTTP GET request to the IP address of the container.\n   *\n   * @param path The URL path to hit\n   * @param options Options\n   */\n  public static fromHttpGet(path: string, options: HttpGetProbeOptions = {}): Probe {\n    return new Probe(options, undefined, undefined, { path, ...options });\n  }\n\n  /**\n   * Defines a probe based on a command which is executed within the container.\n   *\n   * @param command The command to execute\n   * @param options Options\n   */\n  public static fromCommand(command: string[], options: CommandProbeOptions = {}): Probe {\n    return new Probe(options, undefined, { command, ...options }, undefined);\n  }\n\n  /**\n   * Defines a probe based opening a connection to a TCP socket on the container.\n   *\n   * @param options Options\n   */\n  public static fromTcpSocket(options: TcpSocketProbeOptions = {}): Probe {\n    return new Probe(options, options, undefined, undefined);\n  }\n\n  private constructor(\n    private readonly probeOptions: ProbeOptions,\n    private readonly tcpSocketOptions?: TcpSocketProbeOptions,\n    private readonly commandOptions?: { command: string[] } & ProbeOptions,\n    private readonly httpGetOptions?: { path: string } & HttpGetProbeOptions) {}\n\n  /**\n   * @internal\n   */\n  public _toKube(cont: container.Container): k8s.Probe {\n\n    const exec = this.commandOptions ? _action.Action.fromCommand(this.commandOptions.command) : undefined;\n    const httpGet = this.httpGetOptions ? _action.Action.fromHttpGet(cont, this.httpGetOptions.path, this.httpGetOptions) : undefined;\n    const tcpSocket = this.tcpSocketOptions ? _action.Action.fromTcpSocket(cont, this.tcpSocketOptions) : undefined;\n\n    return {\n      failureThreshold: this.probeOptions.failureThreshold ?? 3,\n      initialDelaySeconds: this.probeOptions.initialDelaySeconds ? this.probeOptions.initialDelaySeconds.toSeconds() : undefined,\n      periodSeconds: this.probeOptions.periodSeconds ? this.probeOptions.periodSeconds.toSeconds() : undefined,\n      successThreshold: this.probeOptions.successThreshold,\n      timeoutSeconds: this.probeOptions.timeoutSeconds ? this.probeOptions.timeoutSeconds.toSeconds() : undefined,\n      exec: exec,\n      httpGet,\n      tcpSocket,\n    };\n  }\n}\n"]}
package/lib/pv.d.ts ADDED
@@ -0,0 +1,375 @@
1
+ import { ApiObject, Size } from 'cdk8s';
2
+ import { Construct } from 'constructs';
3
+ import * as base from './base';
4
+ import * as k8s from './imports/k8s';
5
+ import * as pvc from './pvc';
6
+ import * as volume from './volume';
7
+ /**
8
+ * Contract of a `PersistentVolumeClaim`.
9
+ */
10
+ export interface IPersistentVolume extends base.IResource {
11
+ }
12
+ /**
13
+ * Properties for `PersistentVolume`.
14
+ */
15
+ export interface PersistentVolumeProps extends base.ResourceProps {
16
+ /**
17
+ * Contains all ways the volume can be mounted.
18
+ *
19
+ * @see https://kubernetes.io/docs/concepts/storage/persistent-volumes#access-modes
20
+ * @default - No access modes.
21
+ */
22
+ readonly accessModes?: pvc.PersistentVolumeAccessMode[];
23
+ /**
24
+ * What is the storage capacity of this volume.
25
+ *
26
+ * @see https://kubernetes.io/docs/concepts/storage/persistent-volumes#resources
27
+ * @default - No specified.
28
+ */
29
+ readonly storage?: Size;
30
+ /**
31
+ * Part of a bi-directional binding between PersistentVolume and PersistentVolumeClaim.
32
+ * Expected to be non-nil when bound.
33
+ *
34
+ * @see https://kubernetes.io/docs/concepts/storage/persistent-volumes#binding
35
+ * @default - Not bound to a specific claim.
36
+ */
37
+ readonly claim?: pvc.IPersistentVolumeClaim;
38
+ /**
39
+ * A list of mount options, e.g. ["ro", "soft"]. Not validated - mount will simply fail if one is invalid.
40
+ *
41
+ * @see https://kubernetes.io/docs/concepts/storage/persistent-volumes/#mount-options
42
+ * @default - No options.
43
+ */
44
+ readonly mountOptions?: string[];
45
+ /**
46
+ * When a user is done with their volume, they can delete the PVC objects from the API that
47
+ * allows reclamation of the resource. The reclaim policy tells the cluster what to do with
48
+ * the volume after it has been released of its claim.
49
+ *
50
+ * @see https://kubernetes.io/docs/concepts/storage/persistent-volumes#reclaiming
51
+ * @default PersistentVolumeReclaimPolicy.RETAIN
52
+ */
53
+ readonly reclaimPolicy?: PersistentVolumeReclaimPolicy;
54
+ /**
55
+ * Name of StorageClass to which this persistent volume belongs.
56
+ *
57
+ * @default - Volume does not belong to any storage class.
58
+ */
59
+ readonly storageClassName?: string;
60
+ /**
61
+ * Defines what type of volume is required by the claim.
62
+ *
63
+ * @default VolumeMode.FILE_SYSTEM
64
+ */
65
+ readonly volumeMode?: pvc.PersistentVolumeMode;
66
+ }
67
+ /**
68
+ * A PersistentVolume (PV) is a piece of storage in the cluster that has been
69
+ * provisioned by an administrator or dynamically provisioned using Storage Classes.
70
+ * It is a resource in the cluster just like a node is a cluster resource.
71
+ * PVs are volume plugins like Volumes, but have a lifecycle independent of any
72
+ * individual Pod that uses the PV. This API object captures the details of the
73
+ * implementation of the storage, be that NFS, iSCSI, or a
74
+ * cloud-provider-specific storage system.
75
+ */
76
+ export declare class PersistentVolume extends base.Resource implements IPersistentVolume, volume.IStorage {
77
+ /**
78
+ * Imports a pv from the cluster as a reference.
79
+ */
80
+ static fromPersistentVolumeName(scope: Construct, id: string, volumeName: string): IPersistentVolume;
81
+ /**
82
+ * @see base.Resource.apiObject
83
+ */
84
+ protected readonly apiObject: ApiObject;
85
+ readonly resourceType = "persistentvolumes";
86
+ private _claim?;
87
+ /**
88
+ * Storage size of this volume.
89
+ */
90
+ readonly storage?: Size;
91
+ /**
92
+ * Volume mode of this volume.
93
+ */
94
+ readonly mode: pvc.PersistentVolumeMode;
95
+ /**
96
+ * Storage class this volume belongs to.
97
+ */
98
+ readonly storageClassName?: string;
99
+ /**
100
+ * Access modes requirement of this claim.
101
+ */
102
+ private readonly _accessModes?;
103
+ /**
104
+ * Mount options of this volume.
105
+ */
106
+ readonly mountOptions?: string[];
107
+ /**
108
+ * Reclaim policy of this volume.
109
+ */
110
+ readonly reclaimPolicy: PersistentVolumeReclaimPolicy;
111
+ protected constructor(scope: Construct, id: string, props?: PersistentVolumeProps);
112
+ /**
113
+ * Access modes requirement of this claim.
114
+ */
115
+ get accessModes(): pvc.PersistentVolumeAccessMode[] | undefined;
116
+ /**
117
+ * PVC this volume is bound to. Undefined means this volume is not yet
118
+ * claimed by any PVC.
119
+ */
120
+ get claim(): pvc.IPersistentVolumeClaim | undefined;
121
+ /**
122
+ * Reserve a `PersistentVolume` by creating a `PersistentVolumeClaim`
123
+ * that is wired to claim this volume.
124
+ *
125
+ * Note that this method will throw in case the volume is already claimed.
126
+ *
127
+ * @see https://kubernetes.io/docs/concepts/storage/persistent-volumes/#reserving-a-persistentvolume
128
+ */
129
+ reserve(): pvc.PersistentVolumeClaim;
130
+ /**
131
+ * Bind a volume to a specific claim.
132
+ * Note that you must also bind the claim to the volume.
133
+ *
134
+ * @see https://kubernetes.io/docs/concepts/storage/persistent-volumes/#binding
135
+ *
136
+ * @param claim The PVC to bind to.
137
+ */
138
+ bind(claim: pvc.IPersistentVolumeClaim): void;
139
+ asVolume(): volume.Volume;
140
+ /**
141
+ * @internal
142
+ */
143
+ _toKube(): k8s.PersistentVolumeSpec;
144
+ }
145
+ /**
146
+ * Reclaim Policies.
147
+ */
148
+ export declare enum PersistentVolumeReclaimPolicy {
149
+ /**
150
+ * The Retain reclaim policy allows for manual reclamation of the resource.
151
+ * When the PersistentVolumeClaim is deleted, the PersistentVolume still exists and the
152
+ * volume is considered "released". But it is not yet available for another claim
153
+ * because the previous claimant's data remains on the volume.
154
+ * An administrator can manually reclaim the volume with the following steps:
155
+ *
156
+ * 1. Delete the PersistentVolume. The associated storage asset in external
157
+ * infrastructure (such as an AWS EBS, GCE PD, Azure Disk, or Cinder volume) still exists after the PV is deleted.
158
+ * 2. Manually clean up the data on the associated storage asset accordingly.
159
+ * 3. Manually delete the associated storage asset.
160
+ *
161
+ * If you want to reuse the same storage asset, create a new PersistentVolume
162
+ * with the same storage asset definition.
163
+ */
164
+ RETAIN = "Retain",
165
+ /**
166
+ * For volume plugins that support the Delete reclaim policy, deletion removes both the
167
+ * PersistentVolume object from Kubernetes, as well as the associated storage asset in
168
+ * the external infrastructure, such as an AWS EBS, GCE PD, Azure Disk, or Cinder volume.
169
+ * Volumes that were dynamically provisioned inherit the reclaim policy of their StorageClass, which defaults to Delete.
170
+ * The administrator should configure the StorageClass according to users' expectations; otherwise,
171
+ * the PV must be edited or patched after it is created
172
+ */
173
+ DELETE = "Delete"
174
+ }
175
+ /**
176
+ * Properties for `AwsElasticBlockStorePersistentVolume`.
177
+ */
178
+ export interface AwsElasticBlockStorePersistentVolumeProps extends PersistentVolumeProps {
179
+ /**
180
+ * Unique ID of the persistent disk resource in AWS (Amazon EBS volume). More info: https://kubernetes.io/docs/concepts/storage/volumes#awselasticblockstore
181
+ *
182
+ * @see https://kubernetes.io/docs/concepts/storage/volumes#awselasticblockstore
183
+ */
184
+ readonly volumeId: string;
185
+ /**
186
+ * Filesystem type of the volume that you want to mount.
187
+ * Tip: Ensure that the filesystem type is supported by the host operating system.
188
+ *
189
+ * @see https://kubernetes.io/docs/concepts/storage/volumes#awselasticblockstore
190
+ * @default 'ext4'
191
+ */
192
+ readonly fsType?: string;
193
+ /**
194
+ * The partition in the volume that you want to mount. If omitted, the default is to mount by volume name.
195
+ * Examples: For volume /dev/sda1, you specify the partition as "1".
196
+ * Similarly, the volume partition for /dev/sda is "0" (or you can leave the property empty).
197
+ *
198
+ * @default - No partition.
199
+ */
200
+ readonly partition?: number;
201
+ /**
202
+ * Specify "true" to force and set the ReadOnly property in VolumeMounts to "true".
203
+ *
204
+ * @see https://kubernetes.io/docs/concepts/storage/volumes#awselasticblockstore
205
+ * @default false
206
+ */
207
+ readonly readOnly?: boolean;
208
+ }
209
+ /**
210
+ * Represents an AWS Disk resource that is attached to a kubelet's host machine and
211
+ * then exposed to the pod.
212
+ *
213
+ * @see https://kubernetes.io/docs/concepts/storage/volumes#awselasticblockstore
214
+ */
215
+ export declare class AwsElasticBlockStorePersistentVolume extends PersistentVolume {
216
+ /**
217
+ * Volume id of this volume.
218
+ */
219
+ readonly volumeId: string;
220
+ /**
221
+ * Whether or not it is mounted as a read-only volume.
222
+ */
223
+ readonly readOnly: boolean;
224
+ /**
225
+ * File system type of this volume.
226
+ */
227
+ readonly fsType: string;
228
+ /**
229
+ * Partition of this volume.
230
+ */
231
+ readonly partition?: number;
232
+ constructor(scope: Construct, id: string, props: AwsElasticBlockStorePersistentVolumeProps);
233
+ /**
234
+ * @internal
235
+ */
236
+ _toKube(): k8s.PersistentVolumeSpec;
237
+ }
238
+ /**
239
+ * Properties for `AzureDiskPersistentVolume`.
240
+ */
241
+ export interface AzureDiskPersistentVolumeProps extends PersistentVolumeProps {
242
+ /**
243
+ * The Name of the data disk in the blob storage
244
+ */
245
+ readonly diskName: string;
246
+ /**
247
+ * The URI the data disk in the blob storage
248
+ */
249
+ readonly diskUri: string;
250
+ /**
251
+ * Host Caching mode.
252
+ *
253
+ * @default - AzureDiskPersistentVolumeCachingMode.NONE.
254
+ */
255
+ readonly cachingMode?: volume.AzureDiskPersistentVolumeCachingMode;
256
+ /**
257
+ * Filesystem type to mount. Must be a filesystem type supported by the host operating system.
258
+ *
259
+ * @default 'ext4'
260
+ */
261
+ readonly fsType?: string;
262
+ /**
263
+ * Kind of disk.
264
+ *
265
+ * @default AzureDiskPersistentVolumeKind.SHARED
266
+ */
267
+ readonly kind?: volume.AzureDiskPersistentVolumeKind;
268
+ /**
269
+ * Force the ReadOnly setting in VolumeMounts.
270
+ *
271
+ * @default false
272
+ */
273
+ readonly readOnly?: boolean;
274
+ }
275
+ /**
276
+ * AzureDisk represents an Azure Data Disk mount on the host and bind mount to the pod.
277
+ */
278
+ export declare class AzureDiskPersistentVolume extends PersistentVolume {
279
+ /**
280
+ * Disk name of this volume.
281
+ */
282
+ readonly diskName: string;
283
+ /**
284
+ * Disk URI of this volume.
285
+ */
286
+ readonly diskUri: string;
287
+ /**
288
+ * Whether or not it is mounted as a read-only volume.
289
+ */
290
+ readonly readOnly: boolean;
291
+ /**
292
+ * Caching mode of this volume.
293
+ */
294
+ readonly cachingMode: volume.AzureDiskPersistentVolumeCachingMode;
295
+ /**
296
+ * File system type of this volume.
297
+ */
298
+ readonly fsType: string;
299
+ /**
300
+ * Azure kind of this volume.
301
+ */
302
+ readonly azureKind: volume.AzureDiskPersistentVolumeKind;
303
+ constructor(scope: Construct, id: string, props: AzureDiskPersistentVolumeProps);
304
+ /**
305
+ * @internal
306
+ *
307
+ * @see https://github.com/kubernetes/examples/blob/master/staging/volumes/azure_disk/README.md
308
+ */
309
+ _toKube(): k8s.PersistentVolumeSpec;
310
+ }
311
+ /**
312
+ * Properties for `GCEPersistentDiskPersistentVolume`.
313
+ */
314
+ export interface GCEPersistentDiskPersistentVolumeProps extends PersistentVolumeProps {
315
+ /**
316
+ * Unique name of the PD resource in GCE. Used to identify the disk in GCE.
317
+ *
318
+ * @see https://kubernetes.io/docs/concepts/storage/volumes#gcepersistentdisk
319
+ */
320
+ readonly pdName: string;
321
+ /**
322
+ * Filesystem type of the volume that you want to mount.
323
+ * Tip: Ensure that the filesystem type is supported by the host operating system.
324
+ *
325
+ * @see https://kubernetes.io/docs/concepts/storage/volumes#awselasticblockstore
326
+ * @default 'ext4'
327
+ */
328
+ readonly fsType?: string;
329
+ /**
330
+ * The partition in the volume that you want to mount. If omitted, the default is to mount by volume name.
331
+ * Examples: For volume /dev/sda1, you specify the partition as "1".
332
+ * Similarly, the volume partition for /dev/sda is "0" (or you can leave the property empty).
333
+ *
334
+ * @default - No partition.
335
+ */
336
+ readonly partition?: number;
337
+ /**
338
+ * Specify "true" to force and set the ReadOnly property in VolumeMounts to "true".
339
+ *
340
+ * @see https://kubernetes.io/docs/concepts/storage/volumes#awselasticblockstore
341
+ * @default false
342
+ */
343
+ readonly readOnly?: boolean;
344
+ }
345
+ /**
346
+ * GCEPersistentDisk represents a GCE Disk resource that is attached to a kubelet's host machine
347
+ * and then exposed to the pod. Provisioned by an admin.
348
+ *
349
+ * @see https://kubernetes.io/docs/concepts/storage/volumes#gcepersistentdisk
350
+ */
351
+ export declare class GCEPersistentDiskPersistentVolume extends PersistentVolume {
352
+ /**
353
+ * PD resource in GCE of this volume.
354
+ */
355
+ readonly pdName: string;
356
+ /**
357
+ * Whether or not it is mounted as a read-only volume.
358
+ */
359
+ readonly readOnly: boolean;
360
+ /**
361
+ * File system type of this volume.
362
+ */
363
+ readonly fsType: string;
364
+ /**
365
+ * Partition of this volume.
366
+ */
367
+ readonly partition?: number;
368
+ constructor(scope: Construct, id: string, props: GCEPersistentDiskPersistentVolumeProps);
369
+ /**
370
+ * @internal
371
+ *
372
+ * @see https://github.com/kubernetes/examples/blob/master/staging/volumes/azure_disk/README.md
373
+ */
374
+ _toKube(): k8s.PersistentVolumeSpec;
375
+ }