@bluedynamics/cdk8s-plone 0.0.17 → 0.0.19
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 +87 -14
- package/API.md +56 -1
- package/README.md +76 -13
- package/lib/httpcache.js +3 -2
- package/lib/index.d.ts +1 -1
- package/lib/index.js +3 -2
- package/lib/plone.d.ts +8 -1
- package/lib/plone.js +78 -71
- package/package.json +4 -4
package/.jsii
CHANGED
|
@@ -7,7 +7,7 @@
|
|
|
7
7
|
]
|
|
8
8
|
},
|
|
9
9
|
"dependencies": {
|
|
10
|
-
"cdk8s": "^2.68.
|
|
10
|
+
"cdk8s": "^2.68.94",
|
|
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-
|
|
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 (for API with `plone.volto` or as Classic-UI)\n- Frontend (Plone-Volto, a ReactJS based user interface)\n- Varnish using kube-httpcache. It includes a way to invalidate varnish cluster (optional)\n\n## Installation\n\n### Typescript\n\nTo use this library, create a new CDK8S project (or use an existing one)\n\n```bash\ncdk8s init typescript-app\n```\n\nThen add the following dependency to `package.json`:\n\n```json\n{\n \"dependencies\": {\n \"@bluedynamics/cdk8s-plone\": \"*\"\n }\n}\n```\n\nRun `npm install` to install the new dependency.\n\n### Python\n\nTodo: Document in details how to install.\n\n```bash\ncdk8s init python-app\n```\n\nPython package name is [cdk8s-plone](https://pypi.org/project/cdk8s-plone/).\n\n\n\n\n## Usage\n\nWith `cdk8s-cli` installed, create a new project:\n\n```bash\ncdk8s sythn\n```\n\nAdd the following code to your `main.ts`:\n\n```typescript\n...\nimport { Plone } from '@bluedynamics/cdk8s-plone';\n...\n super(scope, id, props);\n\n // define resources here\n new Plone(this, 'Plone', {});\n...\n```\n\nRun `npm run build ` to generate the Kubernetes manifests.\nThe manifests are stored in the `dist` directory.\n\nFor more 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### Feature Wishlist:\n\nEach step need to be implemented with tests!\n\n- [x] Support Variants for ClassicUI or Volto\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 - [ ] metrics sidecar\n- [ ] Start Frontend\n - [x] deployment\n - [x] service\n - [x] pdb\n - [x] lifecycle checks (readiness, liveness)\n - [x] generic way to inject sidecars\n - [ ] metrics sidecar\n- [x] Start Varnish (using `kube-httpcache`) optional in separate chart\n - [x] provide a default VCL for Volto with routing to backend and frontend\n - [ ] provide a default VCL for ClassicUI\n- [ ] Configure Ingress, optional in separate chart\n - [ ] Traefik\n - [ ] Konq\n\n- [ ] Release packages for other Languages\n - [x] Python\n - [ ] Golang\n - [ ] Java"
|
|
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":
|
|
141
|
+
"line": 65
|
|
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":
|
|
168
|
+
"line": 50
|
|
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":
|
|
179
|
+
"line": 60
|
|
180
180
|
},
|
|
181
181
|
"name": "backendServiceName",
|
|
182
182
|
"type": {
|
|
@@ -190,9 +190,38 @@
|
|
|
190
190
|
"immutable": true,
|
|
191
191
|
"locationInModule": {
|
|
192
192
|
"filename": "src/plone.ts",
|
|
193
|
-
"line":
|
|
193
|
+
"line": 63
|
|
194
|
+
},
|
|
195
|
+
"name": "siteId",
|
|
196
|
+
"type": {
|
|
197
|
+
"primitive": "string"
|
|
198
|
+
}
|
|
199
|
+
},
|
|
200
|
+
{
|
|
201
|
+
"docs": {
|
|
202
|
+
"stability": "stable"
|
|
203
|
+
},
|
|
204
|
+
"immutable": true,
|
|
205
|
+
"locationInModule": {
|
|
206
|
+
"filename": "src/plone.ts",
|
|
207
|
+
"line": 62
|
|
208
|
+
},
|
|
209
|
+
"name": "variant",
|
|
210
|
+
"type": {
|
|
211
|
+
"fqn": "@bluedynamics/cdk8s-plone.PloneVariant"
|
|
212
|
+
}
|
|
213
|
+
},
|
|
214
|
+
{
|
|
215
|
+
"docs": {
|
|
216
|
+
"stability": "stable"
|
|
217
|
+
},
|
|
218
|
+
"immutable": true,
|
|
219
|
+
"locationInModule": {
|
|
220
|
+
"filename": "src/plone.ts",
|
|
221
|
+
"line": 61
|
|
194
222
|
},
|
|
195
223
|
"name": "frontendServiceName",
|
|
224
|
+
"optional": true,
|
|
196
225
|
"type": {
|
|
197
226
|
"primitive": "string"
|
|
198
227
|
}
|
|
@@ -777,7 +806,7 @@
|
|
|
777
806
|
"kind": "interface",
|
|
778
807
|
"locationInModule": {
|
|
779
808
|
"filename": "src/plone.ts",
|
|
780
|
-
"line":
|
|
809
|
+
"line": 40
|
|
781
810
|
},
|
|
782
811
|
"name": "PloneOptions",
|
|
783
812
|
"properties": [
|
|
@@ -789,7 +818,7 @@
|
|
|
789
818
|
"immutable": true,
|
|
790
819
|
"locationInModule": {
|
|
791
820
|
"filename": "src/plone.ts",
|
|
792
|
-
"line":
|
|
821
|
+
"line": 44
|
|
793
822
|
},
|
|
794
823
|
"name": "backend",
|
|
795
824
|
"optional": true,
|
|
@@ -805,7 +834,7 @@
|
|
|
805
834
|
"immutable": true,
|
|
806
835
|
"locationInModule": {
|
|
807
836
|
"filename": "src/plone.ts",
|
|
808
|
-
"line":
|
|
837
|
+
"line": 45
|
|
809
838
|
},
|
|
810
839
|
"name": "frontend",
|
|
811
840
|
"optional": true,
|
|
@@ -821,7 +850,7 @@
|
|
|
821
850
|
"immutable": true,
|
|
822
851
|
"locationInModule": {
|
|
823
852
|
"filename": "src/plone.ts",
|
|
824
|
-
"line":
|
|
853
|
+
"line": 46
|
|
825
854
|
},
|
|
826
855
|
"name": "imagePullSecrets",
|
|
827
856
|
"optional": true,
|
|
@@ -842,7 +871,7 @@
|
|
|
842
871
|
"immutable": true,
|
|
843
872
|
"locationInModule": {
|
|
844
873
|
"filename": "src/plone.ts",
|
|
845
|
-
"line":
|
|
874
|
+
"line": 42
|
|
846
875
|
},
|
|
847
876
|
"name": "siteId",
|
|
848
877
|
"optional": true,
|
|
@@ -858,7 +887,23 @@
|
|
|
858
887
|
"immutable": true,
|
|
859
888
|
"locationInModule": {
|
|
860
889
|
"filename": "src/plone.ts",
|
|
861
|
-
"line":
|
|
890
|
+
"line": 43
|
|
891
|
+
},
|
|
892
|
+
"name": "variant",
|
|
893
|
+
"optional": true,
|
|
894
|
+
"type": {
|
|
895
|
+
"fqn": "@bluedynamics/cdk8s-plone.PloneVariant"
|
|
896
|
+
}
|
|
897
|
+
},
|
|
898
|
+
{
|
|
899
|
+
"abstract": true,
|
|
900
|
+
"docs": {
|
|
901
|
+
"stability": "stable"
|
|
902
|
+
},
|
|
903
|
+
"immutable": true,
|
|
904
|
+
"locationInModule": {
|
|
905
|
+
"filename": "src/plone.ts",
|
|
906
|
+
"line": 41
|
|
862
907
|
},
|
|
863
908
|
"name": "version",
|
|
864
909
|
"optional": true,
|
|
@@ -868,8 +913,36 @@
|
|
|
868
913
|
}
|
|
869
914
|
],
|
|
870
915
|
"symbolId": "src/plone:PloneOptions"
|
|
916
|
+
},
|
|
917
|
+
"@bluedynamics/cdk8s-plone.PloneVariant": {
|
|
918
|
+
"assembly": "@bluedynamics/cdk8s-plone",
|
|
919
|
+
"docs": {
|
|
920
|
+
"stability": "stable"
|
|
921
|
+
},
|
|
922
|
+
"fqn": "@bluedynamics/cdk8s-plone.PloneVariant",
|
|
923
|
+
"kind": "enum",
|
|
924
|
+
"locationInModule": {
|
|
925
|
+
"filename": "src/plone.ts",
|
|
926
|
+
"line": 36
|
|
927
|
+
},
|
|
928
|
+
"members": [
|
|
929
|
+
{
|
|
930
|
+
"docs": {
|
|
931
|
+
"stability": "stable"
|
|
932
|
+
},
|
|
933
|
+
"name": "VOLTO"
|
|
934
|
+
},
|
|
935
|
+
{
|
|
936
|
+
"docs": {
|
|
937
|
+
"stability": "stable"
|
|
938
|
+
},
|
|
939
|
+
"name": "CLASSICUI"
|
|
940
|
+
}
|
|
941
|
+
],
|
|
942
|
+
"name": "PloneVariant",
|
|
943
|
+
"symbolId": "src/plone:PloneVariant"
|
|
871
944
|
}
|
|
872
945
|
},
|
|
873
|
-
"version": "0.0.
|
|
874
|
-
"fingerprint": "
|
|
946
|
+
"version": "0.0.19",
|
|
947
|
+
"fingerprint": "QWW3Y+GJBFJq22QObRAoYC+FsuOmZI688QUE14YOuSI="
|
|
875
948
|
}
|
package/API.md
CHANGED
|
@@ -100,6 +100,8 @@ Any object.
|
|
|
100
100
|
| --- | --- | --- |
|
|
101
101
|
| <code><a href="#@bluedynamics/cdk8s-plone.Plone.property.node">node</a></code> | <code>constructs.Node</code> | The tree node. |
|
|
102
102
|
| <code><a href="#@bluedynamics/cdk8s-plone.Plone.property.backendServiceName">backendServiceName</a></code> | <code>string</code> | *No description.* |
|
|
103
|
+
| <code><a href="#@bluedynamics/cdk8s-plone.Plone.property.siteId">siteId</a></code> | <code>string</code> | *No description.* |
|
|
104
|
+
| <code><a href="#@bluedynamics/cdk8s-plone.Plone.property.variant">variant</a></code> | <code><a href="#@bluedynamics/cdk8s-plone.PloneVariant">PloneVariant</a></code> | *No description.* |
|
|
103
105
|
| <code><a href="#@bluedynamics/cdk8s-plone.Plone.property.frontendServiceName">frontendServiceName</a></code> | <code>string</code> | *No description.* |
|
|
104
106
|
|
|
105
107
|
---
|
|
@@ -126,7 +128,27 @@ public readonly backendServiceName: string;
|
|
|
126
128
|
|
|
127
129
|
---
|
|
128
130
|
|
|
129
|
-
##### `
|
|
131
|
+
##### `siteId`<sup>Required</sup> <a name="siteId" id="@bluedynamics/cdk8s-plone.Plone.property.siteId"></a>
|
|
132
|
+
|
|
133
|
+
```typescript
|
|
134
|
+
public readonly siteId: string;
|
|
135
|
+
```
|
|
136
|
+
|
|
137
|
+
- *Type:* string
|
|
138
|
+
|
|
139
|
+
---
|
|
140
|
+
|
|
141
|
+
##### `variant`<sup>Required</sup> <a name="variant" id="@bluedynamics/cdk8s-plone.Plone.property.variant"></a>
|
|
142
|
+
|
|
143
|
+
```typescript
|
|
144
|
+
public readonly variant: PloneVariant;
|
|
145
|
+
```
|
|
146
|
+
|
|
147
|
+
- *Type:* <a href="#@bluedynamics/cdk8s-plone.PloneVariant">PloneVariant</a>
|
|
148
|
+
|
|
149
|
+
---
|
|
150
|
+
|
|
151
|
+
##### `frontendServiceName`<sup>Optional</sup> <a name="frontendServiceName" id="@bluedynamics/cdk8s-plone.Plone.property.frontendServiceName"></a>
|
|
130
152
|
|
|
131
153
|
```typescript
|
|
132
154
|
public readonly frontendServiceName: string;
|
|
@@ -635,6 +657,7 @@ const ploneOptions: PloneOptions = { ... }
|
|
|
635
657
|
| <code><a href="#@bluedynamics/cdk8s-plone.PloneOptions.property.frontend">frontend</a></code> | <code><a href="#@bluedynamics/cdk8s-plone.PloneBaseOptions">PloneBaseOptions</a></code> | *No description.* |
|
|
636
658
|
| <code><a href="#@bluedynamics/cdk8s-plone.PloneOptions.property.imagePullSecrets">imagePullSecrets</a></code> | <code>string[]</code> | *No description.* |
|
|
637
659
|
| <code><a href="#@bluedynamics/cdk8s-plone.PloneOptions.property.siteId">siteId</a></code> | <code>string</code> | *No description.* |
|
|
660
|
+
| <code><a href="#@bluedynamics/cdk8s-plone.PloneOptions.property.variant">variant</a></code> | <code><a href="#@bluedynamics/cdk8s-plone.PloneVariant">PloneVariant</a></code> | *No description.* |
|
|
638
661
|
| <code><a href="#@bluedynamics/cdk8s-plone.PloneOptions.property.version">version</a></code> | <code>string</code> | *No description.* |
|
|
639
662
|
|
|
640
663
|
---
|
|
@@ -679,6 +702,16 @@ public readonly siteId: string;
|
|
|
679
702
|
|
|
680
703
|
---
|
|
681
704
|
|
|
705
|
+
##### `variant`<sup>Optional</sup> <a name="variant" id="@bluedynamics/cdk8s-plone.PloneOptions.property.variant"></a>
|
|
706
|
+
|
|
707
|
+
```typescript
|
|
708
|
+
public readonly variant: PloneVariant;
|
|
709
|
+
```
|
|
710
|
+
|
|
711
|
+
- *Type:* <a href="#@bluedynamics/cdk8s-plone.PloneVariant">PloneVariant</a>
|
|
712
|
+
|
|
713
|
+
---
|
|
714
|
+
|
|
682
715
|
##### `version`<sup>Optional</sup> <a name="version" id="@bluedynamics/cdk8s-plone.PloneOptions.property.version"></a>
|
|
683
716
|
|
|
684
717
|
```typescript
|
|
@@ -691,3 +724,25 @@ public readonly version: string;
|
|
|
691
724
|
|
|
692
725
|
|
|
693
726
|
|
|
727
|
+
## Enums <a name="Enums" id="Enums"></a>
|
|
728
|
+
|
|
729
|
+
### PloneVariant <a name="PloneVariant" id="@bluedynamics/cdk8s-plone.PloneVariant"></a>
|
|
730
|
+
|
|
731
|
+
#### Members <a name="Members" id="Members"></a>
|
|
732
|
+
|
|
733
|
+
| **Name** | **Description** |
|
|
734
|
+
| --- | --- |
|
|
735
|
+
| <code><a href="#@bluedynamics/cdk8s-plone.PloneVariant.VOLTO">VOLTO</a></code> | *No description.* |
|
|
736
|
+
| <code><a href="#@bluedynamics/cdk8s-plone.PloneVariant.CLASSICUI">CLASSICUI</a></code> | *No description.* |
|
|
737
|
+
|
|
738
|
+
---
|
|
739
|
+
|
|
740
|
+
##### `VOLTO` <a name="VOLTO" id="@bluedynamics/cdk8s-plone.PloneVariant.VOLTO"></a>
|
|
741
|
+
|
|
742
|
+
---
|
|
743
|
+
|
|
744
|
+
|
|
745
|
+
##### `CLASSICUI` <a name="CLASSICUI" id="@bluedynamics/cdk8s-plone.PloneVariant.CLASSICUI"></a>
|
|
746
|
+
|
|
747
|
+
---
|
|
748
|
+
|
package/README.md
CHANGED
|
@@ -3,13 +3,70 @@
|
|
|
3
3
|
This chart provides a library to bootstrap a Plone deployment on a Kubernetes cluster using the [CDK8S](https://cdk8s.io) framework.
|
|
4
4
|
|
|
5
5
|
It provides
|
|
6
|
-
-
|
|
7
|
-
-
|
|
8
|
-
- varnish (optional)
|
|
6
|
+
- Backend (for API with `plone.volto` or as Classic-UI)
|
|
7
|
+
- Frontend (Plone-Volto, a ReactJS based user interface)
|
|
8
|
+
- Varnish using kube-httpcache. It includes a way to invalidate varnish cluster (optional)
|
|
9
|
+
|
|
10
|
+
## Installation
|
|
11
|
+
|
|
12
|
+
### Typescript
|
|
13
|
+
|
|
14
|
+
To use this library, create a new CDK8S project (or use an existing one)
|
|
15
|
+
|
|
16
|
+
```bash
|
|
17
|
+
cdk8s init typescript-app
|
|
18
|
+
```
|
|
19
|
+
|
|
20
|
+
Then add the following dependency to `package.json`:
|
|
21
|
+
|
|
22
|
+
```json
|
|
23
|
+
{
|
|
24
|
+
"dependencies": {
|
|
25
|
+
"@bluedynamics/cdk8s-plone": "*"
|
|
26
|
+
}
|
|
27
|
+
}
|
|
28
|
+
```
|
|
29
|
+
|
|
30
|
+
Run `npm install` to install the new dependency.
|
|
31
|
+
|
|
32
|
+
### Python
|
|
33
|
+
|
|
34
|
+
Todo: Document in details how to install.
|
|
35
|
+
|
|
36
|
+
```bash
|
|
37
|
+
cdk8s init python-app
|
|
38
|
+
```
|
|
39
|
+
|
|
40
|
+
Python package name is [cdk8s-plone](https://pypi.org/project/cdk8s-plone/).
|
|
41
|
+
|
|
42
|
+
|
|
43
|
+
|
|
9
44
|
|
|
10
45
|
## Usage
|
|
11
46
|
|
|
12
|
-
|
|
47
|
+
With `cdk8s-cli` installed, create a new project:
|
|
48
|
+
|
|
49
|
+
```bash
|
|
50
|
+
cdk8s sythn
|
|
51
|
+
```
|
|
52
|
+
|
|
53
|
+
Add the following code to your `main.ts`:
|
|
54
|
+
|
|
55
|
+
```typescript
|
|
56
|
+
...
|
|
57
|
+
import { Plone } from '@bluedynamics/cdk8s-plone';
|
|
58
|
+
...
|
|
59
|
+
super(scope, id, props);
|
|
60
|
+
|
|
61
|
+
// define resources here
|
|
62
|
+
new Plone(this, 'Plone', {});
|
|
63
|
+
...
|
|
64
|
+
```
|
|
65
|
+
|
|
66
|
+
Run `npm run build ` to generate the Kubernetes manifests.
|
|
67
|
+
The manifests are stored in the `dist` directory.
|
|
68
|
+
|
|
69
|
+
For more have a look at the [example project](https://github.com/bluedynamics/cdk8s-plone-example).
|
|
13
70
|
|
|
14
71
|
|
|
15
72
|
## Development
|
|
@@ -26,28 +83,34 @@ Then run the following command to run the test:
|
|
|
26
83
|
npx projen test
|
|
27
84
|
```
|
|
28
85
|
|
|
29
|
-
###
|
|
86
|
+
### Feature Wishlist:
|
|
30
87
|
|
|
31
88
|
Each step need to be implemented with tests!
|
|
32
89
|
|
|
90
|
+
- [x] Support Variants for ClassicUI or Volto
|
|
33
91
|
- [ ] Start Backend
|
|
34
92
|
- [x] deployment
|
|
35
93
|
- [x] service
|
|
36
94
|
- [x] pdb
|
|
37
|
-
- [ ] init container running plone-site-create
|
|
95
|
+
- [ ] init container running `plone-site-create`
|
|
38
96
|
- [x] lifecycle checks (readiness, liveness)
|
|
39
97
|
- [x] generic way to inject sidecars
|
|
98
|
+
- [ ] metrics sidecar
|
|
40
99
|
- [ ] Start Frontend
|
|
41
100
|
- [x] deployment
|
|
42
101
|
- [x] service
|
|
43
102
|
- [x] pdb
|
|
44
103
|
- [x] lifecycle checks (readiness, liveness)
|
|
45
|
-
- [ ] depend on ready/live backend (needed?)
|
|
46
104
|
- [x] generic way to inject sidecars
|
|
105
|
+
- [ ] metrics sidecar
|
|
106
|
+
- [x] Start Varnish (using `kube-httpcache`) optional in separate chart
|
|
107
|
+
- [x] provide a default VCL for Volto with routing to backend and frontend
|
|
108
|
+
- [ ] provide a default VCL for ClassicUI
|
|
109
|
+
- [ ] Configure Ingress, optional in separate chart
|
|
110
|
+
- [ ] Traefik
|
|
111
|
+
- [ ] Konq
|
|
47
112
|
|
|
48
|
-
- [
|
|
49
|
-
|
|
50
|
-
- [ ]
|
|
51
|
-
- [
|
|
52
|
-
- [ ] Check Java distribution
|
|
53
|
-
- [ ] Check Go distribution
|
|
113
|
+
- [ ] Release packages for other Languages
|
|
114
|
+
- [x] Python
|
|
115
|
+
- [ ] Golang
|
|
116
|
+
- [ ] Java
|
package/lib/httpcache.js
CHANGED
|
@@ -40,6 +40,7 @@ class PloneHttpcache extends constructs_1.Construct {
|
|
|
40
40
|
extraEnvVars: [
|
|
41
41
|
{ name: 'BACKEND_SERVICE_NAME', value: options.plone.backendServiceName },
|
|
42
42
|
{ name: 'BACKEND_SERVICE_PORT', value: '8080' },
|
|
43
|
+
{ name: 'BACKEND_SITE_ID', value: options.plone.siteId },
|
|
43
44
|
{ name: 'FRONTEND_SERVICE_NAME', value: options.plone.frontendServiceName },
|
|
44
45
|
{ name: 'FRONTEND_SERVICE_PORT', value: '3000' },
|
|
45
46
|
],
|
|
@@ -89,5 +90,5 @@ class PloneHttpcache extends constructs_1.Construct {
|
|
|
89
90
|
}
|
|
90
91
|
exports.PloneHttpcache = PloneHttpcache;
|
|
91
92
|
_a = JSII_RTTI_SYMBOL_1;
|
|
92
|
-
PloneHttpcache[_a] = { fqn: "@bluedynamics/cdk8s-plone.PloneHttpcache", version: "0.0.
|
|
93
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
93
|
+
PloneHttpcache[_a] = { fqn: "@bluedynamics/cdk8s-plone.PloneHttpcache", version: "0.0.19" };
|
|
94
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaHR0cGNhY2hlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vc3JjL2h0dHBjYWNoZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7OztBQUFBLHlCQUF5QjtBQUN6Qiw2QkFBNkI7QUFDN0IsaUNBQTZCO0FBQzdCLDJDQUF1QztBQWlDdkMsTUFBYSxjQUFlLFNBQVEsc0JBQVM7SUFJM0MsWUFBWSxLQUFnQixFQUFFLEVBQVUsRUFBRSxPQUE4QjtRQUN0RSxLQUFLLENBQUMsS0FBSyxFQUFFLEVBQUUsQ0FBQyxDQUFDO1FBQ2pCLElBQUksVUFBa0IsQ0FBQztRQUN2QixJQUFJLENBQUMsT0FBTyxDQUFDLFVBQVUsRUFBRSxDQUFDO1lBQ3hCLElBQUksT0FBZSxDQUFDO1lBQ3BCLElBQUksQ0FBQyxPQUFPLENBQUMsY0FBYyxFQUFFLENBQUM7Z0JBQzVCLE9BQU8sR0FBRyxJQUFJLENBQUMsSUFBSSxDQUFDLFNBQVMsRUFBRSxRQUFRLEVBQUUsaUJBQWlCLENBQUMsQ0FBQztZQUM5RCxDQUFDO2lCQUFNLENBQUM7Z0JBQ04sT0FBTyxHQUFHLE9BQU8sQ0FBQyxjQUFjLENBQUM7WUFDbkMsQ0FBQztZQUNELFVBQVUsR0FBRyxFQUFFLENBQUMsWUFBWSxDQUFDLE9BQU8sRUFBRSxNQUFNLENBQUMsQ0FBQztRQUNoRCxDQUFDO2FBQU0sQ0FBQztZQUNOLFVBQVUsR0FBRyxPQUFPLENBQUMsVUFBVSxDQUFDO1FBQ2xDLENBQUM7UUFDRCxNQUFNLFNBQVMsR0FBRyxJQUFJLFlBQUksQ0FBQyxJQUFJLEVBQUUsV0FBVyxFQUFFO1lBQzVDLHVEQUF1RDtZQUN2RCxJQUFJLEVBQUUsMEJBQTBCO1lBQ2hDLEtBQUssRUFBRSxnQkFBZ0I7WUFDdkIsTUFBTSxFQUFFO2dCQUNOLFlBQVksRUFBRSxDQUFDO2dCQUNmLEtBQUssRUFBRTtvQkFDTCxxREFBcUQ7b0JBQ3JELGFBQWEsRUFBRSxLQUFLO29CQUNwQixZQUFZLEVBQUUsS0FBSztvQkFDbkIsY0FBYyxFQUFFLE9BQU8sQ0FBQyxjQUFjLElBQUksU0FBUztpQkFDcEQ7Z0JBQ0QsV0FBVyxFQUFFLFVBQVU7Z0JBQ3ZCLFlBQVksRUFBRTtvQkFDWixFQUFFLElBQUksRUFBRSxzQkFBc0IsRUFBRSxLQUFLLEVBQUUsT0FBTyxDQUFDLEtBQUssQ0FBQyxrQkFBa0IsRUFBRTtvQkFDekUsRUFBRSxJQUFJLEVBQUUsc0JBQXNCLEVBQUUsS0FBSyxFQUFFLE1BQU0sRUFBRTtvQkFDL0MsRUFBRSxJQUFJLEVBQUUsaUJBQWlCLEVBQUUsS0FBSyxFQUFFLE9BQU8sQ0FBQyxLQUFLLENBQUMsTUFBTSxFQUFFO29CQUN4RCxFQUFFLElBQUksRUFBRSx1QkFBdUIsRUFBRSxLQUFLLEVBQUUsT0FBTyxDQUFDLEtBQUssQ0FBQyxtQkFBbUIsRUFBRTtvQkFDM0UsRUFBRSxJQUFJLEVBQUUsdUJBQXVCLEVBQUUsS0FBSyxFQUFFLE1BQU0sRUFBRTtpQkFDakQ7Z0JBQ0QsU0FBUyxFQUFFO29CQUNULE1BQU0sRUFBRTt3QkFDTixHQUFHLEVBQUUsT0FBTyxDQUFDLFFBQVEsSUFBSSxNQUFNO3dCQUMvQixNQUFNLEVBQUUsT0FBTyxDQUFDLFdBQVcsSUFBSSxPQUFPO3FCQUN2QztvQkFDRCxRQUFRLEVBQUU7d0JBQ1IsR0FBRyxFQUFFLE9BQU8sQ0FBQyxVQUFVLElBQUksTUFBTTt3QkFDakMsTUFBTSxFQUFFLE9BQU8sQ0FBQyxhQUFhLElBQUksT0FBTztxQkFDekM7aUJBQ0Y7Z0JBQ0QsSUFBSSxFQUFFO29CQUNKLE9BQU8sRUFBRSxLQUFLO2lCQUNmO2dCQUNELFFBQVEsRUFBRTtvQkFDUixPQUFPLEVBQUUsSUFBSTtvQkFDYixTQUFTLEVBQUU7d0JBQ1QsTUFBTSxFQUFFOzRCQUNOLEdBQUcsRUFBRSxNQUFNOzRCQUNYLE1BQU0sRUFBRSxPQUFPO3lCQUNoQjt3QkFDRCxRQUFRLEVBQUU7NEJBQ1IsR0FBRyxFQUFFLEtBQUs7NEJBQ1YsTUFBTSxFQUFFLE1BQU07eUJBQ2Y7cUJBQ0Y7aUJBQ0Y7Z0JBQ0QsY0FBYyxFQUFFO29CQUNkLE9BQU8sRUFBRSxJQUFJO29CQUNiLGVBQWUsRUFBRSxJQUFJO2lCQUN0QjthQUNGO1NBQ0YsQ0FBQyxDQUFDO1FBQ0gsTUFBTSxnQkFBZ0IsR0FBRyxTQUFTLENBQUMsVUFBVSxDQUFDLElBQUksQ0FBQyxDQUFDLFNBQVMsRUFBRSxFQUFFO1lBQy9ELElBQUksQ0FBQyxTQUFTLENBQUMsSUFBSSxLQUFLLFNBQVMsQ0FBQyxJQUFJLENBQUMsU0FBUyxDQUFDLFFBQVEsQ0FBQyxJQUFJLEVBQUUsUUFBUSxDQUFDLGdCQUFnQixDQUFDLENBQUMsRUFBRSxDQUFDO2dCQUM1RixPQUFPLFNBQVMsQ0FBQyxJQUFJLENBQUM7WUFDeEIsQ0FBQztZQUNELE9BQU8sU0FBUyxDQUFDO1FBQ25CLENBQUMsQ0FBQyxDQUFDO1FBQ0gsSUFBSSxnQkFBZ0IsS0FBSyxTQUFTLEVBQUUsQ0FBQztZQUNuQyxNQUFNLElBQUksS0FBSyxDQUFDLGtDQUFrQyxDQUFDLENBQUM7UUFDdEQsQ0FBQztRQUNELElBQUksQ0FBQyxvQkFBb0IsR0FBRyxnQkFBZ0IsQ0FBQyxJQUFJLENBQUM7SUFDcEQsQ0FBQzs7QUFoRkgsd0NBaUZDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0ICogYXMgZnMgZnJvbSAnZnMnO1xuaW1wb3J0ICogYXMgcGF0aCBmcm9tICdwYXRoJztcbmltcG9ydCB7IEhlbG0gfSBmcm9tICdjZGs4cyc7XG5pbXBvcnQgeyBDb25zdHJ1Y3QgfSBmcm9tICdjb25zdHJ1Y3RzJztcbmltcG9ydCB7IFBsb25lIH0gZnJvbSAnLi9wbG9uZSc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgUGxvbmVIdHRwY2FjaGVPcHRpb25zIHtcbiAgLyoqXG4gICAqIHBsb25lIGNoYXJ0XG4gICAqIEBkZWZhdWx0IC0gbm9uZVxuICAgKi9cbiAgcmVhZG9ubHkgcGxvbmU6IFBsb25lO1xuXG4gIC8qKiB2YXJuaXNoVmNsXG4gICAqIEBkZWZhdWx0IC0gZmlsZSBpbiBjb25maWcgZm9sZGVyXG4gICAqL1xuICByZWFkb25seSB2YXJuaXNoVmNsPzogc3RyaW5nO1xuXG4gIC8qKiB2YXJuaXNoVmNsRmlsZVxuICAgKiBAZGVmYXVsdCAtIHVuZGVmaW5lZFxuICAgKi9cbiAgcmVhZG9ubHkgdmFybmlzaFZjbEZpbGU/OiBzdHJpbmcgfCB1bmRlZmluZWQ7XG5cbiAgLyoqIGV4aXN0aW5nU2VjcmV0IC0gUmVhZCBhZG1pbiBjcmVkZW50aWFscyBmcm9tIHVzZXIgcHJvdmlkZWQgc2VjcmV0XG4gICAqIEBkZWZhdWx0IC0gdW5kZWZpbmVkXG4gICovXG4gIHJlYWRvbmx5IGV4aXN0aW5nU2VjcmV0Pzogc3RyaW5nO1xuXG5cbiAgLy8gcmVzb3VyY2VzXG4gIHJlYWRvbmx5IGxpbWl0Q3B1Pzogc3RyaW5nO1xuICByZWFkb25seSBsaW1pdE1lbW9yeT86IHN0cmluZztcbiAgcmVhZG9ubHkgcmVxdWVzdENwdT86IHN0cmluZztcbiAgcmVhZG9ubHkgcmVxdWVzdE1lbW9yeT86IHN0cmluZztcbn1cblxuZXhwb3J0IGNsYXNzIFBsb25lSHR0cGNhY2hlIGV4dGVuZHMgQ29uc3RydWN0IHtcblxuICBwdWJsaWMgcmVhZG9ubHkgaHR0cGNhY2hlU2VydmljZU5hbWU6IHN0cmluZztcblxuICBjb25zdHJ1Y3RvcihzY29wZTogQ29uc3RydWN0LCBpZDogc3RyaW5nLCBvcHRpb25zOiBQbG9uZUh0dHBjYWNoZU9wdGlvbnMpIHtcbiAgICBzdXBlcihzY29wZSwgaWQpO1xuICAgIGxldCB2YXJuaXNoVmNsOiBzdHJpbmc7XG4gICAgaWYgKCFvcHRpb25zLnZhcm5pc2hWY2wpIHtcbiAgICAgIGxldCB2Y2xQYXRoOiBzdHJpbmc7XG4gICAgICBpZiAoIW9wdGlvbnMudmFybmlzaFZjbEZpbGUpIHtcbiAgICAgICAgdmNsUGF0aCA9IHBhdGguam9pbihfX2Rpcm5hbWUsICdjb25maWcnLCAndmFybmlzaC50cGwudmNsJyk7XG4gICAgICB9IGVsc2Uge1xuICAgICAgICB2Y2xQYXRoID0gb3B0aW9ucy52YXJuaXNoVmNsRmlsZTtcbiAgICAgIH1cbiAgICAgIHZhcm5pc2hWY2wgPSBmcy5yZWFkRmlsZVN5bmModmNsUGF0aCwgJ3V0ZjgnKTtcbiAgICB9IGVsc2Uge1xuICAgICAgdmFybmlzaFZjbCA9IG9wdGlvbnMudmFybmlzaFZjbDtcbiAgICB9XG4gICAgY29uc3QgaHR0cGNhY2hlID0gbmV3IEhlbG0odGhpcywgJ2h0dHBjYWNoZScsIHtcbiAgICAgIC8vIHNlZSBodHRwczovL2dpdGh1Yi5jb20vbWl0dHdhbGQva3ViZS1odHRwY2FjaGUvY2hhcnRcbiAgICAgIHJlcG86ICdodHRwczovL2hlbG0ubWl0dHdhbGQuZGUnLFxuICAgICAgY2hhcnQ6ICdrdWJlLWh0dHBjYWNoZScsXG4gICAgICB2YWx1ZXM6IHtcbiAgICAgICAgcmVwbGljYUNvdW50OiAyLFxuICAgICAgICBjYWNoZToge1xuICAgICAgICAgIC8vIG5lZWQgdG8gbG9va3MgYXQgdGhlIGZyb250ZW5kV2F0Y2gsIGRvIHdlIG5lZWQgaXQ/XG4gICAgICAgICAgZnJvbnRlbmRXYXRjaDogZmFsc2UsXG4gICAgICAgICAgYmFja2VuZFdhdGNoOiBmYWxzZSxcbiAgICAgICAgICBleGlzdGluZ1NlY3JldDogb3B0aW9ucy5leGlzdGluZ1NlY3JldCA/PyB1bmRlZmluZWQsXG4gICAgICAgIH0sXG4gICAgICAgIHZjbFRlbXBsYXRlOiB2YXJuaXNoVmNsLFxuICAgICAgICBleHRyYUVudlZhcnM6IFtcbiAgICAgICAgICB7IG5hbWU6ICdCQUNLRU5EX1NFUlZJQ0VfTkFNRScsIHZhbHVlOiBvcHRpb25zLnBsb25lLmJhY2tlbmRTZXJ2aWNlTmFtZSB9LFxuICAgICAgICAgIHsgbmFtZTogJ0JBQ0tFTkRfU0VSVklDRV9QT1JUJywgdmFsdWU6ICc4MDgwJyB9LFxuICAgICAgICAgIHsgbmFtZTogJ0JBQ0tFTkRfU0lURV9JRCcsIHZhbHVlOiBvcHRpb25zLnBsb25lLnNpdGVJZCB9LFxuICAgICAgICAgIHsgbmFtZTogJ0ZST05URU5EX1NFUlZJQ0VfTkFNRScsIHZhbHVlOiBvcHRpb25zLnBsb25lLmZyb250ZW5kU2VydmljZU5hbWUgfSxcbiAgICAgICAgICB7IG5hbWU6ICdGUk9OVEVORF9TRVJWSUNFX1BPUlQnLCB2YWx1ZTogJzMwMDAnIH0sXG4gICAgICAgIF0sXG4gICAgICAgIHJlc291cmNlczoge1xuICAgICAgICAgIGxpbWl0czoge1xuICAgICAgICAgICAgY3B1OiBvcHRpb25zLmxpbWl0Q3B1IHx8ICc1MDBtJyxcbiAgICAgICAgICAgIG1lbW9yeTogb3B0aW9ucy5saW1pdE1lbW9yeSB8fCAnNTAwTWknLFxuICAgICAgICAgIH0sXG4gICAgICAgICAgcmVxdWVzdHM6IHtcbiAgICAgICAgICAgIGNwdTogb3B0aW9ucy5yZXF1ZXN0Q3B1IHx8ICcxMDBtJyxcbiAgICAgICAgICAgIG1lbW9yeTogb3B0aW9ucy5yZXF1ZXN0TWVtb3J5IHx8ICcxMDBNaScsXG4gICAgICAgICAgfSxcbiAgICAgICAgfSxcbiAgICAgICAgcmJhYzoge1xuICAgICAgICAgIGVuYWJsZWQ6IGZhbHNlLFxuICAgICAgICB9LFxuICAgICAgICBleHBvcnRlcjoge1xuICAgICAgICAgIGVuYWJsZWQ6IHRydWUsXG4gICAgICAgICAgcmVzb3VyY2VzOiB7XG4gICAgICAgICAgICBsaW1pdHM6IHtcbiAgICAgICAgICAgICAgY3B1OiAnMTAwbScsXG4gICAgICAgICAgICAgIG1lbW9yeTogJzEwME1pJyxcbiAgICAgICAgICAgIH0sXG4gICAgICAgICAgICByZXF1ZXN0czoge1xuICAgICAgICAgICAgICBjcHU6ICcxMG0nLFxuICAgICAgICAgICAgICBtZW1vcnk6ICc1ME1pJyxcbiAgICAgICAgICAgIH0sXG4gICAgICAgICAgfSxcbiAgICAgICAgfSxcbiAgICAgICAgc2VydmljZU1vbml0b3I6IHtcbiAgICAgICAgICBlbmFibGVkOiB0cnVlLFxuICAgICAgICAgIHNjcmFwZVNpZ25hbGxlcjogdHJ1ZSxcbiAgICAgICAgfSxcbiAgICAgIH0sXG4gICAgfSk7XG4gICAgY29uc3QgaHR0cGNhY2hlU2VydmljZSA9IGh0dHBjYWNoZS5hcGlPYmplY3RzLmZpbmQoKGNvbnN0cnVjdCkgPT4ge1xuICAgICAgaWYgKChjb25zdHJ1Y3Qua2luZCA9PT0gJ1NlcnZpY2UnKSAmJiAoY29uc3RydWN0Lm1ldGFkYXRhLm5hbWU/LmVuZHNXaXRoKCdrdWJlLWh0dHBjYWNoZScpKSkge1xuICAgICAgICByZXR1cm4gY29uc3RydWN0Lm5hbWU7XG4gICAgICB9XG4gICAgICByZXR1cm4gdW5kZWZpbmVkO1xuICAgIH0pO1xuICAgIGlmIChodHRwY2FjaGVTZXJ2aWNlID09PSB1bmRlZmluZWQpIHtcbiAgICAgIHRocm93IG5ldyBFcnJvcignQ291bGQgbm90IGZpbmQgaHR0cGNhY2hlIHNlcnZpY2UnKTtcbiAgICB9XG4gICAgdGhpcy5odHRwY2FjaGVTZXJ2aWNlTmFtZSA9IGh0dHBjYWNoZVNlcnZpY2UubmFtZTtcbiAgfVxufSJdfQ==
|
package/lib/index.d.ts
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
export { Plone, PloneOptions, PloneBaseOptions } from './plone';
|
|
1
|
+
export { Plone, PloneOptions, PloneBaseOptions, PloneVariant } from './plone';
|
|
2
2
|
export { PloneHttpcache, PloneHttpcacheOptions } from './httpcache';
|
package/lib/index.js
CHANGED
|
@@ -1,8 +1,9 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.PloneHttpcache = exports.Plone = void 0;
|
|
3
|
+
exports.PloneHttpcache = exports.PloneVariant = 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
|
+
Object.defineProperty(exports, "PloneVariant", { enumerable: true, get: function () { return plone_1.PloneVariant; } });
|
|
6
7
|
var httpcache_1 = require("./httpcache");
|
|
7
8
|
Object.defineProperty(exports, "PloneHttpcache", { enumerable: true, get: function () { return httpcache_1.PloneHttpcache; } });
|
|
8
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
9
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBQUEsaUNBQThFO0FBQXJFLDhGQUFBLEtBQUssT0FBQTtBQUFrQyxxR0FBQSxZQUFZLE9BQUE7QUFDNUQseUNBQW9FO0FBQTNELDJHQUFBLGNBQWMsT0FBQSIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCB7IFBsb25lLCBQbG9uZU9wdGlvbnMsIFBsb25lQmFzZU9wdGlvbnMsIFBsb25lVmFyaWFudCB9IGZyb20gJy4vcGxvbmUnO1xuZXhwb3J0IHsgUGxvbmVIdHRwY2FjaGUsIFBsb25lSHR0cGNhY2hlT3B0aW9ucyB9IGZyb20gJy4vaHR0cGNhY2hlJztcbiJdfQ==
|
package/lib/plone.d.ts
CHANGED
|
@@ -22,15 +22,22 @@ export interface PloneBaseOptions {
|
|
|
22
22
|
readonly livenessSuccessThreshold?: number;
|
|
23
23
|
readonly livenessFailureThreshold?: number;
|
|
24
24
|
}
|
|
25
|
+
export declare enum PloneVariant {
|
|
26
|
+
VOLTO = "volto",
|
|
27
|
+
CLASSICUI = "classicui"
|
|
28
|
+
}
|
|
25
29
|
export interface PloneOptions {
|
|
26
30
|
readonly version?: string;
|
|
27
31
|
readonly siteId?: string;
|
|
32
|
+
readonly variant?: PloneVariant;
|
|
28
33
|
readonly backend?: PloneBaseOptions;
|
|
29
34
|
readonly frontend?: PloneBaseOptions;
|
|
30
35
|
readonly imagePullSecrets?: string[];
|
|
31
36
|
}
|
|
32
37
|
export declare class Plone extends Construct {
|
|
33
38
|
readonly backendServiceName: string;
|
|
34
|
-
readonly frontendServiceName: string;
|
|
39
|
+
readonly frontendServiceName: string | undefined;
|
|
40
|
+
readonly variant: PloneVariant;
|
|
41
|
+
readonly siteId: string;
|
|
35
42
|
constructor(scope: Construct, id: string, options?: PloneOptions);
|
|
36
43
|
}
|
package/lib/plone.js
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
var _a;
|
|
3
3
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
4
|
-
exports.Plone = void 0;
|
|
4
|
+
exports.Plone = exports.PloneVariant = void 0;
|
|
5
5
|
const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
|
|
6
6
|
const cdk8s_1 = require("cdk8s");
|
|
7
7
|
const kplus = require("cdk8s-plus-24");
|
|
@@ -9,12 +9,17 @@ const constructs_1 = require("constructs");
|
|
|
9
9
|
const deployment_1 = require("./deployment");
|
|
10
10
|
const k8s_1 = require("./imports/k8s");
|
|
11
11
|
const service_1 = require("./service");
|
|
12
|
+
var PloneVariant;
|
|
13
|
+
(function (PloneVariant) {
|
|
14
|
+
PloneVariant["VOLTO"] = "volto";
|
|
15
|
+
PloneVariant["CLASSICUI"] = "classicui";
|
|
16
|
+
})(PloneVariant || (exports.PloneVariant = PloneVariant = {}));
|
|
12
17
|
class Plone extends constructs_1.Construct {
|
|
13
18
|
constructor(scope, id, options = {}) {
|
|
14
19
|
super(scope, id);
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
20
|
+
this.frontendServiceName = undefined;
|
|
21
|
+
this.siteId = options.siteId ?? 'Plone';
|
|
22
|
+
this.variant = options.variant ?? PloneVariant.VOLTO;
|
|
18
23
|
// ------------------------------------------------------------------------
|
|
19
24
|
// Backend
|
|
20
25
|
const backend = options.backend ?? {};
|
|
@@ -79,75 +84,77 @@ class Plone extends constructs_1.Construct {
|
|
|
79
84
|
this.backendServiceName = backendService.name;
|
|
80
85
|
// ------------------------------------------------------------------------
|
|
81
86
|
// Frontend
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
|
|
87
|
+
if (this.variant == PloneVariant.VOLTO) {
|
|
88
|
+
const frontend = options.frontend ?? {};
|
|
89
|
+
const frontendPort = 3000;
|
|
90
|
+
const frontendLabels = {
|
|
91
|
+
'app.kubernetes.io/name': 'plone-frontend',
|
|
92
|
+
'app.kubernetes.io/component': 'frontend',
|
|
93
|
+
'app.kubernetes.io/version': options.version ?? 'undefined',
|
|
94
|
+
};
|
|
95
|
+
// Probing
|
|
96
|
+
const frontendActionHttpGet = {
|
|
97
|
+
path: '/',
|
|
98
|
+
port: k8s_1.IntOrString.fromNumber(frontendPort),
|
|
99
|
+
};
|
|
100
|
+
const frontendLivenessProbe = {
|
|
101
|
+
httpGet: frontendActionHttpGet,
|
|
102
|
+
initialDelaySeconds: frontend.livenessInitialDelaySeconds ?? 30,
|
|
103
|
+
timeoutSeconds: frontend.livenessIimeoutSeconds ?? 5,
|
|
104
|
+
periodSeconds: frontend.livenessPeriodSeconds ?? 10,
|
|
105
|
+
successThreshold: frontend.livenessSuccessThreshold ?? 1,
|
|
106
|
+
failureThreshold: frontend.livenessFailureThreshold ?? 3,
|
|
107
|
+
};
|
|
108
|
+
const frontendReadinessProbe = {
|
|
109
|
+
httpGet: frontendActionHttpGet,
|
|
110
|
+
initialDelaySeconds: frontend.readinessInitialDelaySeconds ?? 10,
|
|
111
|
+
timeoutSeconds: frontend.readinessIimeoutSeconds ?? 15,
|
|
112
|
+
periodSeconds: frontend.readinessPeriodSeconds ?? 10,
|
|
113
|
+
successThreshold: frontend.readinessSuccessThreshold ?? 1,
|
|
114
|
+
failureThreshold: frontend.readinessFailureThreshold ?? 3,
|
|
115
|
+
};
|
|
116
|
+
// Environment for RAZZLE
|
|
117
|
+
var frontendEnvironment = frontend.environment ?? new kplus.Env([], {});
|
|
118
|
+
if (frontendEnvironment.variables.RAZZLE_INTERNAL_API_PATH === undefined) {
|
|
119
|
+
// connect with backend service
|
|
120
|
+
frontendEnvironment?.addVariable('RAZZLE_INTERNAL_API_PATH', kplus.EnvValue.fromValue(`http://${backendService.name}:${backendPort}/${this.siteId}`));
|
|
121
|
+
}
|
|
122
|
+
// Deployment
|
|
123
|
+
const frontendDeployment = new deployment_1.PloneDeployment(this, 'frontend', {
|
|
124
|
+
labels: frontendLabels,
|
|
125
|
+
image: {
|
|
126
|
+
image: frontend.image ?? 'plone/plone-frontend:latest',
|
|
127
|
+
imagePullSecrets: options.imagePullSecrets ?? [],
|
|
128
|
+
imagePullPolicy: frontend.imagePullPolicy ?? 'IfNotPresent',
|
|
129
|
+
},
|
|
130
|
+
replicas: frontend.replicas,
|
|
131
|
+
limitCpu: frontend.limitCpu ?? '500m',
|
|
132
|
+
limitMemory: frontend.limitMemory ?? '1Gi',
|
|
133
|
+
requestCpu: backend.requestCpu ?? '200m',
|
|
134
|
+
requestMemory: backend.requestMemory ?? '256Mi',
|
|
135
|
+
pdb: {
|
|
136
|
+
maxUnavailable: frontend.maxUnavailable ?? undefined,
|
|
137
|
+
minAvailable: frontend.minAvailable ?? undefined,
|
|
138
|
+
},
|
|
139
|
+
port: frontendPort,
|
|
140
|
+
environment: frontendEnvironment,
|
|
141
|
+
livenessProbe: frontendLivenessProbe,
|
|
142
|
+
readinessProbe: frontendReadinessProbe,
|
|
143
|
+
});
|
|
144
|
+
// Service
|
|
145
|
+
const frontendService = new service_1.PloneService(frontendDeployment, 'service', {
|
|
146
|
+
labels: {
|
|
147
|
+
'app.kubernetes.io/name': 'plone-frontend-service',
|
|
148
|
+
'app.kubernetes.io/component': 'service',
|
|
149
|
+
},
|
|
150
|
+
targetPort: frontendPort,
|
|
151
|
+
selectorLabel: { app: cdk8s_1.Names.toLabelValue(frontendDeployment) },
|
|
152
|
+
});
|
|
153
|
+
this.frontendServiceName = frontendService.name;
|
|
115
154
|
}
|
|
116
|
-
// Deployment
|
|
117
|
-
const frontendDeployment = new deployment_1.PloneDeployment(this, 'frontend', {
|
|
118
|
-
labels: frontendLabels,
|
|
119
|
-
image: {
|
|
120
|
-
image: frontend.image ?? 'plone/plone-frontend:latest',
|
|
121
|
-
imagePullSecrets: options.imagePullSecrets ?? [],
|
|
122
|
-
imagePullPolicy: frontend.imagePullPolicy ?? 'IfNotPresent',
|
|
123
|
-
},
|
|
124
|
-
replicas: frontend.replicas,
|
|
125
|
-
limitCpu: frontend.limitCpu ?? '500m',
|
|
126
|
-
limitMemory: frontend.limitMemory ?? '1Gi',
|
|
127
|
-
requestCpu: backend.requestCpu ?? '200m',
|
|
128
|
-
requestMemory: backend.requestMemory ?? '256Mi',
|
|
129
|
-
pdb: {
|
|
130
|
-
maxUnavailable: frontend.maxUnavailable ?? undefined,
|
|
131
|
-
minAvailable: frontend.minAvailable ?? undefined,
|
|
132
|
-
},
|
|
133
|
-
port: frontendPort,
|
|
134
|
-
environment: frontendEnvironment,
|
|
135
|
-
livenessProbe: frontendLivenessProbe,
|
|
136
|
-
readinessProbe: frontendReadinessProbe,
|
|
137
|
-
});
|
|
138
|
-
// Service
|
|
139
|
-
const frontendService = new service_1.PloneService(frontendDeployment, 'service', {
|
|
140
|
-
labels: {
|
|
141
|
-
'app.kubernetes.io/name': 'plone-frontend-service',
|
|
142
|
-
'app.kubernetes.io/component': 'service',
|
|
143
|
-
},
|
|
144
|
-
targetPort: frontendPort,
|
|
145
|
-
selectorLabel: { app: cdk8s_1.Names.toLabelValue(frontendDeployment) },
|
|
146
|
-
});
|
|
147
|
-
this.frontendServiceName = frontendService.name;
|
|
148
155
|
}
|
|
149
156
|
}
|
|
150
157
|
exports.Plone = Plone;
|
|
151
158
|
_a = JSII_RTTI_SYMBOL_1;
|
|
152
|
-
Plone[_a] = { fqn: "@bluedynamics/cdk8s-plone.Plone", version: "0.0.
|
|
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}"]}
|
|
159
|
+
Plone[_a] = { fqn: "@bluedynamics/cdk8s-plone.Plone", version: "0.0.19" };
|
|
160
|
+
//# 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 enum PloneVariant {\n  VOLTO = 'volto',\n  CLASSICUI = 'classicui',\n}\nexport interface PloneOptions {\n  readonly version?: string;\n  readonly siteId?: string;\n  readonly variant?: PloneVariant;\n  readonly backend?: PloneBaseOptions;\n  readonly frontend?: PloneBaseOptions;\n  readonly imagePullSecrets?: string[];\n\n}\n\nexport class Plone extends Construct {\n  /* Create all elements for a Plone deployment in Kubernetes\n    * there are two variants of Plone deployment:\n      - \"volto\": frontend and backend and frontend, default (reactjs rendered HTML)\n      - \"classicui: backend only (SSR HTML)\n\n    * @param scope - Construct scope\n    * @param id - Construct id\n    * @param options - PloneOptions\n    */\n  public readonly backendServiceName: string;\n  public readonly frontendServiceName: string | undefined;\n  public readonly variant: PloneVariant;\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    // 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    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      // 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}/${this.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  }\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.
|
|
43
|
+
"cdk8s": "^2.68.94",
|
|
44
44
|
"cdk8s-plus-24": "^2.12.1",
|
|
45
45
|
"constructs": "^10.0.0",
|
|
46
46
|
"eslint": "^8",
|
|
@@ -61,12 +61,12 @@
|
|
|
61
61
|
"yaml": "^2.5.0"
|
|
62
62
|
},
|
|
63
63
|
"peerDependencies": {
|
|
64
|
-
"cdk8s": "^2.68.
|
|
64
|
+
"cdk8s": "^2.68.94",
|
|
65
65
|
"cdk8s-plus-24": "^2.12.1",
|
|
66
66
|
"constructs": "^10.3.0"
|
|
67
67
|
},
|
|
68
68
|
"dependencies": {
|
|
69
|
-
"cdk8s": "^2.68.
|
|
69
|
+
"cdk8s": "^2.68.94",
|
|
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.
|
|
78
|
+
"version": "0.0.19",
|
|
79
79
|
"jest": {
|
|
80
80
|
"coverageProvider": "v8",
|
|
81
81
|
"testMatch": [
|