@bluedynamics/cdk8s-plone 0.0.38 → 0.0.39

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 (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\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\n```\nnvm use lts/*\nnpx projen 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"
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\n## Development\n\nClone the repository and install the dependencies:\n\n```bash\n```\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"
112
112
  },
113
113
  "repository": {
114
114
  "type": "git",
@@ -975,6 +975,6 @@
975
975
  "symbolId": "src/plone:PloneVariant"
976
976
  }
977
977
  },
978
- "version": "0.0.38",
979
- "fingerprint": "8k/UI+qsa6m4YghHBlmuqYpYspkN005Txiywt5Gmz4M="
978
+ "version": "0.0.39",
979
+ "fingerprint": "TJ8OY0Q9BXcufJnBpNAlhvecSi6skySnHwFf5/+Dmuw="
980
980
  }
package/README.md CHANGED
@@ -3,7 +3,7 @@
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
- - Backend (for API with `plone.volto` or as Classic-UI)
6
+ - Backend (as API with `plone.volto` or as Classic-UI)
7
7
  - Frontend (Plone-Volto, a ReactJS based user interface)
8
8
  - Varnish using kube-httpcache. It includes a way to invalidate varnish cluster (optional)
9
9
 
@@ -39,8 +39,6 @@ cdk8s init python-app
39
39
  Python package name is [cdk8s-plone](https://pypi.org/project/cdk8s-plone/).
40
40
 
41
41
 
42
-
43
-
44
42
  ## Usage
45
43
 
46
44
  With `cdk8s-cli` installed, create a new project:
@@ -75,7 +73,8 @@ Clone the repository and install the dependencies:
75
73
  ```bash
76
74
  ```
77
75
  nvm use lts/*
78
- npx projen install
76
+ corepack enable
77
+ npx projen
79
78
  ```
80
79
 
81
80
  Then run the following command to run the test:
@@ -83,35 +82,3 @@ Then run the following command to run the test:
83
82
  ```bash
84
83
  npx projen test
85
84
  ```
86
-
87
- ### Feature Wishlist:
88
-
89
- Each step need to be implemented with tests!
90
-
91
- - [x] Support Variants for ClassicUI or Volto
92
- - [ ] Start Backend
93
- - [x] deployment
94
- - [x] service
95
- - [x] pdb
96
- - [ ] init container running `plone-site-create`
97
- - [x] lifecycle checks (readiness, liveness)
98
- - [x] generic way to inject sidecars
99
- - [ ] metrics sidecar
100
- - [ ] Start Frontend
101
- - [x] deployment
102
- - [x] service
103
- - [x] pdb
104
- - [x] lifecycle checks (readiness, liveness)
105
- - [x] generic way to inject sidecars
106
- - [ ] metrics sidecar
107
- - [x] Start Varnish (using `kube-httpcache`) optional in separate chart
108
- - [x] provide a default VCL for Volto with routing to backend and frontend
109
- - [ ] provide a default VCL for ClassicUI
110
- - [ ] Configure Ingress, optional in separate chart
111
- - [ ] Traefik
112
- - [ ] Konq
113
-
114
- - [ ] Release packages for other Languages
115
- - [x] Python
116
- - [ ] Golang
117
- - [ ] Java
@@ -86,12 +86,12 @@ export interface PloneDeploymentOptions {
86
86
  * Liveness Probe for the pod.
87
87
  * @default - generated
88
88
  */
89
- readonly livenessProbe?: k8s.Probe;
89
+ livenessProbe?: k8s.Probe;
90
90
  /**
91
91
  * Readiness Probe for the pod.
92
92
  * @default - generated
93
93
  */
94
- readonly readinessProbe?: k8s.Probe;
94
+ readinessProbe?: k8s.Probe;
95
95
  }
96
96
  export declare class PloneDeployment extends Construct {
97
97
  constructor(scope: Construct, id: string, options: PloneDeploymentOptions);
package/lib/deployment.js CHANGED
@@ -50,8 +50,8 @@ class PloneDeployment extends constructs_1.Construct {
50
50
  memory: k8s.Quantity.fromString(options.requestMemory ?? '300Mi'),
51
51
  },
52
52
  },
53
- livenessProbe: options.livenessProbe ?? {},
54
- readinessProbe: options.readinessProbe ?? {},
53
+ livenessProbe: options.livenessProbe ?? undefined,
54
+ readinessProbe: options.readinessProbe ?? undefined,
55
55
  };
