@bluedynamics/cdk8s-plone 0.0.15 → 0.0.17

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
@@ -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 - [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"
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- [x] Start Varnish (using kube-httcache)\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",
@@ -555,6 +555,218 @@
555
555
  ],
556
556
  "symbolId": "src/plone:PloneBaseOptions"
557
557
  },
558
+ "@bluedynamics/cdk8s-plone.PloneHttpcache": {
559
+ "assembly": "@bluedynamics/cdk8s-plone",
560
+ "base": "constructs.Construct",
561
+ "docs": {
562
+ "stability": "stable"
563
+ },
564
+ "fqn": "@bluedynamics/cdk8s-plone.PloneHttpcache",
565
+ "initializer": {
566
+ "docs": {
567
+ "stability": "stable"
568
+ },
569
+ "locationInModule": {
570
+ "filename": "src/httpcache.ts",
571
+ "line": 41
572
+ },
573
+ "parameters": [
574
+ {
575
+ "name": "scope",
576
+ "type": {
577
+ "fqn": "constructs.Construct"
578
+ }
579
+ },
580
+ {
581
+ "name": "id",
582
+ "type": {
583
+ "primitive": "string"
584
+ }
585
+ },
586
+ {
587
+ "name": "options",
588
+ "type": {
589
+ "fqn": "@bluedynamics/cdk8s-plone.PloneHttpcacheOptions"
590
+ }
591
+ }
592
+ ]
593
+ },
594
+ "kind": "class",
595
+ "locationInModule": {
596
+ "filename": "src/httpcache.ts",
597
+ "line": 37
598
+ },
599
+ "name": "PloneHttpcache",
600
+ "properties": [
601
+ {
602
+ "docs": {
603
+ "stability": "stable"
604
+ },
605
+ "immutable": true,
606
+ "locationInModule": {
607
+ "filename": "src/httpcache.ts",
608
+ "line": 39
609
+ },
610
+ "name": "httpcacheServiceName",
611
+ "type": {
612
+ "primitive": "string"
613
+ }
614
+ }
615
+ ],
616
+ "symbolId": "src/httpcache:PloneHttpcache"
617
+ },
618
+ "@bluedynamics/cdk8s-plone.PloneHttpcacheOptions": {
619
+ "assembly": "@bluedynamics/cdk8s-plone",
620
+ "datatype": true,
621
+ "docs": {
622
+ "stability": "stable"
623
+ },
624
+ "fqn": "@bluedynamics/cdk8s-plone.PloneHttpcacheOptions",
625
+ "kind": "interface",
626
+ "locationInModule": {
627
+ "filename": "src/httpcache.ts",
628
+ "line": 7
629
+ },
630
+ "name": "PloneHttpcacheOptions",
631
+ "properties": [
632
+ {
633
+ "abstract": true,
634
+ "docs": {
635
+ "default": "- none",
636
+ "stability": "stable",
637
+ "summary": "plone chart."
638
+ },
639
+ "immutable": true,
640
+ "locationInModule": {
641
+ "filename": "src/httpcache.ts",
642
+ "line": 12
643
+ },
644
+ "name": "plone",
645
+ "type": {
646
+ "fqn": "@bluedynamics/cdk8s-plone.Plone"
647
+ }
648
+ },
649
+ {
650
+ "abstract": true,
651
+ "docs": {
652
+ "default": "- undefined",
653
+ "stability": "stable",
654
+ "summary": "existingSecret - Read admin credentials from user provided secret."
655
+ },
656
+ "immutable": true,
657
+ "locationInModule": {
658
+ "filename": "src/httpcache.ts",
659
+ "line": 27
660
+ },
661
+ "name": "existingSecret",
662
+ "optional": true,
663
+ "type": {
664
+ "primitive": "string"
665
+ }
666
+ },
667
+ {
668
+ "abstract": true,
669
+ "docs": {
670
+ "stability": "stable"
671
+ },
672
+ "immutable": true,
673
+ "locationInModule": {
674
+ "filename": "src/httpcache.ts",
675
+ "line": 31
676
+ },
677
+ "name": "limitCpu",
678
+ "optional": true,
679
+ "type": {
680
+ "primitive": "string"
681
+ }
682
+ },
683
+ {
684
+ "abstract": true,
685
+ "docs": {
686
+ "stability": "stable"
687
+ },
688
+ "immutable": true,
689
+ "locationInModule": {
690
+ "filename": "src/httpcache.ts",
691
+ "line": 32
692
+ },
693
+ "name": "limitMemory",
694
+ "optional": true,
695
+ "type": {
696
+ "primitive": "string"
697
+ }
698
+ },
699
+ {
700
+ "abstract": true,
701
+ "docs": {
702
+ "stability": "stable"
703
+ },
704
+ "immutable": true,
705
+ "locationInModule": {
706
+ "filename": "src/httpcache.ts",
707
+ "line": 33
708
+ },
709
+ "name": "requestCpu",
710
+ "optional": true,
711
+ "type": {
712
+ "primitive": "string"
713
+ }
714
+ },
715
+ {
716
+ "abstract": true,
717
+ "docs": {
718
+ "stability": "stable"
719
+ },
720
+ "immutable": true,
721
+ "locationInModule": {
722
+ "filename": "src/httpcache.ts",
723
+ "line": 34
724
+ },
725
+ "name": "requestMemory",
726
+ "optional": true,
727
+ "type": {
728
+ "primitive": "string"
729
+ }
730
+ },
731
+ {
732
+ "abstract": true,
733
+ "docs": {
734
+ "default": "- file in config folder",
735
+ "stability": "stable",
736
+ "summary": "varnishVcl."
737
+ },
738
+ "immutable": true,
739
+ "locationInModule": {
740
+ "filename": "src/httpcache.ts",
741
+ "line": 17
742
+ },
743
+ "name": "varnishVcl",
744
+ "optional": true,
745
+ "type": {
746
+ "primitive": "string"
747
+ }
748
+ },
749
+ {
750
+ "abstract": true,
751
+ "docs": {
752
+ "default": "- undefined",
753
+ "stability": "stable",
754
+ "summary": "varnishVclFile."
755
+ },
756
+ "immutable": true,
757
+ "locationInModule": {
758
+ "filename": "src/httpcache.ts",
759
+ "line": 22
760
+ },
761
+ "name": "varnishVclFile",
762
+ "optional": true,
763
+ "type": {
764
+ "primitive": "string"
765
+ }
766
+ }
767
+ ],
768
+ "symbolId": "src/httpcache:PloneHttpcacheOptions"
769
+ },
558
770
  "@bluedynamics/cdk8s-plone.PloneOptions": {
559
771
  "assembly": "@bluedynamics/cdk8s-plone",
560
772
  "datatype": true,
@@ -658,6 +870,6 @@
658
870
  "symbolId": "src/plone:PloneOptions"
659
871
  }
