@bluedynamics/cdk8s-plone 0.0.80 → 0.1.0

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.
@@ -1,30 +1,85 @@
1
1
  import { Construct } from 'constructs';
2
2
  import { Plone } from './plone';
3
+ /**
4
+ * Configuration options for PloneHttpcache (Varnish caching layer).
5
+ */
3
6
  export interface PloneHttpcacheOptions {
4
7
  /**
5
- * plone chart
6
- * @default - none
8
+ * The Plone construct to attach the HTTP cache to.
9
+ * The cache will automatically connect to the backend and frontend services.
7
10
  */
8
11
  readonly plone: Plone;
9
- /** varnishVcl
10
- * @default - file in config folder
12
+ /**
13
+ * Varnish VCL configuration as a string.
14
+ * If provided, this takes precedence over varnishVclFile.
15
+ * @default - loaded from varnishVclFile or default config file
11
16
  */
12
17
  readonly varnishVcl?: string;
13
- /** varnishVclFile
14
- * @default - undefined
18
+ /**
19
+ * Path to a Varnish VCL configuration file.
20
+ * If not provided, uses the default VCL file included in the library.
21
+ * @default - uses default config/varnish.tpl.vcl
15
22
  */
16
23
  readonly varnishVclFile?: string | undefined;
17
- /** existingSecret - Read admin credentials from user provided secret
18
- * @default - undefined
19
- */
24
+ /**
25
+ * Name of an existing Kubernetes secret containing Varnish admin credentials.
26
+ * The secret should be created separately in the same namespace.
27
+ * @default - undefined (no existing secret)
28
+ */
20
29
  readonly existingSecret?: string;
30
+ /**
31
+ * CPU limit for Varnish pods.
32
+ * @default '500m'
33
+ */
21
34
  readonly limitCpu?: string;
35
+ /**
36
+ * Memory limit for Varnish pods.
37
+ * @default '500Mi'
38
+ */
22
39
  readonly limitMemory?: string;
40
+ /**
41
+ * CPU request for Varnish pods.
42
+ * @default '100m'
43
+ */
23
44
  readonly requestCpu?: string;
45
+ /**
46
+ * Memory request for Varnish pods.
47
+ * @default '100Mi'
48
+ */
24
49
  readonly requestMemory?: string;
50
+ /**
51
+ * Enable Prometheus ServiceMonitor for metrics collection.
52
+ * Requires Prometheus Operator to be installed in the cluster.
53
+ * @default false
54
+ */
25
55
  readonly servicemonitor?: boolean;
56
+ /**
57
+ * Number of Varnish pod replicas to run.
58
+ * @default 2
59
+ */
60
+ readonly replicas?: number;
26
61
  }
62
+ /**
63
+ * PloneHttpcache construct for deploying Varnish HTTP caching layer.
64
+ *
65
+ * Uses the mittwald/kube-httpcache Helm chart to deploy Varnish as a
66
+ * caching proxy in front of Plone backend and/or frontend services.
67
+ *
68
+ * The cache automatically connects to the Plone services and provides
69
+ * HTTP cache invalidation capabilities.
70
+ *
71
+ * @example
72
+ * const plone = new Plone(chart, 'plone');
73
+ * const cache = new PloneHttpcache(chart, 'cache', {
74
+ * plone: plone,
75
+ * existingSecret: 'varnish-secret',
76
+ * });
77
+ */
27
78
  export declare class PloneHttpcache extends Construct {
79
+ /**
80
+ * Name of the Varnish service created by the Helm chart.
81
+ * Use this to reference the cache service from ingress or other constructs.
82
+ */
28
83
  readonly httpcacheServiceName: string;
29
84
  constructor(scope: Construct, id: string, options: PloneHttpcacheOptions);
30
85
  }
package/lib/httpcache.js CHANGED
@@ -7,6 +7,22 @@ const fs = require("fs");
7
7
  const path = require("path");
8
8
  const cdk8s_1 = require("cdk8s");
9
9
  const constructs_1 = require("constructs");