56
56
  const deploymentOptions = {
57
57
  metadata: {
@@ -82,4 +82,4 @@ class PloneDeployment extends constructs_1.Construct {
82
82
  }
83
83
  }
84
84
  exports.PloneDeployment = PloneDeployment;
85
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"deployment.js","sourceRoot":"","sources":["../src/deployment.ts"],"names":[],"mappings":"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","sourcesContent":["// import { log } from 'console';\nimport { Names } from 'cdk8s';\nimport * as kplus from 'cdk8s-plus-29';\nimport { Construct } from 'constructs';\nimport * as k8s from './imports/k8s';\nimport { PlonePDB, PlonePDBOptions } from './pdb';\n\nexport interface PloneImageOptions {\n  /**\n   * Specify a custom image for Plone .\n   * @default \"\"\n   */\n  readonly image?: string;\n\n  /**\n   * Specify Secret to pull image .\n   * @default \"\"\n   */\n  readonly imagePullSecrets?: string[];\n\n  /**\n   * Specify Pull Policy .\n   * @default \"\"\n   */\n  readonly imagePullPolicy?: string;\n}\n\nexport interface PloneDeploymentOptions {\n  /**\n   * Specify a custom image for Plone .\n   * @default \"plone/plone-backend:latest\"\n   */\n  readonly image?: PloneImageOptions;\n\n  /**\n   * Specify an environment for Plone .\n   * @default - none\n  */\n  readonly environment?: kplus.Env;\n\n  /**\n * Number of replicas.\n * @default 2\n */\n  readonly replicas?: number;\n\n  /**\n * CPU limit\n * @default 1\n */\n  readonly limitCpu?: string;\n\n  /**\n * memory limit\n * @default 1\n */\n  readonly limitMemory?: string;\n\n  /**\n * CPU request\n * @default 1\n */\n  readonly requestCpu?: string;\n\n  /**\n * memory request\n * @default 1\n */\n  readonly requestMemory?: string;\n\n  /**\n   * Port number.\n   */\n  readonly port: number;\n\n  /**\n   * Extra labels to associate with resources.\n   * @default - none\n   */\n  readonly labels?: { [name: string]: string };\n\n  /**\n   * Extra container spec to use for ploencontainer.\n   * @default - []\n   */\n  readonly ploneContainer?: k8s.Container;\n\n  /**\n   * Sidecar container spec to associate with resources.\n   * @default - []\n   */\n  readonly sidecars?: k8s.Container[];\n\n  /**\n   * Create a PodDisruptionBugdet for the deployment?\n   * If given\n   * @default - none\n   */\n  readonly pdb?: PlonePDBOptions;\n\n  /**\n   * Liveness Probe for the pod.\n   * @default - generated\n   */\n  readonly livenessProbe?: k8s.Probe;\n\n  /**\n   * Readiness Probe for the pod.\n   * @default - generated\n   */\n  readonly readinessProbe?: k8s.Probe;\n\n}\n\nexport class PloneDeployment extends Construct {\n\n  constructor(scope: Construct, id: string, options: PloneDeploymentOptions) {\n    super(scope, id);\n    const image = options.image ?? {};\n    const replicas = options.replicas ?? 2;\n    const label = { app: Names.toLabelValue(this) };\n    const optionLabels = options.labels ?? {};\n    const deploymentLabels = {\n      'app.kubernetes.io/name': optionLabels['app.kubernetes.io/name'] + '-deployment',\n      'app.kubernetes.io/component': optionLabels['app.kubernetes.io/component'] ?? '' + '-deployment',\n    };\n    const template_labels = {\n      ...optionLabels,\n      ...label,\n      'app.kubernetes.io/part-of': 'plone',\n      'app.kubernetes.io/managed-by': 'cdk8s-plone',\n    };\n    const kpEnv: kplus.Env = options?.environment ?? new kplus.Env([], {});\n    var env: k8s.EnvVar[] = [];\n    for (const name in kpEnv.variables) {\n      env.push({ name: name, value: kpEnv.variables[name].value, valueFrom: kpEnv.variables[name].valueFrom });\n    }\n    var envFrom: k8s.EnvFromSource[] = [];\n    for (const idx in kpEnv.sources) {\n      const source = kpEnv.sources[idx];\n      envFrom.push(source._toKube());\n    }\n    var ploneContainerSpec: k8s.Container = {\n      name: id + '-container', // here the namespaced name shold be used, but how?\n      image: image.image,\n      imagePullPolicy: image.imagePullPolicy,\n      env: env,\n      envFrom: envFrom,\n      resources: {\n        limits: {\n          cpu: k8s.Quantity.fromString(options.limitCpu ?? '1000m'),\n          memory: k8s.Quantity.fromString(options.limitMemory ?? '1Gi'),\n        },\n        requests: {\n          cpu: k8s.Quantity.fromString(options.requestCpu ?? '200m'),\n          memory: k8s.Quantity.fromString(options.requestMemory ?? '300Mi'),\n        },\n      },\n      livenessProbe: options.livenessProbe ?? {},\n      readinessProbe: options.readinessProbe ?? {},\n    };\n    const deploymentOptions: k8s.KubeDeploymentProps = {\n      metadata: {\n        labels: deploymentLabels,\n      },\n      spec: {\n        replicas,\n        selector: {\n          matchLabels: label,\n        },\n        template: {\n          metadata: { labels: template_labels },\n          spec: {\n            imagePullSecrets: (image.imagePullSecrets ?? []).map((name) => ({ name: name })),\n            containers: [\n              ploneContainerSpec,\n              ...options.sidecars ?? [],\n            ],\n          },\n        },\n      },\n    };\n\n    new k8s.KubeDeployment(this, 'deployment', deploymentOptions);\n\n    if (options.pdb ?? false) {\n      const pdbOptions = options.pdb ?? {};\n      new PlonePDB(this, 'pdb', label, pdbOptions);\n    }\n  }\n}\n"]}
85
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"deployment.js","sourceRoot":"","sources":["../src/deployment.ts"],"names":[],"mappings":"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","sourcesContent":["// import { log } from 'console';\nimport { Names } from 'cdk8s';\nimport * as kplus from 'cdk8s-plus-29';\nimport { Construct } from 'constructs';\nimport * as k8s from './imports/k8s';\nimport { PlonePDB, PlonePDBOptions } from './pdb';\n\nexport interface PloneImageOptions {\n  /**\n   * Specify a custom image for Plone .\n   * @default \"\"\n   */\n  readonly image?: string;\n\n  /**\n   * Specify Secret to pull image .\n   * @default \"\"\n   */\n  readonly imagePullSecrets?: string[];\n\n  /**\n   * Specify Pull Policy .\n   * @default \"\"\n   */\n  readonly imagePullPolicy?: string;\n}\n\nexport interface PloneDeploymentOptions {\n  /**\n   * Specify a custom image for Plone .\n   * @default \"plone/plone-backend:latest\"\n   */\n  readonly image?: PloneImageOptions;\n\n  /**\n   * Specify an environment for Plone .\n   * @default - none\n  */\n  readonly environment?: kplus.Env;\n\n  /**\n * Number of replicas.\n * @default 2\n */\n  readonly replicas?: number;\n\n  /**\n * CPU limit\n * @default 1\n */\n  readonly limitCpu?: string;\n\n  /**\n * memory limit\n * @default 1\n */\n  readonly limitMemory?: string;\n\n  /**\n * CPU request\n * @default 1\n */\n  readonly requestCpu?: string;\n\n  /**\n * memory request\n * @default 1\n */\n  readonly requestMemory?: string;\n\n  /**\n   * Port number.\n   */\n  readonly port: number;\n\n  /**\n   * Extra labels to associate with resources.\n   * @default - none\n   */\n  readonly labels?: { [name: string]: string };\n\n  /**\n   * Extra container spec to use for ploencontainer.\n   * @default - []\n   */\n  readonly ploneContainer?: k8s.Container;\n\n  /**\n   * Sidecar container spec to associate with resources.\n   * @default - []\n   */\n  readonly sidecars?: k8s.Container[];\n\n  /**\n   * Create a PodDisruptionBugdet for the deployment?\n   * If given\n   * @default - none\n   */\n  readonly pdb?: PlonePDBOptions;\n\n  /**\n   * Liveness Probe for the pod.\n   * @default - generated\n   */\n  livenessProbe?: k8s.Probe;\n\n  /**\n   * Readiness Probe for the pod.\n   * @default - generated\n   */\n  readinessProbe?: k8s.Probe;\n\n}\n\nexport class PloneDeployment extends Construct {\n\n  constructor(scope: Construct, id: string, options: PloneDeploymentOptions) {\n    super(scope, id);\n    const image = options.image ?? {};\n    const replicas = options.replicas ?? 2;\n    const label = { app: Names.toLabelValue(this) };\n    const optionLabels = options.labels ?? {};\n    const deploymentLabels = {\n      'app.kubernetes.io/name': optionLabels['app.kubernetes.io/name'] + '-deployment',\n      'app.kubernetes.io/component': optionLabels['app.kubernetes.io/component'] ?? '' + '-deployment',\n    };\n    const template_labels = {\n      ...optionLabels,\n      ...label,\n      'app.kubernetes.io/part-of': 'plone',\n      'app.kubernetes.io/managed-by': 'cdk8s-plone',\n    };\n    const kpEnv: kplus.Env = options?.environment ?? new kplus.Env([], {});\n    var env: k8s.EnvVar[] = [];\n    for (const name in kpEnv.variables) {\n      env.push({ name: name, value: kpEnv.variables[name].value, valueFrom: kpEnv.variables[name].valueFrom });\n    }\n    var envFrom: k8s.EnvFromSource[] = [];\n    for (const idx in kpEnv.sources) {\n      const source = kpEnv.sources[idx];\n      envFrom.push(source._toKube());\n    }\n    var ploneContainerSpec: k8s.Container = {\n      name: id + '-container', // here the namespaced name shold be used, but how?\n      image: image.image,\n      imagePullPolicy: image.imagePullPolicy,\n      env: env,\n      envFrom: envFrom,\n      resources: {\n        limits: {\n          cpu: k8s.Quantity.fromString(options.limitCpu ?? '1000m'),\n          memory: k8s.Quantity.fromString(options.limitMemory ?? '1Gi'),\n        },\n        requests: {\n          cpu: k8s.Quantity.fromString(options.requestCpu ?? '200m'),\n          memory: k8s.Quantity.fromString(options.requestMemory ?? '300Mi'),\n        },\n      },\n      livenessProbe: options.livenessProbe ?? undefined,\n      readinessProbe: options.readinessProbe ?? undefined,\n    };\n    const deploymentOptions: k8s.KubeDeploymentProps = {\n      metadata: {\n        labels: deploymentLabels,\n      },\n      spec: {\n        replicas,\n        selector: {\n          matchLabels: label,\n        },\n        template: {\n          metadata: { labels: template_labels },\n          spec: {\n            imagePullSecrets: (image.imagePullSecrets ?? []).map((name) => ({ name: name })),\n            containers: [\n              ploneContainerSpec,\n              ...options.sidecars ?? [],\n            ],\n          },\n        },\n      },\n    };\n\n    new k8s.KubeDeployment(this, 'deployment', deploymentOptions);\n\n    if (options.pdb ?? false) {\n      const pdbOptions = options.pdb ?? {};\n      new PlonePDB(this, 'pdb', label, pdbOptions);\n    }\n  }\n}\n"]}
package/lib/httpcache.js CHANGED
@@ -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.38" };
97
+ PloneHttpcache[_a] = { fqn: "@bluedynamics/cdk8s-plone.PloneHttpcache", version: "0.0.39" };
98
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}\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: true,\n          scrapeSignaller: true,\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
@@ -29,14 +29,33 @@ class Plone extends constructs_1.Construct {
29
29
  'app.kubernetes.io/version': options.version ?? 'undefined',
30
30
  };