660
872
  },
661
- "version": "0.0.15",
662
- "fingerprint": "DlL7SuQ3mTQj4ZiIlq6mgrA+1sU52zDzfxDDoMQkTJI="
873
+ "version": "0.0.17",
874
+ "fingerprint": "A/xEzbcuWadoBZ9TFudPiB3EbdpLxmHlYL8Uv21wq5U="
663
875
  }
package/API.md CHANGED
@@ -137,6 +137,130 @@ public readonly frontendServiceName: string;
137
137
  ---
138
138
 
139
139
 
140
+ ### PloneHttpcache <a name="PloneHttpcache" id="@bluedynamics/cdk8s-plone.PloneHttpcache"></a>
141
+
142
+ #### Initializers <a name="Initializers" id="@bluedynamics/cdk8s-plone.PloneHttpcache.Initializer"></a>
143
+
144
+ ```typescript
145
+ import { PloneHttpcache } from '@bluedynamics/cdk8s-plone'
146
+
147
+ new PloneHttpcache(scope: Construct, id: string, options: PloneHttpcacheOptions)
148
+ ```
149
+
150
+ | **Name** | **Type** | **Description** |
151
+ | --- | --- | --- |
152
+ | <code><a href="#@bluedynamics/cdk8s-plone.PloneHttpcache.Initializer.parameter.scope">scope</a></code> | <code>constructs.Construct</code> | *No description.* |
153
+ | <code><a href="#@bluedynamics/cdk8s-plone.PloneHttpcache.Initializer.parameter.id">id</a></code> | <code>string</code> | *No description.* |
154
+ | <code><a href="#@bluedynamics/cdk8s-plone.PloneHttpcache.Initializer.parameter.options">options</a></code> | <code><a href="#@bluedynamics/cdk8s-plone.PloneHttpcacheOptions">PloneHttpcacheOptions</a></code> | *No description.* |
155
+
156
+ ---
157
+
158
+ ##### `scope`<sup>Required</sup> <a name="scope" id="@bluedynamics/cdk8s-plone.PloneHttpcache.Initializer.parameter.scope"></a>
159
+
160
+ - *Type:* constructs.Construct
161
+
162
+ ---
163
+
164
+ ##### `id`<sup>Required</sup> <a name="id" id="@bluedynamics/cdk8s-plone.PloneHttpcache.Initializer.parameter.id"></a>
165
+
166
+ - *Type:* string
167
+
168
+ ---
169
+
170
+ ##### `options`<sup>Required</sup> <a name="options" id="@bluedynamics/cdk8s-plone.PloneHttpcache.Initializer.parameter.options"></a>
171
+
172
+ - *Type:* <a href="#@bluedynamics/cdk8s-plone.PloneHttpcacheOptions">PloneHttpcacheOptions</a>
173
+
174
+ ---
175
+
176
+ #### Methods <a name="Methods" id="Methods"></a>
177
+
178
+ | **Name** | **Description** |
179
+ | --- | --- |
180
+ | <code><a href="#@bluedynamics/cdk8s-plone.PloneHttpcache.toString">toString</a></code> | Returns a string representation of this construct. |
181
+
182
+ ---
183
+
184
+ ##### `toString` <a name="toString" id="@bluedynamics/cdk8s-plone.PloneHttpcache.toString"></a>
185
+
186
+ ```typescript
187
+ public toString(): string
188
+ ```
189
+
190
+ Returns a string representation of this construct.
191
+
192
+ #### Static Functions <a name="Static Functions" id="Static Functions"></a>
193
+
194
+ | **Name** | **Description** |
195
+ | --- | --- |
196
+ | <code><a href="#@bluedynamics/cdk8s-plone.PloneHttpcache.isConstruct">isConstruct</a></code> | Checks if `x` is a construct. |
197
+
198
+ ---
199
+
200
+ ##### `isConstruct` <a name="isConstruct" id="@bluedynamics/cdk8s-plone.PloneHttpcache.isConstruct"></a>
201
+
202
+ ```typescript
203
+ import { PloneHttpcache } from '@bluedynamics/cdk8s-plone'
204
+
205
+ PloneHttpcache.isConstruct(x: any)
206
+ ```
207
+
208
+ Checks if `x` is a construct.
209
+
210
+ Use this method instead of `instanceof` to properly detect `Construct`
211
+ instances, even when the construct library is symlinked.
212
+
213
+ Explanation: in JavaScript, multiple copies of the `constructs` library on
214
+ disk are seen as independent, completely different libraries. As a
215
+ consequence, the class `Construct` in each copy of the `constructs` library
216
+ is seen as a different class, and an instance of one class will not test as
217
+ `instanceof` the other class. `npm install` will not create installations
218
+ like this, but users may manually symlink construct libraries together or
219
+ use a monorepo tool: in those cases, multiple copies of the `constructs`
220
+ library can be accidentally installed, and `instanceof` will behave
221
+ unpredictably. It is safest to avoid using `instanceof`, and using
222
+ this type-testing method instead.
223
+
224
+ ###### `x`<sup>Required</sup> <a name="x" id="@bluedynamics/cdk8s-plone.PloneHttpcache.isConstruct.parameter.x"></a>
225
+
226
+ - *Type:* any
227
+
228
+ Any object.
229
+
230
+ ---
231
+
232
+ #### Properties <a name="Properties" id="Properties"></a>
233
+
234
+ | **Name** | **Type** | **Description** |
235
+ | --- | --- | --- |
236
+ | <code><a href="#@bluedynamics/cdk8s-plone.PloneHttpcache.property.node">node</a></code> | <code>constructs.Node</code> | The tree node. |
237
+ | <code><a href="#@bluedynamics/cdk8s-plone.PloneHttpcache.property.httpcacheServiceName">httpcacheServiceName</a></code> | <code>string</code> | *No description.* |
238
+
239
+ ---
240
+
241
+ ##### `node`<sup>Required</sup> <a name="node" id="@bluedynamics/cdk8s-plone.PloneHttpcache.property.node"></a>
242
+
243
+ ```typescript
244
+ public readonly node: Node;
245
+ ```
246
+
247
+ - *Type:* constructs.Node
248
+
249
+ The tree node.
250
+
251
+ ---
252
+
253
+ ##### `httpcacheServiceName`<sup>Required</sup> <a name="httpcacheServiceName" id="@bluedynamics/cdk8s-plone.PloneHttpcache.property.httpcacheServiceName"></a>
254
+
255
+ ```typescript
256
+ public readonly httpcacheServiceName: string;
257
+ ```
258
+
259
+ - *Type:* string
260
+
261
+ ---
262
+
263
+
140
264
  ## Structs <a name="Structs" id="Structs"></a>
