@bluedynamics/cdk8s-plone 0.0.12 → 0.0.14

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.68.92",
10
+ "cdk8s": "^2.68.93",
11
11
  "cdk8s-plus-24": "^2.12.1",
12
12
  "constructs": "^10.3.0"
13
13
  },
@@ -108,7 +108,7 @@
108
108
  },
109
109
  "name": "@bluedynamics/cdk8s-plone",
110
110
  "readme": {
111
- "markdown": "# CMS Plone Chart for CDK8S\n\nThis chart provides a library to bootstrap a Plone deployment on a Kubernetes cluster using the [CDK8S](https://cdk8s.io) framework.\n\nIt provides\n- backend (with `plone.volto` or Classic-UI)\n- frontend (Plone-Volto, a ReactJS based user interface)\n- varnish (optional)\n\n## Usage\n\nFor now have a look at the [example project](https://github.com/bluedynamics/cdk8s-plone-example)..\n\n\n## Development\n\nClone the repository and install the dependencies:\n\n```bash\nyarn install\n```\n\nThen run the following command to run the test:\n\n```bash\nnpx projen test\n```\n\n### WIP Checklist:\n\nEach step need to be implemented with tests!\n\n- [ ] Start Backend\n - [x] deployment\n - [x] service\n - [x] pdb\n - [ ] init container running plone-site-create\n - [x] lifecycle checks (readiness, liveness)\n - [x] generic way to inject sidecars\n- [ ] Start Frontend\n - [x] deployment\n - [x] service\n - [x] pdb\n - [ ] lifecycle checks (readiness, liveness)\n - [ ] depend on ready/live backend (needed?)\n - [x] generic way to inject sidecars\n\n- [ ] Start Varnish\n - [ ] deployment\n - [ ] do not depend on backend/front end to be up, but configure to deliver from cache if possible.\n - [ ] service\n - [ ] pdb\n - [ ] lifecycle checks (readiness, liveness)\n - [ ] generic way to inject sidecars\n - find a way to purge caches. based on kitconcept varnish purger? needs\n\n- [ ] Other Languages\n - [x] Check Python distribution\n - [ ] Check Java distribution\n - [ ] Check Go distribution"
111
+ "markdown": "# CMS Plone Chart for CDK8S\n\nThis chart provides a library to bootstrap a Plone deployment on a Kubernetes cluster using the [CDK8S](https://cdk8s.io) framework.\n\nIt provides\n- backend (with `plone.volto` or Classic-UI)\n- frontend (Plone-Volto, a ReactJS based user interface)\n- varnish (optional)\n\n## Usage\n\nFor now have a look at the [example project](https://github.com/bluedynamics/cdk8s-plone-example)..\n\n\n## Development\n\nClone the repository and install the dependencies:\n\n```bash\nyarn install\n```\n\nThen run the following command to run the test:\n\n```bash\nnpx projen test\n```\n\n### WIP Checklist:\n\nEach step need to be implemented with tests!\n\n- [ ] Start Backend\n - [x] deployment\n - [x] service\n - [x] pdb\n - [ ] init container running plone-site-create\n - [x] lifecycle checks (readiness, liveness)\n - [x] generic way to inject sidecars\n- [ ] Start Frontend\n - [x] deployment\n - [x] service\n - [x] pdb\n - [x] lifecycle checks (readiness, liveness)\n - [ ] depend on ready/live backend (needed?)\n - [x] generic way to inject sidecars\n\n- [ ] Start Varnish\n - [ ] deployment\n - [ ] do not depend on backend/front end to be up, but configure to deliver from cache if possible.\n - [ ] service\n - [ ] pdb\n - [ ] lifecycle checks (readiness, liveness)\n - [ ] generic way to inject sidecars\n - find a way to purge caches. based on kitconcept varnish purger? needs evaluation\n\n- [ ] Other Languages\n - [x] Check Python distribution\n - [ ] Check Java distribution\n - [ ] Check Go distribution"
112
112
  },
113
113
  "repository": {
114
114
  "type": "git",
@@ -138,7 +138,7 @@
138
138
  },
139
139
  "locationInModule": {
140
140
  "filename": "src/plone.ts",
141
- "line": 33
141
+ "line": 50
142
142
  },