31
31
  const backendPort = 8080;
32
+ // Options
33
+ var backendOptions = {
34
+ labels: backendLabels,
35
+ image: {
36
+ image: backend.image ?? 'plone/plone-backend:latest',
37
+ imagePullSecrets: options.imagePullSecrets ?? [],
38
+ imagePullPolicy: backend.imagePullPolicy ?? 'IfNotPresent',
39
+ },
40
+ replicas: backend.replicas,
41
+ limitCpu: backend.limitCpu ?? '500m',
42
+ limitMemory: backend.limitMemory ?? '512Mi',
43
+ requestCpu: backend.requestCpu ?? '200m',
44
+ requestMemory: backend.requestMemory ?? '256Mi',
45
+ pdb: {
46
+ maxUnavailable: backend.maxUnavailable ?? undefined,
47
+ minAvailable: backend.minAvailable ?? undefined,
48
+ },
49
+ port: backendPort,
50
+ environment: backend.environment,
51
+ };
32
52
  // Probing
33
53
  const backendActionHttpGet = {
34
54
  path: '/',
35
55
  port: k8s_1.IntOrString.fromNumber(backendPort),
36
56
  };
37
- var backendLivenessProbe = undefined;
38
57
  if (backend.livenessEnabled ?? false) {
39
- backendLivenessProbe = {
58
+ backendOptions.livenessProbe = {
40
59
  httpGet: backendActionHttpGet,
41
60
  initialDelaySeconds: backend.livenessInitialDelaySeconds ?? 30,
42
61
  timeoutSeconds: backend.livenessIimeoutSeconds ?? 5,
@@ -45,9 +64,8 @@ class Plone extends constructs_1.Construct {
45
64
  failureThreshold: backend.livenessFailureThreshold ?? 3,
46
65
  };
47
66
  }
48
- var backendReadinessProbe = undefined;
49
67
  if (backend.readinessEnabled ?? true) {
50
- backendReadinessProbe = {
68
+ backendOptions.readinessProbe = {
51
69
  httpGet: backendActionHttpGet,
52
70
  initialDelaySeconds: backend.readinessInitialDelaySeconds ?? 10,
53
71
  timeoutSeconds: backend.readinessIimeoutSeconds ?? 15,
@@ -57,27 +75,7 @@ class Plone extends constructs_1.Construct {
57
75
  };
58
76
  }
59
77
  // Deployment
60
- const backendDeployment = new deployment_1.PloneDeployment(this, 'backend', {
61
- labels: backendLabels,
62
- image: {
63
- image: backend.image ?? 'plone/plone-backend:latest',
64
- imagePullSecrets: options.imagePullSecrets ?? [],
65
- imagePullPolicy: backend.imagePullPolicy ?? 'IfNotPresent',
66
- },
67
- replicas: backend.replicas,
68
- limitCpu: backend.limitCpu ?? '500m',
69
- limitMemory: backend.limitMemory ?? '512Mi',
70
- requestCpu: backend.requestCpu ?? '200m',
71
- requestMemory: backend.requestMemory ?? '256Mi',
72
- pdb: {
73
- maxUnavailable: backend.maxUnavailable ?? undefined,
74
- minAvailable: backend.minAvailable ?? undefined,
75
- },
76
- port: backendPort,
77
- environment: backend.environment,
78
- livenessProbe: backendLivenessProbe,
79
- readinessProbe: backendReadinessProbe,
80
- });
78
+ var backendDeployment = new deployment_1.PloneDeployment(this, 'backend', backendOptions);
81
79
  // Service
82
80
  const backendService = new service_1.PloneService(backendDeployment, 'service', {
83
81
  labels: {
@@ -98,14 +96,39 @@ class Plone extends constructs_1.Construct {
98
96
  'app.kubernetes.io/component': 'frontend',
99
97
  'app.kubernetes.io/version': options.version ?? 'undefined',
100
98
  };
99
+ // Environment for RAZZLE
100
+ var frontendEnvironment = frontend.environment ?? new kplus.Env([], {});
101
+ if (frontendEnvironment.variables.RAZZLE_INTERNAL_API_PATH === undefined) {
102
+ // connect with backend service
103
+ frontendEnvironment?.addVariable('RAZZLE_INTERNAL_API_PATH', kplus.EnvValue.fromValue(`http://${backendService.name}:${backendPort}/${this.siteId}`));
104
+ }
105
+ // Options
106
+ var frontendOptions = {
107
+ labels: frontendLabels,
108
+ image: {
109
+ image: frontend.image ?? 'plone/plone-frontend:latest',
110
+ imagePullSecrets: options.imagePullSecrets ?? [],
111
+ imagePullPolicy: frontend.imagePullPolicy ?? 'IfNotPresent',
112
+ },
113
+ replicas: frontend.replicas,
114
+ limitCpu: frontend.limitCpu ?? '500m',
115
+ limitMemory: frontend.limitMemory ?? '1Gi',
116
+ requestCpu: frontend.requestCpu ?? '200m',
117
+ requestMemory: frontend.requestMemory ?? '256Mi',
118
+ pdb: {
119
+ maxUnavailable: frontend.maxUnavailable ?? undefined,
120
+ minAvailable: frontend.minAvailable ?? undefined,
121
+ },
122
+ port: frontendPort,
123
+ environment: frontendEnvironment,
124
+ };
101
125
  // Probing
102
126
  const frontendActionHttpGet = {
103
127
  path: '/',
104
128
  port: k8s_1.IntOrString.fromNumber(frontendPort),
105
129
  };
106
- var frontendLivenessProbe = undefined;
107
130
  if (frontend.livenessEnabled ?? false) {
108
- frontendLivenessProbe = {
131
+ frontendOptions.livenessProbe = {
109
132
  httpGet: frontendActionHttpGet,
110
133
  initialDelaySeconds: frontend.livenessInitialDelaySeconds ?? 30,
111
134
  timeoutSeconds: frontend.livenessIimeoutSeconds ?? 5,
@@ -114,9 +137,8 @@ class Plone extends constructs_1.Construct {
114
137
  failureThreshold: frontend.livenessFailureThreshold ?? 3,
115
138
  };
116
139
  }
117
- var frontendReadinessProbe = undefined;
118
140
  if (frontend.readinessEnabled ?? true) {
119
- frontendReadinessProbe = {
141
+ frontendOptions.readinessProbe = {
120
142
  httpGet: frontendActionHttpGet,
121
143
  initialDelaySeconds: frontend.readinessInitialDelaySeconds ?? 10,
122
144
  timeoutSeconds: frontend.readinessIimeoutSeconds ?? 15,
@@ -125,34 +147,8 @@ class Plone extends constructs_1.Construct {
125
147
  failureThreshold: frontend.readinessFailureThreshold ?? 3,
126
148
  };
127
149
  }
128
- // Environment for RAZZLE
129
- var frontendEnvironment = frontend.environment ?? new kplus.Env([], {});
130
- if (frontendEnvironment.variables.RAZZLE_INTERNAL_API_PATH === undefined) {
131
- // connect with backend service
132
- frontendEnvironment?.addVariable('RAZZLE_INTERNAL_API_PATH', kplus.EnvValue.fromValue(`http://${backendService.name}:${backendPort}/${this.siteId}`));
133
- }
134
150
  // Deployment
135
- const frontendDeployment = new deployment_1.PloneDeployment(this, 'frontend', {
136
- labels: frontendLabels,
137
- image: {
138
- image: frontend.image ?? 'plone/plone-frontend:latest',
139
- imagePullSecrets: options.imagePullSecrets ?? [],
140
- imagePullPolicy: frontend.imagePullPolicy ?? 'IfNotPresent',
141
- },
142
- replicas: frontend.replicas,
143
- limitCpu: frontend.limitCpu ?? '500m',
144
- limitMemory: frontend.limitMemory ?? '1Gi',
145
- requestCpu: frontend.requestCpu ?? '200m',
146
- requestMemory: frontend.requestMemory ?? '256Mi',
147
- pdb: {
148
- maxUnavailable: frontend.maxUnavailable ?? undefined,
149
- minAvailable: frontend.minAvailable ?? undefined,
150
- },
151
- port: frontendPort,
152
- environment: frontendEnvironment,
153
- livenessProbe: frontendLivenessProbe,
154
- readinessProbe: frontendReadinessProbe,
155
- });
151
+ const frontendDeployment = new deployment_1.PloneDeployment(this, 'frontend', frontendOptions);
156
152
  // Service
157
153
  const frontendService = new service_1.PloneService(frontendDeployment, 'service', {
158
154
  labels: {
@@ -168,5 +164,5 @@ class Plone extends constructs_1.Construct {
168
164
  }
169
165
  exports.Plone = Plone;
170
166
  _a = JSII_RTTI_SYMBOL_1;
171
- Plone[_a] = { fqn: "@bluedynamics/cdk8s-plone.Plone", version: "0.0.38" };
172
- //# 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 } 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 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    // Probing\n    const backendActionHttpGet: k8s.HttpGetAction = {\n      path: '/',\n      port: IntOrString.fromNumber(backendPort),\n    };\n    var backendLivenessProbe: Probe | undefined = undefined;\n    if (backend.livenessEnabled ?? false) {\n      backendLivenessProbe = {\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    var backendReadinessProbe: Probe | undefined = undefined;\n    if (backend.readinessEnabled ?? true) {\n      backendReadinessProbe = {\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      var frontendLivenessProbe: Probe | undefined = undefined;\n      if (frontend.livenessEnabled ?? false) {\n        frontendLivenessProbe = {\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      var frontendReadinessProbe: Probe | undefined = undefined;\n      if (frontend.readinessEnabled ?? true) {\n        frontendReadinessProbe = {\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      // 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: 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        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}"]}
167
+ Plone[_a] = { fqn: "@bluedynamics/cdk8s-plone.Plone", version: "0.0.39" };
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
@@ -73,7 +73,7 @@
73
73
  "publishConfig": {
74
74
  "access": "public"
75
75
  },
76
- "version": "0.0.38",
76
+ "version": "0.0.39",
77
77
  "jest": {
78
78
  "coverageProvider": "v8",
79
79
  "testMatch": [