141
265
 
142
266
  ### PloneBaseOptions <a name="PloneBaseOptions" id="@bluedynamics/cdk8s-plone.PloneBaseOptions"></a>
@@ -376,6 +500,123 @@ public readonly requestMemory: string;
376
500
 
377
501
  ---
378
502
 
503
+ ### PloneHttpcacheOptions <a name="PloneHttpcacheOptions" id="@bluedynamics/cdk8s-plone.PloneHttpcacheOptions"></a>
504
+
505
+ #### Initializer <a name="Initializer" id="@bluedynamics/cdk8s-plone.PloneHttpcacheOptions.Initializer"></a>
506
+
507
+ ```typescript
508
+ import { PloneHttpcacheOptions } from '@bluedynamics/cdk8s-plone'
509
+
510
+ const ploneHttpcacheOptions: PloneHttpcacheOptions = { ... }
511
+ ```
512
+
513
+ #### Properties <a name="Properties" id="Properties"></a>
514
+
515
+ | **Name** | **Type** | **Description** |
516
+ | --- | --- | --- |
517
+ | <code><a href="#@bluedynamics/cdk8s-plone.PloneHttpcacheOptions.property.plone">plone</a></code> | <code><a href="#@bluedynamics/cdk8s-plone.Plone">Plone</a></code> | plone chart. |
518
+ | <code><a href="#@bluedynamics/cdk8s-plone.PloneHttpcacheOptions.property.existingSecret">existingSecret</a></code> | <code>string</code> | existingSecret - Read admin credentials from user provided secret. |
519
+ | <code><a href="#@bluedynamics/cdk8s-plone.PloneHttpcacheOptions.property.limitCpu">limitCpu</a></code> | <code>string</code> | *No description.* |
520
+ | <code><a href="#@bluedynamics/cdk8s-plone.PloneHttpcacheOptions.property.limitMemory">limitMemory</a></code> | <code>string</code> | *No description.* |
521
+ | <code><a href="#@bluedynamics/cdk8s-plone.PloneHttpcacheOptions.property.requestCpu">requestCpu</a></code> | <code>string</code> | *No description.* |
522
+ | <code><a href="#@bluedynamics/cdk8s-plone.PloneHttpcacheOptions.property.requestMemory">requestMemory</a></code> | <code>string</code> | *No description.* |
523
+ | <code><a href="#@bluedynamics/cdk8s-plone.PloneHttpcacheOptions.property.varnishVcl">varnishVcl</a></code> | <code>string</code> | varnishVcl. |
524
+ | <code><a href="#@bluedynamics/cdk8s-plone.PloneHttpcacheOptions.property.varnishVclFile">varnishVclFile</a></code> | <code>string</code> | varnishVclFile. |
525
+
526
+ ---
527
+
528
+ ##### `plone`<sup>Required</sup> <a name="plone" id="@bluedynamics/cdk8s-plone.PloneHttpcacheOptions.property.plone"></a>
529
+
530
+ ```typescript
531
+ public readonly plone: Plone;
532
+ ```
533
+
534
+ - *Type:* <a href="#@bluedynamics/cdk8s-plone.Plone">Plone</a>
535
+ - *Default:* none
536
+
537
+ plone chart.
538
+
539
+ ---
540
+
541
+ ##### `existingSecret`<sup>Optional</sup> <a name="existingSecret" id="@bluedynamics/cdk8s-plone.PloneHttpcacheOptions.property.existingSecret"></a>
542
+
543
+ ```typescript
544
+ public readonly existingSecret: string;
545
+ ```
546
+
547
+ - *Type:* string
548
+ - *Default:* undefined
549
+
550
+ existingSecret - Read admin credentials from user provided secret.
551
+
552
+ ---
553
+
554
+ ##### `limitCpu`<sup>Optional</sup> <a name="limitCpu" id="@bluedynamics/cdk8s-plone.PloneHttpcacheOptions.property.limitCpu"></a>
555
+
556
+ ```typescript
557
+ public readonly limitCpu: string;
558
+ ```
559
+
560
+ - *Type:* string
561
+
562
+ ---
563
+
564
+ ##### `limitMemory`<sup>Optional</sup> <a name="limitMemory" id="@bluedynamics/cdk8s-plone.PloneHttpcacheOptions.property.limitMemory"></a>
565
+
566
+ ```typescript
567
+ public readonly limitMemory: string;
568
+ ```
569
+
570
+ - *Type:* string
571
+
572
+ ---
573
+
574
+ ##### `requestCpu`<sup>Optional</sup> <a name="requestCpu" id="@bluedynamics/cdk8s-plone.PloneHttpcacheOptions.property.requestCpu"></a>
575
+
576
+ ```typescript
577
+ public readonly requestCpu: string;
578
+ ```
579
+
580
+ - *Type:* string
581
+
582
+ ---
583
+
584
+ ##### `requestMemory`<sup>Optional</sup> <a name="requestMemory" id="@bluedynamics/cdk8s-plone.PloneHttpcacheOptions.property.requestMemory"></a>
585
+
586
+ ```typescript
587
+ public readonly requestMemory: string;
588
+ ```
589
+
590
+ - *Type:* string
591
+
592
+ ---
593
+
594
+ ##### `varnishVcl`<sup>Optional</sup> <a name="varnishVcl" id="@bluedynamics/cdk8s-plone.PloneHttpcacheOptions.property.varnishVcl"></a>
595
+
596
+ ```typescript
597
+ public readonly varnishVcl: string;
598
+ ```
599
+
600
+ - *Type:* string
601
+ - *Default:* file in config folder
602
+
603
+ varnishVcl.
604
+
605
+ ---
606
+
607
+ ##### `varnishVclFile`<sup>Optional</sup> <a name="varnishVclFile" id="@bluedynamics/cdk8s-plone.PloneHttpcacheOptions.property.varnishVclFile"></a>
608
+
609
+ ```typescript
610
+ public readonly varnishVclFile: string;
611
+ ```
612
+
613
+ - *Type:* string
614
+ - *Default:* undefined
615
+
616
+ varnishVclFile.
617
+
618
+ ---
619
+
379
620
  ### PloneOptions <a name="PloneOptions" id="@bluedynamics/cdk8s-plone.PloneOptions"></a>
