@bluedynamics/cdk8s-plone 0.1.28 → 0.1.30
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 +276 -46
- package/API.md +196 -0
- package/lib/deployment.d.ts +7 -0
- package/lib/deployment.js +2 -1
- package/lib/httpcache.js +1 -1
- package/lib/imports/vinyl.bluedynamics.eu.d.ts +154 -2
- package/lib/imports/vinyl.bluedynamics.eu.js +104 -2
- package/lib/index.d.ts +1 -1
- package/lib/index.js +1 -1
- package/lib/plone.d.ts +64 -0
- package/lib/plone.js +4 -2
- package/lib/vinylcache.js +1 -1
- package/package.json +30 -30
package/API.md
CHANGED
|
@@ -726,6 +726,7 @@ const ploneBaseOptions: PloneBaseOptions = { ... }
|
|
|
726
726
|
| <code><a href="#@bluedynamics/cdk8s-plone.PloneBaseOptions.property.replicas">replicas</a></code> | <code>number</code> | Number of pod replicas to run. |
|
|
727
727
|
| <code><a href="#@bluedynamics/cdk8s-plone.PloneBaseOptions.property.requestCpu">requestCpu</a></code> | <code>string</code> | CPU request for the container. |
|
|
728
728
|
| <code><a href="#@bluedynamics/cdk8s-plone.PloneBaseOptions.property.requestMemory">requestMemory</a></code> | <code>string</code> | Memory request for the container. |
|
|
729
|
+
| <code><a href="#@bluedynamics/cdk8s-plone.PloneBaseOptions.property.securityContext">securityContext</a></code> | <code><a href="#@bluedynamics/cdk8s-plone.PloneSecurityContext">PloneSecurityContext</a></code> | Security context for the container. |
|
|
729
730
|
| <code><a href="#@bluedynamics/cdk8s-plone.PloneBaseOptions.property.serviceAnnotations">serviceAnnotations</a></code> | <code>{[ key: string ]: string}</code> | Annotations to add to the Service metadata. |
|
|
730
731
|
| <code><a href="#@bluedynamics/cdk8s-plone.PloneBaseOptions.property.servicemonitor">servicemonitor</a></code> | <code>boolean</code> | Enable Prometheus ServiceMonitor for metrics collection. |
|
|
731
732
|
|
|
@@ -1159,6 +1160,28 @@ Memory request for the container.
|
|
|
1159
1160
|
```
|
|
1160
1161
|
|
|
1161
1162
|
|
|
1163
|
+
##### `securityContext`<sup>Optional</sup> <a name="securityContext" id="@bluedynamics/cdk8s-plone.PloneBaseOptions.property.securityContext"></a>
|
|
1164
|
+
|
|
1165
|
+
```typescript
|
|
1166
|
+
public readonly securityContext: PloneSecurityContext;
|
|
1167
|
+
```
|
|
1168
|
+
|
|
1169
|
+
- *Type:* <a href="#@bluedynamics/cdk8s-plone.PloneSecurityContext">PloneSecurityContext</a>
|
|
1170
|
+
- *Default:* no security context
|
|
1171
|
+
|
|
1172
|
+
Security context for the container.
|
|
1173
|
+
|
|
1174
|
+
Use to set capabilities, run as non-root, read-only filesystem, etc.
|
|
1175
|
+
|
|
1176
|
+
---
|
|
1177
|
+
|
|
1178
|
+
*Example*
|
|
1179
|
+
|
|
1180
|
+
```typescript
|
|
1181
|
+
{ capabilities: { add: ['SYS_PTRACE'] } }
|
|
1182
|
+
```
|
|
1183
|
+
|
|
1184
|
+
|
|
1162
1185
|
##### `serviceAnnotations`<sup>Optional</sup> <a name="serviceAnnotations" id="@bluedynamics/cdk8s-plone.PloneBaseOptions.property.serviceAnnotations"></a>
|
|
1163
1186
|
|
|
1164
1187
|
```typescript
|
|
@@ -1197,6 +1220,53 @@ When enabled, a ServiceMonitor resource will be created to scrape metrics.
|
|
|
1197
1220
|
|
|
1198
1221
|
---
|
|
1199
1222
|
|
|
1223
|
+
### PloneCapabilities <a name="PloneCapabilities" id="@bluedynamics/cdk8s-plone.PloneCapabilities"></a>
|
|
1224
|
+
|
|
1225
|
+
Linux capabilities to add or drop on a container.
|
|
1226
|
+
|
|
1227
|
+
#### Initializer <a name="Initializer" id="@bluedynamics/cdk8s-plone.PloneCapabilities.Initializer"></a>
|
|
1228
|
+
|
|
1229
|
+
```typescript
|
|
1230
|
+
import { PloneCapabilities } from '@bluedynamics/cdk8s-plone'
|
|
1231
|
+
|
|
1232
|
+
const ploneCapabilities: PloneCapabilities = { ... }
|
|
1233
|
+
```
|
|
1234
|
+
|
|
1235
|
+
#### Properties <a name="Properties" id="Properties"></a>
|
|
1236
|
+
|
|
1237
|
+
| **Name** | **Type** | **Description** |
|
|
1238
|
+
| --- | --- | --- |
|
|
1239
|
+
| <code><a href="#@bluedynamics/cdk8s-plone.PloneCapabilities.property.add">add</a></code> | <code>string[]</code> | Capabilities to add (e.g. 'SYS_PTRACE', 'NET_ADMIN'). |
|
|
1240
|
+
| <code><a href="#@bluedynamics/cdk8s-plone.PloneCapabilities.property.drop">drop</a></code> | <code>string[]</code> | Capabilities to drop (e.g. 'ALL', 'NET_RAW'). |
|
|
1241
|
+
|
|
1242
|
+
---
|
|
1243
|
+
|
|
1244
|
+
##### `add`<sup>Optional</sup> <a name="add" id="@bluedynamics/cdk8s-plone.PloneCapabilities.property.add"></a>
|
|
1245
|
+
|
|
1246
|
+
```typescript
|
|
1247
|
+
public readonly add: string[];
|
|
1248
|
+
```
|
|
1249
|
+
|
|
1250
|
+
- *Type:* string[]
|
|
1251
|
+
- *Default:* no capabilities added
|
|
1252
|
+
|
|
1253
|
+
Capabilities to add (e.g. 'SYS_PTRACE', 'NET_ADMIN').
|
|
1254
|
+
|
|
1255
|
+
---
|
|
1256
|
+
|
|
1257
|
+
##### `drop`<sup>Optional</sup> <a name="drop" id="@bluedynamics/cdk8s-plone.PloneCapabilities.property.drop"></a>
|
|
1258
|
+
|
|
1259
|
+
```typescript
|
|
1260
|
+
public readonly drop: string[];
|
|
1261
|
+
```
|
|
1262
|
+
|
|
1263
|
+
- *Type:* string[]
|
|
1264
|
+
- *Default:* no capabilities dropped
|
|
1265
|
+
|
|
1266
|
+
Capabilities to drop (e.g. 'ALL', 'NET_RAW').
|
|
1267
|
+
|
|
1268
|
+
---
|
|
1269
|
+
|
|
1200
1270
|
### PloneHttpcacheOptions <a name="PloneHttpcacheOptions" id="@bluedynamics/cdk8s-plone.PloneHttpcacheOptions"></a>
|
|
1201
1271
|
|
|
1202
1272
|
Configuration options for PloneHttpcache (Varnish caching layer).
|
|
@@ -1565,6 +1635,132 @@ This is used in Kubernetes labels and doesn't affect the actual image versions.
|
|
|
1565
1635
|
|
|
1566
1636
|
---
|
|
1567
1637
|
|
|
1638
|
+
### PloneSecurityContext <a name="PloneSecurityContext" id="@bluedynamics/cdk8s-plone.PloneSecurityContext"></a>
|
|
1639
|
+
|
|
1640
|
+
Security context for a Plone container.
|
|
1641
|
+
|
|
1642
|
+
Controls privilege and access settings.
|
|
1643
|
+
|
|
1644
|
+
#### Initializer <a name="Initializer" id="@bluedynamics/cdk8s-plone.PloneSecurityContext.Initializer"></a>
|
|
1645
|
+
|
|
1646
|
+
```typescript
|
|
1647
|
+
import { PloneSecurityContext } from '@bluedynamics/cdk8s-plone'
|
|
1648
|
+
|
|
1649
|
+
const ploneSecurityContext: PloneSecurityContext = { ... }
|
|
1650
|
+
```
|
|
1651
|
+
|
|
1652
|
+
#### Properties <a name="Properties" id="Properties"></a>
|
|
1653
|
+
|
|
1654
|
+
| **Name** | **Type** | **Description** |
|
|
1655
|
+
| --- | --- | --- |
|
|
1656
|
+
| <code><a href="#@bluedynamics/cdk8s-plone.PloneSecurityContext.property.allowPrivilegeEscalation">allowPrivilegeEscalation</a></code> | <code>boolean</code> | Allow privilege escalation for the container process. |
|
|
1657
|
+
| <code><a href="#@bluedynamics/cdk8s-plone.PloneSecurityContext.property.capabilities">capabilities</a></code> | <code><a href="#@bluedynamics/cdk8s-plone.PloneCapabilities">PloneCapabilities</a></code> | Linux capabilities to add or drop. |
|
|
1658
|
+
| <code><a href="#@bluedynamics/cdk8s-plone.PloneSecurityContext.property.privileged">privileged</a></code> | <code>boolean</code> | Run the container in privileged mode. |
|
|
1659
|
+
| <code><a href="#@bluedynamics/cdk8s-plone.PloneSecurityContext.property.readOnlyRootFilesystem">readOnlyRootFilesystem</a></code> | <code>boolean</code> | Mount the root filesystem as read-only. |
|
|
1660
|
+
| <code><a href="#@bluedynamics/cdk8s-plone.PloneSecurityContext.property.runAsGroup">runAsGroup</a></code> | <code>number</code> | Run the container as a specific group ID. |
|
|
1661
|
+
| <code><a href="#@bluedynamics/cdk8s-plone.PloneSecurityContext.property.runAsNonRoot">runAsNonRoot</a></code> | <code>boolean</code> | Require the container to run as non-root. |
|
|
1662
|
+
| <code><a href="#@bluedynamics/cdk8s-plone.PloneSecurityContext.property.runAsUser">runAsUser</a></code> | <code>number</code> | Run the container as a specific user ID. |
|
|
1663
|
+
|
|
1664
|
+
---
|
|
1665
|
+
|
|
1666
|
+
##### `allowPrivilegeEscalation`<sup>Optional</sup> <a name="allowPrivilegeEscalation" id="@bluedynamics/cdk8s-plone.PloneSecurityContext.property.allowPrivilegeEscalation"></a>
|
|
1667
|
+
|
|
1668
|
+
```typescript
|
|
1669
|
+
public readonly allowPrivilegeEscalation: boolean;
|
|
1670
|
+
```
|
|
1671
|
+
|
|
1672
|
+
- *Type:* boolean
|
|
1673
|
+
- *Default:* undefined
|
|
1674
|
+
|
|
1675
|
+
Allow privilege escalation for the container process.
|
|
1676
|
+
|
|
1677
|
+
---
|
|
1678
|
+
|
|
1679
|
+
##### `capabilities`<sup>Optional</sup> <a name="capabilities" id="@bluedynamics/cdk8s-plone.PloneSecurityContext.property.capabilities"></a>
|
|
1680
|
+
|
|
1681
|
+
```typescript
|
|
1682
|
+
public readonly capabilities: PloneCapabilities;
|
|
1683
|
+
```
|
|
1684
|
+
|
|
1685
|
+
- *Type:* <a href="#@bluedynamics/cdk8s-plone.PloneCapabilities">PloneCapabilities</a>
|
|
1686
|
+
- *Default:* no capability changes
|
|
1687
|
+
|
|
1688
|
+
Linux capabilities to add or drop.
|
|
1689
|
+
|
|
1690
|
+
---
|
|
1691
|
+
|
|
1692
|
+
*Example*
|
|
1693
|
+
|
|
1694
|
+
```typescript
|
|
1695
|
+
{ add: ['SYS_PTRACE'] }
|
|
1696
|
+
```
|
|
1697
|
+
|
|
1698
|
+
|
|
1699
|
+
##### `privileged`<sup>Optional</sup> <a name="privileged" id="@bluedynamics/cdk8s-plone.PloneSecurityContext.property.privileged"></a>
|
|
1700
|
+
|
|
1701
|
+
```typescript
|
|
1702
|
+
public readonly privileged: boolean;
|
|
1703
|
+
```
|
|
1704
|
+
|
|
1705
|
+
- *Type:* boolean
|
|
1706
|
+
- *Default:* undefined
|
|
1707
|
+
|
|
1708
|
+
Run the container in privileged mode.
|
|
1709
|
+
|
|
1710
|
+
---
|
|
1711
|
+
|
|
1712
|
+
##### `readOnlyRootFilesystem`<sup>Optional</sup> <a name="readOnlyRootFilesystem" id="@bluedynamics/cdk8s-plone.PloneSecurityContext.property.readOnlyRootFilesystem"></a>
|
|
1713
|
+
|
|
1714
|
+
```typescript
|
|
1715
|
+
public readonly readOnlyRootFilesystem: boolean;
|
|
1716
|
+
```
|
|
1717
|
+
|
|
1718
|
+
- *Type:* boolean
|
|
1719
|
+
- *Default:* undefined
|
|
1720
|
+
|
|
1721
|
+
Mount the root filesystem as read-only.
|
|
1722
|
+
|
|
1723
|
+
---
|
|
1724
|
+
|
|
1725
|
+
##### `runAsGroup`<sup>Optional</sup> <a name="runAsGroup" id="@bluedynamics/cdk8s-plone.PloneSecurityContext.property.runAsGroup"></a>
|
|
1726
|
+
|
|
1727
|
+
```typescript
|
|
1728
|
+
public readonly runAsGroup: number;
|
|
1729
|
+
```
|
|
1730
|
+
|
|
1731
|
+
- *Type:* number
|
|
1732
|
+
- *Default:* container default
|
|
1733
|
+
|
|
1734
|
+
Run the container as a specific group ID.
|
|
1735
|
+
|
|
1736
|
+
---
|
|
1737
|
+
|
|
1738
|
+
##### `runAsNonRoot`<sup>Optional</sup> <a name="runAsNonRoot" id="@bluedynamics/cdk8s-plone.PloneSecurityContext.property.runAsNonRoot"></a>
|
|
1739
|
+
|
|
1740
|
+
```typescript
|
|
1741
|
+
public readonly runAsNonRoot: boolean;
|
|
1742
|
+
```
|
|
1743
|
+
|
|
1744
|
+
- *Type:* boolean
|
|
1745
|
+
- *Default:* undefined
|
|
1746
|
+
|
|
1747
|
+
Require the container to run as non-root.
|
|
1748
|
+
|
|
1749
|
+
---
|
|
1750
|
+
|
|
1751
|
+
##### `runAsUser`<sup>Optional</sup> <a name="runAsUser" id="@bluedynamics/cdk8s-plone.PloneSecurityContext.property.runAsUser"></a>
|
|
1752
|
+
|
|
1753
|
+
```typescript
|
|
1754
|
+
public readonly runAsUser: number;
|
|
1755
|
+
```
|
|
1756
|
+
|
|
1757
|
+
- *Type:* number
|
|
1758
|
+
- *Default:* container default
|
|
1759
|
+
|
|
1760
|
+
Run the container as a specific user ID.
|
|
1761
|
+
|
|
1762
|
+
---
|
|
1763
|
+
|
|
1568
1764
|
### PloneVinylCacheOptions <a name="PloneVinylCacheOptions" id="@bluedynamics/cdk8s-plone.PloneVinylCacheOptions"></a>
|
|
1569
1765
|
|
|
1570
1766
|
Configuration options for PloneVinylCache (cloud-vinyl operator).
|
package/lib/deployment.d.ts
CHANGED
|
@@ -118,6 +118,13 @@ export interface PloneDeploymentOptions {
|
|
|
118
118
|
readonly nodeSelector?: {
|
|
119
119
|
[key: string]: string;
|
|
120
120
|
};
|
|
121
|
+
/**
|
|
122
|
+
* Security context for the container.
|
|
123
|
+
* Use to set capabilities, run as non-root, read-only filesystem, etc.
|
|
124
|
+
* @example { capabilities: { add: ['SYS_PTRACE'] } }
|
|
125
|
+
* @default - no security context
|
|
126
|
+
*/
|
|
127
|
+
readonly securityContext?: k8s.SecurityContext;
|
|
121
128
|
/**
|
|
122
129
|
* Liveness probe configuration for the container.
|
|
123
130
|
* @default - undefined (no liveness probe)
|
package/lib/deployment.js
CHANGED
|
@@ -59,6 +59,7 @@ class PloneDeployment extends constructs_1.Construct {
|
|
|
59
59
|
},
|
|
60
60
|
livenessProbe: options.livenessProbe ?? undefined,
|
|
61
61
|
readinessProbe: options.readinessProbe ?? undefined,
|
|
62
|
+
securityContext: options.securityContext,
|
|
62
63
|
};
|
|
63
64
|
const deploymentOptions = {
|
|
64
65
|
metadata: {
|
|
@@ -94,4 +95,4 @@ class PloneDeployment extends constructs_1.Construct {
|
|
|
94
95
|
}
|
|
95
96
|
}
|
|
96
97
|
exports.PloneDeployment = PloneDeployment;
|
|
97
|
-
//# 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-30';\nimport { Construct } from 'constructs';\nimport * as k8s from './imports/k8s';\nimport { PlonePDB, PlonePDBOptions } from './pdb';\n\n/**\n * Container image configuration options.\n */\nexport interface PloneImageOptions {\n  /**\n   * Container image name and tag.\n   * @example 'plone/plone-backend:6.0.10'\n   * @default 'plone/plone-backend:latest'\n   */\n  readonly image?: string;\n\n  /**\n   * Names of Kubernetes secrets for pulling private images.\n   * @default []\n   */\n  readonly imagePullSecrets?: string[];\n\n  /**\n   * Image pull policy (Always, IfNotPresent, Never).\n   * @default 'IfNotPresent'\n   */\n  readonly imagePullPolicy?: string;\n}\n\n/**\n * Configuration options for PloneDeployment.\n */\nexport interface PloneDeploymentOptions {\n  /**\n   * Container image configuration.\n   * @default 'plone/plone-backend:latest'\n   */\n  readonly image?: PloneImageOptions;\n\n  /**\n   * Environment variables for the container.\n   * Use cdk8s-plus-30 Env to define variables and sources.\n   * @default - no additional environment variables\n   */\n  readonly environment?: kplus.Env;\n\n  /**\n   * Number of pod replicas to run.\n   * @default 2\n   */\n  readonly replicas?: number;\n\n  /**\n   * CPU limit for the container.\n   * @default '1000m'\n   */\n  readonly limitCpu?: string;\n\n  /**\n   * Memory limit for the container.\n   * @default '1Gi'\n   */\n  readonly limitMemory?: string;\n\n  /**\n   * CPU request for the container.\n   * @default '200m'\n   */\n  readonly requestCpu?: string;\n\n  /**\n   * Memory request for the container.\n   * @default '300Mi'\n   */\n  readonly requestMemory?: string;\n\n  /**\n   * Container port number to expose.\n   */\n  readonly port: number;\n\n  /**\n   * Additional Kubernetes labels for the deployment.\n   * @default - standard Plone labels only\n   */\n  readonly labels?: { [name: string]: string };\n\n  /**\n   * Annotations to add to the Deployment metadata.\n   * Common annotations include: deployment timestamps, change tracking, etc.\n   * @example { 'deployment.kubernetes.io/revision': '1' }\n   * @default - no additional annotations\n   */\n  readonly annotations?: { [name: string]: string };\n\n  /**\n   * Annotations to add to the Pod template metadata.\n   * Common annotations include: Prometheus scraping config, Istio config,\n   * backup policies, logging configurations, etc.\n   * @example { 'prometheus.io/scrape': 'true', 'prometheus.io/port': '8080' }\n   * @default - no additional annotations\n   */\n  readonly podAnnotations?: { [name: string]: string };\n\n  /**\n   * Additional container specification overrides.\n   * Advanced use only - merges with generated container spec.\n   * @default - undefined\n   */\n  readonly ploneContainer?: k8s.Container;\n\n  /**\n   * Sidecar containers to run alongside the main container.\n   * @example [{ name: 'log-forwarder', image: 'fluentd:latest' }]\n   * @default []\n   */\n  readonly sidecars?: k8s.Container[];\n\n  /**\n   * PodDisruptionBudget configuration for high availability.\n   * If provided, creates a PDB with the specified constraints.\n   * @default - no PDB created\n   */\n  readonly pdb?: PlonePDBOptions;\n\n  /**\n   * Node selector labels for pod scheduling.\n   * @default - no node selector\n   */\n  readonly nodeSelector?: { [key: string]: string };\n\n  /**\n   * Liveness probe configuration for the container.\n   * @default - undefined (no liveness probe)\n   */\n  livenessProbe?: k8s.Probe;\n\n  /**\n   * Readiness probe configuration for the container.\n   * @default - undefined (no readiness probe)\n   */\n  readinessProbe?: k8s.Probe;\n}\n\n/**\n * PloneDeployment creates a Kubernetes Deployment for Plone containers.\n *\n * This is an internal construct used by the Plone class.\n * It creates a Deployment with configurable replicas, resources, probes,\n * and an optional PodDisruptionBudget.\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        annotations: options.annotations,\n      },\n      spec: {\n        replicas,\n        selector: {\n          matchLabels: label,\n        },\n        template: {\n          metadata: {\n            labels: template_labels,\n            annotations: options.podAnnotations,\n          },\n          spec: {\n            imagePullSecrets: (image.imagePullSecrets ?? []).map((name) => ({ name: name })),\n            nodeSelector: options.nodeSelector,\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"]}
|
|
98
|
+
//# 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-30';\nimport { Construct } from 'constructs';\nimport * as k8s from './imports/k8s';\nimport { PlonePDB, PlonePDBOptions } from './pdb';\n\n/**\n * Container image configuration options.\n */\nexport interface PloneImageOptions {\n  /**\n   * Container image name and tag.\n   * @example 'plone/plone-backend:6.0.10'\n   * @default 'plone/plone-backend:latest'\n   */\n  readonly image?: string;\n\n  /**\n   * Names of Kubernetes secrets for pulling private images.\n   * @default []\n   */\n  readonly imagePullSecrets?: string[];\n\n  /**\n   * Image pull policy (Always, IfNotPresent, Never).\n   * @default 'IfNotPresent'\n   */\n  readonly imagePullPolicy?: string;\n}\n\n/**\n * Configuration options for PloneDeployment.\n */\nexport interface PloneDeploymentOptions {\n  /**\n   * Container image configuration.\n   * @default 'plone/plone-backend:latest'\n   */\n  readonly image?: PloneImageOptions;\n\n  /**\n   * Environment variables for the container.\n   * Use cdk8s-plus-30 Env to define variables and sources.\n   * @default - no additional environment variables\n   */\n  readonly environment?: kplus.Env;\n\n  /**\n   * Number of pod replicas to run.\n   * @default 2\n   */\n  readonly replicas?: number;\n\n  /**\n   * CPU limit for the container.\n   * @default '1000m'\n   */\n  readonly limitCpu?: string;\n\n  /**\n   * Memory limit for the container.\n   * @default '1Gi'\n   */\n  readonly limitMemory?: string;\n\n  /**\n   * CPU request for the container.\n   * @default '200m'\n   */\n  readonly requestCpu?: string;\n\n  /**\n   * Memory request for the container.\n   * @default '300Mi'\n   */\n  readonly requestMemory?: string;\n\n  /**\n   * Container port number to expose.\n   */\n  readonly port: number;\n\n  /**\n   * Additional Kubernetes labels for the deployment.\n   * @default - standard Plone labels only\n   */\n  readonly labels?: { [name: string]: string };\n\n  /**\n   * Annotations to add to the Deployment metadata.\n   * Common annotations include: deployment timestamps, change tracking, etc.\n   * @example { 'deployment.kubernetes.io/revision': '1' }\n   * @default - no additional annotations\n   */\n  readonly annotations?: { [name: string]: string };\n\n  /**\n   * Annotations to add to the Pod template metadata.\n   * Common annotations include: Prometheus scraping config, Istio config,\n   * backup policies, logging configurations, etc.\n   * @example { 'prometheus.io/scrape': 'true', 'prometheus.io/port': '8080' }\n   * @default - no additional annotations\n   */\n  readonly podAnnotations?: { [name: string]: string };\n\n  /**\n   * Additional container specification overrides.\n   * Advanced use only - merges with generated container spec.\n   * @default - undefined\n   */\n  readonly ploneContainer?: k8s.Container;\n\n  /**\n   * Sidecar containers to run alongside the main container.\n   * @example [{ name: 'log-forwarder', image: 'fluentd:latest' }]\n   * @default []\n   */\n  readonly sidecars?: k8s.Container[];\n\n  /**\n   * PodDisruptionBudget configuration for high availability.\n   * If provided, creates a PDB with the specified constraints.\n   * @default - no PDB created\n   */\n  readonly pdb?: PlonePDBOptions;\n\n  /**\n   * Node selector labels for pod scheduling.\n   * @default - no node selector\n   */\n  readonly nodeSelector?: { [key: string]: string };\n\n  /**\n   * Security context for the container.\n   * Use to set capabilities, run as non-root, read-only filesystem, etc.\n   * @example { capabilities: { add: ['SYS_PTRACE'] } }\n   * @default - no security context\n   */\n  readonly securityContext?: k8s.SecurityContext;\n\n  /**\n   * Liveness probe configuration for the container.\n   * @default - undefined (no liveness probe)\n   */\n  livenessProbe?: k8s.Probe;\n\n  /**\n   * Readiness probe configuration for the container.\n   * @default - undefined (no readiness probe)\n   */\n  readinessProbe?: k8s.Probe;\n}\n\n/**\n * PloneDeployment creates a Kubernetes Deployment for Plone containers.\n *\n * This is an internal construct used by the Plone class.\n * It creates a Deployment with configurable replicas, resources, probes,\n * and an optional PodDisruptionBudget.\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      securityContext: options.securityContext,\n    };\n    const deploymentOptions: k8s.KubeDeploymentProps = {\n      metadata: {\n        labels: deploymentLabels,\n        annotations: options.annotations,\n      },\n      spec: {\n        replicas,\n        selector: {\n          matchLabels: label,\n        },\n        template: {\n          metadata: {\n            labels: template_labels,\n            annotations: options.podAnnotations,\n          },\n          spec: {\n            imagePullSecrets: (image.imagePullSecrets ?? []).map((name) => ({ name: name })),\n            nodeSelector: options.nodeSelector,\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
|
@@ -118,5 +118,5 @@ class PloneHttpcache extends constructs_1.Construct {
|
|
|
118
118
|
}
|
|
119
119
|
exports.PloneHttpcache = PloneHttpcache;
|
|
120
120
|
_a = JSII_RTTI_SYMBOL_1;
|
|
121
|
-
PloneHttpcache[_a] = { fqn: "@bluedynamics/cdk8s-plone.PloneHttpcache", version: "0.1.
|
|
121
|
+
PloneHttpcache[_a] = { fqn: "@bluedynamics/cdk8s-plone.PloneHttpcache", version: "0.1.30" };
|
|
122
122
|
//# 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 * An environment variable to pass to the kube-httpcache container.\n */\nexport interface HttpcacheEnvVar {\n  /**\n   * The name of the environment variable.\n   */\n  readonly name: string;\n\n  /**\n   * The value of the environment variable.\n   */\n  readonly value: string;\n}\n\n/**\n * A Kubernetes toleration for the Varnish pods.\n */\nexport interface HttpcacheToleration {\n  /**\n   * The taint key to tolerate.\n   */\n  readonly key: string;\n\n  /**\n   * The operator (Equal or Exists).\n   * @default 'Equal'\n   */\n  readonly operator?: string;\n\n  /**\n   * The taint value to match (when operator is Equal).\n   * @default - no value\n   */\n  readonly value?: string;\n\n  /**\n   * The taint effect to tolerate (NoSchedule, PreferNoSchedule, NoExecute).\n   * @default - tolerate all effects\n   */\n  readonly effect?: string;\n}\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   * Enable the Prometheus exporter for Varnish metrics.\n   * When enabled, the exporter sidecar container will be deployed alongside Varnish.\n   * @default true\n   */\n  readonly exporterEnabled?: boolean;\n\n  /**\n   * Version of the kube-httpcache Helm chart to use.\n   * If not specified, the latest version from the repository will be used.\n   * @default undefined (latest)\n   */\n  readonly chartVersion?: string;\n\n  /**\n   * Version of the kube-httpcache Container Image to use.\n   * If not specified, the latest version from the repository will be used.\n   * @default undefined (chartVersion = with each chart release there is an image release too )\n   */\n  readonly appVersion?: string;\n\n  /**\n   * Number of Varnish pod replicas to run.\n   * @default 2\n   */\n  readonly replicas?: number;\n\n  /**\n   * Additional environment variables to pass to the kube-httpcache container.\n   * These are appended to the built-in env vars (BACKEND_SERVICE_NAME, etc.)\n   * and can be referenced in VCL templates using Go template syntax: {{ .Env.VAR_NAME }}\n   * @default - no additional env vars\n   */\n  readonly extraEnvVars?: HttpcacheEnvVar[];\n\n  /**\n   * Tolerations for the Varnish pods.\n   * Use this to allow scheduling on nodes with specific taints,\n   * e.g. nodes tainted with kubernetes.io/arch=amd64:NoSchedule.\n   * @default - no tolerations\n   */\n  readonly tolerations?: HttpcacheToleration[];\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 imageTag = options.appVersion ?? options.chartVersion;\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      version: options.chartVersion,\n      values: {\n        replicaCount: options.replicas ?? 2,\n        ...(imageTag && { image: { tag: imageTag } }),\n        cache: {\n          backendService: options.plone.backendServiceName,\n          frontendWatch: false,\n          backendWatch: true,\n          existingSecret: options.existingSecret ?? undefined,\n        },\n        // Workaround: upstream chart accepts backendPortName but never\n        // renders it as CLI arg. Pass via cacheExtraArgs instead.\n        cacheExtraArgs: '- -backend-portname=backend-http',\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          ...(options.extraEnvVars ?? []),\n        ],\n        // see https://github.com/mittwald/kube-httpcache/issues/253\n        nodeSelector: {\n          'kubernetes.io/arch': 'amd64',\n        },\n        ...(options.tolerations && { tolerations: options.tolerations }),\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: true,\n        },\n        exporter: {\n          enabled: options.exporterEnabled ?? 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}"]}
|
|
@@ -180,6 +180,15 @@ export interface VinylCacheSpecBackends {
|
|
|
180
180
|
* @schema VinylCacheSpecBackends#connectionParameters
|
|
181
181
|
*/
|
|
182
182
|
readonly connectionParameters?: VinylCacheSpecBackendsConnectionParameters;
|
|
183
|
+
/**
|
|
184
|
+
* director overrides the cluster-wide director for this backend only.
|
|
185
|
+
* If nil, a shard director with defaults is generated, grouping all resolved
|
|
186
|
+
* per-pod backends for this serviceRef. Use "round_robin" or "random" if
|
|
187
|
+
* consistent hashing is undesirable (e.g. stateless backends).
|
|
188
|
+
*
|
|
189
|
+
* @schema VinylCacheSpecBackends#director
|
|
190
|
+
*/
|
|
191
|
+
readonly director?: VinylCacheSpecBackendsDirector;
|
|
183
192
|
/**
|
|
184
193
|
* name is the VCL identifier for this backend. Must match ^[a-zA-Z][a-zA-Z0-9_]*$.
|
|
185
194
|
*
|
|
@@ -247,7 +256,7 @@ export declare function toJson_VinylCacheSpecCluster(obj: VinylCacheSpecCluster
|
|
|
247
256
|
export interface VinylCacheSpecDebounce {
|
|
248
257
|
/**
|
|
249
258
|
* duration is the time to wait after the last endpoint change before pushing a VCL update.
|
|
250
|
-
* This prevents thundering-herd on rapid endpoint churn. Default:
|
|
259
|
+
* This prevents thundering-herd on rapid endpoint churn. Default: 1s.
|
|
251
260
|
*
|
|
252
261
|
* @schema VinylCacheSpecDebounce#duration
|
|
253
262
|
*/
|
|
@@ -624,6 +633,40 @@ export interface VinylCacheSpecBackendsConnectionParameters {
|
|
|
624
633
|
* Converts an object of type 'VinylCacheSpecBackendsConnectionParameters' to JSON representation.
|
|
625
634
|
*/
|
|
626
635
|
export declare function toJson_VinylCacheSpecBackendsConnectionParameters(obj: VinylCacheSpecBackendsConnectionParameters | undefined): Record<string, any> | undefined;
|
|
636
|
+
/**
|
|
637
|
+
* director overrides the cluster-wide director for this backend only.
|
|
638
|
+
* If nil, a shard director with defaults is generated, grouping all resolved
|
|
639
|
+
* per-pod backends for this serviceRef. Use "round_robin" or "random" if
|
|
640
|
+
* consistent hashing is undesirable (e.g. stateless backends).
|
|
641
|
+
*
|
|
642
|
+
* @schema VinylCacheSpecBackendsDirector
|
|
643
|
+
*/
|
|
644
|
+
export interface VinylCacheSpecBackendsDirector {
|
|
645
|
+
/**
|
|
646
|
+
* hash configures the hash director. Only used when type is "hash".
|
|
647
|
+
*
|
|
648
|
+
* @schema VinylCacheSpecBackendsDirector#hash
|
|
649
|
+
*/
|
|
650
|
+
readonly hash?: VinylCacheSpecBackendsDirectorHash;
|
|
651
|
+
/**
|
|
652
|
+
* shard configures the shard director (consistent-hash). Only used when type is "shard".
|
|
653
|
+
*
|
|
654
|
+
* @schema VinylCacheSpecBackendsDirector#shard
|
|
655
|
+
*/
|
|
656
|
+
readonly shard?: VinylCacheSpecBackendsDirectorShard;
|
|
657
|
+
/**
|
|
658
|
+
* type selects the Varnish director algorithm.
|
|
659
|
+
* "shard" (default) provides consistent hashing; "round_robin", "random", and "hash"
|
|
660
|
+
* are also supported.
|
|
661
|
+
*
|
|
662
|
+
* @schema VinylCacheSpecBackendsDirector#type
|
|
663
|
+
*/
|
|
664
|
+
readonly type?: VinylCacheSpecBackendsDirectorType;
|
|
665
|
+
}
|
|
666
|
+
/**
|
|
667
|
+
* Converts an object of type 'VinylCacheSpecBackendsDirector' to JSON representation.
|
|
668
|
+
*/
|
|
669
|
+
export declare function toJson_VinylCacheSpecBackendsDirector(obj: VinylCacheSpecBackendsDirector | undefined): Record<string, any> | undefined;
|
|
627
670
|
/**
|
|
628
671
|
* probe configures the Varnish backend health probe.
|
|
629
672
|
*
|
|
@@ -785,7 +828,9 @@ export declare enum VinylCacheSpecDirectorType {
|
|
|
785
828
|
/** random */
|
|
786
829
|
RANDOM = "random",
|
|
787
830
|
/** hash */
|
|
788
|
-
HASH = "hash"
|
|
831
|
+
HASH = "hash",
|
|
832
|
+
/** fallback */
|
|
833
|
+
FALLBACK = "fallback"
|
|
789
834
|
}
|
|
790
835
|
/**
|
|
791
836
|
* ban configures BAN-based cache invalidation.
|
|
@@ -1183,6 +1228,88 @@ export interface VinylCacheSpecVclSnippets {
|
|
|
1183
1228
|
* Converts an object of type 'VinylCacheSpecVclSnippets' to JSON representation.
|
|
1184
1229
|
*/
|
|
1185
1230
|
export declare function toJson_VinylCacheSpecVclSnippets(obj: VinylCacheSpecVclSnippets | undefined): Record<string, any> | undefined;
|
|
1231
|
+
/**
|
|
1232
|
+
* hash configures the hash director. Only used when type is "hash".
|
|
1233
|
+
*
|
|
1234
|
+
* @schema VinylCacheSpecBackendsDirectorHash
|
|
1235
|
+
*/
|
|
1236
|
+
export interface VinylCacheSpecBackendsDirectorHash {
|
|
1237
|
+
/**
|
|
1238
|
+
* header is the request header name used as the hash key.
|
|
1239
|
+
*
|
|
1240
|
+
* @schema VinylCacheSpecBackendsDirectorHash#header
|
|
1241
|
+
*/
|
|
1242
|
+
readonly header?: string;
|
|
1243
|
+
}
|
|
1244
|
+
/**
|
|
1245
|
+
* Converts an object of type 'VinylCacheSpecBackendsDirectorHash' to JSON representation.
|
|
1246
|
+
*/
|
|
1247
|
+
export declare function toJson_VinylCacheSpecBackendsDirectorHash(obj: VinylCacheSpecBackendsDirectorHash | undefined): Record<string, any> | undefined;
|
|
1248
|
+
/**
|
|
1249
|
+
* shard configures the shard director (consistent-hash). Only used when type is "shard".
|
|
1250
|
+
*
|
|
1251
|
+
* @schema VinylCacheSpecBackendsDirectorShard
|
|
1252
|
+
*/
|
|
1253
|
+
export interface VinylCacheSpecBackendsDirectorShard {
|
|
1254
|
+
/**
|
|
1255
|
+
* by determines what value is hashed for shard selection. "HASH" uses the Varnish
|
|
1256
|
+
* hash (default); "URL" uses the request URL.
|
|
1257
|
+
*
|
|
1258
|
+
* @schema VinylCacheSpecBackendsDirectorShard#by
|
|
1259
|
+
*/
|
|
1260
|
+
readonly by?: VinylCacheSpecBackendsDirectorShardBy;
|
|
1261
|
+
/**
|
|
1262
|
+
* healthy controls which backends the director considers when selecting a shard.
|
|
1263
|
+
* "CHOSEN" (default) only considers the chosen backend healthy; "ALL" requires all
|
|
1264
|
+
* backends to be healthy.
|
|
1265
|
+
*
|
|
1266
|
+
* @schema VinylCacheSpecBackendsDirectorShard#healthy
|
|
1267
|
+
*/
|
|
1268
|
+
readonly healthy?: VinylCacheSpecBackendsDirectorShardHealthy;
|
|
1269
|
+
/**
|
|
1270
|
+
* rampup is the time after adding a backend before it receives its full share of traffic,
|
|
1271
|
+
* preventing thundering-herd. Default: 30s.
|
|
1272
|
+
*
|
|
1273
|
+
* @schema VinylCacheSpecBackendsDirectorShard#rampup
|
|
1274
|
+
*/
|
|
1275
|
+
readonly rampup?: string;
|
|
1276
|
+
/**
|
|
1277
|
+
* replicas is the number of Ketama replicas per backend in the hash ring. Default: 67.
|
|
1278
|
+
*
|
|
1279
|
+
* @schema VinylCacheSpecBackendsDirectorShard#replicas
|
|
1280
|
+
*/
|
|
1281
|
+
readonly replicas?: number;
|
|
1282
|
+
/**
|
|
1283
|
+
* warmup is the proportion of requests (0.0–1.0) sent to the alternative backend
|
|
1284
|
+
* to pre-populate its cache. Default: 0.1. Must be between 0.0 and 1.0.
|
|
1285
|
+
*
|
|
1286
|
+
* @schema VinylCacheSpecBackendsDirectorShard#warmup
|
|
1287
|
+
*/
|
|
1288
|
+
readonly warmup?: number;
|
|
1289
|
+
}
|
|
1290
|
+
/**
|
|
1291
|
+
* Converts an object of type 'VinylCacheSpecBackendsDirectorShard' to JSON representation.
|
|
1292
|
+
*/
|
|
1293
|
+
export declare function toJson_VinylCacheSpecBackendsDirectorShard(obj: VinylCacheSpecBackendsDirectorShard | undefined): Record<string, any> | undefined;
|
|
1294
|
+
/**
|
|
1295
|
+
* type selects the Varnish director algorithm.
|
|
1296
|
+
* "shard" (default) provides consistent hashing; "round_robin", "random", and "hash"
|
|
1297
|
+
* are also supported.
|
|
1298
|
+
*
|
|
1299
|
+
* @schema VinylCacheSpecBackendsDirectorType
|
|
1300
|
+
*/
|
|
1301
|
+
export declare enum VinylCacheSpecBackendsDirectorType {
|
|
1302
|
+
/** shard */
|
|
1303
|
+
SHARD = "shard",
|
|
1304
|
+
/** round_robin */
|
|
1305
|
+
ROUND_UNDERSCORE_ROBIN = "round_robin",
|
|
1306
|
+
/** random */
|
|
1307
|
+
RANDOM = "random",
|
|
1308
|
+
/** hash */
|
|
1309
|
+
HASH = "hash",
|
|
1310
|
+
/** fallback */
|
|
1311
|
+
FALLBACK = "fallback"
|
|
1312
|
+
}
|
|
1186
1313
|
/**
|
|
1187
1314
|
* type is the routing strategy between Varnish pods. Only "shard" is supported.
|
|
1188
1315
|
*
|
|
@@ -1326,6 +1453,31 @@ export interface VinylCacheSpecPodAffinityPodAntiAffinity {
|
|
|
1326
1453
|
* Converts an object of type 'VinylCacheSpecPodAffinityPodAntiAffinity' to JSON representation.
|
|
1327
1454
|
*/
|
|
1328
1455
|
export declare function toJson_VinylCacheSpecPodAffinityPodAntiAffinity(obj: VinylCacheSpecPodAffinityPodAntiAffinity | undefined): Record<string, any> | undefined;
|
|
1456
|
+
/**
|
|
1457
|
+
* by determines what value is hashed for shard selection. "HASH" uses the Varnish
|
|
1458
|
+
* hash (default); "URL" uses the request URL.
|
|
1459
|
+
*
|
|
1460
|
+
* @schema VinylCacheSpecBackendsDirectorShardBy
|
|
1461
|
+
*/
|
|
1462
|
+
export declare enum VinylCacheSpecBackendsDirectorShardBy {
|
|
1463
|
+
/** HASH */
|
|
1464
|
+
HASH = "HASH",
|
|
1465
|
+
/** URL */
|
|
1466
|
+
URL = "URL"
|
|
1467
|
+
}
|
|
1468
|
+
/**
|
|
1469
|
+
* healthy controls which backends the director considers when selecting a shard.
|
|
1470
|
+
* "CHOSEN" (default) only considers the chosen backend healthy; "ALL" requires all
|
|
1471
|
+
* backends to be healthy.
|
|
1472
|
+
*
|
|
1473
|
+
* @schema VinylCacheSpecBackendsDirectorShardHealthy
|
|
1474
|
+
*/
|
|
1475
|
+
export declare enum VinylCacheSpecBackendsDirectorShardHealthy {
|
|
1476
|
+
/** CHOSEN */
|
|
1477
|
+
CHOSEN = "CHOSEN",
|
|
1478
|
+
/** ALL */
|
|
1479
|
+
ALL = "ALL"
|
|
1480
|
+
}
|
|
1329
1481
|
/**
|
|
1330
1482
|
* An empty preferred scheduling term matches all objects with implicit weight 0
|
|
1331
1483
|
* (i.e. it's a no-op). A null preferred scheduling term matches no objects (i.e. is also a no-op).
|