@bluedynamics/cdk8s-plone 0.1.16 → 0.1.18

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/.jsii CHANGED
@@ -7,7 +7,7 @@
7
7
  ]
8
8
  },
9
9
  "dependencies": {
10
- "cdk8s": "^2.70.37",
10
+ "cdk8s": "^2.70.50",
11
11
  "cdk8s-plus-30": "^2.4.10",
12
12
  "constructs": "^10.4.2"
13
13
  },
@@ -96,7 +96,7 @@
96
96
  "stability": "stable"
97
97
  },
98
98
  "homepage": "https://github.com/bluedynamics/cdk8s-plone.git",
99
- "jsiiVersion": "5.9.20 (build 6e2b13a)",
99
+ "jsiiVersion": "5.9.31 (build 550e607)",
100
100
  "license": "Apache-2.0",
101
101
  "metadata": {
102
102
  "jsii": {
@@ -125,6 +125,56 @@
125
125
  }
126
126
  },
127
127
  "types": {
128
+ "@bluedynamics/cdk8s-plone.HttpcacheEnvVar": {
129
+ "assembly": "@bluedynamics/cdk8s-plone",
130
+ "datatype": true,
131
+ "docs": {
132
+ "stability": "stable",
133
+ "summary": "An environment variable to pass to the kube-httpcache container."
134
+ },
135
+ "fqn": "@bluedynamics/cdk8s-plone.HttpcacheEnvVar",
136
+ "kind": "interface",
137
+ "locationInModule": {
138
+ "filename": "src/httpcache.ts",
139
+ "line": 10
140
+ },
141
+ "name": "HttpcacheEnvVar",
142
+ "properties": [
143
+ {
144
+ "abstract": true,
145
+ "docs": {
146
+ "stability": "stable",
147
+ "summary": "The name of the environment variable."
148
+ },
149
+ "immutable": true,
150
+ "locationInModule": {
151
+ "filename": "src/httpcache.ts",
152
+ "line": 14
153
+ },
154
+ "name": "name",
155
+ "type": {
156
+ "primitive": "string"
157
+ }
158
+ },
159
+ {
160
+ "abstract": true,
161
+ "docs": {
162
+ "stability": "stable",
163
+ "summary": "The value of the environment variable."
164
+ },
165
+ "immutable": true,
166
+ "locationInModule": {
167
+ "filename": "src/httpcache.ts",
168
+ "line": 19
169
+ },
170
+ "name": "value",
171
+ "type": {
172
+ "primitive": "string"
173
+ }
174
+ }
175
+ ],
176
+ "symbolId": "src/httpcache:HttpcacheEnvVar"
177
+ },
128
178
  "@bluedynamics/cdk8s-plone.Plone": {
129
179
  "assembly": "@bluedynamics/cdk8s-plone",
130
180
  "base": "constructs.Construct",
@@ -837,7 +887,7 @@
837
887
  },
838
888
  "locationInModule": {
839
889
  "filename": "src/httpcache.ts",
840
- "line": 120
890
+ "line": 143
841
891
  },
842
892
  "parameters": [
843
893
  {
@@ -863,7 +913,7 @@
863
913
  "kind": "class",
864
914
  "locationInModule": {
865
915
  "filename": "src/httpcache.ts",
866
- "line": 113
916
+ "line": 136
867
917
  },
868
918
  "name": "PloneHttpcache",
869
919
  "properties": [
@@ -876,7 +926,7 @@
876
926
  "immutable": true,
877
927
  "locationInModule": {
878
928
  "filename": "src/httpcache.ts",
879
- "line": 118
929
+ "line": 141
880
930
  },
881
931
  "name": "httpcacheServiceName",
882
932
  "type": {
@@ -897,7 +947,7 @@
897
947
  "kind": "interface",
898
948
  "locationInModule": {
899
949
  "filename": "src/httpcache.ts",
900
- "line": 10
950
+ "line": 25
901
951
  },
902
952
  "name": "PloneHttpcacheOptions",
903
953
  "properties": [
@@ -911,7 +961,7 @@
911
961
  "immutable": true,
912
962
  "locationInModule": {
913
963
  "filename": "src/httpcache.ts",
914
- "line": 15
964
+ "line": 30
915
965
  },
916
966
  "name": "plone",
917
967
  "type": {
@@ -929,7 +979,7 @@
929
979
  "immutable": true,
930
980
  "locationInModule": {
931
981
  "filename": "src/httpcache.ts",
932
- "line": 88
982
+ "line": 103
933
983
  },
934
984
  "name": "appVersion",
935
985
  "optional": true,
@@ -948,7 +998,7 @@
948
998
  "immutable": true,
949
999
  "locationInModule": {
950
1000
  "filename": "src/httpcache.ts",
951
- "line": 81
1001
+ "line": 96
952
1002
  },
953
1003
  "name": "chartVersion",
954
1004
  "optional": true,
@@ -967,7 +1017,7 @@
967
1017
  "immutable": true,
968
1018
  "locationInModule": {
969
1019
  "filename": "src/httpcache.ts",
970
- "line": 36
1020
+ "line": 51
971
1021
  },
972
1022
  "name": "existingSecret",
973
1023
  "optional": true,
@@ -986,7 +1036,7 @@
986
1036
  "immutable": true,
987
1037
  "locationInModule": {
988
1038
  "filename": "src/httpcache.ts",
989
- "line": 74
1039
+ "line": 89
990
1040
  },
991
1041
  "name": "exporterEnabled",
992
1042
  "optional": true,
@@ -994,6 +1044,30 @@
994
1044
  "primitive": "boolean"
995
1045
  }
996
1046
  },
1047
+ {
1048
+ "abstract": true,
1049
+ "docs": {
1050
+ "default": "- no additional env vars",
1051
+ "remarks": "These are appended to the built-in env vars (BACKEND_SERVICE_NAME, etc.)\nand can be referenced in VCL templates using Go template syntax: {{ .Env.VAR_NAME }}",
1052
+ "stability": "stable",
1053
+ "summary": "Additional environment variables to pass to the kube-httpcache container."
1054
+ },
1055
+ "immutable": true,
1056
+ "locationInModule": {
1057
+ "filename": "src/httpcache.ts",
1058
+ "line": 117
1059
+ },
1060
+ "name": "extraEnvVars",
1061
+ "optional": true,
1062
+ "type": {
1063
+ "collection": {
1064
+ "elementtype": {
1065
+ "fqn": "@bluedynamics/cdk8s-plone.HttpcacheEnvVar"
1066
+ },
1067
+ "kind": "array"
1068
+ }
1069
+ }
1070
+ },
997
1071
  {
998
1072
  "abstract": true,
999
1073
  "docs": {
@@ -1004,7 +1078,7 @@
1004
1078
  "immutable": true,
1005
1079
  "locationInModule": {
1006
1080
  "filename": "src/httpcache.ts",
1007
- "line": 42
1081
+ "line": 57
1008
1082
  },
1009
1083
  "name": "limitCpu",
1010
1084
  "optional": true,
@@ -1022,7 +1096,7 @@
1022
1096
  "immutable": true,
1023
1097
  "locationInModule": {
1024
1098
  "filename": "src/httpcache.ts",
1025
- "line": 48
1099
+ "line": 63
1026
1100
  },
1027
1101
  "name": "limitMemory",
1028
1102
  "optional": true,
@@ -1040,7 +1114,7 @@
1040
1114
  "immutable": true,
1041
1115
  "locationInModule": {
1042
1116
  "filename": "src/httpcache.ts",
1043
- "line": 94
1117
+ "line": 109
1044
1118
  },
1045
1119
  "name": "replicas",
1046
1120
  "optional": true,
@@ -1058,7 +1132,7 @@
1058
1132
  "immutable": true,
1059
1133
  "locationInModule": {
1060
1134
  "filename": "src/httpcache.ts",
1061
- "line": 54
1135
+ "line": 69
1062
1136
  },
1063
1137
  "name": "requestCpu",
1064
1138
  "optional": true,
@@ -1076,7 +1150,7 @@
1076
1150
  "immutable": true,
1077
1151
  "locationInModule": {
1078
1152
  "filename": "src/httpcache.ts",
1079
- "line": 60
1153
+ "line": 75
1080
1154
  },
1081
1155
  "name": "requestMemory",
1082
1156
  "optional": true,
@@ -1095,7 +1169,7 @@
1095
1169
  "immutable": true,
1096
1170
  "locationInModule": {
1097
1171
  "filename": "src/httpcache.ts",
1098
- "line": 67
1172
+ "line": 82
1099
1173
  },
1100
1174
  "name": "servicemonitor",
1101
1175
  "optional": true,
@@ -1114,7 +1188,7 @@
1114
1188
  "immutable": true,
1115
1189
  "locationInModule": {
1116
1190
  "filename": "src/httpcache.ts",
1117
- "line": 22
1191
+ "line": 37
1118
1192
  },
1119
1193
  "name": "varnishVcl",
1120
1194
  "optional": true,
@@ -1133,7 +1207,7 @@
1133
1207
  "immutable": true,
1134
1208
  "locationInModule": {
1135
1209
  "filename": "src/httpcache.ts",
1136
- "line": 29
1210
+ "line": 44
1137
1211
  },
1138
1212
  "name": "varnishVclFile",
1139
1213
  "optional": true,
@@ -1314,6 +1388,6 @@
1314
1388
  "symbolId": "src/plone:PloneVariant"
1315
1389
  }
1316
1390
  },
1317
- "version": "0.1.16",
1318
- "fingerprint": "vn8DzOjqPfv9F0IIpbk8fsuZMmk3SnNaAW/DSy5WCcQ="
1391
+ "version": "0.1.18",
1392
+ "fingerprint": "PutbKa0ZpIMPizWN+Q4KOwTmMtcKubkFp2yfaaYkn+A="
1319
1393
  }
package/API.md CHANGED
@@ -70,6 +70,7 @@ new Plone(scope: Construct, id: string, options?: PloneOptions)
70
70
  | **Name** | **Description** |
71
71
  | --- | --- |
72
72
  | <code><a href="#@bluedynamics/cdk8s-plone.Plone.toString">toString</a></code> | Returns a string representation of this construct. |
73
+ | <code><a href="#@bluedynamics/cdk8s-plone.Plone.with">with</a></code> | Applies one or more mixins to this construct. |
73
74
 
74
75
  ---
75
76
 
@@ -81,6 +82,27 @@ public toString(): string
81
82
 
82
83
  Returns a string representation of this construct.
83
84
 
85
+ ##### `with` <a name="with" id="@bluedynamics/cdk8s-plone.Plone.with"></a>
86
+
87
+ ```typescript
88
+ public with(mixins: ...IMixin[]): IConstruct
89
+ ```
90
+
91
+ Applies one or more mixins to this construct.
92
+
93
+ Mixins are applied in order. The list of constructs is captured at the
94
+ start of the call, so constructs added by a mixin will not be visited.
95
+ Use multiple `with()` calls if subsequent mixins should apply to added
96
+ constructs.
97
+
98
+ ###### `mixins`<sup>Required</sup> <a name="mixins" id="@bluedynamics/cdk8s-plone.Plone.with.parameter.mixins"></a>
99
+
100
+ - *Type:* ...constructs.IMixin[]
101
+
102
+ The mixins to apply.
103
+
104
+ ---
105
+
84
106
  #### Static Functions <a name="Static Functions" id="Static Functions"></a>
85
107
 
86
108
  | **Name** | **Description** |
@@ -258,6 +280,7 @@ new PloneHttpcache(scope: Construct, id: string, options: PloneHttpcacheOptions)
258
280
  | **Name** | **Description** |
259
281
  | --- | --- |
260
282
  | <code><a href="#@bluedynamics/cdk8s-plone.PloneHttpcache.toString">toString</a></code> | Returns a string representation of this construct. |
283
+ | <code><a href="#@bluedynamics/cdk8s-plone.PloneHttpcache.with">with</a></code> | Applies one or more mixins to this construct. |
261
284
 
262
285
  ---
263
286
 
@@ -269,6 +292,27 @@ public toString(): string
269
292
 
270
293
  Returns a string representation of this construct.
271
294
 
295
+ ##### `with` <a name="with" id="@bluedynamics/cdk8s-plone.PloneHttpcache.with"></a>
296
+
297
+ ```typescript
298
+ public with(mixins: ...IMixin[]): IConstruct
299
+ ```
300
+
301
+ Applies one or more mixins to this construct.
302
+
303
+ Mixins are applied in order. The list of constructs is captured at the
304
+ start of the call, so constructs added by a mixin will not be visited.
305
+ Use multiple `with()` calls if subsequent mixins should apply to added
306
+ constructs.
307
+
308
+ ###### `mixins`<sup>Required</sup> <a name="mixins" id="@bluedynamics/cdk8s-plone.PloneHttpcache.with.parameter.mixins"></a>
309
+
310
+ - *Type:* ...constructs.IMixin[]
311
+
312
+ The mixins to apply.
313
+
314
+ ---
315
+
272
316
  #### Static Functions <a name="Static Functions" id="Static Functions"></a>
273
317
 
274
318
  | **Name** | **Description** |
@@ -347,6 +391,51 @@ Use this to reference the cache service from ingress or other constructs.
347
391
 
348
392
  ## Structs <a name="Structs" id="Structs"></a>
349
393
 
394
+ ### HttpcacheEnvVar <a name="HttpcacheEnvVar" id="@bluedynamics/cdk8s-plone.HttpcacheEnvVar"></a>
395
+
396
+ An environment variable to pass to the kube-httpcache container.
397
+
398
+ #### Initializer <a name="Initializer" id="@bluedynamics/cdk8s-plone.HttpcacheEnvVar.Initializer"></a>
399
+
400
+ ```typescript
401
+ import { HttpcacheEnvVar } from '@bluedynamics/cdk8s-plone'
402
+
403
+ const httpcacheEnvVar: HttpcacheEnvVar = { ... }
404
+ ```
405
+
406
+ #### Properties <a name="Properties" id="Properties"></a>
407
+
408
+ | **Name** | **Type** | **Description** |
409
+ | --- | --- | --- |
410
+ | <code><a href="#@bluedynamics/cdk8s-plone.HttpcacheEnvVar.property.name">name</a></code> | <code>string</code> | The name of the environment variable. |
411
+ | <code><a href="#@bluedynamics/cdk8s-plone.HttpcacheEnvVar.property.value">value</a></code> | <code>string</code> | The value of the environment variable. |
412
+
413
+ ---
414
+
415
+ ##### `name`<sup>Required</sup> <a name="name" id="@bluedynamics/cdk8s-plone.HttpcacheEnvVar.property.name"></a>
416
+
417
+ ```typescript
418
+ public readonly name: string;
419
+ ```
420
+
421
+ - *Type:* string
422
+
423
+ The name of the environment variable.
424
+
425
+ ---
426
+
427
+ ##### `value`<sup>Required</sup> <a name="value" id="@bluedynamics/cdk8s-plone.HttpcacheEnvVar.property.value"></a>
428
+
429
+ ```typescript
430
+ public readonly value: string;
431
+ ```
432
+
433
+ - *Type:* string
434
+
435
+ The value of the environment variable.
436
+
437
+ ---
438
+
350
439
  ### PloneBaseOptions <a name="PloneBaseOptions" id="@bluedynamics/cdk8s-plone.PloneBaseOptions"></a>
351
440
 
352
441
  Base options for Plone backend or frontend configuration.
@@ -862,6 +951,7 @@ const ploneHttpcacheOptions: PloneHttpcacheOptions = { ... }
862
951
  | <code><a href="#@bluedynamics/cdk8s-plone.PloneHttpcacheOptions.property.chartVersion">chartVersion</a></code> | <code>string</code> | Version of the kube-httpcache Helm chart to use. |
863
952
  | <code><a href="#@bluedynamics/cdk8s-plone.PloneHttpcacheOptions.property.existingSecret">existingSecret</a></code> | <code>string</code> | Name of an existing Kubernetes secret containing Varnish admin credentials. |
864
953
  | <code><a href="#@bluedynamics/cdk8s-plone.PloneHttpcacheOptions.property.exporterEnabled">exporterEnabled</a></code> | <code>boolean</code> | Enable the Prometheus exporter for Varnish metrics. |
954
+ | <code><a href="#@bluedynamics/cdk8s-plone.PloneHttpcacheOptions.property.extraEnvVars">extraEnvVars</a></code> | <code><a href="#@bluedynamics/cdk8s-plone.HttpcacheEnvVar">HttpcacheEnvVar</a>[]</code> | Additional environment variables to pass to the kube-httpcache container. |
865
955
  | <code><a href="#@bluedynamics/cdk8s-plone.PloneHttpcacheOptions.property.limitCpu">limitCpu</a></code> | <code>string</code> | CPU limit for Varnish pods. |
866
956
  | <code><a href="#@bluedynamics/cdk8s-plone.PloneHttpcacheOptions.property.limitMemory">limitMemory</a></code> | <code>string</code> | Memory limit for Varnish pods. |
867
957
  | <code><a href="#@bluedynamics/cdk8s-plone.PloneHttpcacheOptions.property.replicas">replicas</a></code> | <code>number</code> | Number of Varnish pod replicas to run. |
@@ -947,6 +1037,22 @@ When enabled, the exporter sidecar container will be deployed alongside Varnish.
947
1037
 
948
1038
  ---
949
1039
 
1040
+ ##### `extraEnvVars`<sup>Optional</sup> <a name="extraEnvVars" id="@bluedynamics/cdk8s-plone.PloneHttpcacheOptions.property.extraEnvVars"></a>
1041
+
1042
+ ```typescript
1043
+ public readonly extraEnvVars: HttpcacheEnvVar[];
1044
+ ```
1045
+
1046
+ - *Type:* <a href="#@bluedynamics/cdk8s-plone.HttpcacheEnvVar">HttpcacheEnvVar</a>[]
1047
+ - *Default:* no additional env vars
1048
+
1049
+ Additional environment variables to pass to the kube-httpcache container.
1050
+
1051
+ These are appended to the built-in env vars (BACKEND_SERVICE_NAME, etc.)
1052
+ and can be referenced in VCL templates using Go template syntax: {{ .Env.VAR_NAME }}
1053
+
1054
+ ---
1055
+
950
1056
  ##### `limitCpu`<sup>Optional</sup> <a name="limitCpu" id="@bluedynamics/cdk8s-plone.PloneHttpcacheOptions.property.limitCpu"></a>
951
1057
 
952
1058
  ```typescript
@@ -239,6 +239,7 @@ Configuration for the Varnish HTTP cache layer.
239
239
  | `servicemonitor` | `boolean` | No | `false` | Enable Prometheus ServiceMonitor |
240
240
  | `exporterEnabled` | `boolean` | No | `true` | Enable Prometheus exporter sidecar |
241
241
  | `chartVersion` | `string` | No | latest | kube-httpcache Helm chart version |
242
+ | `extraEnvVars` | `HttpcacheEnvVar[]` | No | - | Additional env vars for kube-httpcache container |
242
243
 
243
244
  **Example:**
244
245
  ```typescript
@@ -276,6 +277,21 @@ new PloneHttpcache(chart, 'cache', {
276
277
  });
277
278
  ```
278
279
 
280
+ **Extra Environment Variables:**
281
+
282
+ Pass additional environment variables to the kube-httpcache container.
283
+ These are appended to the built-in env vars (`BACKEND_SERVICE_NAME`, `BACKEND_SERVICE_PORT`, `BACKEND_SITE_ID`, `FRONTEND_SERVICE_NAME`, `FRONTEND_SERVICE_PORT`) and can be referenced in VCL templates using Go template syntax `{{ .Env.VAR_NAME }}`.
284
+
285
+ ```typescript
286
+ new PloneHttpcache(chart, 'cache', {
287
+ plone: ploneInstance,
288
+ varnishVclFile: './config/custom-varnish.tpl.vcl',
289
+ extraEnvVars: [
290
+ { name: 'THUMBOR_SERVICE_NAME', value: 'my-thumbor-service' },
291
+ ],
292
+ });
293
+ ```
294
+
279
295
  ---
280
296
 
281
297
  ## PloneVariant Enum
@@ -1,5 +1,18 @@
1
1
  import { Construct } from 'constructs';
2
2
  import { Plone } from './plone';
3
+ /**
4
+ * An environment variable to pass to the kube-httpcache container.
5
+ */
6
+ export interface HttpcacheEnvVar {
7
+ /**
8
+ * The name of the environment variable.
9
+ */
10
+ readonly name: string;
11
+ /**
12
+ * The value of the environment variable.
13
+ */
14
+ readonly value: string;
15
+ }
3
16
  /**
4
17
  * Configuration options for PloneHttpcache (Varnish caching layer).
5
18
  */
@@ -76,6 +89,13 @@ export interface PloneHttpcacheOptions {
76
89
  * @default 2
77
90
  */
78
91
  readonly replicas?: number;
92
+ /**
93
+ * Additional environment variables to pass to the kube-httpcache container.
94
+ * These are appended to the built-in env vars (BACKEND_SERVICE_NAME, etc.)
95
+ * and can be referenced in VCL templates using Go template syntax: {{ .Env.VAR_NAME }}
96
+ * @default - no additional env vars
97
+ */
98
+ readonly extraEnvVars?: HttpcacheEnvVar[];
79
99
  }
80
100
  /**
81
101
  * PloneHttpcache construct for deploying Varnish HTTP caching layer.
package/lib/httpcache.js CHANGED
@@ -62,6 +62,7 @@ class PloneHttpcache extends constructs_1.Construct {
62
62
  { name: 'BACKEND_SITE_ID', value: options.plone.siteId },
63
63
  { name: 'FRONTEND_SERVICE_NAME', value: options.plone.frontendServiceName },
64
64
  { name: 'FRONTEND_SERVICE_PORT', value: '3000' },
65
+ ...(options.extraEnvVars ?? []),
65
66
  ],
66
67
  // see https://github.com/mittwald/kube-httpcache/issues/253
67
68
  nodeSelector: {
@@ -113,5 +114,5 @@ class PloneHttpcache extends constructs_1.Construct {
113
114
  }
114
115
  exports.PloneHttpcache = PloneHttpcache;
115
116
  _a = JSII_RTTI_SYMBOL_1;
116
- PloneHttpcache[_a] = { fqn: "@bluedynamics/cdk8s-plone.PloneHttpcache", version: "0.1.16" };
117
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"httpcache.js","sourceRoot":"","sources":["../src/httpcache.ts"],"names":[],"mappings":"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","sourcesContent":["import * as fs from 'fs';\nimport * as path from 'path';\nimport { Helm } from 'cdk8s';\nimport { Construct } from 'constructs';\nimport { Plone } from './plone';\n\n/**\n * Configuration options for PloneHttpcache (Varnish caching layer).\n */\nexport interface PloneHttpcacheOptions {\n  /**\n   * The Plone construct to attach the HTTP cache to.\n   * The cache will automatically connect to the backend and frontend services.\n   */\n  readonly plone: Plone;\n\n  /**\n   * Varnish VCL configuration as a string.\n   * If provided, this takes precedence over varnishVclFile.\n   * @default - loaded from varnishVclFile or default config file\n   */\n  readonly varnishVcl?: string;\n\n  /**\n   * Path to a Varnish VCL configuration file.\n   * If not provided, uses the default VCL file included in the library.\n   * @default - uses default config/varnish.tpl.vcl\n   */\n  readonly varnishVclFile?: string | undefined;\n\n  /**\n   * Name of an existing Kubernetes secret containing Varnish admin credentials.\n   * The secret should be created separately in the same namespace.\n   * @default - undefined (no existing secret)\n   */\n  readonly existingSecret?: string;\n\n  /**\n   * CPU limit for Varnish pods.\n   * @default '500m'\n   */\n  readonly limitCpu?: string;\n\n  /**\n   * Memory limit for Varnish pods.\n   * @default '500Mi'\n   */\n  readonly limitMemory?: string;\n\n  /**\n   * CPU request for Varnish pods.\n   * @default '100m'\n   */\n  readonly requestCpu?: string;\n\n  /**\n   * Memory request for Varnish pods.\n   * @default '100Mi'\n   */\n  readonly requestMemory?: string;\n\n  /**\n   * Enable Prometheus ServiceMonitor for metrics collection.\n   * Requires Prometheus Operator to be installed in the cluster.\n   * @default false\n   */\n  readonly servicemonitor?: boolean;\n\n  /**\n   * Enable the Prometheus exporter for Varnish metrics.\n   * When enabled, the exporter sidecar container will be deployed alongside Varnish.\n   * @default true\n   */\n  readonly exporterEnabled?: boolean;\n\n  /**\n   * Version of the kube-httpcache Helm chart to use.\n   * If not specified, the latest version from the repository will be used.\n   * @default undefined (latest)\n   */\n  readonly chartVersion?: string;\n\n  /**\n   * Version of the kube-httpcache Container Image to use.\n   * If not specified, the latest version from the repository will be used.\n   * @default undefined (chartVersion = with each chart release there is an image release too )\n   */\n  readonly appVersion?: string;\n\n  /**\n   * Number of Varnish pod replicas to run.\n   * @default 2\n   */\n  readonly replicas?: number;\n}\n\n/**\n * PloneHttpcache construct for deploying Varnish HTTP caching layer.\n *\n * Uses the mittwald/kube-httpcache Helm chart to deploy Varnish as a\n * caching proxy in front of Plone backend and/or frontend services.\n *\n * The cache automatically connects to the Plone services and provides\n * HTTP cache invalidation capabilities.\n *\n * @example\n * const plone = new Plone(chart, 'plone');\n * const cache = new PloneHttpcache(chart, 'cache', {\n *   plone: plone,\n *   existingSecret: 'varnish-secret',\n * });\n */\nexport class PloneHttpcache extends Construct {\n  /**\n   * Name of the Varnish service created by the Helm chart.\n   * Use this to reference the cache service from ingress or other constructs.\n   */\n  public readonly httpcacheServiceName: string;\n\n  constructor(scope: Construct, id: string, options: PloneHttpcacheOptions) {\n    super(scope, id);\n    let varnishVcl: string;\n    if (!options.varnishVcl) {\n      let vclPath: string;\n      if (!options.varnishVclFile) {\n        vclPath = path.join(__dirname, 'config', 'varnish.tpl.vcl');\n      } else {\n        vclPath = options.varnishVclFile;\n      }\n      varnishVcl = fs.readFileSync(vclPath, 'utf8');\n    } else {\n      varnishVcl = options.varnishVcl;\n    }\n    const imageTag = options.appVersion ?? options.chartVersion;\n    const httpcache = new Helm(this, 'httpcache', {\n      // see https://github.com/mittwald/kube-httpcache/chart\n      repo: 'https://helm.mittwald.de',\n      chart: 'kube-httpcache',\n      version: options.chartVersion,\n      values: {\n        replicaCount: options.replicas ?? 2,\n        ...(imageTag && { image: { tag: imageTag } }),\n        cache: {\n          // need to looks at the frontendWatch, do we need it?\n          frontendWatch: false,\n          backendWatch: false,\n          existingSecret: options.existingSecret ?? undefined,\n        },\n        vclTemplate: varnishVcl,\n        extraEnvVars: [\n          { name: 'BACKEND_SERVICE_NAME', value: options.plone.backendServiceName },\n          { name: 'BACKEND_SERVICE_PORT', value: '8080' },\n          { name: 'BACKEND_SITE_ID', value: options.plone.siteId },\n          { name: 'FRONTEND_SERVICE_NAME', value: options.plone.frontendServiceName },\n          { name: 'FRONTEND_SERVICE_PORT', value: '3000' },\n        ],\n        // see https://github.com/mittwald/kube-httpcache/issues/253\n        nodeSelector: {\n          'kubernetes.io/arch': 'amd64',\n        },\n        resources: {\n          limits: {\n            cpu: options.limitCpu || '500m',\n            memory: options.limitMemory || '500Mi',\n          },\n          requests: {\n            cpu: options.requestCpu || '100m',\n            memory: options.requestMemory || '100Mi',\n          },\n        },\n        rbac: {\n          enabled: false,\n        },\n        exporter: {\n          enabled: options.exporterEnabled ?? true,\n          resources: {\n            limits: {\n              cpu: '100m',\n              memory: '100Mi',\n            },\n            requests: {\n              cpu: '10m',\n              memory: '50Mi',\n            },\n          },\n        },\n        serviceMonitor: {\n          enabled: options.servicemonitor || false,\n          scrapeSignaller: options.servicemonitor || false,\n        },\n      },\n    });\n    const httpcacheService = httpcache.apiObjects.find((construct) => {\n      if ((construct.kind === 'Service') && (construct.metadata.name?.endsWith('kube-httpcache'))) {\n        return construct.name;\n      }\n      return undefined;\n    });\n    if (httpcacheService === undefined) {\n      throw new Error('Could not find httpcache service');\n    }\n    this.httpcacheServiceName = httpcacheService.name;\n  }\n}"]}
117
+ PloneHttpcache[_a] = { fqn: "@bluedynamics/cdk8s-plone.PloneHttpcache", version: "0.1.18" };
118
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"httpcache.js","sourceRoot":"","sources":["../src/httpcache.ts"],"names":[],"mappings":"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","sourcesContent":["import * as fs from 'fs';\nimport * as path from 'path';\nimport { Helm } from 'cdk8s';\nimport { Construct } from 'constructs';\nimport { Plone } from './plone';\n\n/**\n * An environment variable to pass to the kube-httpcache container.\n */\nexport interface HttpcacheEnvVar {\n  /**\n   * The name of the environment variable.\n   */\n  readonly name: string;\n\n  /**\n   * The value of the environment variable.\n   */\n  readonly value: string;\n}\n\n/**\n * Configuration options for PloneHttpcache (Varnish caching layer).\n */\nexport interface PloneHttpcacheOptions {\n  /**\n   * The Plone construct to attach the HTTP cache to.\n   * The cache will automatically connect to the backend and frontend services.\n   */\n  readonly plone: Plone;\n\n  /**\n   * Varnish VCL configuration as a string.\n   * If provided, this takes precedence over varnishVclFile.\n   * @default - loaded from varnishVclFile or default config file\n   */\n  readonly varnishVcl?: string;\n\n  /**\n   * Path to a Varnish VCL configuration file.\n   * If not provided, uses the default VCL file included in the library.\n   * @default - uses default config/varnish.tpl.vcl\n   */\n  readonly varnishVclFile?: string | undefined;\n\n  /**\n   * Name of an existing Kubernetes secret containing Varnish admin credentials.\n   * The secret should be created separately in the same namespace.\n   * @default - undefined (no existing secret)\n   */\n  readonly existingSecret?: string;\n\n  /**\n   * CPU limit for Varnish pods.\n   * @default '500m'\n   */\n  readonly limitCpu?: string;\n\n  /**\n   * Memory limit for Varnish pods.\n   * @default '500Mi'\n   */\n  readonly limitMemory?: string;\n\n  /**\n   * CPU request for Varnish pods.\n   * @default '100m'\n   */\n  readonly requestCpu?: string;\n\n  /**\n   * Memory request for Varnish pods.\n   * @default '100Mi'\n   */\n  readonly requestMemory?: string;\n\n  /**\n   * Enable Prometheus ServiceMonitor for metrics collection.\n   * Requires Prometheus Operator to be installed in the cluster.\n   * @default false\n   */\n  readonly servicemonitor?: boolean;\n\n  /**\n   * Enable the Prometheus exporter for Varnish metrics.\n   * When enabled, the exporter sidecar container will be deployed alongside Varnish.\n   * @default true\n   */\n  readonly exporterEnabled?: boolean;\n\n  /**\n   * Version of the kube-httpcache Helm chart to use.\n   * If not specified, the latest version from the repository will be used.\n   * @default undefined (latest)\n   */\n  readonly chartVersion?: string;\n\n  /**\n   * Version of the kube-httpcache Container Image to use.\n   * If not specified, the latest version from the repository will be used.\n   * @default undefined (chartVersion = with each chart release there is an image release too )\n   */\n  readonly appVersion?: string;\n\n  /**\n   * Number of Varnish pod replicas to run.\n   * @default 2\n   */\n  readonly replicas?: number;\n\n  /**\n   * Additional environment variables to pass to the kube-httpcache container.\n   * These are appended to the built-in env vars (BACKEND_SERVICE_NAME, etc.)\n   * and can be referenced in VCL templates using Go template syntax: {{ .Env.VAR_NAME }}\n   * @default - no additional env vars\n   */\n  readonly extraEnvVars?: HttpcacheEnvVar[];\n}\n\n/**\n * PloneHttpcache construct for deploying Varnish HTTP caching layer.\n *\n * Uses the mittwald/kube-httpcache Helm chart to deploy Varnish as a\n * caching proxy in front of Plone backend and/or frontend services.\n *\n * The cache automatically connects to the Plone services and provides\n * HTTP cache invalidation capabilities.\n *\n * @example\n * const plone = new Plone(chart, 'plone');\n * const cache = new PloneHttpcache(chart, 'cache', {\n *   plone: plone,\n *   existingSecret: 'varnish-secret',\n * });\n */\nexport class PloneHttpcache extends Construct {\n  /**\n   * Name of the Varnish service created by the Helm chart.\n   * Use this to reference the cache service from ingress or other constructs.\n   */\n  public readonly httpcacheServiceName: string;\n\n  constructor(scope: Construct, id: string, options: PloneHttpcacheOptions) {\n    super(scope, id);\n    let varnishVcl: string;\n    if (!options.varnishVcl) {\n      let vclPath: string;\n      if (!options.varnishVclFile) {\n        vclPath = path.join(__dirname, 'config', 'varnish.tpl.vcl');\n      } else {\n        vclPath = options.varnishVclFile;\n      }\n      varnishVcl = fs.readFileSync(vclPath, 'utf8');\n    } else {\n      varnishVcl = options.varnishVcl;\n    }\n    const imageTag = options.appVersion ?? options.chartVersion;\n    const httpcache = new Helm(this, 'httpcache', {\n      // see https://github.com/mittwald/kube-httpcache/chart\n      repo: 'https://helm.mittwald.de',\n      chart: 'kube-httpcache',\n      version: options.chartVersion,\n      values: {\n        replicaCount: options.replicas ?? 2,\n        ...(imageTag && { image: { tag: imageTag } }),\n        cache: {\n          // need to looks at the frontendWatch, do we need it?\n          frontendWatch: false,\n          backendWatch: false,\n          existingSecret: options.existingSecret ?? undefined,\n        },\n        vclTemplate: varnishVcl,\n        extraEnvVars: [\n          { name: 'BACKEND_SERVICE_NAME', value: options.plone.backendServiceName },\n          { name: 'BACKEND_SERVICE_PORT', value: '8080' },\n          { name: 'BACKEND_SITE_ID', value: options.plone.siteId },\n          { name: 'FRONTEND_SERVICE_NAME', value: options.plone.frontendServiceName },\n          { name: 'FRONTEND_SERVICE_PORT', value: '3000' },\n          ...(options.extraEnvVars ?? []),\n        ],\n        // see https://github.com/mittwald/kube-httpcache/issues/253\n        nodeSelector: {\n          'kubernetes.io/arch': 'amd64',\n        },\n        resources: {\n          limits: {\n            cpu: options.limitCpu || '500m',\n            memory: options.limitMemory || '500Mi',\n          },\n          requests: {\n            cpu: options.requestCpu || '100m',\n            memory: options.requestMemory || '100Mi',\n          },\n        },\n        rbac: {\n          enabled: false,\n        },\n        exporter: {\n          enabled: options.exporterEnabled ?? true,\n          resources: {\n            limits: {\n              cpu: '100m',\n              memory: '100Mi',\n            },\n            requests: {\n              cpu: '10m',\n              memory: '50Mi',\n            },\n          },\n        },\n        serviceMonitor: {\n          enabled: options.servicemonitor || false,\n          scrapeSignaller: options.servicemonitor || false,\n        },\n      },\n    });\n    const httpcacheService = httpcache.apiObjects.find((construct) => {\n      if ((construct.kind === 'Service') && (construct.metadata.name?.endsWith('kube-httpcache'))) {\n        return construct.name;\n      }\n      return undefined;\n    });\n    if (httpcacheService === undefined) {\n      throw new Error('Could not find httpcache service');\n    }\n    this.httpcacheServiceName = httpcacheService.name;\n  }\n}"]}
package/lib/index.d.ts CHANGED
@@ -1,2 +1,2 @@
1
1
  export { Plone, PloneOptions, PloneBaseOptions, PloneVariant } from './plone';
2
- export { PloneHttpcache, PloneHttpcacheOptions } from './httpcache';
2
+ export { PloneHttpcache, PloneHttpcacheOptions, HttpcacheEnvVar } from './httpcache';
package/lib/index.js CHANGED
@@ -6,4 +6,4 @@ Object.defineProperty(exports, "Plone", { enumerable: true, get: function () { r
6
6
  Object.defineProperty(exports, "PloneVariant", { enumerable: true, get: function () { return plone_1.PloneVariant; } });
7
7
  var httpcache_1 = require("./httpcache");
8
8
  Object.defineProperty(exports, "PloneHttpcache", { enumerable: true, get: function () { return httpcache_1.PloneHttpcache; } });
9
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBQUEsaUNBQThFO0FBQXJFLDhGQUFBLEtBQUssT0FBQTtBQUFrQyxxR0FBQSxZQUFZLE9BQUE7QUFDNUQseUNBQW9FO0FBQTNELDJHQUFBLGNBQWMsT0FBQSIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCB7IFBsb25lLCBQbG9uZU9wdGlvbnMsIFBsb25lQmFzZU9wdGlvbnMsIFBsb25lVmFyaWFudCB9IGZyb20gJy4vcGxvbmUnO1xuZXhwb3J0IHsgUGxvbmVIdHRwY2FjaGUsIFBsb25lSHR0cGNhY2hlT3B0aW9ucyB9IGZyb20gJy4vaHR0cGNhY2hlJztcbiJdfQ==
9
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBQUEsaUNBQThFO0FBQXJFLDhGQUFBLEtBQUssT0FBQTtBQUFrQyxxR0FBQSxZQUFZLE9BQUE7QUFDNUQseUNBQXFGO0FBQTVFLDJHQUFBLGNBQWMsT0FBQSIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCB7IFBsb25lLCBQbG9uZU9wdGlvbnMsIFBsb25lQmFzZU9wdGlvbnMsIFBsb25lVmFyaWFudCB9IGZyb20gJy4vcGxvbmUnO1xuZXhwb3J0IHsgUGxvbmVIdHRwY2FjaGUsIFBsb25lSHR0cGNhY2hlT3B0aW9ucywgSHR0cGNhY2hlRW52VmFyIH0gZnJvbSAnLi9odHRwY2FjaGUnO1xuIl19
package/lib/plone.js CHANGED
@@ -258,5 +258,5 @@ class Plone extends constructs_1.Construct {
258
258
  }
259
259
  exports.Plone = Plone;
260
260
  _a = JSII_RTTI_SYMBOL_1;
261
- Plone[_a] = { fqn: "@bluedynamics/cdk8s-plone.Plone", version: "0.1.16" };
261
+ Plone[_a] = { fqn: "@bluedynamics/cdk8s-plone.Plone", version: "0.1.18" };
262
262
  //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"plone.js","sourceRoot":"","sources":["../src/plone.ts"],"names":[],"mappings":"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","sourcesContent":["import { Names } from 'cdk8s';\nimport * as kplus from 'cdk8s-plus-30';\nimport { Construct } from 'constructs';\nimport { PloneDeployment, PloneDeploymentOptions } from './deployment';\nimport { IntOrString } from './imports/k8s';\nimport * as k8s from './imports/k8s';\nimport { ServiceMonitor, ServiceMonitorSpecEndpointsTargetPort } from './imports/monitoring.coreos.com';\nimport { PloneService } from './service';\n\n/**\n * Base options for Plone backend or frontend configuration.\n * These options control container image, replica count, resource limits,\n * environment variables, and health probes.\n */\nexport interface PloneBaseOptions {\n  /**\n   * Container image to use for the deployment.\n   * @example 'plone/plone-backend:6.0.10' or 'plone/plone-frontend:16.0.0'\n   * @default - 'plone/plone-backend:latest' for backend, 'plone/plone-frontend:latest' for frontend\n   */\n  readonly image?: string;\n\n  /**\n   * Image pull policy for the container.\n   * @default 'IfNotPresent'\n   */\n  readonly imagePullPolicy?: string;\n\n  /**\n   * Number of pod replicas to run.\n   * @default 2\n   */\n  readonly replicas?: number;\n\n  /**\n   * Maximum number of pods that can be unavailable during updates.\n   * Can be an absolute number (e.g., 1) or a percentage (e.g., '50%').\n   * Used in PodDisruptionBudget if specified.\n   * @default - undefined (not set)\n   */\n  readonly maxUnavailable?: number | string;\n\n  /**\n   * Minimum number of pods that must be available during updates.\n   * Can be an absolute number (e.g., 1) or a percentage (e.g., '50%').\n   * Used in PodDisruptionBudget if specified.\n   * @default - undefined (not set)\n   */\n  readonly minAvailable?: number | string;\n\n  /**\n   * CPU limit for the container.\n   * @example '500m' or '1' or '2000m'\n   * @default '500m' for both backend and frontend\n   */\n  readonly limitCpu?: string;\n\n  /**\n   * Memory limit for the container.\n   * @example '512Mi' or '1Gi'\n   * @default '512Mi' for backend, '1Gi' for frontend\n   */\n  readonly limitMemory?: string;\n\n  /**\n   * CPU request for the container.\n   * @example '200m' or '0.5'\n   * @default '200m'\n   */\n  readonly requestCpu?: string;\n\n  /**\n   * Memory request for the container.\n   * @example '256Mi' or '512Mi'\n   * @default '256Mi'\n   */\n  readonly requestMemory?: string;\n\n  /**\n   * Environment variables to set in the container.\n   * Use cdk8s-plus-30 Env class to define variables and sources.\n   * @default - undefined (no additional environment variables)\n   */\n  readonly environment?: kplus.Env;\n\n  /**\n   * Enable readiness probe for the container.\n   * Readiness probes determine when a container is ready to accept traffic.\n   * @default true\n   */\n  readonly readinessEnabled?: boolean;\n\n  /**\n   * Number of seconds after container start before readiness probe is initiated.\n   * @default 10\n   */\n  readonly readinessInitialDelaySeconds?: number;\n\n  /**\n   * Number of seconds after which the readiness probe times out.\n   * @default 15\n   */\n  readonly readinessTimeoutSeconds?: number;\n\n  /**\n   * How often (in seconds) to perform the readiness probe.\n   * @default 10\n   */\n  readonly readinessPeriodSeconds?: number;\n\n  /**\n   * Minimum consecutive successes for the readiness probe to be considered successful.\n   * @default 1\n   */\n  readonly readinessSuccessThreshold?: number;\n\n  /**\n   * Minimum consecutive failures for the readiness probe to be considered failed.\n   * @default 3\n   */\n  readonly readinessFailureThreshold?: number;\n\n  /**\n   * Enable liveness probe for the container.\n   * Liveness probes determine when to restart a container.\n   * Recommended: true for frontend, false for backend (Zope has its own recovery).\n   * @default false\n   */\n  readonly livenessEnabled?: boolean;\n\n  /**\n   * Number of seconds after container start before liveness probe is initiated.\n   * @default 30\n   */\n  readonly livenessInitialDelaySeconds?: number;\n\n  /**\n   * Number of seconds after which the liveness probe times out.\n   * @default 5\n   */\n  readonly livenessTimeoutSeconds?: number;\n\n  /**\n   * How often (in seconds) to perform the liveness probe.\n   * @default 10\n   */\n  readonly livenessPeriodSeconds?: number;\n\n  /**\n   * Minimum consecutive successes for the liveness probe to be considered successful.\n   * @default 1\n   */\n  readonly livenessSuccessThreshold?: number;\n\n  /**\n   * Minimum consecutive failures for the liveness probe to be considered failed.\n   * @default 3\n   */\n  readonly livenessFailureThreshold?: number;\n\n  /**\n   * Annotations to add to the Deployment metadata.\n   * @example { 'deployment.kubernetes.io/revision': '1' }\n   * @default - no additional annotations\n   */\n  readonly annotations?: { [name: string]: string };\n\n  /**\n   * Annotations to add to the Pod template metadata.\n   * Common for Prometheus, Istio, backup policies, etc.\n   * @example { 'prometheus.io/scrape': 'true', 'prometheus.io/port': '8080' }\n   * @default - no additional annotations\n   */\n  readonly podAnnotations?: { [name: string]: string };\n\n  /**\n   * Annotations to add to the Service metadata.\n   * Common for external-dns, load balancers, service mesh, etc.\n   * @example { 'external-dns.alpha.kubernetes.io/hostname': 'plone.example.com' }\n   * @default - no additional annotations\n   */\n  readonly serviceAnnotations?: { [name: string]: string };\n\n  /**\n   * Enable Prometheus ServiceMonitor for metrics collection.\n   * Requires Prometheus Operator to be installed in the cluster.\n   * When enabled, a ServiceMonitor resource will be created to scrape metrics.\n   * @default false\n   */\n  readonly servicemonitor?: boolean;\n\n  /**\n   * Port name or number to scrape metrics from.\n   * Only used when servicemonitor is enabled.\n   * @default - uses the main service port\n   */\n  readonly metricsPort?: string | number;\n\n  /**\n   * Path to scrape metrics from.\n   * Only used when servicemonitor is enabled.\n   * @default '/metrics'\n   */\n  readonly metricsPath?: string;\n}\n/**\n * Plone deployment variants.\n */\nexport enum PloneVariant {\n  /**\n   * Volto variant: ReactJS frontend (Volto) with REST API backend.\n   * Deploys both frontend and backend services.\n   */\n  VOLTO = 'volto',\n\n  /**\n   * Classic UI variant: Traditional Plone with server-side rendering.\n   * Deploys only the backend service.\n   */\n  CLASSICUI = 'classicui',\n}\n\n/**\n * Main configuration options for Plone deployment.\n */\nexport interface PloneOptions {\n  /**\n   * Version string for labeling the deployment.\n   * This is used in Kubernetes labels and doesn't affect the actual image versions.\n   * @default 'undefined'\n   */\n  readonly version?: string;\n\n  /**\n   * Plone site ID in the ZODB.\n   * This is used to construct the internal API path for Volto frontend.\n   * @default 'Plone'\n   */\n  readonly siteId?: string;\n\n  /**\n   * Plone deployment variant to use.\n   * @default PloneVariant.VOLTO\n   */\n  readonly variant?: PloneVariant;\n\n  /**\n   * Backend (Plone API) configuration.\n   * @default {} (uses default values from PloneBaseOptions)\n   */\n  readonly backend?: PloneBaseOptions;\n\n  /**\n   * Frontend (Volto) configuration.\n   * Only used when variant is PloneVariant.VOLTO.\n   * @default {} (uses default values from PloneBaseOptions)\n   */\n  readonly frontend?: PloneBaseOptions;\n\n  /**\n   * Names of Kubernetes secrets to use for pulling private container images.\n   * These secrets must exist in the same namespace as the deployment.\n   * @example ['my-registry-secret']\n   * @default [] (no image pull secrets)\n   */\n  readonly imagePullSecrets?: string[];\n}\n\n/**\n * Plone construct for deploying Plone CMS to Kubernetes.\n *\n * This construct creates all necessary Kubernetes resources for running Plone:\n * - Deployment(s) for backend (and optionally frontend)\n * - Service(s) for network access\n * - Optional PodDisruptionBudget for high availability\n *\n * Supports two deployment variants:\n * - VOLTO: Modern React frontend with REST API backend (default)\n * - CLASSICUI: Traditional server-side rendered Plone\n *\n * @example\n * new Plone(chart, 'my-plone', {\n *   variant: PloneVariant.VOLTO,\n *   backend: {\n *     image: 'plone/plone-backend:6.0.10',\n *     replicas: 3,\n *   },\n *   frontend: {\n *     image: 'plone/plone-frontend:16.0.0',\n *   },\n * });\n */\nexport class Plone extends Construct {\n  /**\n   * Name of the backend Kubernetes service.\n   * Use this to reference the backend service from other constructs.\n   */\n  public readonly backendServiceName: string;\n\n  /**\n   * Name of the frontend Kubernetes service.\n   * Only set when variant is VOLTO, otherwise undefined.\n   */\n  public readonly frontendServiceName: string | undefined;\n\n  /**\n   * The deployment variant being used (VOLTO or CLASSICUI).\n   */\n  public readonly variant: PloneVariant;\n\n  /**\n   * The Plone site ID in ZODB.\n   */\n  public readonly siteId: string;\n\n  constructor(scope: Construct, id: string, options: PloneOptions = {}) {\n    super(scope, id);\n    this.frontendServiceName = undefined;\n    this.siteId = options.siteId ?? 'Plone';\n    this.variant = options.variant ?? PloneVariant.VOLTO;\n\n    // ------------------------------------------------------------------------\n    // Backend\n    const backend = options.backend ?? {};\n    const backendLabels = {\n      'app.kubernetes.io/name': 'plone-backend',\n      'app.kubernetes.io/component': 'backend',\n      'app.kubernetes.io/version': options.version ?? 'undefined',\n    };\n    const backendPort = 8080;\n\n    // Options\n    var backendOptions: PloneDeploymentOptions = {\n      labels: backendLabels,\n      image: {\n        image: backend.image ?? 'plone/plone-backend:latest',\n        imagePullSecrets: options.imagePullSecrets ?? [],\n        imagePullPolicy: backend.imagePullPolicy ?? 'IfNotPresent',\n      },\n      replicas: backend.replicas,\n      limitCpu: backend.limitCpu ?? '500m',\n      limitMemory: backend.limitMemory ?? '512Mi',\n      requestCpu: backend.requestCpu ?? '200m',\n      requestMemory: backend.requestMemory ?? '256Mi',\n      pdb: {\n        maxUnavailable: backend.maxUnavailable ?? undefined,\n        minAvailable: backend.minAvailable ?? undefined,\n      },\n      port: backendPort,\n      environment: backend.environment,\n      annotations: backend.annotations,\n      podAnnotations: backend.podAnnotations,\n    };\n\n    // Probing\n    const backendActionHttpGet: k8s.HttpGetAction = {\n      path: '/',\n      port: IntOrString.fromNumber(backendPort),\n    };\n    if (backend.livenessEnabled ?? false) {\n      backendOptions.livenessProbe = {\n        httpGet: backendActionHttpGet,\n        initialDelaySeconds: backend.livenessInitialDelaySeconds ?? 30,\n        timeoutSeconds: backend.livenessTimeoutSeconds ?? 5,\n        periodSeconds: backend.livenessPeriodSeconds ?? 10,\n        successThreshold: backend.livenessSuccessThreshold ?? 1,\n        failureThreshold: backend.livenessFailureThreshold ?? 3,\n      };\n    }\n    if (backend.readinessEnabled ?? true) {\n      backendOptions.readinessProbe = {\n        httpGet: backendActionHttpGet,\n        initialDelaySeconds: backend.readinessInitialDelaySeconds ?? 10,\n        timeoutSeconds: backend.readinessTimeoutSeconds ?? 15,\n        periodSeconds: backend.readinessPeriodSeconds ?? 10,\n        successThreshold: backend.readinessSuccessThreshold ?? 1,\n        failureThreshold: backend.readinessFailureThreshold ?? 3,\n      };\n    }\n    // Deployment\n    var backendDeployment = new PloneDeployment(this, 'backend', backendOptions);\n\n    // Service\n    const backendService = new PloneService(backendDeployment, 'service', {\n      labels: {\n        'app.kubernetes.io/name': 'plone-backend-service',\n        'app.kubernetes.io/component': 'service',\n      },\n      targetPort: backendPort,\n      selectorLabel: { app: Names.toLabelValue(backendDeployment) },\n      portName: 'backend-http',\n      annotations: backend.serviceAnnotations,\n    });\n    this.backendServiceName = backendService.name;\n\n    // ServiceMonitor for backend\n    if (backend.servicemonitor) {\n      this.createServiceMonitor(backendService, 'backend', {\n        port: backend.metricsPort ?? 'backend-http',\n        path: backend.metricsPath ?? '/metrics',\n      });\n    }\n\n    // ------------------------------------------------------------------------\n    // Frontend\n    if (this.variant == PloneVariant.VOLTO) {\n      const frontend = options.frontend ?? {};\n      const frontendPort = 3000;\n      const frontendLabels = {\n        'app.kubernetes.io/name': 'plone-frontend',\n        'app.kubernetes.io/component': 'frontend',\n        'app.kubernetes.io/version': options.version ?? 'undefined',\n      };\n\n      // Environment for RAZZLE\n      var frontendEnvironment = frontend.environment ?? new kplus.Env([], {});\n      if (frontendEnvironment.variables.RAZZLE_INTERNAL_API_PATH === undefined) {\n        // connect with backend service\n        frontendEnvironment?.addVariable('RAZZLE_INTERNAL_API_PATH', kplus.EnvValue.fromValue(`http://${backendService.name}:${backendPort}/${this.siteId}`));\n      }\n\n      // Options\n      var frontendOptions: PloneDeploymentOptions = {\n        labels: frontendLabels,\n        image: {\n          image: frontend.image ?? 'plone/plone-frontend:latest',\n          imagePullSecrets: options.imagePullSecrets ?? [],\n          imagePullPolicy: frontend.imagePullPolicy ?? 'IfNotPresent',\n        },\n        replicas: frontend.replicas,\n        limitCpu: frontend.limitCpu ?? '500m',\n        limitMemory: frontend.limitMemory ?? '1Gi',\n        requestCpu: frontend.requestCpu ?? '200m',\n        requestMemory: frontend.requestMemory ?? '256Mi',\n\n        pdb: {\n          maxUnavailable: frontend.maxUnavailable ?? undefined,\n          minAvailable: frontend.minAvailable ?? undefined,\n        },\n        port: frontendPort,\n        environment: frontendEnvironment,\n        annotations: frontend.annotations,\n        podAnnotations: frontend.podAnnotations,\n      };\n\n      // Probing\n      const frontendActionHttpGet: k8s.HttpGetAction = {\n        path: '/',\n        port: IntOrString.fromNumber(frontendPort),\n      };\n      if (frontend.livenessEnabled ?? false) {\n        frontendOptions.livenessProbe = {\n          httpGet: frontendActionHttpGet,\n          initialDelaySeconds: frontend.livenessInitialDelaySeconds ?? 30,\n          timeoutSeconds: frontend.livenessTimeoutSeconds ?? 5,\n          periodSeconds: frontend.livenessPeriodSeconds ?? 10,\n          successThreshold: frontend.livenessSuccessThreshold ?? 1,\n          failureThreshold: frontend.livenessFailureThreshold ?? 3,\n        };\n      }\n      if (frontend.readinessEnabled ?? true) {\n        frontendOptions.readinessProbe = {\n          httpGet: frontendActionHttpGet,\n          initialDelaySeconds: frontend.readinessInitialDelaySeconds ?? 10,\n          timeoutSeconds: frontend.readinessTimeoutSeconds ?? 15,\n          periodSeconds: frontend.readinessPeriodSeconds ?? 10,\n          successThreshold: frontend.readinessSuccessThreshold ?? 1,\n          failureThreshold: frontend.readinessFailureThreshold ?? 3,\n        };\n      }\n\n      // Deployment\n      const frontendDeployment = new PloneDeployment(this, 'frontend', frontendOptions);\n\n      // Service\n      const frontendService = new PloneService(frontendDeployment, 'service', {\n        labels: {\n          'app.kubernetes.io/name': 'plone-frontend-service',\n          'app.kubernetes.io/component': 'service',\n        },\n        targetPort: frontendPort,\n        selectorLabel: { app: Names.toLabelValue(frontendDeployment) },\n        portName: 'frontend-http',\n        annotations: frontend.serviceAnnotations,\n      });\n      this.frontendServiceName = frontendService.name;\n\n      // ServiceMonitor for frontend\n      if (frontend.servicemonitor) {\n        this.createServiceMonitor(frontendService, 'frontend', {\n          port: frontend.metricsPort ?? 'frontend-http',\n          path: frontend.metricsPath ?? '/metrics',\n        });\n      }\n    }\n  }\n\n  /**\n   * Creates a Prometheus ServiceMonitor resource for the given service.\n   * @param service The PloneService to monitor\n   * @param id Unique identifier for the ServiceMonitor\n   * @param config Configuration for the ServiceMonitor\n   */\n  private createServiceMonitor(\n    service: PloneService,\n    id: string,\n    config: { port: string | number; path: string },\n  ): void {\n    const portName = typeof config.port === 'string' ? config.port : undefined;\n    const portNumber = typeof config.port === 'number'\n      ? ServiceMonitorSpecEndpointsTargetPort.fromNumber(config.port)\n      : undefined;\n\n    new ServiceMonitor(this, `servicemonitor-${id}`, {\n      metadata: {\n        name: `${service.name}-monitor`,\n        labels: {\n          'app.kubernetes.io/name': service.name,\n          'app.kubernetes.io/component': 'servicemonitor',\n        },\n      },\n      spec: {\n        selector: {\n          matchLabels: {\n            'app.kubernetes.io/name': service.labels['app.kubernetes.io/name'],\n          },\n        },\n        endpoints: [\n          {\n            ...(portName && { port: portName }),\n            ...(portNumber && { targetPort: portNumber }),\n            path: config.path,\n            interval: '30s',\n          },\n        ],\n      },\n    });\n  }\n}"]}
package/package.json CHANGED
@@ -42,7 +42,7 @@
42
42
  "@types/node": "^18",
43
43
  "@typescript-eslint/eslint-plugin": "^8",
44
44
  "@typescript-eslint/parser": "^8",
45
- "cdk8s-cli": "^2.203.14",
45
+ "cdk8s-cli": "^2.204.9",
46
46
  "cdk8s-plus-30": "^2.4.10",
47
47
  "commit-and-tag-version": "^12",
48
48
  "constructs": "10.4.2",
@@ -52,11 +52,11 @@
52
52
  "jest": "^29.7.0",
53
53
  "jest-junit": "^16",
54
54
  "jsii": "~5.9.11",
55
- "jsii-diff": "^1.122.0",
55
+ "jsii-diff": "^1.127.0",
56
56
  "jsii-docgen": "^10.5.0",
57
- "jsii-pacmak": "^1.122.0",
57
+ "jsii-pacmak": "^1.127.0",
58
58
  "jsii-rosetta": "~5.9.11",
59
- "projen": "^0.98.30",
59
+ "projen": "^0.99.17",
60
60
  "ts-jest": "^29.4.6",
61
61
  "ts-node": "^10.9.2",
62
62
  "typescript": "^5.9.3",
@@ -67,7 +67,7 @@
67
67
  "constructs": "^10.4.2"
68
68
  },
69
69
  "dependencies": {
70
- "cdk8s": "^2.70.37",
70
+ "cdk8s": "^2.70.50",
71
71
  "cdk8s-plus-30": "^2.4.10",
72
72
  "constructs": "^10.4.2"
73
73
  },
@@ -76,7 +76,7 @@
76
76
  "publishConfig": {
77
77
  "access": "public"
78
78
  },
79
- "version": "0.1.16",
79
+ "version": "0.1.18",
80
80
  "jest": {
81
81
  "coverageProvider": "v8",
82
82
  "testMatch": [