380
621
 
381
622
  #### Initializer <a name="Initializer" id="@bluedynamics/cdk8s-plone.PloneOptions.Initializer"></a>
package/README.md CHANGED
@@ -45,14 +45,7 @@ Each step need to be implemented with tests!
45
45
  - [ ] depend on ready/live backend (needed?)
46
46
  - [x] generic way to inject sidecars
47
47
 
48
- - [ ] Start Varnish
49
- - [ ] deployment
50
- - [ ] do not depend on backend/front end to be up, but configure to deliver from cache if possible.
51
- - [ ] service
52
- - [ ] pdb
53
- - [ ] lifecycle checks (readiness, liveness)
54
- - [ ] generic way to inject sidecars
55
- - find a way to purge caches. based on kitconcept varnish purger? needs evaluation
48
+ - [x] Start Varnish (using kube-httcache)
56
49
 
57
50
  - [ ] Other Languages
58
51
  - [x] Check Python distribution
@@ -0,0 +1,29 @@
1
+ import { Construct } from 'constructs';
2
+ import { Plone } from './plone';
3
+ export interface PloneHttpcacheOptions {
4
+ /**
5
+ * plone chart
6
+ * @default - none
7
+ */
8
+ readonly plone: Plone;
9
+ /** varnishVcl
10
+ * @default - file in config folder
11
+ */
12
+ readonly varnishVcl?: string;
13
+ /** varnishVclFile
14
+ * @default - undefined
15
+ */
16
+ readonly varnishVclFile?: string | undefined;
17
+ /** existingSecret - Read admin credentials from user provided secret
18
+ * @default - undefined
19
+ */
20
+ readonly existingSecret?: string;
21
+ readonly limitCpu?: string;
22
+ readonly limitMemory?: string;
23
+ readonly requestCpu?: string;
24
+ readonly requestMemory?: string;
25
+ }
26
+ export declare class PloneHttpcache extends Construct {
27
+ readonly httpcacheServiceName: string;
28
+ constructor(scope: Construct, id: string, options: PloneHttpcacheOptions);
29
+ }
@@ -0,0 +1,93 @@
1
+ "use strict";
2
+ var _a;
3
+ Object.defineProperty(exports, "__esModule", { value: true });
4
+ exports.PloneHttpcache = void 0;
5
+ const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
6
+ const fs = require("fs");
7
+ const path = require("path");
8
+ const cdk8s_1 = require("cdk8s");
9
+ const constructs_1 = require("constructs");
10
+ class PloneHttpcache extends constructs_1.Construct {
11
+ constructor(scope, id, options) {
12
+ super(scope, id);
13
+ let varnishVcl;
14
+ if (!options.varnishVcl) {
15
+ let vclPath;
16
+ if (!options.varnishVclFile) {
17
+ vclPath = path.join(__dirname, 'config', 'varnish.tpl.vcl');
18
+ }
19
+ else {
20
+ vclPath = options.varnishVclFile;
21
+ }
22
+ varnishVcl = fs.readFileSync(vclPath, 'utf8');
23
+ }
24
+ else {
25
+ varnishVcl = options.varnishVcl;
26
+ }
27
+ const httpcache = new cdk8s_1.Helm(this, 'httpcache', {
28
+ // see https://github.com/mittwald/kube-httpcache/chart
29
+ repo: 'https://helm.mittwald.de',
30
+ chart: 'kube-httpcache',
31
+ values: {
32
+ replicaCount: 2,
33
+ cache: {
34
+ // need to looks at the frontendWatch, do we need it?
35
+ frontendWatch: false,
36
+ backendWatch: false,
37
+ existingSecret: options.existingSecret ?? undefined,
38
+ },
39
+ vclTemplate: varnishVcl,
40
+ extraEnvVars: [
41
+ { name: 'BACKEND_SERVICE_NAME', value: options.plone.backendServiceName },
42
+ { name: 'BACKEND_SERVICE_PORT', value: '8080' },
43
+ { name: 'FRONTEND_SERVICE_NAME', value: options.plone.frontendServiceName },
44
+ { name: 'FRONTEND_SERVICE_PORT', value: '3000' },
45
+ ],
46
+ resources: {
47
+ limits: {
48
+ cpu: options.limitCpu || '500m',
49
+ memory: options.limitMemory || '500Mi',
50
+ },
51
+ requests: {
52
+ cpu: options.requestCpu || '100m',
53
+ memory: options.requestMemory || '100Mi',
54
+ },
55
+ },
56
+ rbac: {
57
+ enabled: false,
58
+ },
59
+ exporter: {
60
+ enabled: true,
61
+ resources: {
62
+ limits: {
63
+ cpu: '100m',
64
+ memory: '100Mi',
65
+ },
66
+ requests: {
67
+ cpu: '10m',
68
+ memory: '50Mi',
69
+ },
70
+ },
71
+ },
72
+ serviceMonitor: {
73
+ enabled: true,
74
+ scrapeSignaller: true,
75
+ },
76
+ },
77
+ });
78
+ const httpcacheService = httpcache.apiObjects.find((construct) => {
79
+ if ((construct.kind === 'Service') && (construct.metadata.name?.endsWith('kube-httpcache'))) {
80
+ return construct.name;
81
+ }
82
+ return undefined;
83
+ });
84
+ if (httpcacheService === undefined) {
85
+ throw new Error('Could not find httpcache service');
86
+ }
87
+ this.httpcacheServiceName = httpcacheService.name;
88
+ }
89
+ }
90
+ exports.PloneHttpcache = PloneHttpcache;
91
+ _a = JSII_RTTI_SYMBOL_1;
92
+ PloneHttpcache[_a] = { fqn: "@bluedynamics/cdk8s-plone.PloneHttpcache", version: "0.0.17" };
93
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaHR0cGNhY2hlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vc3JjL2h0dHBjYWNoZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7OztBQUFBLHlCQUF5QjtBQUN6Qiw2QkFBNkI7QUFDN0IsaUNBQTZCO0FBQzdCLDJDQUF1QztBQWlDdkMsTUFBYSxjQUFlLFNBQVEsc0JBQVM7SUFJM0MsWUFBWSxLQUFnQixFQUFFLEVBQVUsRUFBRSxPQUE4QjtRQUN0RSxLQUFLLENBQUMsS0FBSyxFQUFFLEVBQUUsQ0FBQyxDQUFDO1FBQ2pCLElBQUksVUFBa0IsQ0FBQztRQUN2QixJQUFJLENBQUMsT0FBTyxDQUFDLFVBQVUsRUFBRSxDQUFDO1lBQ3hCLElBQUksT0FBZSxDQUFDO1lBQ3BCLElBQUksQ0FBQyxPQUFPLENBQUMsY0FBYyxFQUFFLENBQUM7Z0JBQzVCLE9BQU8sR0FBRyxJQUFJLENBQUMsSUFBSSxDQUFDLFNBQVMsRUFBRSxRQUFRLEVBQUUsaUJBQWlCLENBQUMsQ0FBQztZQUM5RCxDQUFDO2lCQUFNLENBQUM7Z0JBQ04sT0FBTyxHQUFHLE9BQU8sQ0FBQyxjQUFjLENBQUM7WUFDbkMsQ0FBQztZQUNELFVBQVUsR0FBRyxFQUFFLENBQUMsWUFBWSxDQUFDLE9BQU8sRUFBRSxNQUFNLENBQUMsQ0FBQztRQUNoRCxDQUFDO2FBQU0sQ0FBQztZQUNOLFVBQVUsR0FBRyxPQUFPLENBQUMsVUFBVSxDQUFDO1FBQ2xDLENBQUM7UUFDRCxNQUFNLFNBQVMsR0FBRyxJQUFJLFlBQUksQ0FBQyxJQUFJLEVBQUUsV0FBVyxFQUFFO1lBQzVDLHVEQUF1RDtZQUN2RCxJQUFJLEVBQUUsMEJBQTBCO1lBQ2hDLEtBQUssRUFBRSxnQkFBZ0I7WUFDdkIsTUFBTSxFQUFFO2dCQUNOLFlBQVksRUFBRSxDQUFDO2dCQUNmLEtBQUssRUFBRTtvQkFDTCxxREFBcUQ7b0JBQ3JELGFBQWEsRUFBRSxLQUFLO29CQUNwQixZQUFZLEVBQUUsS0FBSztvQkFDbkIsY0FBYyxFQUFFLE9BQU8sQ0FBQyxjQUFjLElBQUksU0FBUztpQkFDcEQ7Z0JBQ0QsV0FBVyxFQUFFLFVBQVU7Z0JBQ3ZCLFlBQVksRUFBRTtvQkFDWixFQUFFLElBQUksRUFBRSxzQkFBc0IsRUFBRSxLQUFLLEVBQUUsT0FBTyxDQUFDLEtBQUssQ0FBQyxrQkFBa0IsRUFBRTtvQkFDekUsRUFBRSxJQUFJLEVBQUUsc0JBQXNCLEVBQUUsS0FBSyxFQUFFLE1BQU0sRUFBRTtvQkFDL0MsRUFBRSxJQUFJLEVBQUUsdUJBQXVCLEVBQUUsS0FBSyxFQUFFLE9BQU8sQ0FBQyxLQUFLLENBQUMsbUJBQW1CLEVBQUU7b0JBQzNFLEVBQUUsSUFBSSxFQUFFLHVCQUF1QixFQUFFLEtBQUssRUFBRSxNQUFNLEVBQUU7aUJBQ2pEO2dCQUNELFNBQVMsRUFBRTtvQkFDVCxNQUFNLEVBQUU7d0JBQ04sR0FBRyxFQUFFLE9BQU8sQ0FBQyxRQUFRLElBQUksTUFBTTt3QkFDL0IsTUFBTSxFQUFFLE9BQU8sQ0FBQyxXQUFXLElBQUksT0FBTztxQkFDdkM7b0JBQ0QsUUFBUSxFQUFFO3dCQUNSLEdBQUcsRUFBRSxPQUFPLENBQUMsVUFBVSxJQUFJLE1BQU07d0JBQ2pDLE1BQU0sRUFBRSxPQUFPLENBQUMsYUFBYSxJQUFJLE9BQU87cUJBQ3pDO2lCQUNGO2dCQUNELElBQUksRUFBRTtvQkFDSixPQUFPLEVBQUUsS0FBSztpQkFDZjtnQkFDRCxRQUFRLEVBQUU7b0JBQ1IsT0FBTyxFQUFFLElBQUk7b0JBQ2IsU0FBUyxFQUFFO3dCQUNULE1BQU0sRUFBRTs0QkFDTixHQUFHLEVBQUUsTUFBTTs0QkFDWCxNQUFNLEVBQUUsT0FBTzt5QkFDaEI7d0JBQ0QsUUFBUSxFQUFFOzRCQUNSLEdBQUcsRUFBRSxLQUFLOzRCQUNWLE1BQU0sRUFBRSxNQUFNO3lCQUNmO3FCQUNGO2lCQUNGO2dCQUNELGNBQWMsRUFBRTtvQkFDZCxPQUFPLEVBQUUsSUFBSTtvQkFDYixlQUFlLEVBQUUsSUFBSTtpQkFDdEI7YUFDRjtTQUNGLENBQUMsQ0FBQztRQUNILE1BQU0sZ0JBQWdCLEdBQUcsU0FBUyxDQUFDLFVBQVUsQ0FBQyxJQUFJLENBQUMsQ0FBQyxTQUFTLEVBQUUsRUFBRTtZQUMvRCxJQUFJLENBQUMsU0FBUyxDQUFDLElBQUksS0FBSyxTQUFTLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxRQUFRLENBQUMsSUFBSSxFQUFFLFFBQVEsQ0FBQyxnQkFBZ0IsQ0FBQyxDQUFDLEVBQUUsQ0FBQztnQkFDNUYsT0FBTyxTQUFTLENBQUMsSUFBSSxDQUFDO1lBQ3hCLENBQUM7WUFDRCxPQUFPLFNBQVMsQ0FBQztRQUNuQixDQUFDLENBQUMsQ0FBQztRQUNILElBQUksZ0JBQWdCLEtBQUssU0FBUyxFQUFFLENBQUM7WUFDbkMsTUFBTSxJQUFJLEtBQUssQ0FBQyxrQ0FBa0MsQ0FBQyxDQUFDO1FBQ3RELENBQUM7UUFDRCxJQUFJLENBQUMsb0JBQW9CLEdBQUcsZ0JBQWdCLENBQUMsSUFBSSxDQUFDO0lBQ3BELENBQUM7O0FBL0VILHdDQWdGQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCAqIGFzIGZzIGZyb20gJ2ZzJztcbmltcG9ydCAqIGFzIHBhdGggZnJvbSAncGF0aCc7XG5pbXBvcnQgeyBIZWxtIH0gZnJvbSAnY2RrOHMnO1xuaW1wb3J0IHsgQ29uc3RydWN0IH0gZnJvbSAnY29uc3RydWN0cyc7XG5pbXBvcnQgeyBQbG9uZSB9IGZyb20gJy4vcGxvbmUnO1xuXG5leHBvcnQgaW50ZXJmYWNlIFBsb25lSHR0cGNhY2hlT3B0aW9ucyB7XG4gIC8qKlxuICAgKiBwbG9uZSBjaGFydFxuICAgKiBAZGVmYXVsdCAtIG5vbmVcbiAgICovXG4gIHJlYWRvbmx5IHBsb25lOiBQbG9uZTtcblxuICAvKiogdmFybmlzaFZjbFxuICAgKiBAZGVmYXVsdCAtIGZpbGUgaW4gY29uZmlnIGZvbGRlclxuICAgKi9cbiAgcmVhZG9ubHkgdmFybmlzaFZjbD86IHN0cmluZztcblxuICAvKiogdmFybmlzaFZjbEZpbGVcbiAgICogQGRlZmF1bHQgLSB1bmRlZmluZWRcbiAgICovXG4gIHJlYWRvbmx5IHZhcm5pc2hWY2xGaWxlPzogc3RyaW5nIHwgdW5kZWZpbmVkO1xuXG4gIC8qKiBleGlzdGluZ1NlY3JldCAtIFJlYWQgYWRtaW4gY3JlZGVudGlhbHMgZnJvbSB1c2VyIHByb3ZpZGVkIHNlY3JldFxuICAgKiBAZGVmYXVsdCAtIHVuZGVmaW5lZFxuICAqL1xuICByZWFkb25seSBleGlzdGluZ1NlY3JldD86IHN0cmluZztcblxuXG4gIC8vIHJlc291cmNlc1xuICByZWFkb25seSBsaW1pdENwdT86IHN0cmluZztcbiAgcmVhZG9ubHkgbGltaXRNZW1vcnk/OiBzdHJpbmc7XG4gIHJlYWRvbmx5IHJlcXVlc3RDcHU/OiBzdHJpbmc7XG4gIHJlYWRvbmx5IHJlcXVlc3RNZW1vcnk/OiBzdHJpbmc7XG59XG5cbmV4cG9ydCBjbGFzcyBQbG9uZUh0dHBjYWNoZSBleHRlbmRzIENvbnN0cnVjdCB7XG5cbiAgcHVibGljIHJlYWRvbmx5IGh0dHBjYWNoZVNlcnZpY2VOYW1lOiBzdHJpbmc7XG5cbiAgY29uc3RydWN0b3Ioc2NvcGU6IENvbnN0cnVjdCwgaWQ6IHN0cmluZywgb3B0aW9uczogUGxvbmVIdHRwY2FjaGVPcHRpb25zKSB7XG4gICAgc3VwZXIoc2NvcGUsIGlkKTtcbiAgICBsZXQgdmFybmlzaFZjbDogc3RyaW5nO1xuICAgIGlmICghb3B0aW9ucy52YXJuaXNoVmNsKSB7XG4gICAgICBsZXQgdmNsUGF0aDogc3RyaW5nO1xuICAgICAgaWYgKCFvcHRpb25zLnZhcm5pc2hWY2xGaWxlKSB7XG4gICAgICAgIHZjbFBhdGggPSBwYXRoLmpvaW4oX19kaXJuYW1lLCAnY29uZmlnJywgJ3Zhcm5pc2gudHBsLnZjbCcpO1xuICAgICAgfSBlbHNlIHtcbiAgICAgICAgdmNsUGF0aCA9IG9wdGlvbnMudmFybmlzaFZjbEZpbGU7XG4gICAgICB9XG4gICAgICB2YXJuaXNoVmNsID0gZnMucmVhZEZpbGVTeW5jKHZjbFBhdGgsICd1dGY4Jyk7XG4gICAgfSBlbHNlIHtcbiAgICAgIHZhcm5pc2hWY2wgPSBvcHRpb25zLnZhcm5pc2hWY2w7XG4gICAgfVxuICAgIGNvbnN0IGh0dHBjYWNoZSA9IG5ldyBIZWxtKHRoaXMsICdodHRwY2FjaGUnLCB7XG4gICAgICAvLyBzZWUgaHR0cHM6Ly9naXRodWIuY29tL21pdHR3YWxkL2t1YmUtaHR0cGNhY2hlL2NoYXJ0XG4gICAgICByZXBvOiAnaHR0cHM6Ly9oZWxtLm1pdHR3YWxkLmRlJyxcbiAgICAgIGNoYXJ0OiAna3ViZS1odHRwY2FjaGUnLFxuICAgICAgdmFsdWVzOiB7XG4gICAgICAgIHJlcGxpY2FDb3VudDogMixcbiAgICAgICAgY2FjaGU6IHtcbiAgICAgICAgICAvLyBuZWVkIHRvIGxvb2tzIGF0IHRoZSBmcm9udGVuZFdhdGNoLCBkbyB3ZSBuZWVkIGl0P1xuICAgICAgICAgIGZyb250ZW5kV2F0Y2g6IGZhbHNlLFxuICAgICAgICAgIGJhY2tlbmRXYXRjaDogZmFsc2UsXG4gICAgICAgICAgZXhpc3RpbmdTZWNyZXQ6IG9wdGlvbnMuZXhpc3RpbmdTZWNyZXQgPz8gdW5kZWZpbmVkLFxuICAgICAgICB9LFxuICAgICAgICB2Y2xUZW1wbGF0ZTogdmFybmlzaFZjbCxcbiAgICAgICAgZXh0cmFFbnZWYXJzOiBbXG4gICAgICAgICAgeyBuYW1lOiAnQkFDS0VORF9TRVJWSUNFX05BTUUnLCB2YWx1ZTogb3B0aW9ucy5wbG9uZS5iYWNrZW5kU2VydmljZU5hbWUgfSxcbiAgICAgICAgICB7IG5hbWU6ICdCQUNLRU5EX1NFUlZJQ0VfUE9SVCcsIHZhbHVlOiAnODA4MCcgfSxcbiAgICAgICAgICB7IG5hbWU6ICdGUk9OVEVORF9TRVJWSUNFX05BTUUnLCB2YWx1ZTogb3B0aW9ucy5wbG9uZS5mcm9udGVuZFNlcnZpY2VOYW1lIH0sXG4gICAgICAgICAgeyBuYW1lOiAnRlJPTlRFTkRfU0VSVklDRV9QT1JUJywgdmFsdWU6ICczMDAwJyB9LFxuICAgICAgICBdLFxuICAgICAgICByZXNvdXJjZXM6IHtcbiAgICAgICAgICBsaW1pdHM6IHtcbiAgICAgICAgICAgIGNwdTogb3B0aW9ucy5saW1pdENwdSB8fCAnNTAwbScsXG4gICAgICAgICAgICBtZW1vcnk6IG9wdGlvbnMubGltaXRNZW1vcnkgfHwgJzUwME1pJyxcbiAgICAgICAgICB9LFxuICAgICAgICAgIHJlcXVlc3RzOiB7XG4gICAgICAgICAgICBjcHU6IG9wdGlvbnMucmVxdWVzdENwdSB8fCAnMTAwbScsXG4gICAgICAgICAgICBtZW1vcnk6IG9wdGlvbnMucmVxdWVzdE1lbW9yeSB8fCAnMTAwTWknLFxuICAgICAgICAgIH0sXG4gICAgICAgIH0sXG4gICAgICAgIHJiYWM6IHtcbiAgICAgICAgICBlbmFibGVkOiBmYWxzZSxcbiAgICAgICAgfSxcbiAgICAgICAgZXhwb3J0ZXI6IHtcbiAgICAgICAgICBlbmFibGVkOiB0cnVlLFxuICAgICAgICAgIHJlc291cmNlczoge1xuICAgICAgICAgICAgbGltaXRzOiB7XG4gICAgICAgICAgICAgIGNwdTogJzEwMG0nLFxuICAgICAgICAgICAgICBtZW1vcnk6ICcxMDBNaScsXG4gICAgICAgICAgICB9LFxuICAgICAgICAgICAgcmVxdWVzdHM6IHtcbiAgICAgICAgICAgICAgY3B1OiAnMTBtJyxcbiAgICAgICAgICAgICAgbWVtb3J5OiAnNTBNaScsXG4gICAgICAgICAgICB9LFxuICAgICAgICAgIH0sXG4gICAgICAgIH0sXG4gICAgICAgIHNlcnZpY2VNb25pdG9yOiB7XG4gICAgICAgICAgZW5hYmxlZDogdHJ1ZSxcbiAgICAgICAgICBzY3JhcGVTaWduYWxsZXI6IHRydWUsXG4gICAgICAgIH0sXG4gICAgICB9LFxuICAgIH0pO1xuICAgIGNvbnN0IGh0dHBjYWNoZVNlcnZpY2UgPSBodHRwY2FjaGUuYXBpT2JqZWN0cy5maW5kKChjb25zdHJ1Y3QpID0+IHtcbiAgICAgIGlmICgoY29uc3RydWN0LmtpbmQgPT09ICdTZXJ2aWNlJykgJiYgKGNvbnN0cnVjdC5tZXRhZGF0YS5uYW1lPy5lbmRzV2l0aCgna3ViZS1odHRwY2FjaGUnKSkpIHtcbiAgICAgICAgcmV0dXJuIGNvbnN0cnVjdC5uYW1lO1xuICAgICAgfVxuICAgICAgcmV0dXJuIHVuZGVmaW5lZDtcbiAgICB9KTtcbiAgICBpZiAoaHR0cGNhY2hlU2VydmljZSA9PT0gdW5kZWZpbmVkKSB7XG4gICAgICB0aHJvdyBuZXcgRXJyb3IoJ0NvdWxkIG5vdCBmaW5kIGh0dHBjYWNoZSBzZXJ2aWNlJyk7XG4gICAgfVxuICAgIHRoaXMuaHR0cGNhY2hlU2VydmljZU5hbWUgPSBodHRwY2FjaGVTZXJ2aWNlLm5hbWU7XG4gIH1cbn0iXX0=
package/lib/index.d.ts CHANGED
@@ -1 +1,2 @@
1
1
  export { Plone, PloneOptions, PloneBaseOptions } from './plone';