10
+ /**
11
+ * PloneHttpcache construct for deploying Varnish HTTP caching layer.
12
+ *
13
+ * Uses the mittwald/kube-httpcache Helm chart to deploy Varnish as a
14
+ * caching proxy in front of Plone backend and/or frontend services.
15
+ *
16
+ * The cache automatically connects to the Plone services and provides
17
+ * HTTP cache invalidation capabilities.
18
+ *
19
+ * @example
20
+ * const plone = new Plone(chart, 'plone');
21
+ * const cache = new PloneHttpcache(chart, 'cache', {
22
+ * plone: plone,
23
+ * existingSecret: 'varnish-secret',
24
+ * });
25
+ */
10
26
  class PloneHttpcache extends constructs_1.Construct {
11
27
  constructor(scope, id, options) {
12
28
  super(scope, id);
@@ -29,7 +45,7 @@ class PloneHttpcache extends constructs_1.Construct {
29
45
  repo: 'https://helm.mittwald.de',
30
46
  chart: 'kube-httpcache',
31
47
  values: {
32
- replicaCount: 2,
48
+ replicaCount: options.replicas ?? 2,
33
49
  cache: {
34
50
  // need to looks at the frontendWatch, do we need it?
35
51
  frontendWatch: false,
@@ -94,5 +110,5 @@ class PloneHttpcache extends constructs_1.Construct {
94
110
  }
95
111
  exports.PloneHttpcache = PloneHttpcache;
96
112
  _a = JSII_RTTI_SYMBOL_1;
97
- PloneHttpcache[_a] = { fqn: "@bluedynamics/cdk8s-plone.PloneHttpcache", version: "0.0.80" };
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}"]}
113
+ PloneHttpcache[_a] = { fqn: "@bluedynamics/cdk8s-plone.PloneHttpcache", version: "0.1.0" };
114
+ //# 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\n/**\n * Configuration options for PloneHttpcache (Varnish caching layer).\n */\nexport interface PloneHttpcacheOptions {\n  /**\n   * The Plone construct to attach the HTTP cache to.\n   * The cache will automatically connect to the backend and frontend services.\n   */\n  readonly plone: Plone;\n\n  /**\n   * Varnish VCL configuration as a string.\n   * If provided, this takes precedence over varnishVclFile.\n   * @default - loaded from varnishVclFile or default config file\n   */\n  readonly varnishVcl?: string;\n\n  /**\n   * Path to a Varnish VCL configuration file.\n   * If not provided, uses the default VCL file included in the library.\n   * @default - uses default config/varnish.tpl.vcl\n   */\n  readonly varnishVclFile?: string | undefined;\n\n  /**\n   * Name of an existing Kubernetes secret containing Varnish admin credentials.\n   * The secret should be created separately in the same namespace.\n   * @default - undefined (no existing secret)\n   */\n  readonly existingSecret?: string;\n\n  /**\n   * CPU limit for Varnish pods.\n   * @default '500m'\n   */\n  readonly limitCpu?: string;\n\n  /**\n   * Memory limit for Varnish pods.\n   * @default '500Mi'\n   */\n  readonly limitMemory?: string;\n\n  /**\n   * CPU request for Varnish pods.\n   * @default '100m'\n   */\n  readonly requestCpu?: string;\n\n  /**\n   * Memory request for Varnish pods.\n   * @default '100Mi'\n   */\n  readonly requestMemory?: string;\n\n  /**\n   * Enable Prometheus ServiceMonitor for metrics collection.\n   * Requires Prometheus Operator to be installed in the cluster.\n   * @default false\n   */\n  readonly servicemonitor?: boolean;\n\n  /**\n   * Number of Varnish pod replicas to run.\n   * @default 2\n   */\n  readonly replicas?: number;\n}\n\n/**\n * PloneHttpcache construct for deploying Varnish HTTP caching layer.\n *\n * Uses the mittwald/kube-httpcache Helm chart to deploy Varnish as a\n * caching proxy in front of Plone backend and/or frontend services.\n *\n * The cache automatically connects to the Plone services and provides\n * HTTP cache invalidation capabilities.\n *\n * @example\n * const plone = new Plone(chart, 'plone');\n * const cache = new PloneHttpcache(chart, 'cache', {\n *   plone: plone,\n *   existingSecret: 'varnish-secret',\n * });\n */\nexport class PloneHttpcache extends Construct {\n  /**\n   * Name of the Varnish service created by the Helm chart.\n   * Use this to reference the cache service from ingress or other constructs.\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: options.replicas ?? 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/pdb.d.ts CHANGED
@@ -1,24 +1,39 @@
1
1
  import { Construct } from 'constructs';
2
+ /**
3
+ * Configuration options for PodDisruptionBudget.
4
+ */
2
5
  export interface PlonePDBOptions {
3
6
  /**
4
- * maxUnavailable specification
5
- * @default - none
7
+ * Maximum number or percentage of pods that can be unavailable during voluntary disruptions.
8
+ * Can be an absolute number (e.g., 1) or a percentage (e.g., '50%').
9
+ * Cannot be used together with minAvailable.
10
+ * @example 1 or '25%'
11
+ * @default - not set (defaults to minAvailable=1 if neither is specified)
6
12
  */
7
13
  readonly maxUnavailable?: number | string;
8
14
  /**
9
- * minAvailable specification.
10
- * default only set if maxUnavailable is not set.
11
- * @default 1
15
+ * Minimum number or percentage of pods that must remain available during voluntary disruptions.
16
+ * Can be an absolute number (e.g., 1) or a percentage (e.g., '50%').
17
+ * Cannot be used together with maxUnavailable.
18
+ * @example 2 or '50%'
19
+ * @default 1 (if maxUnavailable is not set)
12
20
  */
13
21
  readonly minAvailable?: number | string;
14
22
  /**
15
- * Extra labels to associate with resources.
16
- * @default - none
23
+ * Additional Kubernetes labels for the PodDisruptionBudget.
24
+ * @default - standard Plone labels only
17
25
  */
18
26
  readonly labels?: {
19
27
  [name: string]: string;
20
28
  };
21
29
  }
30
+ /**
31
+ * PlonePDB creates a Kubernetes PodDisruptionBudget for high availability.
32
+ *
33
+ * This is an internal construct used by PloneDeployment.
34
+ * It ensures a minimum number of pods remain available during voluntary
35
+ * disruptions like node drains or cluster upgrades.
36
+ */
22
37
  export declare class PlonePDB extends Construct {
23
38
  constructor(scope: Construct, id: string, selectorLabel: {
24
39
  [name: string]: string;
package/lib/pdb.js CHANGED
@@ -3,6 +3,13 @@ Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.PlonePDB = void 0;
4
4
  const constructs_1 = require("constructs");
5
5
  const k8s = require("./imports/k8s");
6
+ /**
7
+ * PlonePDB creates a Kubernetes PodDisruptionBudget for high availability.
8
+ *
9
+ * This is an internal construct used by PloneDeployment.
10
+ * It ensures a minimum number of pods remain available during voluntary
11
+ * disruptions like node drains or cluster upgrades.
12
+ */
6
13
  class PlonePDB extends constructs_1.Construct {
7
14
  constructor(scope, id, selectorLabel, options) {
8
15
  super(scope, id);
@@ -52,4 +59,4 @@ class PlonePDB extends constructs_1.Construct {
52
59
  }
53
60
  }
54
61
  exports.PlonePDB = PlonePDB;
55
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGRiLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vc3JjL3BkYi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7QUFBQSwyQ0FBdUM7QUFDdkMscUNBQXFDO0FBdUJyQyxNQUFhLFFBQVMsU0FBUSxzQkFBUztJQUVyQyxZQUFZLEtBQWdCLEVBQUUsRUFBVSxFQUFFLGFBQXlDLEVBQUUsT0FBd0I7UUFDM0csS0FBSyxDQUFDLEtBQUssRUFBRSxFQUFFLENBQUMsQ0FBQztRQUVqQixJQUFJLElBQUksR0FBZ0MsRUFBRSxDQUFDO1FBQzNDLElBQUksT0FBTyxPQUFPLENBQUMsY0FBYyxLQUFLLFFBQVEsRUFBRSxDQUFDO1lBQy9DLElBQUksR0FBRztnQkFDTCxjQUFjLEVBQUUsR0FBRyxDQUFDLFdBQVcsQ0FBQyxVQUFVLENBQUMsT0FBTyxDQUFDLGNBQXdCLENBQUM7YUFDN0UsQ0FBQztRQUNKLENBQUM7YUFBTSxJQUFJLE9BQU8sT0FBTyxDQUFDLGNBQWMsS0FBSyxRQUFRLEVBQUUsQ0FBQztZQUN0RCxJQUFJLEdBQUc7Z0JBQ0wsY0FBYyxFQUFFLEdBQUcsQ0FBQyxXQUFXLENBQUMsVUFBVSxDQUFDLE9BQU8sQ0FBQyxjQUF3QixDQUFDO2FBQzdFLENBQUM7UUFDSixDQUFDO1FBQ0QsSUFBSSxPQUFPLE9BQU8sQ0FBQyxZQUFZLEtBQUssUUFBUSxFQUFFLENBQUM7WUFDN0MsSUFBSSxHQUFHO2dCQUNMLEdBQUcsSUFBSTtnQkFDUCxZQUFZLEVBQUUsR0FBRyxDQUFDLFdBQVcsQ0FBQyxVQUFVLENBQUMsT0FBTyxDQUFDLFlBQXNCLENBQUM7YUFDekUsQ0FBQztRQUNKLENBQUM7YUFBTSxJQUFJLE9BQU8sT0FBTyxDQUFDLFlBQVksS0FBSyxRQUFRLEVBQUUsQ0FBQztZQUNwRCxJQUFJLEdBQUc7Z0JBQ0wsR0FBRyxJQUFJO2dCQUNQLFlBQVksRUFBRSxHQUFHLENBQUMsV0FBVyxDQUFDLFVBQVUsQ0FBQyxPQUFPLENBQUMsWUFBc0IsQ0FBQzthQUN6RSxDQUFDO1FBQ0osQ0FBQztRQUNELElBQUksT0FBTyxDQUFDLGNBQWMsS0FBSyxTQUFTLElBQUksT0FBTyxDQUFDLFlBQVksS0FBSyxTQUFTLEVBQUUsQ0FBQztZQUMvRSxJQUFJLEdBQUc7Z0JBQ0wsWUFBWSxFQUFFLEdBQUcsQ0FBQyxXQUFXLENBQUMsVUFBVSxDQUFDLENBQUMsQ0FBQzthQUM1QyxDQUFDO1FBQ0osQ0FBQztRQUVELElBQUksR0FBRztZQUNMLEdBQUcsSUFBSTtZQUNQLFFBQVEsRUFBRSxFQUFFLFdBQVcsRUFBRSxhQUFhLEVBQUU7U0FDekMsQ0FBQztRQUNGLE1BQU0sVUFBVSxHQUFHO1lBQ2pCLEdBQUcsT0FBTyxDQUFDLE1BQU0sSUFBSSxFQUFFO1lBQ3ZCLDJCQUEyQixFQUFFLE9BQU87WUFDcEMsOEJBQThCLEVBQUUsYUFBYTtTQUM5QyxDQUFDO1FBRUYsSUFBSSxHQUFHLENBQUMsdUJBQXVCLENBQUMsSUFBSSxFQUFFLEtBQUssRUFBRTtZQUMzQyxRQUFRLEVBQUU7Z0JBQ1IsTUFBTSxFQUFFLFVBQVU7YUFDbkI7WUFDRCxJQUFJLEVBQUUsSUFBSTtTQUNYLENBQUMsQ0FBQztJQUNMLENBQUM7Q0FDRjtBQWpERCw0QkFpREMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb25zdHJ1Y3QgfSBmcm9tICdjb25zdHJ1Y3RzJztcbmltcG9ydCAqIGFzIGs4cyBmcm9tICcuL2ltcG9ydHMvazhzJztcblxuZXhwb3J0IGludGVyZmFjZSBQbG9uZVBEQk9wdGlvbnMge1xuICAvKipcbiAgICogbWF4VW5hdmFpbGFibGUgc3BlY2lmaWNhdGlvblxuICAgKiBAZGVmYXVsdCAtIG5vbmVcbiAgICovXG4gIHJlYWRvbmx5IG1heFVuYXZhaWxhYmxlPzogbnVtYmVyIHwgc3RyaW5nO1xuXG4gIC8qKlxuICAgKiBtaW5BdmFpbGFibGUgc3BlY2lmaWNhdGlvbi5cbiAgICogZGVmYXVsdCBvbmx5IHNldCBpZiBtYXhVbmF2YWlsYWJsZSBpcyBub3Qgc2V0LlxuICAgKiBAZGVmYXVsdCAxXG4gICAqL1xuICByZWFkb25seSBtaW5BdmFpbGFibGU/OiBudW1iZXIgfCBzdHJpbmc7XG5cbiAgLyoqXG4gICAqIEV4dHJhIGxhYmVscyB0byBhc3NvY2lhdGUgd2l0aCByZXNvdXJjZXMuXG4gICAqIEBkZWZhdWx0IC0gbm9uZVxuICAgKi9cbiAgcmVhZG9ubHkgbGFiZWxzPzogeyBbbmFtZTogc3RyaW5nXTogc3RyaW5nIH07XG59XG5cbmV4cG9ydCBjbGFzcyBQbG9uZVBEQiBleHRlbmRzIENvbnN0cnVjdCB7XG5cbiAgY29uc3RydWN0b3Ioc2NvcGU6IENvbnN0cnVjdCwgaWQ6IHN0cmluZywgc2VsZWN0b3JMYWJlbDogeyBbbmFtZTogc3RyaW5nXTogc3RyaW5nIH0sIG9wdGlvbnM6IFBsb25lUERCT3B0aW9ucykge1xuICAgIHN1cGVyKHNjb3BlLCBpZCk7XG5cbiAgICB2YXIgc3BlYzogazhzLlBvZERpc3J1cHRpb25CdWRnZXRTcGVjID0ge307XG4gICAgaWYgKHR5cGVvZiBvcHRpb25zLm1heFVuYXZhaWxhYmxlID09PSAnbnVtYmVyJykge1xuICAgICAgc3BlYyA9IHtcbiAgICAgICAgbWF4VW5hdmFpbGFibGU6IGs4cy5JbnRPclN0cmluZy5mcm9tTnVtYmVyKG9wdGlvbnMubWF4VW5hdmFpbGFibGUgYXMgbnVtYmVyKSxcbiAgICAgIH07XG4gICAgfSBlbHNlIGlmICh0eXBlb2Ygb3B0aW9ucy5tYXhVbmF2YWlsYWJsZSA9PT0gJ3N0cmluZycpIHtcbiAgICAgIHNwZWMgPSB7XG4gICAgICAgIG1heFVuYXZhaWxhYmxlOiBrOHMuSW50T3JTdHJpbmcuZnJvbVN0cmluZyhvcHRpb25zLm1heFVuYXZhaWxhYmxlIGFzIHN0cmluZyksXG4gICAgICB9O1xuICAgIH1cbiAgICBpZiAodHlwZW9mIG9wdGlvbnMubWluQXZhaWxhYmxlID09PSAnbnVtYmVyJykge1xuICAgICAgc3BlYyA9IHtcbiAgICAgICAgLi4uc3BlYyxcbiAgICAgICAgbWluQXZhaWxhYmxlOiBrOHMuSW50T3JTdHJpbmcuZnJvbU51bWJlcihvcHRpb25zLm1pbkF2YWlsYWJsZSBhcyBudW1iZXIpLFxuICAgICAgfTtcbiAgICB9IGVsc2UgaWYgKHR5cGVvZiBvcHRpb25zLm1pbkF2YWlsYWJsZSA9PT0gJ3N0cmluZycpIHtcbiAgICAgIHNwZWMgPSB7XG4gICAgICAgIC4uLnNwZWMsXG4gICAgICAgIG1pbkF2YWlsYWJsZTogazhzLkludE9yU3RyaW5nLmZyb21TdHJpbmcob3B0aW9ucy5taW5BdmFpbGFibGUgYXMgc3RyaW5nKSxcbiAgICAgIH07XG4gICAgfVxuICAgIGlmIChvcHRpb25zLm1heFVuYXZhaWxhYmxlID09PSB1bmRlZmluZWQgJiYgb3B0aW9ucy5taW5BdmFpbGFibGUgPT09IHVuZGVmaW5lZCkge1xuICAgICAgc3BlYyA9IHtcbiAgICAgICAgbWluQXZhaWxhYmxlOiBrOHMuSW50T3JTdHJpbmcuZnJvbU51bWJlcigxKSxcbiAgICAgIH07XG4gICAgfVxuXG4gICAgc3BlYyA9IHtcbiAgICAgIC4uLnNwZWMsXG4gICAgICBzZWxlY3RvcjogeyBtYXRjaExhYmVsczogc2VsZWN0b3JMYWJlbCB9LFxuICAgIH07XG4gICAgY29uc3QgcGRiX2xhYmVscyA9IHtcbiAgICAgIC4uLm9wdGlvbnMubGFiZWxzID8/IHt9LFxuICAgICAgJ2FwcC5rdWJlcm5ldGVzLmlvL3BhcnQtb2YnOiAncGxvbmUnLFxuICAgICAgJ2FwcC5rdWJlcm5ldGVzLmlvL21hbmFnZWQtYnknOiAnY2RrOHMtcGxvbmUnLFxuICAgIH07XG5cbiAgICBuZXcgazhzLkt1YmVQb2REaXNydXB0aW9uQnVkZ2V0KHRoaXMsICdQREInLCB7XG4gICAgICBtZXRhZGF0YToge1xuICAgICAgICBsYWJlbHM6IHBkYl9sYWJlbHMsXG4gICAgICB9LFxuICAgICAgc3BlYzogc3BlYyxcbiAgICB9KTtcbiAgfVxufVxuIl19
62
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGRiLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vc3JjL3BkYi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7QUFBQSwyQ0FBdUM7QUFDdkMscUNBQXFDO0FBK0JyQzs7Ozs7O0dBTUc7QUFDSCxNQUFhLFFBQVMsU0FBUSxzQkFBUztJQUVyQyxZQUFZLEtBQWdCLEVBQUUsRUFBVSxFQUFFLGFBQXlDLEVBQUUsT0FBd0I7UUFDM0csS0FBSyxDQUFDLEtBQUssRUFBRSxFQUFFLENBQUMsQ0FBQztRQUVqQixJQUFJLElBQUksR0FBZ0MsRUFBRSxDQUFDO1FBQzNDLElBQUksT0FBTyxPQUFPLENBQUMsY0FBYyxLQUFLLFFBQVEsRUFBRSxDQUFDO1lBQy9DLElBQUksR0FBRztnQkFDTCxjQUFjLEVBQUUsR0FBRyxDQUFDLFdBQVcsQ0FBQyxVQUFVLENBQUMsT0FBTyxDQUFDLGNBQXdCLENBQUM7YUFDN0UsQ0FBQztRQUNKLENBQUM7YUFBTSxJQUFJLE9BQU8sT0FBTyxDQUFDLGNBQWMsS0FBSyxRQUFRLEVBQUUsQ0FBQztZQUN0RCxJQUFJLEdBQUc7Z0JBQ0wsY0FBYyxFQUFFLEdBQUcsQ0FBQyxXQUFXLENBQUMsVUFBVSxDQUFDLE9BQU8sQ0FBQyxjQUF3QixDQUFDO2FBQzdFLENBQUM7UUFDSixDQUFDO1FBQ0QsSUFBSSxPQUFPLE9BQU8sQ0FBQyxZQUFZLEtBQUssUUFBUSxFQUFFLENBQUM7WUFDN0MsSUFBSSxHQUFHO2dCQUNMLEdBQUcsSUFBSTtnQkFDUCxZQUFZLEVBQUUsR0FBRyxDQUFDLFdBQVcsQ0FBQyxVQUFVLENBQUMsT0FBTyxDQUFDLFlBQXNCLENBQUM7YUFDekUsQ0FBQztRQUNKLENBQUM7YUFBTSxJQUFJLE9BQU8sT0FBTyxDQUFDLFlBQVksS0FBSyxRQUFRLEVBQUUsQ0FBQztZQUNwRCxJQUFJLEdBQUc7Z0JBQ0wsR0FBRyxJQUFJO2dCQUNQLFlBQVksRUFBRSxHQUFHLENBQUMsV0FBVyxDQUFDLFVBQVUsQ0FBQyxPQUFPLENBQUMsWUFBc0IsQ0FBQzthQUN6RSxDQUFDO1FBQ0osQ0FBQztRQUNELElBQUksT0FBTyxDQUFDLGNBQWMsS0FBSyxTQUFTLElBQUksT0FBTyxDQUFDLFlBQVksS0FBSyxTQUFTLEVBQUUsQ0FBQztZQUMvRSxJQUFJLEdBQUc7Z0JBQ0wsWUFBWSxFQUFFLEdBQUcsQ0FBQyxXQUFXLENBQUMsVUFBVSxDQUFDLENBQUMsQ0FBQzthQUM1QyxDQUFDO1FBQ0osQ0FBQztRQUVELElBQUksR0FBRztZQUNMLEdBQUcsSUFBSTtZQUNQLFFBQVEsRUFBRSxFQUFFLFdBQVcsRUFBRSxhQUFhLEVBQUU7U0FDekMsQ0FBQztRQUNGLE1BQU0sVUFBVSxHQUFHO1lBQ2pCLEdBQUcsT0FBTyxDQUFDLE1BQU0sSUFBSSxFQUFFO1lBQ3ZCLDJCQUEyQixFQUFFLE9BQU87WUFDcEMsOEJBQThCLEVBQUUsYUFBYTtTQUM5QyxDQUFDO1FBRUYsSUFBSSxHQUFHLENBQUMsdUJBQXVCLENBQUMsSUFBSSxFQUFFLEtBQUssRUFBRTtZQUMzQyxRQUFRLEVBQUU7Z0JBQ1IsTUFBTSxFQUFFLFVBQVU7YUFDbkI7WUFDRCxJQUFJLEVBQUUsSUFBSTtTQUNYLENBQUMsQ0FBQztJQUNMLENBQUM7Q0FDRjtBQWpERCw0QkFpREMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb25zdHJ1Y3QgfSBmcm9tICdjb25zdHJ1Y3RzJztcbmltcG9ydCAqIGFzIGs4cyBmcm9tICcuL2ltcG9ydHMvazhzJztcblxuLyoqXG4gKiBDb25maWd1cmF0aW9uIG9wdGlvbnMgZm9yIFBvZERpc3J1cHRpb25CdWRnZXQuXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgUGxvbmVQREJPcHRpb25zIHtcbiAgLyoqXG4gICAqIE1heGltdW0gbnVtYmVyIG9yIHBlcmNlbnRhZ2Ugb2YgcG9kcyB0aGF0IGNhbiBiZSB1bmF2YWlsYWJsZSBkdXJpbmcgdm9sdW50YXJ5IGRpc3J1cHRpb25zLlxuICAgKiBDYW4gYmUgYW4gYWJzb2x1dGUgbnVtYmVyIChlLmcuLCAxKSBvciBhIHBlcmNlbnRhZ2UgKGUuZy4sICc1MCUnKS5cbiAgICogQ2Fubm90IGJlIHVzZWQgdG9nZXRoZXIgd2l0aCBtaW5BdmFpbGFibGUuXG4gICAqIEBleGFtcGxlIDEgb3IgJzI1JSdcbiAgICogQGRlZmF1bHQgLSBub3Qgc2V0IChkZWZhdWx0cyB0byBtaW5BdmFpbGFibGU9MSBpZiBuZWl0aGVyIGlzIHNwZWNpZmllZClcbiAgICovXG4gIHJlYWRvbmx5IG1heFVuYXZhaWxhYmxlPzogbnVtYmVyIHwgc3RyaW5nO1xuXG4gIC8qKlxuICAgKiBNaW5pbXVtIG51bWJlciBvciBwZXJjZW50YWdlIG9mIHBvZHMgdGhhdCBtdXN0IHJlbWFpbiBhdmFpbGFibGUgZHVyaW5nIHZvbHVudGFyeSBkaXNydXB0aW9ucy5cbiAgICogQ2FuIGJlIGFuIGFic29sdXRlIG51bWJlciAoZS5nLiwgMSkgb3IgYSBwZXJjZW50YWdlIChlLmcuLCAnNTAlJykuXG4gICAqIENhbm5vdCBiZSB1c2VkIHRvZ2V0aGVyIHdpdGggbWF4VW5hdmFpbGFibGUuXG4gICAqIEBleGFtcGxlIDIgb3IgJzUwJSdcbiAgICogQGRlZmF1bHQgMSAoaWYgbWF4VW5hdmFpbGFibGUgaXMgbm90IHNldClcbiAgICovXG4gIHJlYWRvbmx5IG1pbkF2YWlsYWJsZT86IG51bWJlciB8IHN0cmluZztcblxuICAvKipcbiAgICogQWRkaXRpb25hbCBLdWJlcm5ldGVzIGxhYmVscyBmb3IgdGhlIFBvZERpc3J1cHRpb25CdWRnZXQuXG4gICAqIEBkZWZhdWx0IC0gc3RhbmRhcmQgUGxvbmUgbGFiZWxzIG9ubHlcbiAgICovXG4gIHJlYWRvbmx5IGxhYmVscz86IHsgW25hbWU6IHN0cmluZ106IHN0cmluZyB9O1xufVxuXG4vKipcbiAqIFBsb25lUERCIGNyZWF0ZXMgYSBLdWJlcm5ldGVzIFBvZERpc3J1cHRpb25CdWRnZXQgZm9yIGhpZ2ggYXZhaWxhYmlsaXR5LlxuICpcbiAqIFRoaXMgaXMgYW4gaW50ZXJuYWwgY29uc3RydWN0IHVzZWQgYnkgUGxvbmVEZXBsb3ltZW50LlxuICogSXQgZW5zdXJlcyBhIG1pbmltdW0gbnVtYmVyIG9mIHBvZHMgcmVtYWluIGF2YWlsYWJsZSBkdXJpbmcgdm9sdW50YXJ5XG4gKiBkaXNydXB0aW9ucyBsaWtlIG5vZGUgZHJhaW5zIG9yIGNsdXN0ZXIgdXBncmFkZXMuXG4gKi9cbmV4cG9ydCBjbGFzcyBQbG9uZVBEQiBleHRlbmRzIENvbnN0cnVjdCB7XG5cbiAgY29uc3RydWN0b3Ioc2NvcGU6IENvbnN0cnVjdCwgaWQ6IHN0cmluZywgc2VsZWN0b3JMYWJlbDogeyBbbmFtZTogc3RyaW5nXTogc3RyaW5nIH0sIG9wdGlvbnM6IFBsb25lUERCT3B0aW9ucykge1xuICAgIHN1cGVyKHNjb3BlLCBpZCk7XG5cbiAgICB2YXIgc3BlYzogazhzLlBvZERpc3J1cHRpb25CdWRnZXRTcGVjID0ge307XG4gICAgaWYgKHR5cGVvZiBvcHRpb25zLm1heFVuYXZhaWxhYmxlID09PSAnbnVtYmVyJykge1xuICAgICAgc3BlYyA9IHtcbiAgICAgICAgbWF4VW5hdmFpbGFibGU6IGs4cy5JbnRPclN0cmluZy5mcm9tTnVtYmVyKG9wdGlvbnMubWF4VW5hdmFpbGFibGUgYXMgbnVtYmVyKSxcbiAgICAgIH07XG4gICAgfSBlbHNlIGlmICh0eXBlb2Ygb3B0aW9ucy5tYXhVbmF2YWlsYWJsZSA9PT0gJ3N0cmluZycpIHtcbiAgICAgIHNwZWMgPSB7XG4gICAgICAgIG1heFVuYXZhaWxhYmxlOiBrOHMuSW50T3JTdHJpbmcuZnJvbVN0cmluZyhvcHRpb25zLm1heFVuYXZhaWxhYmxlIGFzIHN0cmluZyksXG4gICAgICB9O1xuICAgIH1cbiAgICBpZiAodHlwZW9mIG9wdGlvbnMubWluQXZhaWxhYmxlID09PSAnbnVtYmVyJykge1xuICAgICAgc3BlYyA9IHtcbiAgICAgICAgLi4uc3BlYyxcbiAgICAgICAgbWluQXZhaWxhYmxlOiBrOHMuSW50T3JTdHJpbmcuZnJvbU51bWJlcihvcHRpb25zLm1pbkF2YWlsYWJsZSBhcyBudW1iZXIpLFxuICAgICAgfTtcbiAgICB9IGVsc2UgaWYgKHR5cGVvZiBvcHRpb25zLm1pbkF2YWlsYWJsZSA9PT0gJ3N0cmluZycpIHtcbiAgICAgIHNwZWMgPSB7XG4gICAgICAgIC4uLnNwZWMsXG4gICAgICAgIG1pbkF2YWlsYWJsZTogazhzLkludE9yU3RyaW5nLmZyb21TdHJpbmcob3B0aW9ucy5taW5BdmFpbGFibGUgYXMgc3RyaW5nKSxcbiAgICAgIH07XG4gICAgfVxuICAgIGlmIChvcHRpb25zLm1heFVuYXZhaWxhYmxlID09PSB1bmRlZmluZWQgJiYgb3B0aW9ucy5taW5BdmFpbGFibGUgPT09IHVuZGVmaW5lZCkge1xuICAgICAgc3BlYyA9IHtcbiAgICAgICAgbWluQXZhaWxhYmxlOiBrOHMuSW50T3JTdHJpbmcuZnJvbU51bWJlcigxKSxcbiAgICAgIH07XG4gICAgfVxuXG4gICAgc3BlYyA9IHtcbiAgICAgIC4uLnNwZWMsXG4gICAgICBzZWxlY3RvcjogeyBtYXRjaExhYmVsczogc2VsZWN0b3JMYWJlbCB9LFxuICAgIH07XG4gICAgY29uc3QgcGRiX2xhYmVscyA9IHtcbiAgICAgIC4uLm9wdGlvbnMubGFiZWxzID8/IHt9LFxuICAgICAgJ2FwcC5rdWJlcm5ldGVzLmlvL3BhcnQtb2YnOiAncGxvbmUnLFxuICAgICAgJ2FwcC5rdWJlcm5ldGVzLmlvL21hbmFnZWQtYnknOiAnY2RrOHMtcGxvbmUnLFxuICAgIH07XG5cbiAgICBuZXcgazhzLkt1YmVQb2REaXNydXB0aW9uQnVkZ2V0KHRoaXMsICdQREInLCB7XG4gICAgICBtZXRhZGF0YToge1xuICAgICAgICBsYWJlbHM6IHBkYl9sYWJlbHMsXG4gICAgICB9LFxuICAgICAgc3BlYzogc3BlYyxcbiAgICB9KTtcbiAgfVxufVxuIl19
package/lib/plone.d.ts CHANGED
@@ -1,45 +1,258 @@
1
1
  import * as kplus from 'cdk8s-plus-30';
2
2
  import { Construct } from 'constructs';
3
+ /**
4
+ * Base options for Plone backend or frontend configuration.
5
+ * These options control container image, replica count, resource limits,
6
+ * environment variables, and health probes.
7
+ */
3
8
  export interface PloneBaseOptions {
9
+ /**
10
+ * Container image to use for the deployment.
11
+ * @example 'plone/plone-backend:6.0.10' or 'plone/plone-frontend:16.0.0'
12
+ * @default - 'plone/plone-backend:latest' for backend, 'plone/plone-frontend:latest' for frontend
13
+ */
4
14
  readonly image?: string;
15
+ /**
16
+ * Image pull policy for the container.
17
+ * @default 'IfNotPresent'
18
+ */
5
19
  readonly imagePullPolicy?: string;
20
+ /**
21
+ * Number of pod replicas to run.
22
+ * @default 2
23
+ */
6
24
  readonly replicas?: number;
25
+ /**
26
+ * Maximum number of pods that can be unavailable during updates.
27
+ * Can be an absolute number (e.g., 1) or a percentage (e.g., '50%').
28
+ * Used in PodDisruptionBudget if specified.
29
+ * @default - undefined (not set)
30
+ */
7
31
  readonly maxUnavailable?: number | string;
32
+ /**
33
+ * Minimum number of pods that must be available during updates.
34
+ * Can be an absolute number (e.g., 1) or a percentage (e.g., '50%').
35
+ * Used in PodDisruptionBudget if specified.
36
+ * @default - undefined (not set)
37
+ */
8
38
  readonly minAvailable?: number | string;
39
+ /**
40
+ * CPU limit for the container.
41
+ * @example '500m' or '1' or '2000m'
42
+ * @default '500m' for both backend and frontend
43
+ */
9
44
  readonly limitCpu?: string;
45
+ /**
46
+ * Memory limit for the container.
47
+ * @example '512Mi' or '1Gi'
48
+ * @default '512Mi' for backend, '1Gi' for frontend
49
+ */
10
50
  readonly limitMemory?: string;
51
+ /**
52
+ * CPU request for the container.
53
+ * @example '200m' or '0.5'
54
+ * @default '200m'
55
+ */
11
56
  readonly requestCpu?: string;
57
+ /**
58
+ * Memory request for the container.
59
+ * @example '256Mi' or '512Mi'
60
+ * @default '256Mi'
61
+ */
12
62
  readonly requestMemory?: string;
63
+ /**
64
+ * Environment variables to set in the container.
65
+ * Use cdk8s-plus-30 Env class to define variables and sources.
66
+ * @default - undefined (no additional environment variables)
67
+ */
13
68
  readonly environment?: kplus.Env;
69
+ /**
70
+ * Enable readiness probe for the container.
71
+ * Readiness probes determine when a container is ready to accept traffic.
72
+ * @default true
73
+ */
14
74
  readonly readinessEnabled?: boolean;
75
+ /**
76
+ * Number of seconds after container start before readiness probe is initiated.
77
+ * @default 10
78
+ */
15
79
  readonly readinessInitialDelaySeconds?: number;
16
- readonly readinessIimeoutSeconds?: number;
80
+ /**
81
+ * Number of seconds after which the readiness probe times out.
82
+ * @default 15
83
+ */
84
+ readonly readinessTimeoutSeconds?: number;
85
+ /**
86
+ * How often (in seconds) to perform the readiness probe.
87
+ * @default 10
88
+ */
17
89
  readonly readinessPeriodSeconds?: number;
90
+ /**
91
+ * Minimum consecutive successes for the readiness probe to be considered successful.
92
+ * @default 1
93
+ */
18
94
  readonly readinessSuccessThreshold?: number;
95
+ /**
96
+ * Minimum consecutive failures for the readiness probe to be considered failed.
97
+ * @default 3
98
+ */
19
99
  readonly readinessFailureThreshold?: number;
100
+ /**
101
+ * Enable liveness probe for the container.
102
+ * Liveness probes determine when to restart a container.
103
+ * Recommended: true for frontend, false for backend (Zope has its own recovery).
104
+ * @default false
105
+ */
20
106
  readonly livenessEnabled?: boolean;
107
+ /**
108
+ * Number of seconds after container start before liveness probe is initiated.
109
+ * @default 30
110
+ */
21
111
  readonly livenessInitialDelaySeconds?: number;
22
- readonly livenessIimeoutSeconds?: number;
112
+ /**
113
+ * Number of seconds after which the liveness probe times out.
114
+ * @default 5
115
+ */
116
+ readonly livenessTimeoutSeconds?: number;
117
+ /**
118
+ * How often (in seconds) to perform the liveness probe.
119
+ * @default 10
120
+ */
23
121
  readonly livenessPeriodSeconds?: number;
122
+ /**
123
+ * Minimum consecutive successes for the liveness probe to be considered successful.
124
+ * @default 1
125
+ */
24
126
  readonly livenessSuccessThreshold?: number;
127
+ /**
128
+ * Minimum consecutive failures for the liveness probe to be considered failed.
129
+ * @default 3
130
+ */
25
131
  readonly livenessFailureThreshold?: number;
132
+ /**
133
+ * Annotations to add to the Deployment metadata.
134
+ * @example { 'deployment.kubernetes.io/revision': '1' }
135
+ * @default - no additional annotations
136
+ */
137
+ readonly annotations?: {
138
+ [name: string]: string;
139
+ };
140
+ /**
141
+ * Annotations to add to the Pod template metadata.
142
+ * Common for Prometheus, Istio, backup policies, etc.
143
+ * @example { 'prometheus.io/scrape': 'true', 'prometheus.io/port': '8080' }
144
+ * @default - no additional annotations
145
+ */
146
+ readonly podAnnotations?: {
147
+ [name: string]: string;
148
+ };
149
+ /**
150
+ * Annotations to add to the Service metadata.
151
+ * Common for external-dns, load balancers, service mesh, etc.
152
+ * @example { 'external-dns.alpha.kubernetes.io/hostname': 'plone.example.com' }
153
+ * @default - no additional annotations
154
+ */
155
+ readonly serviceAnnotations?: {
156
+ [name: string]: string;
157
+ };
26
158
  }
159
+ /**
160
+ * Plone deployment variants.
161
+ */
27
162
  export declare enum PloneVariant {
163
+ /**
164
+ * Volto variant: ReactJS frontend (Volto) with REST API backend.
165
+ * Deploys both frontend and backend services.
166
+ */
28
167
  VOLTO = "volto",
168
+ /**
169
+ * Classic UI variant: Traditional Plone with server-side rendering.
170
+ * Deploys only the backend service.
171
+ */
29
172
  CLASSICUI = "classicui"
30
173
  }
174
+ /**
175
+ * Main configuration options for Plone deployment.
176
+ */
31
177
  export interface PloneOptions {
178
+ /**
179
+ * Version string for labeling the deployment.
180
+ * This is used in Kubernetes labels and doesn't affect the actual image versions.
181
+ * @default 'undefined'
182
+ */
32
183
  readonly version?: string;
184
+ /**
185
+ * Plone site ID in the ZODB.
186
+ * This is used to construct the internal API path for Volto frontend.
187
+ * @default 'Plone'
188
+ */
33
189
  readonly siteId?: string;
190
+ /**
191
+ * Plone deployment variant to use.
192
+ * @default PloneVariant.VOLTO
193
+ */
34
194
  readonly variant?: PloneVariant;
195
+ /**
196
+ * Backend (Plone API) configuration.
197
+ * @default {} (uses default values from PloneBaseOptions)
198
+ */
35
199
  readonly backend?: PloneBaseOptions;
200
+ /**
201
+ * Frontend (Volto) configuration.
202
+ * Only used when variant is PloneVariant.VOLTO.
203
+ * @default {} (uses default values from PloneBaseOptions)
204
+ */
36
205
  readonly frontend?: PloneBaseOptions;
206
+ /**
207
+ * Names of Kubernetes secrets to use for pulling private container images.
208
+ * These secrets must exist in the same namespace as the deployment.
209
+ * @example ['my-registry-secret']
210
+ * @default [] (no image pull secrets)
211
+ */
37
212
  readonly imagePullSecrets?: string[];
38
213
  }
214
+ /**
215
+ * Plone construct for deploying Plone CMS to Kubernetes.
216
+ *
217
+ * This construct creates all necessary Kubernetes resources for running Plone:
218
+ * - Deployment(s) for backend (and optionally frontend)
219
+ * - Service(s) for network access
220
+ * - Optional PodDisruptionBudget for high availability
221
+ *
222
+ * Supports two deployment variants:
223
+ * - VOLTO: Modern React frontend with REST API backend (default)
224
+ * - CLASSICUI: Traditional server-side rendered Plone
225
+ *
226
+ * @example
227
+ * new Plone(chart, 'my-plone', {
228
+ * variant: PloneVariant.VOLTO,
229
+ * backend: {
230
+ * image: 'plone/plone-backend:6.0.10',
231
+ * replicas: 3,
232
+ * },
233
+ * frontend: {
234
+ * image: 'plone/plone-frontend:16.0.0',
235
+ * },
236
+ * });
237
+ */
39
238
  export declare class Plone extends Construct {
239
+ /**
240
+ * Name of the backend Kubernetes service.
241
+ * Use this to reference the backend service from other constructs.
242
+ */
40
243
  readonly backendServiceName: string;
244
+ /**
245
+ * Name of the frontend Kubernetes service.
246
+ * Only set when variant is VOLTO, otherwise undefined.
247
+ */
41
248
  readonly frontendServiceName: string | undefined;
249
+ /**
250
+ * The deployment variant being used (VOLTO or CLASSICUI).
251
+ */
42
252
  readonly variant: PloneVariant;
253
+ /**
254
+ * The Plone site ID in ZODB.
255
+ */
43
256
  readonly siteId: string;
44
257
  constructor(scope: Construct, id: string, options?: PloneOptions);
45
258
  }