143
143
  "parameters": [
144
144
  {
@@ -165,7 +165,7 @@
165
165
  "kind": "class",
166
166
  "locationInModule": {
167
167
  "filename": "src/plone.ts",
168
- "line": 28
168
+ "line": 45
169
169
  },
170
170
  "name": "Plone",
171
171
  "properties": [
@@ -176,7 +176,7 @@
176
176
  "immutable": true,
177
177
  "locationInModule": {
178
178
  "filename": "src/plone.ts",
179
- "line": 30
179
+ "line": 47
180
180
  },
181
181
  "name": "backendServiceName",
182
182
  "type": {
@@ -190,7 +190,7 @@
190
190
  "immutable": true,
191
191
  "locationInModule": {
192
192
  "filename": "src/plone.ts",
193
- "line": 31
193
+ "line": 48
194
194
  },
195
195
  "name": "frontendServiceName",
196
196
  "type": {
@@ -210,7 +210,7 @@
210
210
  "kind": "interface",
211
211
  "locationInModule": {
212
212
  "filename": "src/plone.ts",
213
- "line": 8
213
+ "line": 9
214
214
  },
215
215
  "name": "PloneBaseOptions",
216
216
  "properties": [
@@ -222,7 +222,7 @@
222
222
  "immutable": true,
223
223
  "locationInModule": {
224
224
  "filename": "src/plone.ts",
225
- "line": 18
225
+ "line": 22
226
226
  },
227
227
  "name": "environment",
228
228
  "optional": true,
@@ -238,7 +238,7 @@
238
238
  "immutable": true,
239
239
  "locationInModule": {
240
240
  "filename": "src/plone.ts",
241
- "line": 9
241
+ "line": 11
242
242
  },
243
243
  "name": "image",
244
244
  "optional": true,
@@ -254,7 +254,7 @@
254
254
  "immutable": true,
255
255
  "locationInModule": {
256
256
  "filename": "src/plone.ts",
257
- "line": 10
257
+ "line": 12
258
258
  },
259
259
  "name": "imagePullPolicy",
260
260
  "optional": true,
@@ -270,7 +270,7 @@
270
270
  "immutable": true,
271
271
  "locationInModule": {
272
272
  "filename": "src/plone.ts",
273
- "line": 14
273
+ "line": 18
274
274
  },
275
275
  "name": "limitCpu",
276
276
  "optional": true,
@@ -286,7 +286,7 @@
286
286
  "immutable": true,
287
287
  "locationInModule": {
288
288
  "filename": "src/plone.ts",
289
- "line": 15
289
+ "line": 19
290
290
  },
291
291
  "name": "limitMemory",
292
292
  "optional": true,
@@ -302,7 +302,87 @@
302
302
  "immutable": true,
303
303
  "locationInModule": {
304
304
  "filename": "src/plone.ts",
305
- "line": 12
305
+ "line": 34
306
+ },
307
+ "name": "livenessFailureThreshold",
308
+ "optional": true,
309
+ "type": {
310
+ "primitive": "number"
311
+ }
312
+ },
313
+ {
314
+ "abstract": true,
315
+ "docs": {
316
+ "stability": "stable"
317
+ },
318
+ "immutable": true,
319
+ "locationInModule": {
320
+ "filename": "src/plone.ts",
321
+ "line": 31
322
+ },
323
+ "name": "livenessIimeoutSeconds",
324
+ "optional": true,
325
+ "type": {
326
+ "primitive": "number"
327
+ }
328
+ },
329
+ {
330
+ "abstract": true,
331
+ "docs": {
332
+ "stability": "stable"
333
+ },
334
+ "immutable": true,
335
+ "locationInModule": {
336
+ "filename": "src/plone.ts",
337
+ "line": 30
338
+ },
339
+ "name": "livenessInitialDelaySeconds",
340
+ "optional": true,
341
+ "type": {
342
+ "primitive": "number"
343
+ }
344
+ },
345
+ {
346
+ "abstract": true,
347
+ "docs": {
348
+ "stability": "stable"
349
+ },
350
+ "immutable": true,
351
+ "locationInModule": {
352
+ "filename": "src/plone.ts",
353
+ "line": 32
354
+ },
355
+ "name": "livenessPeriodSeconds",
356
+ "optional": true,
357
+ "type": {
358
+ "primitive": "number"
359
+ }
360
+ },
361
+ {
362
+ "abstract": true,
363
+ "docs": {
364
+ "stability": "stable"
365
+ },
366
+ "immutable": true,
367
+ "locationInModule": {
368
+ "filename": "src/plone.ts",
369
+ "line": 33
370
+ },
371
+ "name": "livenessSuccessThreshold",
372
+ "optional": true,
373
+ "type": {
374
+ "primitive": "number"
375
+ }
376
+ },
377
+ {
378
+ "abstract": true,
379
+ "docs": {
380
+ "stability": "stable"
381
+ },
382
+ "immutable": true,
383
+ "locationInModule": {
384
+ "filename": "src/plone.ts",
385
+ "line": 15
306
386
  },
307
387
  "name": "maxUnavailable",
308
388
  "optional": true,
@@ -327,7 +407,7 @@
327
407
  "immutable": true,
328
408
  "locationInModule": {
329
409
  "filename": "src/plone.ts",
330
- "line": 13
410
+ "line": 16
331
411
  },
332
412
  "name": "minAvailable",
333
413
  "optional": true,
@@ -352,7 +432,87 @@
352
432
  "immutable": true,
353
433
  "locationInModule": {
354
434
  "filename": "src/plone.ts",
355
- "line": 11
435
+ "line": 28
436
+ },
437
+ "name": "readinessFailureThreshold",
438
+ "optional": true,
439
+ "type": {
440
+ "primitive": "number"
441
+ }
442
+ },
443
+ {
444
+ "abstract": true,
445
+ "docs": {
446
+ "stability": "stable"
447
+ },
448
+ "immutable": true,
449
+ "locationInModule": {
450
+ "filename": "src/plone.ts",
451
+ "line": 25
452
+ },
453
+ "name": "readinessIimeoutSeconds",
454
+ "optional": true,
455
+ "type": {
456
+ "primitive": "number"
457
+ }
458
+ },
459
+ {
460
+ "abstract": true,
461
+ "docs": {
462
+ "stability": "stable"
463
+ },
464
+ "immutable": true,
465
+ "locationInModule": {
466
+ "filename": "src/plone.ts",
467
+ "line": 24
468
+ },
469
+ "name": "readinessInitialDelaySeconds",
470
+ "optional": true,
471
+ "type": {
472
+ "primitive": "number"
473
+ }
474
+ },
475
+ {
476
+ "abstract": true,
477
+ "docs": {
478
+ "stability": "stable"
479
+ },
480
+ "immutable": true,
481
+ "locationInModule": {
482
+ "filename": "src/plone.ts",
483
+ "line": 26
484
+ },
485
+ "name": "readinessPeriodSeconds",
486
+ "optional": true,
487
+ "type": {
488
+ "primitive": "number"
489
+ }
490
+ },
491
+ {
492
+ "abstract": true,
493
+ "docs": {
494
+ "stability": "stable"
495
+ },
496
+ "immutable": true,
497
+ "locationInModule": {
498
+ "filename": "src/plone.ts",
499
+ "line": 27
500
+ },
501
+ "name": "readinessSuccessThreshold",
502
+ "optional": true,
503
+ "type": {
504
+ "primitive": "number"
505
+ }
506
+ },
507
+ {
508
+ "abstract": true,
509
+ "docs": {
510
+ "stability": "stable"
511
+ },
512
+ "immutable": true,
513
+ "locationInModule": {
514
+ "filename": "src/plone.ts",
515
+ "line": 14
356
516
  },
357
517
  "name": "replicas",
358
518
  "optional": true,
@@ -368,7 +528,7 @@
368
528
  "immutable": true,
369
529
  "locationInModule": {
370
530
  "filename": "src/plone.ts",
371
- "line": 16
531
+ "line": 20
372
532
  },
373
533
  "name": "requestCpu",
374
534
  "optional": true,
@@ -384,7 +544,7 @@
384
544
  "immutable": true,
385
545
  "locationInModule": {
386
546
  "filename": "src/plone.ts",
387
- "line": 17
547
+ "line": 21
388
548
  },
389
549
  "name": "requestMemory",
390
550
  "optional": true,
@@ -405,7 +565,7 @@
405
565
  "kind": "interface",
406
566
  "locationInModule": {
407
567
  "filename": "src/plone.ts",
408
- "line": 20
568
+ "line": 36
409
569
  },
410
570
  "name": "PloneOptions",
411
571
  "properties": [
@@ -417,7 +577,7 @@
417
577
  "immutable": true,
418
578
  "locationInModule": {
419
579
  "filename": "src/plone.ts",
420
- "line": 23
580
+ "line": 39
421
581
  },
422
582
  "name": "backend",
423
583
  "optional": true,
@@ -433,7 +593,7 @@
433
593
  "immutable": true,
434
594
  "locationInModule": {
435
595
  "filename": "src/plone.ts",
436
- "line": 24
596
+ "line": 40
437
597
  },
438
598
  "name": "frontend",
439
599
  "optional": true,
@@ -449,7 +609,7 @@
449
609
  "immutable": true,
450
610
  "locationInModule": {
451
611
  "filename": "src/plone.ts",
452
- "line": 25
612
+ "line": 41
453
613
  },
454
614
  "name": "imagePullSecrets",
455
615
  "optional": true,
@@ -470,7 +630,7 @@
470
630
  "immutable": true,
471
631
  "locationInModule": {
472
632
  "filename": "src/plone.ts",
473
- "line": 22
633
+ "line": 38
474
634
  },
475
635
  "name": "siteId",
476
636
  "optional": true,
@@ -486,7 +646,7 @@
486
646
  "immutable": true,
487
647
  "locationInModule": {
488
648
  "filename": "src/plone.ts",
489
- "line": 21
649
+ "line": 37
490
650
  },
491
651
  "name": "version",
492
652
  "optional": true,
@@ -498,6 +658,6 @@
498
658
  "symbolId": "src/plone:PloneOptions"
499
659
  }
500
660
  },
501
- "version": "0.0.12",
502
- "fingerprint": "+Yh3z85xcrAe7crf0RtO0W/Ic8RSuoWpDLOkwNSyl3k="
661
+ "version": "0.0.14",
662
+ "fingerprint": "T5YGv9NfhQ6I4EHikmsv0RbRyiS6QswQX2dZBZn6JYk="
503
663
  }
package/API.md CHANGED
@@ -158,8 +158,18 @@ const ploneBaseOptions: PloneBaseOptions = { ... }
158
158
  | <code><a href="#@bluedynamics/cdk8s-plone.PloneBaseOptions.property.imagePullPolicy">imagePullPolicy</a></code> | <code>string</code> | *No description.* |
159
159
  | <code><a href="#@bluedynamics/cdk8s-plone.PloneBaseOptions.property.limitCpu">limitCpu</a></code> | <code>string</code> | *No description.* |
160
160
  | <code><a href="#@bluedynamics/cdk8s-plone.PloneBaseOptions.property.limitMemory">limitMemory</a></code> | <code>string</code> | *No description.* |
161
+ | <code><a href="#@bluedynamics/cdk8s-plone.PloneBaseOptions.property.livenessFailureThreshold">livenessFailureThreshold</a></code> | <code>number</code> | *No description.* |
162
+ | <code><a href="#@bluedynamics/cdk8s-plone.PloneBaseOptions.property.livenessIimeoutSeconds">livenessIimeoutSeconds</a></code> | <code>number</code> | *No description.* |
163
+ | <code><a href="#@bluedynamics/cdk8s-plone.PloneBaseOptions.property.livenessInitialDelaySeconds">livenessInitialDelaySeconds</a></code> | <code>number</code> | *No description.* |
164
+ | <code><a href="#@bluedynamics/cdk8s-plone.PloneBaseOptions.property.livenessPeriodSeconds">livenessPeriodSeconds</a></code> | <code>number</code> | *No description.* |
165
+ | <code><a href="#@bluedynamics/cdk8s-plone.PloneBaseOptions.property.livenessSuccessThreshold">livenessSuccessThreshold</a></code> | <code>number</code> | *No description.* |
161
166
  | <code><a href="#@bluedynamics/cdk8s-plone.PloneBaseOptions.property.maxUnavailable">maxUnavailable</a></code> | <code>string \| number</code> | *No description.* |
162
167
  | <code><a href="#@bluedynamics/cdk8s-plone.PloneBaseOptions.property.minAvailable">minAvailable</a></code> | <code>string \| number</code> | *No description.* |
168
+ | <code><a href="#@bluedynamics/cdk8s-plone.PloneBaseOptions.property.readinessFailureThreshold">readinessFailureThreshold</a></code> | <code>number</code> | *No description.* |
169
+ | <code><a href="#@bluedynamics/cdk8s-plone.PloneBaseOptions.property.readinessIimeoutSeconds">readinessIimeoutSeconds</a></code> | <code>number</code> | *No description.* |
170
+ | <code><a href="#@bluedynamics/cdk8s-plone.PloneBaseOptions.property.readinessInitialDelaySeconds">readinessInitialDelaySeconds</a></code> | <code>number</code> | *No description.* |
171
+ | <code><a href="#@bluedynamics/cdk8s-plone.PloneBaseOptions.property.readinessPeriodSeconds">readinessPeriodSeconds</a></code> | <code>number</code> | *No description.* |
172
+ | <code><a href="#@bluedynamics/cdk8s-plone.PloneBaseOptions.property.readinessSuccessThreshold">readinessSuccessThreshold</a></code> | <code>number</code> | *No description.* |
163
173
  | <code><a href="#@bluedynamics/cdk8s-plone.PloneBaseOptions.property.replicas">replicas</a></code> | <code>number</code> | *No description.* |
164
174
  | <code><a href="#@bluedynamics/cdk8s-plone.PloneBaseOptions.property.requestCpu">requestCpu</a></code> | <code>string</code> | *No description.* |
165
175
  | <code><a href="#@bluedynamics/cdk8s-plone.PloneBaseOptions.property.requestMemory">requestMemory</a></code> | <code>string</code> | *No description.* |
@@ -216,6 +226,56 @@ public readonly limitMemory: string;
216
226
 
217
227
  ---
218
228
 
229
+ ##### `livenessFailureThreshold`<sup>Optional</sup> <a name="livenessFailureThreshold" id="@bluedynamics/cdk8s-plone.PloneBaseOptions.property.livenessFailureThreshold"></a>
230
+
231
+ ```typescript
232
+ public readonly livenessFailureThreshold: number;
233
+ ```
234
+
235
+ - *Type:* number
236
+
237
+ ---
238
+
239
+ ##### `livenessIimeoutSeconds`<sup>Optional</sup> <a name="livenessIimeoutSeconds" id="@bluedynamics/cdk8s-plone.PloneBaseOptions.property.livenessIimeoutSeconds"></a>
240
+
241
+ ```typescript
242
+ public readonly livenessIimeoutSeconds: number;
243
+ ```
244
+
245
+ - *Type:* number
246
+
247
+ ---
248
+
249
+ ##### `livenessInitialDelaySeconds`<sup>Optional</sup> <a name="livenessInitialDelaySeconds" id="@bluedynamics/cdk8s-plone.PloneBaseOptions.property.livenessInitialDelaySeconds"></a>
250
+
251
+ ```typescript
252
+ public readonly livenessInitialDelaySeconds: number;
253
+ ```
254
+
255
+ - *Type:* number
256
+
257
+ ---
258
+
259
+ ##### `livenessPeriodSeconds`<sup>Optional</sup> <a name="livenessPeriodSeconds" id="@bluedynamics/cdk8s-plone.PloneBaseOptions.property.livenessPeriodSeconds"></a>
260
+
261
+ ```typescript
262
+ public readonly livenessPeriodSeconds: number;
263
+ ```
264
+
265
+ - *Type:* number
266
+
267
+ ---
268
+
269
+ ##### `livenessSuccessThreshold`<sup>Optional</sup> <a name="livenessSuccessThreshold" id="@bluedynamics/cdk8s-plone.PloneBaseOptions.property.livenessSuccessThreshold"></a>
270
+
271
+ ```typescript
272
+ public readonly livenessSuccessThreshold: number;
273
+ ```
274
+
275
+ - *Type:* number
276
+
277
+ ---
278
+
219
279
  ##### `maxUnavailable`<sup>Optional</sup> <a name="maxUnavailable" id="@bluedynamics/cdk8s-plone.PloneBaseOptions.property.maxUnavailable"></a>
220
280
 
221
281
  ```typescript
@@ -236,6 +296,56 @@ public readonly minAvailable: string | number;
236
296
 
237
297
  ---
238
298
 
299
+ ##### `readinessFailureThreshold`<sup>Optional</sup> <a name="readinessFailureThreshold" id="@bluedynamics/cdk8s-plone.PloneBaseOptions.property.readinessFailureThreshold"></a>
300
+
301
+ ```typescript
302
+ public readonly readinessFailureThreshold: number;
303
+ ```
304
+
305
+ - *Type:* number
306
+
307
+ ---
308
+
309
+ ##### `readinessIimeoutSeconds`<sup>Optional</sup> <a name="readinessIimeoutSeconds" id="@bluedynamics/cdk8s-plone.PloneBaseOptions.property.readinessIimeoutSeconds"></a>
310
+
311
+ ```typescript
312
+ public readonly readinessIimeoutSeconds: number;
313
+ ```
314
+
315
+ - *Type:* number
316
+
317
+ ---
318
+
319
+ ##### `readinessInitialDelaySeconds`<sup>Optional</sup> <a name="readinessInitialDelaySeconds" id="@bluedynamics/cdk8s-plone.PloneBaseOptions.property.readinessInitialDelaySeconds"></a>
320
+
321
+ ```typescript
322
+ public readonly readinessInitialDelaySeconds: number;
323
+ ```
324
+
325
+ - *Type:* number
326
+
327
+ ---
328
+
329
+ ##### `readinessPeriodSeconds`<sup>Optional</sup> <a name="readinessPeriodSeconds" id="@bluedynamics/cdk8s-plone.PloneBaseOptions.property.readinessPeriodSeconds"></a>
330
+
331
+ ```typescript
332
+ public readonly readinessPeriodSeconds: number;
333
+ ```
334
+
335
+ - *Type:* number
336
+
337
+ ---
338
+
339
+ ##### `readinessSuccessThreshold`<sup>Optional</sup> <a name="readinessSuccessThreshold" id="@bluedynamics/cdk8s-plone.PloneBaseOptions.property.readinessSuccessThreshold"></a>
340
+
341
+ ```typescript
342
+ public readonly readinessSuccessThreshold: number;
343
+ ```
344
+
345
+ - *Type:* number
346
+
347
+ ---
348
+
239
349
  ##### `replicas`<sup>Optional</sup> <a name="replicas" id="@bluedynamics/cdk8s-plone.PloneBaseOptions.property.replicas"></a>
240
350
 
241
351
  ```typescript
package/README.md CHANGED
@@ -41,7 +41,7 @@ Each step need to be implemented with tests!
41
41
  - [x] deployment
42
42
  - [x] service
43
43
  - [x] pdb
44
- - [ ] lifecycle checks (readiness, liveness)
44
+ - [x] lifecycle checks (readiness, liveness)
45
45
  - [ ] depend on ready/live backend (needed?)
46
46
  - [x] generic way to inject sidecars
47
47
 
@@ -52,7 +52,7 @@ Each step need to be implemented with tests!
52
52
  - [ ] pdb
53
53
  - [ ] lifecycle checks (readiness, liveness)
54
54
  - [ ] generic way to inject sidecars
55
- - find a way to purge caches. based on kitconcept varnish purger? needs
55
+ - find a way to purge caches. based on kitconcept varnish purger? needs evaluation
56
56
 
57
57
  - [ ] Other Languages
58
58
  - [x] Check Python distribution
package/lib/plone.d.ts CHANGED
@@ -11,6 +11,16 @@ export interface PloneBaseOptions {
11
11
  readonly requestCpu?: string;
12
12
  readonly requestMemory?: string;
13
13
  readonly environment?: kplus.Env;
14
+ readonly readinessInitialDelaySeconds?: number;
15
+ readonly readinessIimeoutSeconds?: number;
16
+ readonly readinessPeriodSeconds?: number;
17
+ readonly readinessSuccessThreshold?: number;
18
+ readonly readinessFailureThreshold?: number;
19
+ readonly livenessInitialDelaySeconds?: number;
20
+ readonly livenessIimeoutSeconds?: number;
21
+ readonly livenessPeriodSeconds?: number;
22
+ readonly livenessSuccessThreshold?: number;
23
+ readonly livenessFailureThreshold?: number;
14
24
  }
15
25
  export interface PloneOptions {
16
26
  readonly version?: string;
package/lib/plone.js CHANGED
@@ -18,34 +18,32 @@ class Plone extends constructs_1.Construct {
18
18
  // ------------------------------------------------------------------------
19
19
  // Backend
20
20
  const backend = options.backend ?? {};
21
- const backendPort = 8080;
22
21
  const backendLabels = {
23
22
  'app.kubernetes.io/name': 'plone-backend',
24
23
  'app.kubernetes.io/component': 'backend',
25
24
  'app.kubernetes.io/version': options.version ?? 'undefined',
26
25
  };
26
+ const backendPort = 8080;
27
27
  // Probing
28
+ const backendActionHttpGet = {
29
+ path: '/',
30
+ port: k8s_1.IntOrString.fromNumber(backendPort),
31
+ };
28
32
  const backendLivenessProbe = {
29
- httpGet: {
30
- path: '/',
31
- port: k8s_1.IntOrString.fromNumber(backendPort),
32
- },
33
- initialDelaySeconds: 30,
34
- timeoutSeconds: 1,
35
- periodSeconds: 10,
36
- successThreshold: 1,
37
- failureThreshold: 3,
33
+ httpGet: backendActionHttpGet,
34
+ initialDelaySeconds: backend.livenessInitialDelaySeconds ?? 30,
35
+ timeoutSeconds: backend.livenessIimeoutSeconds ?? 5,
36
+ periodSeconds: backend.livenessPeriodSeconds ?? 10,
37
+ successThreshold: backend.livenessSuccessThreshold ?? 1,
38
+ failureThreshold: backend.livenessFailureThreshold ?? 3,
38
39
  };
39
40
  const backendReadinessProbe = {
40
- httpGet: {
41
- path: '/',
42
- port: k8s_1.IntOrString.fromNumber(backendPort),
43
- },
44
- initialDelaySeconds: 10,
45
- timeoutSeconds: 15,
46
- periodSeconds: 10,
47
- successThreshold: 1,
48
- failureThreshold: 3,
41
+ httpGet: backendActionHttpGet,
42
+ initialDelaySeconds: backend.readinessInitialDelaySeconds ?? 10,
43
+ timeoutSeconds: backend.readinessIimeoutSeconds ?? 15,
44
+ periodSeconds: backend.readinessPeriodSeconds ?? 10,
45
+ successThreshold: backend.readinessSuccessThreshold ?? 1,
46
+ failureThreshold: backend.readinessFailureThreshold ?? 3,
49
47
  };
50
48
  // Deployment
51
49
  const backendDeployment = new deployment_1.PloneDeployment(this, 'backend', {
@@ -89,27 +87,25 @@ class Plone extends constructs_1.Construct {
89
87
  'app.kubernetes.io/version': options.version ?? 'undefined',
90
88
  };
91
89
  // Probing
90
+ const frontendActionHttpGet = {
91
+ path: '/',
92
+ port: k8s_1.IntOrString.fromNumber(frontendPort),
93
+ };
92
94
  const frontendLivenessProbe = {
93
- httpGet: {
94
- path: '/',
95
- port: k8s_1.IntOrString.fromNumber(frontendPort),
96
- },
97
- initialDelaySeconds: 30,
98
- timeoutSeconds: 1,
99
- periodSeconds: 10,
100
- successThreshold: 1,
101
- failureThreshold: 3,
95
+ httpGet: frontendActionHttpGet,
96
+ initialDelaySeconds: frontend.livenessInitialDelaySeconds ?? 30,
97
+ timeoutSeconds: frontend.livenessIimeoutSeconds ?? 5,
98
+ periodSeconds: frontend.livenessPeriodSeconds ?? 10,
99
+ successThreshold: frontend.livenessSuccessThreshold ?? 1,
100
+ failureThreshold: frontend.livenessFailureThreshold ?? 3,
102
101
  };
103
102
  const frontendReadinessProbe = {
104
- httpGet: {
105
- path: '/',
106
- port: k8s_1.IntOrString.fromNumber(frontendPort),
107
- },
108
- initialDelaySeconds: 10,
109
- timeoutSeconds: 15,
110
- periodSeconds: 10,
111
- successThreshold: 1,
112
- failureThreshold: 3,
103
+ httpGet: frontendActionHttpGet,
104
+ initialDelaySeconds: frontend.readinessInitialDelaySeconds ?? 10,
105
+ timeoutSeconds: frontend.readinessIimeoutSeconds ?? 15,
106
+ periodSeconds: frontend.readinessPeriodSeconds ?? 10,
107
+ successThreshold: frontend.readinessSuccessThreshold ?? 1,
108
+ failureThreshold: frontend.readinessFailureThreshold ?? 3,
113
109
  };
114
110
  // Environment for RAZZLE
115
111
  var frontendEnvironment = frontend.environment ?? new kplus.Env([], {});
@@ -153,5 +149,5 @@ class Plone extends constructs_1.Construct {
153
149
  }
154
150
  exports.Plone = Plone;
155
151
  _a = JSII_RTTI_SYMBOL_1;
156
- Plone[_a] = { fqn: "@bluedynamics/cdk8s-plone.Plone", version: "0.0.12" };
157
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"plone.js","sourceRoot":"","sources":["../src/plone.ts"],"names":[],"mappings":";;;;;AAAA,iCAA8B;AAC9B,uCAAuC;AACvC,2CAAuC;AACvC,6CAA+C;AAC/C,uCAAmD;AACnD,uCAAyC;AAsBzC,MAAa,KAAM,SAAQ,sBAAS;IAKlC,YAAY,KAAgB,EAAE,EAAU,EAAE,UAAwB,EAAE;QAClE,KAAK,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC;QAEjB,2EAA2E;QAC3E,UAAU;QACV,MAAM,MAAM,GAAG,OAAO,CAAC,MAAM,IAAI,OAAO,CAAC;QAEzC,2EAA2E;QAC3E,UAAU;QACV,MAAM,OAAO,GAAG,OAAO,CAAC,OAAO,IAAI,EAAE,CAAC;QACtC,MAAM,WAAW,GAAG,IAAI,CAAC;QACzB,MAAM,aAAa,GAAG;YACpB,wBAAwB,EAAE,eAAe;YACzC,6BAA6B,EAAE,SAAS;YACxC,2BAA2B,EAAE,OAAO,CAAC,OAAO,IAAI,WAAW;SAC5D,CAAC;QAEF,UAAU;QACV,MAAM,oBAAoB,GAAU;YAClC,OAAO,EAAE;gBACP,IAAI,EAAE,GAAG;gBACT,IAAI,EAAE,iBAAW,CAAC,UAAU,CAAC,WAAW,CAAC;aAC1C;YACD,mBAAmB,EAAE,EAAE;YACvB,cAAc,EAAE,CAAC;YACjB,aAAa,EAAE,EAAE;YACjB,gBAAgB,EAAE,CAAC;YACnB,gBAAgB,EAAE,CAAC;SACpB,CAAC;QACF,MAAM,qBAAqB,GAAU;YACnC,OAAO,EAAE;gBACP,IAAI,EAAE,GAAG;gBACT,IAAI,EAAE,iBAAW,CAAC,UAAU,CAAC,WAAW,CAAC;aAC1C;YACD,mBAAmB,EAAE,EAAE;YACvB,cAAc,EAAE,EAAE;YAClB,aAAa,EAAE,EAAE;YACjB,gBAAgB,EAAE,CAAC;YACnB,gBAAgB,EAAE,CAAC;SACpB,CAAC;QAEF,aAAa;QACb,MAAM,iBAAiB,GAAG,IAAI,4BAAe,CAAC,IAAI,EAAE,SAAS,EAAE;YAC7D,MAAM,EAAE,aAAa;YACrB,KAAK,EAAE;gBACL,KAAK,EAAE,OAAO,CAAC,KAAK,IAAI,4BAA4B;gBACpD,gBAAgB,EAAE,OAAO,CAAC,gBAAgB,IAAI,EAAE;gBAChD,eAAe,EAAE,OAAO,CAAC,eAAe,IAAI,cAAc;aAC3D;YACD,QAAQ,EAAE,OAAO,CAAC,QAAQ;YAC1B,QAAQ,EAAE,OAAO,CAAC,QAAQ,IAAI,MAAM;YACpC,WAAW,EAAE,OAAO,CAAC,WAAW,IAAI,OAAO;YAC3C,UAAU,EAAE,OAAO,CAAC,UAAU,IAAI,MAAM;YACxC,aAAa,EAAE,OAAO,CAAC,aAAa,IAAI,OAAO;YAC/C,GAAG,EAAE;gBACH,cAAc,EAAE,OAAO,CAAC,cAAc,IAAI,SAAS;gBACnD,YAAY,EAAE,OAAO,CAAC,YAAY,IAAI,SAAS;aAChD;YACD,IAAI,EAAE,WAAW;YACjB,WAAW,EAAE,OAAO,CAAC,WAAW;YAChC,aAAa,EAAE,oBAAoB;YACnC,cAAc,EAAE,qBAAqB;SACtC,CAAC,CAAC;QAEH,UAAU;QACV,MAAM,cAAc,GAAG,IAAI,sBAAY,CAAC,iBAAiB,EAAE,SAAS,EAAE;YACpE,MAAM,EAAE;gBACN,wBAAwB,EAAE,uBAAuB;gBACjD,6BAA6B,EAAE,SAAS;aACzC;YACD,UAAU,EAAE,WAAW;YACvB,aAAa,EAAE,EAAE,GAAG,EAAE,aAAK,CAAC,YAAY,CAAC,iBAAiB,CAAC,EAAE;SAC9D,CAAC,CAAC;QACH,IAAI,CAAC,kBAAkB,GAAG,cAAc,CAAC,IAAI,CAAC;QAE9C,2EAA2E;QAC3E,WAAW;QACX,MAAM,QAAQ,GAAG,OAAO,CAAC,QAAQ,IAAI,EAAE,CAAC;QACxC,MAAM,YAAY,GAAG,IAAI,CAAC;QAC1B,MAAM,cAAc,GAAG;YACrB,wBAAwB,EAAE,gBAAgB;YAC1C,6BAA6B,EAAE,UAAU;YACzC,2BAA2B,EAAE,OAAO,CAAC,OAAO,IAAI,WAAW;SAC5D,CAAC;QAEF,UAAU;QACV,MAAM,qBAAqB,GAAU;YACnC,OAAO,EAAE;gBACP,IAAI,EAAE,GAAG;gBACT,IAAI,EAAE,iBAAW,CAAC,UAAU,CAAC,YAAY,CAAC;aAC3C;YACD,mBAAmB,EAAE,EAAE;YACvB,cAAc,EAAE,CAAC;YACjB,aAAa,EAAE,EAAE;YACjB,gBAAgB,EAAE,CAAC;YACnB,gBAAgB,EAAE,CAAC;SACpB,CAAC;QACF,MAAM,sBAAsB,GAAU;YACpC,OAAO,EAAE;gBACP,IAAI,EAAE,GAAG;gBACT,IAAI,EAAE,iBAAW,CAAC,UAAU,CAAC,YAAY,CAAC;aAC3C;YACD,mBAAmB,EAAE,EAAE;YACvB,cAAc,EAAE,EAAE;YAClB,aAAa,EAAE,EAAE;YACjB,gBAAgB,EAAE,CAAC;YACnB,gBAAgB,EAAE,CAAC;SACpB,CAAC;QAEF,yBAAyB;QACzB,IAAI,mBAAmB,GAAG,QAAQ,CAAC,WAAW,IAAI,IAAI,KAAK,CAAC,GAAG,CAAC,EAAE,EAAE,EAAE,CAAC,CAAC;QACxE,IAAI,mBAAmB,CAAC,SAAS,CAAC,wBAAwB,KAAK,SAAS,EAAE,CAAC;YACzE,+BAA+B;YAC/B,mBAAmB,EAAE,WAAW,CAAC,0BAA0B,EAAE,KAAK,CAAC,QAAQ,CAAC,SAAS,CAAC,UAAU,cAAc,CAAC,IAAI,IAAI,WAAW,IAAI,MAAM,EAAE,CAAC,CAAC,CAAC;QACnJ,CAAC;QAED,aAAa;QACb,MAAM,kBAAkB,GAAG,IAAI,4BAAe,CAAC,IAAI,EAAE,UAAU,EAAE;YAC/D,MAAM,EAAE,cAAc;YACtB,KAAK,EAAE;gBACL,KAAK,EAAE,QAAQ,CAAC,KAAK,IAAI,6BAA6B;gBACtD,gBAAgB,EAAE,OAAO,CAAC,gBAAgB,IAAI,EAAE;gBAChD,eAAe,EAAE,QAAQ,CAAC,eAAe,IAAI,cAAc;aAC5D;YACD,QAAQ,EAAE,QAAQ,CAAC,QAAQ;YAC3B,QAAQ,EAAE,QAAQ,CAAC,QAAQ,IAAI,MAAM;YACrC,WAAW,EAAE,QAAQ,CAAC,WAAW,IAAI,KAAK;YAC1C,UAAU,EAAE,OAAO,CAAC,UAAU,IAAI,MAAM;YACxC,aAAa,EAAE,OAAO,CAAC,aAAa,IAAI,OAAO;YAE/C,GAAG,EAAE;gBACH,cAAc,EAAE,QAAQ,CAAC,cAAc,IAAI,SAAS;gBACpD,YAAY,EAAE,QAAQ,CAAC,YAAY,IAAI,SAAS;aACjD;YACD,IAAI,EAAE,YAAY;YAClB,WAAW,EAAE,mBAAmB;YAChC,aAAa,EAAE,qBAAqB;YACpC,cAAc,EAAE,sBAAsB;SACvC,CAAC,CAAC;QAEH,UAAU;QACV,MAAM,eAAe,GAAG,IAAI,sBAAY,CAAC,kBAAkB,EAAE,SAAS,EAAE;YACtE,MAAM,EAAE;gBACN,wBAAwB,EAAE,wBAAwB;gBAClD,6BAA6B,EAAE,SAAS;aACzC;YACD,UAAU,EAAE,YAAY;YACxB,aAAa,EAAE,EAAE,GAAG,EAAE,aAAK,CAAC,YAAY,CAAC,kBAAkB,CAAC,EAAE;SAC/D,CAAC,CAAC;QACH,IAAI,CAAC,mBAAmB,GAAG,eAAe,CAAC,IAAI,CAAC;IAClD,CAAC;;AA3JH,sBA4JC","sourcesContent":["import { Names } from 'cdk8s';\nimport * as kplus from 'cdk8s-plus-24';\nimport { Construct } from 'constructs';\nimport { PloneDeployment } from './deployment';\nimport { Probe, IntOrString } from './imports/k8s';\nimport { PloneService } from './service';\n\nexport interface PloneBaseOptions {\n  readonly image?: string;\n  readonly imagePullPolicy?: string;\n  readonly replicas?: number;\n  readonly maxUnavailable?: number | string;\n  readonly minAvailable?: number | string;\n  readonly limitCpu?: string;\n  readonly limitMemory?: string;\n  readonly requestCpu?: string;\n  readonly requestMemory?: string;\n  readonly environment?: kplus.Env;\n}\nexport interface PloneOptions {\n  readonly version?: string;\n  readonly siteId?: string;\n  readonly backend?: PloneBaseOptions;\n  readonly frontend?: PloneBaseOptions;\n  readonly imagePullSecrets?: string[];\n}\n\nexport class Plone extends Construct {\n\n  public readonly backendServiceName: string;\n  public readonly frontendServiceName: string;\n\n  constructor(scope: Construct, id: string, options: PloneOptions = {}) {\n    super(scope, id);\n\n    // ------------------------------------------------------------------------\n    // General\n    const siteId = options.siteId ?? 'Plone';\n\n    // ------------------------------------------------------------------------\n    // Backend\n    const backend = options.backend ?? {};\n    const backendPort = 8080;\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\n    // Probing\n    const backendLivenessProbe: Probe = {\n      httpGet: {\n        path: '/',\n        port: IntOrString.fromNumber(backendPort),\n      },\n      initialDelaySeconds: 30,\n      timeoutSeconds: 1,\n      periodSeconds: 10,\n      successThreshold: 1,\n      failureThreshold: 3,\n    };\n    const backendReadinessProbe: Probe = {\n      httpGet: {\n        path: '/',\n        port: IntOrString.fromNumber(backendPort),\n      },\n      initialDelaySeconds: 10,\n      timeoutSeconds: 15,\n      periodSeconds: 10,\n      successThreshold: 1,\n      failureThreshold: 3,\n    };\n\n    // Deployment\n    const backendDeployment = new PloneDeployment(this, 'backend', {\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      livenessProbe: backendLivenessProbe,\n      readinessProbe: backendReadinessProbe,\n    });\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    });\n    this.backendServiceName = backendService.name;\n\n    // ------------------------------------------------------------------------\n    // Frontend\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    // Probing\n    const frontendLivenessProbe: Probe = {\n      httpGet: {\n        path: '/',\n        port: IntOrString.fromNumber(frontendPort),\n      },\n      initialDelaySeconds: 30,\n      timeoutSeconds: 1,\n      periodSeconds: 10,\n      successThreshold: 1,\n      failureThreshold: 3,\n    };\n    const frontendReadinessProbe: Probe = {\n      httpGet: {\n        path: '/',\n        port: IntOrString.fromNumber(frontendPort),\n      },\n      initialDelaySeconds: 10,\n      timeoutSeconds: 15,\n      periodSeconds: 10,\n      successThreshold: 1,\n      failureThreshold: 3,\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}/${siteId}`));\n    }\n\n    // Deployment\n    const frontendDeployment = new PloneDeployment(this, 'frontend', {\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: backend.requestCpu ?? '200m',\n      requestMemory: backend.requestMemory ?? '256Mi',\n\n      pdb: {\n        maxUnavailable: frontend.maxUnavailable ?? undefined,\n        minAvailable: frontend.minAvailable ?? undefined,\n      },\n      port: frontendPort,\n      environment: frontendEnvironment,\n      livenessProbe: frontendLivenessProbe,\n      readinessProbe: frontendReadinessProbe,\n    });\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    });\n    this.frontendServiceName = frontendService.name;\n  }\n}"]}
152
+ Plone[_a] = { fqn: "@bluedynamics/cdk8s-plone.Plone", version: "0.0.14" };
153
+ //# 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-24';\nimport { Construct } from 'constructs';\nimport { PloneDeployment } from './deployment';\nimport { Probe, IntOrString } from './imports/k8s';\nimport * as k8s from './imports/k8s';\nimport { PloneService } from './service';\n\nexport interface PloneBaseOptions {\n  // image\n  readonly image?: string;\n  readonly imagePullPolicy?: string;\n  // replicas\n  readonly replicas?: number;\n  readonly maxUnavailable?: number | string;\n  readonly minAvailable?: number | string;\n  // resources\n  readonly limitCpu?: string;\n  readonly limitMemory?: string;\n  readonly requestCpu?: string;\n  readonly requestMemory?: string;\n  readonly environment?: kplus.Env;\n  // readiness Probe\n  readonly readinessInitialDelaySeconds?: number;\n  readonly readinessIimeoutSeconds?: number;\n  readonly readinessPeriodSeconds?: number;\n  readonly readinessSuccessThreshold?: number;\n  readonly readinessFailureThreshold?: number;\n  // liveness Probe\n  readonly livenessInitialDelaySeconds?: number;\n  readonly livenessIimeoutSeconds?: number;\n  readonly livenessPeriodSeconds?: number;\n  readonly livenessSuccessThreshold?: number;\n  readonly livenessFailureThreshold?: number;\n}\nexport interface PloneOptions {\n  readonly version?: string;\n  readonly siteId?: string;\n  readonly backend?: PloneBaseOptions;\n  readonly frontend?: PloneBaseOptions;\n  readonly imagePullSecrets?: string[];\n\n}\n\nexport class Plone extends Construct {\n\n  public readonly backendServiceName: string;\n  public readonly frontendServiceName: string;\n\n  constructor(scope: Construct, id: string, options: PloneOptions = {}) {\n    super(scope, id);\n\n    // ------------------------------------------------------------------------\n    // General\n    const siteId = options.siteId ?? 'Plone';\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    // Probing\n    const backendActionHttpGet: k8s.HttpGetAction = {\n      path: '/',\n      port: IntOrString.fromNumber(backendPort),\n    };\n\n    const backendLivenessProbe: Probe = {\n      httpGet: backendActionHttpGet,\n      initialDelaySeconds: backend.livenessInitialDelaySeconds ?? 30,\n      timeoutSeconds: backend.livenessIimeoutSeconds ?? 5,\n      periodSeconds: backend.livenessPeriodSeconds ?? 10,\n      successThreshold: backend.livenessSuccessThreshold ?? 1,\n      failureThreshold: backend.livenessFailureThreshold ?? 3,\n    };\n    const backendReadinessProbe: Probe = {\n      httpGet: backendActionHttpGet,\n      initialDelaySeconds: backend.readinessInitialDelaySeconds ?? 10,\n      timeoutSeconds: backend.readinessIimeoutSeconds ?? 15,\n      periodSeconds: backend.readinessPeriodSeconds ?? 10,\n      successThreshold: backend.readinessSuccessThreshold ?? 1,\n      failureThreshold: backend.readinessFailureThreshold ?? 3,\n    };\n\n    // Deployment\n    const backendDeployment = new PloneDeployment(this, 'backend', {\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      livenessProbe: backendLivenessProbe,\n      readinessProbe: backendReadinessProbe,\n    });\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    });\n    this.backendServiceName = backendService.name;\n\n    // ------------------------------------------------------------------------\n    // Frontend\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    // Probing\n    const frontendActionHttpGet: k8s.HttpGetAction = {\n      path: '/',\n      port: IntOrString.fromNumber(frontendPort),\n    };\n    const frontendLivenessProbe: Probe = {\n      httpGet: frontendActionHttpGet,\n      initialDelaySeconds: frontend.livenessInitialDelaySeconds ?? 30,\n      timeoutSeconds: frontend.livenessIimeoutSeconds ?? 5,\n      periodSeconds: frontend.livenessPeriodSeconds ?? 10,\n      successThreshold: frontend.livenessSuccessThreshold ?? 1,\n      failureThreshold: frontend.livenessFailureThreshold ?? 3,\n    };\n    const frontendReadinessProbe: Probe = {\n      httpGet: frontendActionHttpGet,\n      initialDelaySeconds: frontend.readinessInitialDelaySeconds ?? 10,\n      timeoutSeconds: frontend.readinessIimeoutSeconds ?? 15,\n      periodSeconds: frontend.readinessPeriodSeconds ?? 10,\n      successThreshold: frontend.readinessSuccessThreshold ?? 1,\n      failureThreshold: frontend.readinessFailureThreshold ?? 3,\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}/${siteId}`));\n    }\n\n    // Deployment\n    const frontendDeployment = new PloneDeployment(this, 'frontend', {\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: backend.requestCpu ?? '200m',\n      requestMemory: backend.requestMemory ?? '256Mi',\n\n      pdb: {\n        maxUnavailable: frontend.maxUnavailable ?? undefined,\n        minAvailable: frontend.minAvailable ?? undefined,\n      },\n      port: frontendPort,\n      environment: frontendEnvironment,\n      livenessProbe: frontendLivenessProbe,\n      readinessProbe: frontendReadinessProbe,\n    });\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    });\n    this.frontendServiceName = frontendService.name;\n  }\n}"]}
package/package.json CHANGED
@@ -40,7 +40,7 @@
40
40
  "@types/node": "^18",
41
41
  "@typescript-eslint/eslint-plugin": "^7",
42
42
  "@typescript-eslint/parser": "^7",
43
- "cdk8s": "^2.68.92",
43
+ "cdk8s": "^2.68.93",
44
44
  "cdk8s-plus-24": "^2.12.1",
45
45
  "constructs": "^10.0.0",
46
46
  "eslint": "^8",
@@ -53,7 +53,7 @@
53
53
  "jsii-docgen": "^10.4.20",
54
54
  "jsii-pacmak": "^1.102.0",
55
55
  "jsii-rosetta": "~5.4.0",
56
- "projen": "^0.84.13",
56
+ "projen": "^0.85.0",
57
57
  "standard-version": "^9",
58
58
  "ts-jest": "^29.2.4",
59
59
  "ts-node": "^10.9.2",
@@ -61,12 +61,12 @@
61
61
  "yaml": "^2.5.0"
62
62
  },
63
63
  "peerDependencies": {
64
- "cdk8s": "^2.68.92",
64
+ "cdk8s": "^2.68.93",
65
65
  "cdk8s-plus-24": "^2.12.1",
66
66
  "constructs": "^10.3.0"
67
67
  },
68
68
  "dependencies": {
69
- "cdk8s": "^2.68.92",
69
+ "cdk8s": "^2.68.93",
70
70
  "cdk8s-plus-24": "^2.12.1",
71
71
  "constructs": "^10.3.0"
72
72
  },
@@ -75,7 +75,7 @@
75
75
  "publishConfig": {
76
76
  "access": "public"
77
77
  },
78
- "version": "0.0.12",
78
+ "version": "0.0.14",
79
79
  "jest": {
80
80
  "coverageProvider": "v8",
81
81
  "testMatch": [