@bluedynamics/cdk8s-plone 0.0.64 → 0.0.66

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 (as 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\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## 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### Prerequisites\n\nFor using cdk8s-plone, we assume you already have following tools installed:\n\n* kubectl – A command-line tool for interacting with Kubernetes clusters. For deploying the Kubernetes manifest you will need a tool like this. Take a look at the [Install Tools](https://kubernetes.io/docs/tasks/tools/#kubectl) for kubectl.\n\n* (optional) Helm – A Kubernetes package manager for managing Plone/Volto deployments. This tool is optional and only needed if you generate helm charts as output with cdk8s synth - instead of pure manifests. There are several ways to install it see the [install section](https://helm.sh/docs/intro/install/) for Helm.\n\n### References\n[Kubernetes Documentation](https://kubernetes.io/docs/concepts/configuration/liveness-readiness-startup-probes/) relevant for ressource management, readiness and liveness\n\n#### PloneBaseOptions\n*Interface*\n\n\n\n- `image`(string):\n - The used Plone image\n - e.g. `plone/plone-backend:6.1.0`\n- `imagePullPolicy`(string):\n - default `IfNotPresent`\n- `replicas`(numbers)\n- `maxUnavailable`(number|string)\n- `minAvailable`(number|string)\n- `limitCpu`(string)\n- `limitMemory`(string)\n- `requestCpu`(string)\n- `requestMemory`(string)\n- `environment`(kplus.Env)\n- `readinessEnabled`(boolean)\n- `readinessInitialDelaySeconds`(number)\n- `readinessIimeoutSeconds`(number)\n- `readinessPeriodSeconds`(number)\n- `readinessSuccessThreshold`(number)\n- `readinessFailureThreshold`(number)\n- `livenessEnabled`(boolean)\n - should be `true` for `volto`\n - should be `false` for `backend/classicui`\n- `livenessInitialDelaySeconds`(number)\n- `livenessIimeoutSeconds`(number)\n- `livenessPeriodSeconds`(number)\n- `livenessSuccessThreshold`(number)\n- `livenessFailureThreshold`(number)\n\n\n#### PloneOptions\n*Interface*\n\n- `version`(string):\n - version of your project\n- `siteId`(string):\n - default `Plone`\n- `variant`(PloneVariant):\n - default `PloneVariant.VOLTO`\n- `backend` (PloneBaseOptions):\n - default `{}`\n - needs `image` and `enviroment`\n- `frontend` (PloneBaseOptions):\n - default `{}`\n - needs `image` if `PloneVariant.VOLTO`\n- `imagePullSecrets`(string[])\n\n#### PloneVariants\n*Enum*\n\n- VOLTO = 'volto'\n- CLASSICUI = 'classicui'\n - no frontend options/image needed\n\n#### Plone\n*class*\n\nbuilds the `Plone` Construct\n\n- `backendServiceName`(string)\n- `frontendServiceName`(string)\n- `variant`(PloneVariant)\n - default `Volto`\n- `siteId`(string)\n - default `Plone`\n\n#### PloneHttpcacheOptions\n*Interface*\n\n- `plone`(Plone):\n - Plone chart\n- `varnishVcl`{string}:\n - varnishfile\n - per default `varnishVclFile` should be used\n- `varnishVclFile`(string):\n - File in config folder\n- `existingSecret`(string)\n- `limitCpu`(string)\n- `limitMemory`(string)\n- `requestCpu`(string)\n- `requestMemory`(string)\n\n#### PloneHttpcache\n*class*\n\nuses helmchart [kube-httpcache](https://github.com/mittwald/kube-httpcache) and builds the `PloneHttpCache` Construct\n- `scope`(Construct)\n- `id`(string)\n- `options`(PloneHttpcacheOptions)\n\n\n## Development\n\nClone the repository and install the dependencies:\n\n```bash\nnvm use lts/*\ncorepack enable\nnpx projen\n```\n\nThen run the following command to run the test:\n\n```bash\nnpx projen test\n```\n\n## ToDo\n- [ ] Option to enable Servicemonitor"
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 (as 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\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```\nRun `npm install` to install [cdk8s-plone](https://www.npmjs.com/package/@bluedynamics/cdk8s-plone).\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## 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### Prerequisites\n\nFor using cdk8s-plone, we assume you already have following tools installed:\n\n* kubectl – A command-line tool for interacting with Kubernetes clusters. For deploying the Kubernetes manifest you will need a tool like this. Take a look at the [Install Tools](https://kubernetes.io/docs/tasks/tools/#kubectl) for kubectl.\n\n* (optional) Helm – A Kubernetes package manager for managing Plone/Volto deployments. This tool is optional and only needed if you generate helm charts as output with cdk8s synth - instead of pure manifests. There are several ways to install it see the [install section](https://helm.sh/docs/intro/install/) for Helm.\n\n\n### References\n[Kubernetes Documentation](https://kubernetes.io/docs/concepts/configuration/liveness-readiness-startup-probes/) relevant for ressource management, readiness and liveness\n\n#### PloneBaseOptions\n*Interface*\n\n\n\n- `image`(string):\n - The used Plone image\n - e.g. `plone/plone-backend:6.1.0`\n- `imagePullPolicy`(string):\n - default `IfNotPresent`\n- `replicas`(numbers)\n- `maxUnavailable`(number|string)\n- `minAvailable`(number|string)\n- `limitCpu`(string)\n- `limitMemory`(string)\n- `requestCpu`(string)\n- `requestMemory`(string)\n- `environment`(kplus.Env)\n- `readinessEnabled`(boolean)\n- `readinessInitialDelaySeconds`(number)\n- `readinessIimeoutSeconds`(number)\n- `readinessPeriodSeconds`(number)\n- `readinessSuccessThreshold`(number)\n- `readinessFailureThreshold`(number)\n- `livenessEnabled`(boolean)\n - should be `true` for `volto`\n - should be `false` for `backend/classicui`\n- `livenessInitialDelaySeconds`(number)\n- `livenessIimeoutSeconds`(number)\n- `livenessPeriodSeconds`(number)\n- `livenessSuccessThreshold`(number)\n- `livenessFailureThreshold`(number)\n\n\n#### PloneOptions\n*Interface*\n\n- `version`(string):\n - version of your project\n- `siteId`(string):\n - default `Plone`\n- `variant`(PloneVariant):\n - default `PloneVariant.VOLTO`\n- `backend` (PloneBaseOptions):\n - default `{}`\n - needs `image` and `enviroment`\n- `frontend` (PloneBaseOptions):\n - default `{}`\n - needs `image` if `PloneVariant.VOLTO`\n- `imagePullSecrets`(string[])\n\n#### PloneVariants\n*Enum*\n\n- VOLTO = 'volto'\n- CLASSICUI = 'classicui'\n - no frontend options/image needed\n\n#### Plone\n*class*\n\nbuilds the `Plone` Construct\n\n- `backendServiceName`(string)\n- `frontendServiceName`(string)\n- `variant`(PloneVariant)\n - default `Volto`\n- `siteId`(string)\n - default `Plone`\n\n#### PloneHttpcacheOptions\n*Interface*\n\n- `plone`(Plone):\n - Plone chart\n- `varnishVcl`{string}:\n - varnishfile\n - per default `varnishVclFile` should be used\n- `varnishVclFile`(string):\n - File in config folder\n- `existingSecret`(string)\n- `limitCpu`(string)\n- `limitMemory`(string)\n- `requestCpu`(string)\n- `requestMemory`(string)\n- `servicemonitor`(string)\n - default `false` used for metrics\n\n#### PloneHttpcache\n*class*\n\nuses helmchart [kube-httpcache](https://github.com/mittwald/kube-httpcache) and builds the `PloneHttpCache` Construct\n- `scope`(Construct)\n- `id`(string)\n- `options`(PloneHttpcacheOptions)\n\n\n## Development\n\nClone the repository and install the dependencies:\n\n```bash\nnvm use lts/*\ncorepack enable\nnpx projen\n```\n\nThen run the following command to run the test:\n\n```bash\nnpx projen test\n```\n\n## ToDo\n- [ ] Option to enable Servicemonitor"
112
112
  },
113
113
  "repository": {
114
114
  "type": "git",
@@ -629,7 +629,7 @@
629
629
  },
630
630
  "locationInModule": {
631
631
  "filename": "src/httpcache.ts",
632
- "line": 41
632
+ "line": 43
633
633
  },
634
634
  "parameters": [
635
635
  {
@@ -655,7 +655,7 @@
655
655
  "kind": "class",
656
656
  "locationInModule": {
657
657
  "filename": "src/httpcache.ts",
658
- "line": 37
658
+ "line": 39
659
659
  },
660
660
  "name": "PloneHttpcache",
661
661
  "properties": [
@@ -666,7 +666,7 @@
666
666
  "immutable": true,
667
667
  "locationInModule": {
668
668
  "filename": "src/httpcache.ts",
669
- "line": 39
669
+ "line": 41
670
670
  },
671
671
  "name": "httpcacheServiceName",
672
672
  "type": {
@@ -789,6 +789,22 @@
789
789
  "primitive": "string"
790
790
  }
791
791
  },
792
+ {
793
+ "abstract": true,
794
+ "docs": {
795
+ "stability": "stable"
796
+ },
797
+ "immutable": true,
798
+ "locationInModule": {
799
+ "filename": "src/httpcache.ts",
800
+ "line": 36
801
+ },
802
+ "name": "servicemonitor",
803
+ "optional": true,
804
+ "type": {
805
+ "primitive": "boolean"
806
+ }
807
+ },
792
808
  {
793
809
  "abstract": true,
794
810
  "docs": {
@@ -975,6 +991,6 @@
975
991
  "symbolId": "src/plone:PloneVariant"
976
992
  }
977
993
  },
978
- "version": "0.0.64",
979
- "fingerprint": "5ycIqTOju9OBHIsTkXQV9qUgFhBSR9RhZv+9CRtRYGM="
994
+ "version": "0.0.66",
995
+ "fingerprint": "844GXZ7wHQcUXZVKc/exo62OhxNZlpPGYVwa4l8RYhA="
980
996
  }
package/API.md CHANGED
@@ -564,6 +564,7 @@ const ploneHttpcacheOptions: PloneHttpcacheOptions = { ... }
564
564
  | <code><a href="#@bluedynamics/cdk8s-plone.PloneHttpcacheOptions.property.limitMemory">limitMemory</a></code> | <code>string</code> | *No description.* |
565
565
  | <code><a href="#@bluedynamics/cdk8s-plone.PloneHttpcacheOptions.property.requestCpu">requestCpu</a></code> | <code>string</code> | *No description.* |
566
566
  | <code><a href="#@bluedynamics/cdk8s-plone.PloneHttpcacheOptions.property.requestMemory">requestMemory</a></code> | <code>string</code> | *No description.* |
567
+ | <code><a href="#@bluedynamics/cdk8s-plone.PloneHttpcacheOptions.property.servicemonitor">servicemonitor</a></code> | <code>boolean</code> | *No description.* |
567
568
  | <code><a href="#@bluedynamics/cdk8s-plone.PloneHttpcacheOptions.property.varnishVcl">varnishVcl</a></code> | <code>string</code> | varnishVcl. |
568
569
  | <code><a href="#@bluedynamics/cdk8s-plone.PloneHttpcacheOptions.property.varnishVclFile">varnishVclFile</a></code> | <code>string</code> | varnishVclFile. |
569
570
 
@@ -635,6 +636,16 @@ public readonly requestMemory: string;
635
636
 
636
637
  ---
637
638
 
639
+ ##### `servicemonitor`<sup>Optional</sup> <a name="servicemonitor" id="@bluedynamics/cdk8s-plone.PloneHttpcacheOptions.property.servicemonitor"></a>
640
+
641
+ ```typescript
642
+ public readonly servicemonitor: boolean;
643
+ ```
644
+
645
+ - *Type:* boolean
646
+
647
+ ---
648
+
638
649
  ##### `varnishVcl`<sup>Optional</sup> <a name="varnishVcl" id="@bluedynamics/cdk8s-plone.PloneHttpcacheOptions.property.varnishVcl"></a>
639
650
 
640
651
  ```typescript
package/README.md CHANGED
@@ -25,8 +25,7 @@ Then add the following dependency to `package.json`:
25
25
  }
26
26
  }
27
27
  ```
28
-
29
- Run `npm install` to install the new dependency.
28
+ Run `npm install` to install [cdk8s-plone](https://www.npmjs.com/package/@bluedynamics/cdk8s-plone).
30
29
 
31
30
  ### Python
32
31
 
@@ -73,6 +72,7 @@ For using cdk8s-plone, we assume you already have following tools installed:
73
72
 
74
73
  * (optional) Helm – A Kubernetes package manager for managing Plone/Volto deployments. This tool is optional and only needed if you generate helm charts as output with cdk8s synth - instead of pure manifests. There are several ways to install it see the [install section](https://helm.sh/docs/intro/install/) for Helm.
75
74
 
75
+
76
76
  ### References
77
77
  [Kubernetes Documentation](https://kubernetes.io/docs/concepts/configuration/liveness-readiness-startup-probes/) relevant for ressource management, readiness and liveness
78
78
 
@@ -161,6 +161,8 @@ builds the `Plone` Construct
161
161
  - `limitMemory`(string)
162
162
  - `requestCpu`(string)
163
163
  - `requestMemory`(string)
164
+ - `servicemonitor`(string)
165
+ - default `false` used for metrics
164
166
 
165
167
  #### PloneHttpcache
166
168
  *class*
@@ -22,6 +22,7 @@ export interface PloneHttpcacheOptions {
22
22
  readonly limitMemory?: string;
23
23
  readonly requestCpu?: string;
24
24
  readonly requestMemory?: string;
25
+ readonly servicemonitor?: boolean;
25
26
  }
26
27
  export declare class PloneHttpcache extends Construct {
27
28
  readonly httpcacheServiceName: string;
package/lib/httpcache.js CHANGED
@@ -74,10 +74,10 @@ class PloneHttpcache extends constructs_1.Construct {
74
74
  },
75
75
  },
76
76
  },
77
- /*serviceMonitor: {
78
- enabled: true,
79
- scrapeSignaller: true,
80
- },*/
77
+ serviceMonitor: {
78
+ enabled: options.servicemonitor || false,
79
+ scrapeSignaller: options.servicemonitor || false,
80
+ },
81
81
  },
82
82
  });