2
+ export { PloneHttpcache, PloneHttpcacheOptions } from './httpcache';
package/lib/index.js CHANGED
@@ -1,6 +1,8 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.Plone = void 0;
3
+ exports.PloneHttpcache = exports.Plone = void 0;
4
4
  var plone_1 = require("./plone");
5
5
  Object.defineProperty(exports, "Plone", { enumerable: true, get: function () { return plone_1.Plone; } });
6
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBQUEsaUNBQWdFO0FBQXZELDhGQUFBLEtBQUssT0FBQSIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCB7IFBsb25lLCBQbG9uZU9wdGlvbnMsIFBsb25lQmFzZU9wdGlvbnMgfSBmcm9tICcuL3Bsb25lJztcbiJdfQ==
6
+ var httpcache_1 = require("./httpcache");
7
+ Object.defineProperty(exports, "PloneHttpcache", { enumerable: true, get: function () { return httpcache_1.PloneHttpcache; } });
8
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBQUEsaUNBQWdFO0FBQXZELDhGQUFBLEtBQUssT0FBQTtBQUNkLHlDQUFvRTtBQUEzRCwyR0FBQSxjQUFjLE9BQUEiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgeyBQbG9uZSwgUGxvbmVPcHRpb25zLCBQbG9uZUJhc2VPcHRpb25zIH0gZnJvbSAnLi9wbG9uZSc7XG5leHBvcnQgeyBQbG9uZUh0dHBjYWNoZSwgUGxvbmVIdHRwY2FjaGVPcHRpb25zIH0gZnJvbSAnLi9odHRwY2FjaGUnO1xuIl19
package/lib/plone.js CHANGED
@@ -149,5 +149,5 @@ class Plone extends constructs_1.Construct {
149
149
  }
150
150
  exports.Plone = Plone;
151
151
  _a = JSII_RTTI_SYMBOL_1;
152
- Plone[_a] = { fqn: "@bluedynamics/cdk8s-plone.Plone", version: "0.0.15" };
152
+ Plone[_a] = { fqn: "@bluedynamics/cdk8s-plone.Plone", version: "0.0.17" };
153
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
@@ -75,7 +75,7 @@
75
75
  "publishConfig": {
76
76
  "access": "public"
77
77
  },
78
- "version": "0.0.15",
78
+ "version": "0.0.17",
79
79
  "jest": {
80
80
  "coverageProvider": "v8",
81
81
  "testMatch": [