83
83
  const httpcacheService = httpcache.apiObjects.find((construct) => {
@@ -94,5 +94,5 @@ class PloneHttpcache extends constructs_1.Construct {
94
94
  }
95
95
  exports.PloneHttpcache = PloneHttpcache;
96
96
  _a = JSII_RTTI_SYMBOL_1;
97
- PloneHttpcache[_a] = { fqn: "@bluedynamics/cdk8s-plone.PloneHttpcache", version: "0.0.64" };
98
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaHR0cGNhY2hlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vc3JjL2h0dHBjYWNoZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7OztBQUFBLHlCQUF5QjtBQUN6Qiw2QkFBNkI7QUFDN0IsaUNBQTZCO0FBQzdCLDJDQUF1QztBQWlDdkMsTUFBYSxjQUFlLFNBQVEsc0JBQVM7SUFJM0MsWUFBWSxLQUFnQixFQUFFLEVBQVUsRUFBRSxPQUE4QjtRQUN0RSxLQUFLLENBQUMsS0FBSyxFQUFFLEVBQUUsQ0FBQyxDQUFDO1FBQ2pCLElBQUksVUFBa0IsQ0FBQztRQUN2QixJQUFJLENBQUMsT0FBTyxDQUFDLFVBQVUsRUFBRSxDQUFDO1lBQ3hCLElBQUksT0FBZSxDQUFDO1lBQ3BCLElBQUksQ0FBQyxPQUFPLENBQUMsY0FBYyxFQUFFLENBQUM7Z0JBQzVCLE9BQU8sR0FBRyxJQUFJLENBQUMsSUFBSSxDQUFDLFNBQVMsRUFBRSxRQUFRLEVBQUUsaUJBQWlCLENBQUMsQ0FBQztZQUM5RCxDQUFDO2lCQUFNLENBQUM7Z0JBQ04sT0FBTyxHQUFHLE9BQU8sQ0FBQyxjQUFjLENBQUM7WUFDbkMsQ0FBQztZQUNELFVBQVUsR0FBRyxFQUFFLENBQUMsWUFBWSxDQUFDLE9BQU8sRUFBRSxNQUFNLENBQUMsQ0FBQztRQUNoRCxDQUFDO2FBQU0sQ0FBQztZQUNOLFVBQVUsR0FBRyxPQUFPLENBQUMsVUFBVSxDQUFDO1FBQ2xDLENBQUM7UUFDRCxNQUFNLFNBQVMsR0FBRyxJQUFJLFlBQUksQ0FBQyxJQUFJLEVBQUUsV0FBVyxFQUFFO1lBQzVDLHVEQUF1RDtZQUN2RCxJQUFJLEVBQUUsMEJBQTBCO1lBQ2hDLEtBQUssRUFBRSxnQkFBZ0I7WUFDdkIsTUFBTSxFQUFFO2dCQUNOLFlBQVksRUFBRSxDQUFDO2dCQUNmLEtBQUssRUFBRTtvQkFDTCxxREFBcUQ7b0JBQ3JELGFBQWEsRUFBRSxLQUFLO29CQUNwQixZQUFZLEVBQUUsS0FBSztvQkFDbkIsY0FBYyxFQUFFLE9BQU8sQ0FBQyxjQUFjLElBQUksU0FBUztpQkFDcEQ7Z0JBQ0QsV0FBVyxFQUFFLFVBQVU7Z0JBQ3ZCLFlBQVksRUFBRTtvQkFDWixFQUFFLElBQUksRUFBRSxzQkFBc0IsRUFBRSxLQUFLLEVBQUUsT0FBTyxDQUFDLEtBQUssQ0FBQyxrQkFBa0IsRUFBRTtvQkFDekUsRUFBRSxJQUFJLEVBQUUsc0JBQXNCLEVBQUUsS0FBSyxFQUFFLE1BQU0sRUFBRTtvQkFDL0MsRUFBRSxJQUFJLEVBQUUsaUJBQWlCLEVBQUUsS0FBSyxFQUFFLE9BQU8sQ0FBQyxLQUFLLENBQUMsTUFBTSxFQUFFO29CQUN4RCxFQUFFLElBQUksRUFBRSx1QkFBdUIsRUFBRSxLQUFLLEVBQUUsT0FBTyxDQUFDLEtBQUssQ0FBQyxtQkFBbUIsRUFBRTtvQkFDM0UsRUFBRSxJQUFJLEVBQUUsdUJBQXVCLEVBQUUsS0FBSyxFQUFFLE1BQU0sRUFBRTtpQkFDakQ7Z0JBQ0QsNERBQTREO2dCQUM1RCxZQUFZLEVBQUU7b0JBQ1osb0JBQW9CLEVBQUUsT0FBTztpQkFDOUI7Z0JBQ0QsU0FBUyxFQUFFO29CQUNULE1BQU0sRUFBRTt3QkFDTixHQUFHLEVBQUUsT0FBTyxDQUFDLFFBQVEsSUFBSSxNQUFNO3dCQUMvQixNQUFNLEVBQUUsT0FBTyxDQUFDLFdBQVcsSUFBSSxPQUFPO3FCQUN2QztvQkFDRCxRQUFRLEVBQUU7d0JBQ1IsR0FBRyxFQUFFLE9BQU8sQ0FBQyxVQUFVLElBQUksTUFBTTt3QkFDakMsTUFBTSxFQUFFLE9BQU8sQ0FBQyxhQUFhLElBQUksT0FBTztxQkFDekM7aUJBQ0Y7Z0JBQ0QsSUFBSSxFQUFFO29CQUNKLE9BQU8sRUFBRSxLQUFLO2lCQUNmO2dCQUNELFFBQVEsRUFBRTtvQkFDUixPQUFPLEVBQUUsSUFBSTtvQkFDYixTQUFTLEVBQUU7d0JBQ1QsTUFBTSxFQUFFOzRCQUNOLEdBQUcsRUFBRSxNQUFNOzRCQUNYLE1BQU0sRUFBRSxPQUFPO3lCQUNoQjt3QkFDRCxRQUFRLEVBQUU7NEJBQ1IsR0FBRyxFQUFFLEtBQUs7NEJBQ1YsTUFBTSxFQUFFLE1BQU07eUJBQ2Y7cUJBQ0Y7aUJBQ0Y7Z0JBQ0Q7OztvQkFHSTthQUNMO1NBQ0YsQ0FBQyxDQUFDO1FBQ0gsTUFBTSxnQkFBZ0IsR0FBRyxTQUFTLENBQUMsVUFBVSxDQUFDLElBQUksQ0FBQyxDQUFDLFNBQVMsRUFBRSxFQUFFO1lBQy9ELElBQUksQ0FBQyxTQUFTLENBQUMsSUFBSSxLQUFLLFNBQVMsQ0FBQyxJQUFJLENBQUMsU0FBUyxDQUFDLFFBQVEsQ0FBQyxJQUFJLEVBQUUsUUFBUSxDQUFDLGdCQUFnQixDQUFDLENBQUMsRUFBRSxDQUFDO2dCQUM1RixPQUFPLFNBQVMsQ0FBQyxJQUFJLENBQUM7WUFDeEIsQ0FBQztZQUNELE9BQU8sU0FBUyxDQUFDO1FBQ25CLENBQUMsQ0FBQyxDQUFDO1FBQ0gsSUFBSSxnQkFBZ0IsS0FBSyxTQUFTLEVBQUUsQ0FBQztZQUNuQyxNQUFNLElBQUksS0FBSyxDQUFDLGtDQUFrQyxDQUFDLENBQUM7UUFDdEQsQ0FBQztRQUNELElBQUksQ0FBQyxvQkFBb0IsR0FBRyxnQkFBZ0IsQ0FBQyxJQUFJLENBQUM7SUFDcEQsQ0FBQzs7QUFwRkgsd0NBcUZDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0ICogYXMgZnMgZnJvbSAnZnMnO1xuaW1wb3J0ICogYXMgcGF0aCBmcm9tICdwYXRoJztcbmltcG9ydCB7IEhlbG0gfSBmcm9tICdjZGs4cyc7XG5pbXBvcnQgeyBDb25zdHJ1Y3QgfSBmcm9tICdjb25zdHJ1Y3RzJztcbmltcG9ydCB7IFBsb25lIH0gZnJvbSAnLi9wbG9uZSc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgUGxvbmVIdHRwY2FjaGVPcHRpb25zIHtcbiAgLyoqXG4gICAqIHBsb25lIGNoYXJ0XG4gICAqIEBkZWZhdWx0IC0gbm9uZVxuICAgKi9cbiAgcmVhZG9ubHkgcGxvbmU6IFBsb25lO1xuXG4gIC8qKiB2YXJuaXNoVmNsXG4gICAqIEBkZWZhdWx0IC0gZmlsZSBpbiBjb25maWcgZm9sZGVyXG4gICAqL1xuICByZWFkb25seSB2YXJuaXNoVmNsPzogc3RyaW5nO1xuXG4gIC8qKiB2YXJuaXNoVmNsRmlsZVxuICAgKiBAZGVmYXVsdCAtIHVuZGVmaW5lZFxuICAgKi9cbiAgcmVhZG9ubHkgdmFybmlzaFZjbEZpbGU/OiBzdHJpbmcgfCB1bmRlZmluZWQ7XG5cbiAgLyoqIGV4aXN0aW5nU2VjcmV0IC0gUmVhZCBhZG1pbiBjcmVkZW50aWFscyBmcm9tIHVzZXIgcHJvdmlkZWQgc2VjcmV0XG4gICAqIEBkZWZhdWx0IC0gdW5kZWZpbmVkXG4gICovXG4gIHJlYWRvbmx5IGV4aXN0aW5nU2VjcmV0Pzogc3RyaW5nO1xuXG5cbiAgLy8gcmVzb3VyY2VzXG4gIHJlYWRvbmx5IGxpbWl0Q3B1Pzogc3RyaW5nO1xuICByZWFkb25seSBsaW1pdE1lbW9yeT86IHN0cmluZztcbiAgcmVhZG9ubHkgcmVxdWVzdENwdT86IHN0cmluZztcbiAgcmVhZG9ubHkgcmVxdWVzdE1lbW9yeT86IHN0cmluZztcbn1cblxuZXhwb3J0IGNsYXNzIFBsb25lSHR0cGNhY2hlIGV4dGVuZHMgQ29uc3RydWN0IHtcblxuICBwdWJsaWMgcmVhZG9ubHkgaHR0cGNhY2hlU2VydmljZU5hbWU6IHN0cmluZztcblxuICBjb25zdHJ1Y3RvcihzY29wZTogQ29uc3RydWN0LCBpZDogc3RyaW5nLCBvcHRpb25zOiBQbG9uZUh0dHBjYWNoZU9wdGlvbnMpIHtcbiAgICBzdXBlcihzY29wZSwgaWQpO1xuICAgIGxldCB2YXJuaXNoVmNsOiBzdHJpbmc7XG4gICAgaWYgKCFvcHRpb25zLnZhcm5pc2hWY2wpIHtcbiAgICAgIGxldCB2Y2xQYXRoOiBzdHJpbmc7XG4gICAgICBpZiAoIW9wdGlvbnMudmFybmlzaFZjbEZpbGUpIHtcbiAgICAgICAgdmNsUGF0aCA9IHBhdGguam9pbihfX2Rpcm5hbWUsICdjb25maWcnLCAndmFybmlzaC50cGwudmNsJyk7XG4gICAgICB9IGVsc2Uge1xuICAgICAgICB2Y2xQYXRoID0gb3B0aW9ucy52YXJuaXNoVmNsRmlsZTtcbiAgICAgIH1cbiAgICAgIHZhcm5pc2hWY2wgPSBmcy5yZWFkRmlsZVN5bmModmNsUGF0aCwgJ3V0ZjgnKTtcbiAgICB9IGVsc2Uge1xuICAgICAgdmFybmlzaFZjbCA9IG9wdGlvbnMudmFybmlzaFZjbDtcbiAgICB9XG4gICAgY29uc3QgaHR0cGNhY2hlID0gbmV3IEhlbG0odGhpcywgJ2h0dHBjYWNoZScsIHtcbiAgICAgIC8vIHNlZSBodHRwczovL2dpdGh1Yi5jb20vbWl0dHdhbGQva3ViZS1odHRwY2FjaGUvY2hhcnRcbiAgICAgIHJlcG86ICdodHRwczovL2hlbG0ubWl0dHdhbGQuZGUnLFxuICAgICAgY2hhcnQ6ICdrdWJlLWh0dHBjYWNoZScsXG4gICAgICB2YWx1ZXM6IHtcbiAgICAgICAgcmVwbGljYUNvdW50OiAyLFxuICAgICAgICBjYWNoZToge1xuICAgICAgICAgIC8vIG5lZWQgdG8gbG9va3MgYXQgdGhlIGZyb250ZW5kV2F0Y2gsIGRvIHdlIG5lZWQgaXQ/XG4gICAgICAgICAgZnJvbnRlbmRXYXRjaDogZmFsc2UsXG4gICAgICAgICAgYmFja2VuZFdhdGNoOiBmYWxzZSxcbiAgICAgICAgICBleGlzdGluZ1NlY3JldDogb3B0aW9ucy5leGlzdGluZ1NlY3JldCA/PyB1bmRlZmluZWQsXG4gICAgICAgIH0sXG4gICAgICAgIHZjbFRlbXBsYXRlOiB2YXJuaXNoVmNsLFxuICAgICAgICBleHRyYUVudlZhcnM6IFtcbiAgICAgICAgICB7IG5hbWU6ICdCQUNLRU5EX1NFUlZJQ0VfTkFNRScsIHZhbHVlOiBvcHRpb25zLnBsb25lLmJhY2tlbmRTZXJ2aWNlTmFtZSB9LFxuICAgICAgICAgIHsgbmFtZTogJ0JBQ0tFTkRfU0VSVklDRV9QT1JUJywgdmFsdWU6ICc4MDgwJyB9LFxuICAgICAgICAgIHsgbmFtZTogJ0JBQ0tFTkRfU0lURV9JRCcsIHZhbHVlOiBvcHRpb25zLnBsb25lLnNpdGVJZCB9LFxuICAgICAgICAgIHsgbmFtZTogJ0ZST05URU5EX1NFUlZJQ0VfTkFNRScsIHZhbHVlOiBvcHRpb25zLnBsb25lLmZyb250ZW5kU2VydmljZU5hbWUgfSxcbiAgICAgICAgICB7IG5hbWU6ICdGUk9OVEVORF9TRVJWSUNFX1BPUlQnLCB2YWx1ZTogJzMwMDAnIH0sXG4gICAgICAgIF0sXG4gICAgICAgIC8vIHNlZSBodHRwczovL2dpdGh1Yi5jb20vbWl0dHdhbGQva3ViZS1odHRwY2FjaGUvaXNzdWVzLzI1M1xuICAgICAgICBub2RlU2VsZWN0b3I6IHtcbiAgICAgICAgICAna3ViZXJuZXRlcy5pby9hcmNoJzogJ2FtZDY0JyxcbiAgICAgICAgfSxcbiAgICAgICAgcmVzb3VyY2VzOiB7XG4gICAgICAgICAgbGltaXRzOiB7XG4gICAgICAgICAgICBjcHU6IG9wdGlvbnMubGltaXRDcHUgfHwgJzUwMG0nLFxuICAgICAgICAgICAgbWVtb3J5OiBvcHRpb25zLmxpbWl0TWVtb3J5IHx8ICc1MDBNaScsXG4gICAgICAgICAgfSxcbiAgICAgICAgICByZXF1ZXN0czoge1xuICAgICAgICAgICAgY3B1OiBvcHRpb25zLnJlcXVlc3RDcHUgfHwgJzEwMG0nLFxuICAgICAgICAgICAgbWVtb3J5OiBvcHRpb25zLnJlcXVlc3RNZW1vcnkgfHwgJzEwME1pJyxcbiAgICAgICAgICB9LFxuICAgICAgICB9LFxuICAgICAgICByYmFjOiB7XG4gICAgICAgICAgZW5hYmxlZDogZmFsc2UsXG4gICAgICAgIH0sXG4gICAgICAgIGV4cG9ydGVyOiB7XG4gICAgICAgICAgZW5hYmxlZDogdHJ1ZSxcbiAgICAgICAgICByZXNvdXJjZXM6IHtcbiAgICAgICAgICAgIGxpbWl0czoge1xuICAgICAgICAgICAgICBjcHU6ICcxMDBtJyxcbiAgICAgICAgICAgICAgbWVtb3J5OiAnMTAwTWknLFxuICAgICAgICAgICAgfSxcbiAgICAgICAgICAgIHJlcXVlc3RzOiB7XG4gICAgICAgICAgICAgIGNwdTogJzEwbScsXG4gICAgICAgICAgICAgIG1lbW9yeTogJzUwTWknLFxuICAgICAgICAgICAgfSxcbiAgICAgICAgICB9LFxuICAgICAgICB9LFxuICAgICAgICAvKnNlcnZpY2VNb25pdG9yOiB7XG4gICAgICAgICAgZW5hYmxlZDogdHJ1ZSxcbiAgICAgICAgICBzY3JhcGVTaWduYWxsZXI6IHRydWUsXG4gICAgICAgIH0sKi9cbiAgICAgIH0sXG4gICAgfSk7XG4gICAgY29uc3QgaHR0cGNhY2hlU2VydmljZSA9IGh0dHBjYWNoZS5hcGlPYmplY3RzLmZpbmQoKGNvbnN0cnVjdCkgPT4ge1xuICAgICAgaWYgKChjb25zdHJ1Y3Qua2luZCA9PT0gJ1NlcnZpY2UnKSAmJiAoY29uc3RydWN0Lm1ldGFkYXRhLm5hbWU/LmVuZHNXaXRoKCdrdWJlLWh0dHBjYWNoZScpKSkge1xuICAgICAgICByZXR1cm4gY29uc3RydWN0Lm5hbWU7XG4gICAgICB9XG4gICAgICByZXR1cm4gdW5kZWZpbmVkO1xuICAgIH0pO1xuICAgIGlmIChodHRwY2FjaGVTZXJ2aWNlID09PSB1bmRlZmluZWQpIHtcbiAgICAgIHRocm93IG5ldyBFcnJvcignQ291bGQgbm90IGZpbmQgaHR0cGNhY2hlIHNlcnZpY2UnKTtcbiAgICB9XG4gICAgdGhpcy5odHRwY2FjaGVTZXJ2aWNlTmFtZSA9IGh0dHBjYWNoZVNlcnZpY2UubmFtZTtcbiAgfVxufSJdfQ==
97
+ PloneHttpcache[_a] = { fqn: "@bluedynamics/cdk8s-plone.PloneHttpcache", version: "0.0.66" };
98
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"httpcache.js","sourceRoot":"","sources":["../src/httpcache.ts"],"names":[],"mappings":"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","sourcesContent":["import * as fs from 'fs';\nimport * as path from 'path';\nimport { Helm } from 'cdk8s';\nimport { Construct } from 'constructs';\nimport { Plone } from './plone';\n\nexport interface PloneHttpcacheOptions {\n  /**\n   * plone chart\n   * @default - none\n   */\n  readonly plone: Plone;\n\n  /** varnishVcl\n   * @default - file in config folder\n   */\n  readonly varnishVcl?: string;\n\n  /** varnishVclFile\n   * @default - undefined\n   */\n  readonly varnishVclFile?: string | undefined;\n\n  /** existingSecret - Read admin credentials from user provided secret\n   * @default - undefined\n  */\n  readonly existingSecret?: string;\n\n\n  // resources\n  readonly limitCpu?: string;\n  readonly limitMemory?: string;\n  readonly requestCpu?: string;\n  readonly requestMemory?: string;\n  // metrics\n  readonly servicemonitor?: boolean;\n}\n\nexport class PloneHttpcache extends Construct {\n\n  public readonly httpcacheServiceName: string;\n\n  constructor(scope: Construct, id: string, options: PloneHttpcacheOptions) {\n    super(scope, id);\n    let varnishVcl: string;\n    if (!options.varnishVcl) {\n      let vclPath: string;\n      if (!options.varnishVclFile) {\n        vclPath = path.join(__dirname, 'config', 'varnish.tpl.vcl');\n      } else {\n        vclPath = options.varnishVclFile;\n      }\n      varnishVcl = fs.readFileSync(vclPath, 'utf8');\n    } else {\n      varnishVcl = options.varnishVcl;\n    }\n    const httpcache = new Helm(this, 'httpcache', {\n      // see https://github.com/mittwald/kube-httpcache/chart\n      repo: 'https://helm.mittwald.de',\n      chart: 'kube-httpcache',\n      values: {\n        replicaCount: 2,\n        cache: {\n          // need to looks at the frontendWatch, do we need it?\n          frontendWatch: false,\n          backendWatch: false,\n          existingSecret: options.existingSecret ?? undefined,\n        },\n        vclTemplate: varnishVcl,\n        extraEnvVars: [\n          { name: 'BACKEND_SERVICE_NAME', value: options.plone.backendServiceName },\n          { name: 'BACKEND_SERVICE_PORT', value: '8080' },\n          { name: 'BACKEND_SITE_ID', value: options.plone.siteId },\n          { name: 'FRONTEND_SERVICE_NAME', value: options.plone.frontendServiceName },\n          { name: 'FRONTEND_SERVICE_PORT', value: '3000' },\n        ],\n        // see https://github.com/mittwald/kube-httpcache/issues/253\n        nodeSelector: {\n          'kubernetes.io/arch': 'amd64',\n        },\n        resources: {\n          limits: {\n            cpu: options.limitCpu || '500m',\n            memory: options.limitMemory || '500Mi',\n          },\n          requests: {\n            cpu: options.requestCpu || '100m',\n            memory: options.requestMemory || '100Mi',\n          },\n        },\n        rbac: {\n          enabled: false,\n        },\n        exporter: {\n          enabled: true,\n          resources: {\n            limits: {\n              cpu: '100m',\n              memory: '100Mi',\n            },\n            requests: {\n              cpu: '10m',\n              memory: '50Mi',\n            },\n          },\n        },\n        serviceMonitor: {\n          enabled: options.servicemonitor || false,\n          scrapeSignaller: options.servicemonitor || false,\n        },\n      },\n    });\n    const httpcacheService = httpcache.apiObjects.find((construct) => {\n      if ((construct.kind === 'Service') && (construct.metadata.name?.endsWith('kube-httpcache'))) {\n        return construct.name;\n      }\n      return undefined;\n    });\n    if (httpcacheService === undefined) {\n      throw new Error('Could not find httpcache service');\n    }\n    this.httpcacheServiceName = httpcacheService.name;\n  }\n}"]}
package/lib/plone.js CHANGED
@@ -164,5 +164,5 @@ class Plone extends constructs_1.Construct {
164
164
  }
165
165
  exports.Plone = Plone;
166
166
  _a = JSII_RTTI_SYMBOL_1;
167
- Plone[_a] = { fqn: "@bluedynamics/cdk8s-plone.Plone", version: "0.0.64" };
167
+ Plone[_a] = { fqn: "@bluedynamics/cdk8s-plone.Plone", version: "0.0.66" };
168
168
  //# 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-29';\nimport { Construct } from 'constructs';\nimport { PloneDeployment, PloneDeploymentOptions } from './deployment';\nimport { 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 readinessEnabled?: boolean;\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 livenessEnabled?: boolean;\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    // Options\n    var backendOptions: PloneDeploymentOptions = {\n      labels: backendLabels,\n      image: {\n        image: backend.image ?? 'plone/plone-backend:latest',\n        imagePullSecrets: options.imagePullSecrets ?? [],\n        imagePullPolicy: backend.imagePullPolicy ?? 'IfNotPresent',\n      },\n      replicas: backend.replicas,\n      limitCpu: backend.limitCpu ?? '500m',\n      limitMemory: backend.limitMemory ?? '512Mi',\n      requestCpu: backend.requestCpu ?? '200m',\n      requestMemory: backend.requestMemory ?? '256Mi',\n      pdb: {\n        maxUnavailable: backend.maxUnavailable ?? undefined,\n        minAvailable: backend.minAvailable ?? undefined,\n      },\n      port: backendPort,\n      environment: backend.environment,\n    };\n\n    // Probing\n    const backendActionHttpGet: k8s.HttpGetAction = {\n      path: '/',\n      port: IntOrString.fromNumber(backendPort),\n    };\n    if (backend.livenessEnabled ?? false) {\n      backendOptions.livenessProbe = {\n        httpGet: backendActionHttpGet,\n        initialDelaySeconds: backend.livenessInitialDelaySeconds ?? 30,\n        timeoutSeconds: backend.livenessIimeoutSeconds ?? 5,\n        periodSeconds: backend.livenessPeriodSeconds ?? 10,\n        successThreshold: backend.livenessSuccessThreshold ?? 1,\n        failureThreshold: backend.livenessFailureThreshold ?? 3,\n      };\n    }\n    if (backend.readinessEnabled ?? true) {\n      backendOptions.readinessProbe = {\n        httpGet: backendActionHttpGet,\n        initialDelaySeconds: backend.readinessInitialDelaySeconds ?? 10,\n        timeoutSeconds: backend.readinessIimeoutSeconds ?? 15,\n        periodSeconds: backend.readinessPeriodSeconds ?? 10,\n        successThreshold: backend.readinessSuccessThreshold ?? 1,\n        failureThreshold: backend.readinessFailureThreshold ?? 3,\n      };\n    }\n    // Deployment\n    var backendDeployment = new PloneDeployment(this, 'backend', backendOptions);\n\n    // Service\n    const backendService = new PloneService(backendDeployment, 'service', {\n      labels: {\n        'app.kubernetes.io/name': 'plone-backend-service',\n        'app.kubernetes.io/component': 'service',\n      },\n      targetPort: backendPort,\n      selectorLabel: { app: Names.toLabelValue(backendDeployment) },\n    });\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      // Environment for RAZZLE\n      var frontendEnvironment = frontend.environment ?? new kplus.Env([], {});\n      if (frontendEnvironment.variables.RAZZLE_INTERNAL_API_PATH === undefined) {\n        // connect with backend service\n        frontendEnvironment?.addVariable('RAZZLE_INTERNAL_API_PATH', kplus.EnvValue.fromValue(`http://${backendService.name}:${backendPort}/${this.siteId}`));\n      }\n\n      // Options\n      var frontendOptions: PloneDeploymentOptions = {\n        labels: frontendLabels,\n        image: {\n          image: frontend.image ?? 'plone/plone-frontend:latest',\n          imagePullSecrets: options.imagePullSecrets ?? [],\n          imagePullPolicy: frontend.imagePullPolicy ?? 'IfNotPresent',\n        },\n        replicas: frontend.replicas,\n        limitCpu: frontend.limitCpu ?? '500m',\n        limitMemory: frontend.limitMemory ?? '1Gi',\n        requestCpu: frontend.requestCpu ?? '200m',\n        requestMemory: frontend.requestMemory ?? '256Mi',\n\n        pdb: {\n          maxUnavailable: frontend.maxUnavailable ?? undefined,\n          minAvailable: frontend.minAvailable ?? undefined,\n        },\n        port: frontendPort,\n        environment: frontendEnvironment,\n      };\n\n      // Probing\n      const frontendActionHttpGet: k8s.HttpGetAction = {\n        path: '/',\n        port: IntOrString.fromNumber(frontendPort),\n      };\n      if (frontend.livenessEnabled ?? false) {\n        frontendOptions.livenessProbe = {\n          httpGet: frontendActionHttpGet,\n          initialDelaySeconds: frontend.livenessInitialDelaySeconds ?? 30,\n          timeoutSeconds: frontend.livenessIimeoutSeconds ?? 5,\n          periodSeconds: frontend.livenessPeriodSeconds ?? 10,\n          successThreshold: frontend.livenessSuccessThreshold ?? 1,\n          failureThreshold: frontend.livenessFailureThreshold ?? 3,\n        };\n      }\n      if (frontend.readinessEnabled ?? true) {\n        frontendOptions.readinessProbe = {\n          httpGet: frontendActionHttpGet,\n          initialDelaySeconds: frontend.readinessInitialDelaySeconds ?? 10,\n          timeoutSeconds: frontend.readinessIimeoutSeconds ?? 15,\n          periodSeconds: frontend.readinessPeriodSeconds ?? 10,\n          successThreshold: frontend.readinessSuccessThreshold ?? 1,\n          failureThreshold: frontend.readinessFailureThreshold ?? 3,\n        };\n      }\n\n      // Deployment\n      const frontendDeployment = new PloneDeployment(this, 'frontend', frontendOptions);\n\n      // Service\n      const frontendService = new PloneService(frontendDeployment, 'service', {\n        labels: {\n          'app.kubernetes.io/name': 'plone-frontend-service',\n          'app.kubernetes.io/component': 'service',\n        },\n        targetPort: frontendPort,\n        selectorLabel: { app: Names.toLabelValue(frontendDeployment) },\n      });\n      this.frontendServiceName = frontendService.name;\n    }\n  }\n}"]}
package/package.json CHANGED
@@ -74,7 +74,7 @@
74
74
  "publishConfig": {
75
75
  "access": "public"
76
76
  },
77
- "version": "0.0.64",
77
+ "version": "0.0.66",
78
78
  "jest": {
79
79
  "coverageProvider": "v8",
80
80
  "testMatch": [