|
@@ -1,277 +1,499 @@
|
|
|
groups:
|
|
|
- - name: "Configuration"
|
|
|
- description: "Pihole application configuration"
|
|
|
- - name: "Storage"
|
|
|
- description: "Configure storage for pihole"
|
|
|
- - name: "Networking"
|
|
|
- description: "Networking Configuration for pihole"
|
|
|
- - name: "Advanced DNS Settings"
|
|
|
- description: "Configure DNS settings"
|
|
|
- - name: "Resource Limits"
|
|
|
- description: "Set CPU/memory limits for Kubernetes Pod"
|
|
|
-
|
|
|
+ - name: Pi-Hole Configuration
|
|
|
+ description: Configure Pi-Hole
|
|
|
+ - name: Advanced Pod Configuration
|
|
|
+ description: Configure Advanced Pod Options for Pi-Hole
|
|
|
+ - name: Network Configuration
|
|
|
+ description: Configure Network for Pi-Hole
|
|
|
+ - name: Storage Configuration
|
|
|
+ description: Configure Storage for Pi-Hole
|
|
|
+ - name: Resources Configuration
|
|
|
+ description: Configure Resources for Pi-Hole
|
|
|
|
|
|
portals:
|
|
|
web_portal:
|
|
|
protocols:
|
|
|
- - "http"
|
|
|
+ - "$kubernetes-resource_configmap_portal_protocol"
|
|
|
host:
|
|
|
- - "$node_ip"
|
|
|
+ - "$kubernetes-resource_configmap_portal_host"
|
|
|
ports:
|
|
|
- - "$variable-web_port"
|
|
|
- path: "/admin/"
|
|
|
+ - "$kubernetes-resource_configmap_portal_port"
|
|
|
+ path: "$kubernetes-resource_configmap_portal_path"
|
|
|
|
|
|
questions:
|
|
|
- - variable: web_port
|
|
|
- label: "Web Port for pihole"
|
|
|
- group: Networking
|
|
|
+ - variable: TZ
|
|
|
+ group: Pi-Hole Configuration
|
|
|
+ label: Timezone
|
|
|
schema:
|
|
|
- type: int
|
|
|
- min: 8000
|
|
|
- max: 65535
|
|
|
- default: 20720
|
|
|
+ type: string
|
|
|
+ default: Etc/UTC
|
|
|
required: true
|
|
|
+ $ref:
|
|
|
+ - definitions/timezone
|
|
|
|
|
|
- - variable: dhcp
|
|
|
- label: "Enable DHCP"
|
|
|
- group: "Networking"
|
|
|
- schema:
|
|
|
- type: boolean
|
|
|
- default: false
|
|
|
- show_subquestions_if: true
|
|
|
- subquestions:
|
|
|
- - variable: dhcp_start
|
|
|
- label: "DHCP Start Address"
|
|
|
- group: Networking
|
|
|
- schema:
|
|
|
- type: ipaddr
|
|
|
- cidr: false
|
|
|
- required: true
|
|
|
- - variable: dhcp_end
|
|
|
- label: "DHCP End Address"
|
|
|
- group: Networking
|
|
|
- schema:
|
|
|
- type: ipaddr
|
|
|
- cidr: false
|
|
|
- required: true
|
|
|
- - variable: dhcp_gateway
|
|
|
- label: "Gateway"
|
|
|
- group: Networking
|
|
|
- schema:
|
|
|
- type: ipaddr
|
|
|
- cidr: false
|
|
|
- required: true
|
|
|
-
|
|
|
- - variable: dnsConfig
|
|
|
- label: "DNS Configuration"
|
|
|
- group: "Advanced DNS Settings"
|
|
|
+ - variable: piholeConfig
|
|
|
+ label: ""
|
|
|
+ group: Pi-Hole Configuration
|
|
|
schema:
|
|
|
type: dict
|
|
|
attrs:
|
|
|
- - variable: options
|
|
|
- label: "DNS Options"
|
|
|
+ - variable: webPassword
|
|
|
+ label: Web Password
|
|
|
+ description: The password for the Pi-Hole Web UI.
|
|
|
+ schema:
|
|
|
+ type: string
|
|
|
+ required: true
|
|
|
+ private: true
|
|
|
+ - variable: additionalEnvs
|
|
|
+ label: Additional Environment Variables
|
|
|
+ description: Configure additional environment variables for Pi-Hole.
|
|
|
schema:
|
|
|
type: list
|
|
|
+ default: []
|
|
|
items:
|
|
|
- - variable: optionsEntry
|
|
|
- label: "Option Entry Configuration"
|
|
|
+ - variable: env
|
|
|
+ label: Environment Variable
|
|
|
schema:
|
|
|
type: dict
|
|
|
attrs:
|
|
|
- variable: name
|
|
|
- label: "Option Name"
|
|
|
+ label: Name
|
|
|
schema:
|
|
|
type: string
|
|
|
required: true
|
|
|
- variable: value
|
|
|
- label: "Option Value"
|
|
|
+ label: Value
|
|
|
schema:
|
|
|
type: string
|
|
|
required: true
|
|
|
|
|
|
- - variable: ownerUID
|
|
|
- label: "Storage User ID"
|
|
|
- description: "User ID of the dnsmasq volume being used (application will chown the volume path with specified UID)"
|
|
|
- group: Configuration
|
|
|
+ - variable: podOptions
|
|
|
+ label: ""
|
|
|
+ group: Advanced Pod Configuration
|
|
|
schema:
|
|
|
- type: int
|
|
|
- default: 568
|
|
|
- min: 1
|
|
|
- max: 65535
|
|
|
-
|
|
|
- - variable: ownerGID
|
|
|
- label: "Storage Group ID"
|
|
|
- description: "Group ID of the dnsmasq volume being used (application will chown the volume path with specified GID)"
|
|
|
- group: Configuration
|
|
|
- schema:
|
|
|
- type: int
|
|
|
- default: 568
|
|
|
- min: 1
|
|
|
- max: 65535
|
|
|
-
|
|
|
- - variable: password
|
|
|
- label: "Admin password"
|
|
|
- group: "Configuration"
|
|
|
- schema:
|
|
|
- type: string
|
|
|
- private: true
|
|
|
- required: true
|
|
|
- empty: false
|
|
|
- immutable: true
|
|
|
-
|
|
|
- - variable: timezone
|
|
|
- label: "Configure timezone"
|
|
|
- group: "Configuration"
|
|
|
- description: "Configure timezone for pihole"
|
|
|
- schema:
|
|
|
- type: string
|
|
|
- $ref:
|
|
|
- - "definitions/timezone"
|
|
|
+ type: dict
|
|
|
+ attrs:
|
|
|
+ - variable: dnsConfig
|
|
|
+ label: Advanced DNS Configuration
|
|
|
+ schema:
|
|
|
+ type: dict
|
|
|
+ attrs:
|
|
|
+ - variable: options
|
|
|
+ label: DNS Options
|
|
|
+ schema:
|
|
|
+ type: list
|
|
|
+ items:
|
|
|
+ - variable: optionsEntry
|
|
|
+ label: DNS Option Entry
|
|
|
+ schema:
|
|
|
+ type: dict
|
|
|
+ attrs:
|
|
|
+ - variable: name
|
|
|
+ label: Option Name
|
|
|
+ schema:
|
|
|
+ type: string
|
|
|
+ required: true
|
|
|
+ - variable: value
|
|
|
+ label: Option Value
|
|
|
+ schema:
|
|
|
+ type: string
|
|
|
+ required: true
|
|
|
|
|
|
- - variable: environmentVariables
|
|
|
- label: "Pihole environment"
|
|
|
- group: "Configuration"
|
|
|
+ - variable: piholeNetwork
|
|
|
+ label: ""
|
|
|
+ group: Network Configuration
|
|
|
schema:
|
|
|
- type: list
|
|
|
- default: []
|
|
|
- items:
|
|
|
- - variable: environmentVariable
|
|
|
- label: "Environment Variable"
|
|
|
+ type: dict
|
|
|
+ attrs:
|
|
|
+ - variable: webPort
|
|
|
+ label: Web Port
|
|
|
+ description: The port for the Pi-Hole Web UI.
|
|
|
+ schema:
|
|
|
+ type: int
|
|
|
+ default: 20720
|
|
|
+ min: 9000
|
|
|
+ max: 65535
|
|
|
+ required: true
|
|
|
+ - variable: dhcp
|
|
|
+ label: DHCP Configuration
|
|
|
schema:
|
|
|
type: dict
|
|
|
attrs:
|
|
|
- - variable: name
|
|
|
- label: "Name"
|
|
|
+ - variable: enabled
|
|
|
+ label: Enable DHCP
|
|
|
+ description: Enable DHCP for Pi-Hole.
|
|
|
schema:
|
|
|
- type: string
|
|
|
- - variable: value
|
|
|
- label: "Value"
|
|
|
+ type: boolean
|
|
|
+ default: false
|
|
|
+ - variable: start
|
|
|
+ label: DHCP Start
|
|
|
+ description: The start of the DHCP range.
|
|
|
schema:
|
|
|
- type: string
|
|
|
+ type: ipaddr
|
|
|
+ cidr: false
|
|
|
+ show_if: [["enabled", "=", true]]
|
|
|
+ required: true
|
|
|
+ - variable: end
|
|
|
+ label: DHCP End
|
|
|
+ description: The end of the DHCP range.
|
|
|
+ schema:
|
|
|
+ type: ipaddr
|
|
|
+ cidr: false
|
|
|
+ show_if: [["enabled", "=", true]]
|
|
|
+ required: true
|
|
|
+ - variable: gateway
|
|
|
+ label: DHCP Gateway
|
|
|
+ description: The gateway for the DHCP range.
|
|
|
+ schema:
|
|
|
+ type: ipaddr
|
|
|
+ cidr: false
|
|
|
+ show_if: [["enabled", "=", true]]
|
|
|
+ required: true
|
|
|
|
|
|
- - variable: appVolumeMounts
|
|
|
- label: "Pihole Storage"
|
|
|
- group: "Storage"
|
|
|
+ - variable: piholeStorage
|
|
|
+ label: ""
|
|
|
+ group: Storage Configuration
|
|
|
schema:
|
|
|
type: dict
|
|
|
attrs:
|
|
|
- variable: config
|
|
|
- label: "Configuration Volume"
|
|
|
+ label: Pi-Hole Config Storage
|
|
|
+ description: The path to store Pi-Hole Configuration.
|
|
|
schema:
|
|
|
type: dict
|
|
|
attrs:
|
|
|
- - variable: datasetName
|
|
|
- label: "Configuration Volume Dataset Name"
|
|
|
+ - variable: type
|
|
|
+ label: Type
|
|
|
+ description: |
|
|
|
+ ixVolume: Is dataset created automatically by the system.</br>
|
|
|
+ Host Path: Is a path that already exists on the system.
|
|
|
schema:
|
|
|
type: string
|
|
|
- hidden: true
|
|
|
+ required: true
|
|
|
+ immutable: true
|
|
|
+ default: "ixVolume"
|
|
|
+ enum:
|
|
|
+ - value: "hostPath"
|
|
|
+ description: Host Path (Path that already exists on the system)
|
|
|
+ - value: "ixVolume"
|
|
|
+ description: ixVolume (Dataset created automatically by the system)
|
|
|
+ - variable: ixVolumeConfig
|
|
|
+ label: ixVolume Configuration
|
|
|
+ description: The configuration for the ixVolume dataset.
|
|
|
+ schema:
|
|
|
+ type: dict
|
|
|
+ show_if: [["type", "=", "ixVolume"]]
|
|
|
$ref:
|
|
|
- "normalize/ixVolume"
|
|
|
- show_if: [["hostPathEnabled", "=", false]]
|
|
|
- default: "ix-pihole_config"
|
|
|
- editable: false
|
|
|
- - variable: mountPath
|
|
|
- label: "Configuration Mount Path"
|
|
|
- description: "Path where the volume will be mounted inside the pod"
|
|
|
- schema:
|
|
|
- type: path
|
|
|
- hidden: true
|
|
|
- editable: true
|
|
|
- default: "/etc/pihole"
|
|
|
- - variable: hostPathEnabled
|
|
|
- label: "Enable Custom Host Path for Pihole Configuration Volume"
|
|
|
+ attrs:
|
|
|
+ - variable: aclEnable
|
|
|
+ label: Enable ACL
|
|
|
+ description: Enable ACL for the dataset.
|
|
|
+ schema:
|
|
|
+ type: boolean
|
|
|
+ default: false
|
|
|
+ - variable: datasetName
|
|
|
+ label: Dataset Name
|
|
|
+ description: The name of the dataset to use for storage.
|
|
|
+ schema:
|
|
|
+ type: string
|
|
|
+ required: true
|
|
|
+ immutable: true
|
|
|
+ hidden: true
|
|
|
+ default: "config"
|
|
|
+ - variable: aclEntries
|
|
|
+ label: ACL Configuration
|
|
|
+ schema:
|
|
|
+ type: dict
|
|
|
+ show_if: [["aclEnable", "=", true]]
|
|
|
+ attrs: []
|
|
|
+ - variable: hostPathConfig
|
|
|
+ label: Host Path Config
|
|
|
schema:
|
|
|
- type: boolean
|
|
|
- default: false
|
|
|
- show_subquestions_if: true
|
|
|
- subquestions:
|
|
|
+ type: dict
|
|
|
+ show_if: [["type", "=", "hostPath"]]
|
|
|
+ attrs:
|
|
|
+ - variable: aclEnable
|
|
|
+ label: Enable ACL
|
|
|
+ description: Enable ACL for the dataset.
|
|
|
+ schema:
|
|
|
+ type: boolean
|
|
|
+ default: false
|
|
|
+ - variable: acl
|
|
|
+ label: ACL Configuration
|
|
|
+ schema:
|
|
|
+ type: dict
|
|
|
+ show_if: [["aclEnable", "=", true]]
|
|
|
+ attrs: []
|
|
|
+ $ref:
|
|
|
+ - "normalize/acl"
|
|
|
- variable: hostPath
|
|
|
- label: "Host Path for Pihole Configuration Volume"
|
|
|
+ label: Host Path
|
|
|
+ description: The host path to use for storage.
|
|
|
schema:
|
|
|
type: hostpath
|
|
|
+ show_if: [["aclEnable", "=", false]]
|
|
|
required: true
|
|
|
- variable: dnsmasq
|
|
|
- label: "DNSMASQ Volume for pihole"
|
|
|
+ label: Pi-Hole DNSmasq Storage
|
|
|
+ description: The path to store Pi-Hole DNSmasq.
|
|
|
schema:
|
|
|
type: dict
|
|
|
attrs:
|
|
|
- - variable: datasetName
|
|
|
- label: "DNSMASQ Volume Dataset Name"
|
|
|
+ - variable: type
|
|
|
+ label: Type
|
|
|
+ description: |
|
|
|
+ ixVolume: Is dataset created automatically by the system.</br>
|
|
|
+ Host Path: Is a path that already exists on the system.
|
|
|
schema:
|
|
|
type: string
|
|
|
- hidden: true
|
|
|
+ required: true
|
|
|
+ immutable: true
|
|
|
+ default: "ixVolume"
|
|
|
+ enum:
|
|
|
+ - value: "hostPath"
|
|
|
+ description: Host Path (Path that already exists on the system)
|
|
|
+ - value: "ixVolume"
|
|
|
+ description: ixVolume (Dataset created automatically by the system)
|
|
|
+ - variable: ixVolumeConfig
|
|
|
+ label: ixVolume Configuration
|
|
|
+ description: The configuration for the ixVolume dataset.
|
|
|
+ schema:
|
|
|
+ type: dict
|
|
|
+ show_if: [["type", "=", "ixVolume"]]
|
|
|
$ref:
|
|
|
- "normalize/ixVolume"
|
|
|
- show_if: [["hostPathEnabled", "=", false]]
|
|
|
- default: "ix-pihole_dnsmasq"
|
|
|
- editable: false
|
|
|
- - variable: mountPath
|
|
|
- label: "DNSMASQ Mount Path"
|
|
|
- description: "Path where the volume will be mounted inside the pod"
|
|
|
- schema:
|
|
|
- type: path
|
|
|
- hidden: true
|
|
|
- editable: true
|
|
|
- default: "/etc/dnsmasq.d"
|
|
|
- - variable: hostPathEnabled
|
|
|
- label: "Enable Custom Host Path for Pihole DNSMASQ Volume"
|
|
|
+ attrs:
|
|
|
+ - variable: aclEnable
|
|
|
+ label: Enable ACL
|
|
|
+ description: Enable ACL for the dataset.
|
|
|
+ schema:
|
|
|
+ type: boolean
|
|
|
+ default: false
|
|
|
+ - variable: datasetName
|
|
|
+ label: Dataset Name
|
|
|
+ description: The name of the dataset to use for storage.
|
|
|
+ schema:
|
|
|
+ type: string
|
|
|
+ required: true
|
|
|
+ immutable: true
|
|
|
+ hidden: true
|
|
|
+ default: "dnsmasq"
|
|
|
+ - variable: aclEntries
|
|
|
+ label: ACL Configuration
|
|
|
+ schema:
|
|
|
+ type: dict
|
|
|
+ show_if: [["aclEnable", "=", true]]
|
|
|
+ attrs: []
|
|
|
+ - variable: hostPathConfig
|
|
|
+ label: Host Path Config
|
|
|
schema:
|
|
|
- type: boolean
|
|
|
- default: false
|
|
|
- show_subquestions_if: true
|
|
|
- subquestions:
|
|
|
+ type: dict
|
|
|
+ show_if: [["type", "=", "hostPath"]]
|
|
|
+ attrs:
|
|
|
+ - variable: aclEnable
|
|
|
+ label: Enable ACL
|
|
|
+ description: Enable ACL for the dataset.
|
|
|
+ schema:
|
|
|
+ type: boolean
|
|
|
+ default: false
|
|
|
+ - variable: acl
|
|
|
+ label: ACL Configuration
|
|
|
+ schema:
|
|
|
+ type: dict
|
|
|
+ show_if: [["aclEnable", "=", true]]
|
|
|
+ attrs: []
|
|
|
+ $ref:
|
|
|
+ - "normalize/acl"
|
|
|
- variable: hostPath
|
|
|
- label: "Host Path for Pihole DNSMASQ Volume"
|
|
|
+ label: Host Path
|
|
|
+ description: The host path to use for storage.
|
|
|
schema:
|
|
|
type: hostpath
|
|
|
+ show_if: [["aclEnable", "=", false]]
|
|
|
+ required: true
|
|
|
+
|
|
|
+ - variable: additionalStorages
|
|
|
+ label: Additional Storage
|
|
|
+ description: Additional storage for Pi-Hole.
|
|
|
+ schema:
|
|
|
+ type: list
|
|
|
+ default: []
|
|
|
+ items:
|
|
|
+ - variable: storageEntry
|
|
|
+ label: Storage Entry
|
|
|
+ schema:
|
|
|
+ type: dict
|
|
|
+ attrs:
|
|
|
+ - variable: type
|
|
|
+ label: Type
|
|
|
+ description: |
|
|
|
+ ixVolume: Is dataset created automatically by the system.</br>
|
|
|
+ Host Path: Is a path that already exists on the system.</br>
|
|
|
+ SMB Share: Is a SMB share that is mounted to a persistent volume claim.
|
|
|
+ schema:
|
|
|
+ type: string
|
|
|
+ required: true
|
|
|
+ default: "ixVolume"
|
|
|
+ immutable: true
|
|
|
+ enum:
|
|
|
+ - value: "hostPath"
|
|
|
+ description: Host Path (Path that already exists on the system)
|
|
|
+ - value: "ixVolume"
|
|
|
+ description: ixVolume (Dataset created automatically by the system)
|
|
|
+ - value: "smb-pv-pvc"
|
|
|
+ description: SMB Share (Mounts a persistent volume claim to a SMB share)
|
|
|
+ - variable: readOnly
|
|
|
+ label: Read Only
|
|
|
+ description: Mount the volume as read only.
|
|
|
+ schema:
|
|
|
+ type: boolean
|
|
|
+ default: false
|
|
|
+ - variable: mountPath
|
|
|
+ label: Mount Path
|
|
|
+ description: The path inside the container to mount the storage.
|
|
|
+ schema:
|
|
|
+ type: path
|
|
|
required: true
|
|
|
+ - variable: hostPathConfig
|
|
|
+ label: Host Path Config
|
|
|
+ schema:
|
|
|
+ type: dict
|
|
|
+ show_if: [["type", "=", "hostPath"]]
|
|
|
+ attrs:
|
|
|
+ - variable: aclEnable
|
|
|
+ label: Enable ACL
|
|
|
+ description: Enable ACL for the dataset.
|
|
|
+ schema:
|
|
|
+ type: boolean
|
|
|
+ default: false
|
|
|
+ - variable: acl
|
|
|
+ label: ACL Configuration
|
|
|
+ schema:
|
|
|
+ type: dict
|
|
|
+ show_if: [["aclEnable", "=", true]]
|
|
|
+ attrs: []
|
|
|
+ $ref:
|
|
|
+ - "normalize/acl"
|
|
|
+ - variable: hostPath
|
|
|
+ label: Host Path
|
|
|
+ description: The host path to use for storage.
|
|
|
+ schema:
|
|
|
+ type: hostpath
|
|
|
+ show_if: [["aclEnable", "=", false]]
|
|
|
+ required: true
|
|
|
+ - variable: ixVolumeConfig
|
|
|
+ label: ixVolume Configuration
|
|
|
+ description: The configuration for the ixVolume dataset.
|
|
|
+ schema:
|
|
|
+ type: dict
|
|
|
+ show_if: [["type", "=", "ixVolume"]]
|
|
|
+ $ref:
|
|
|
+ - "normalize/ixVolume"
|
|
|
+ attrs:
|
|
|
+ - variable: aclEnable
|
|
|
+ label: Enable ACL
|
|
|
+ description: Enable ACL for the dataset.
|
|
|
+ schema:
|
|
|
+ type: boolean
|
|
|
+ default: false
|
|
|
+ - variable: datasetName
|
|
|
+ label: Dataset Name
|
|
|
+ description: The name of the dataset to use for storage.
|
|
|
+ schema:
|
|
|
+ type: string
|
|
|
+ required: true
|
|
|
+ immutable: true
|
|
|
+ default: "storage_entry"
|
|
|
+ - variable: aclEntries
|
|
|
+ label: ACL Configuration
|
|
|
+ schema:
|
|
|
+ type: dict
|
|
|
+ show_if: [["aclEnable", "=", true]]
|
|
|
+ attrs: []
|
|
|
+ - variable: smbConfig
|
|
|
+ label: SMB Share Configuration
|
|
|
+ description: The configuration for the SMB Share.
|
|
|
+ schema:
|
|
|
+ type: dict
|
|
|
+ show_if: [["type", "=", "smb-pv-pvc"]]
|
|
|
+ attrs:
|
|
|
+ - variable: server
|
|
|
+ label: Server
|
|
|
+ description: The server for the SMB share.
|
|
|
+ schema:
|
|
|
+ type: string
|
|
|
+ required: true
|
|
|
+ - variable: share
|
|
|
+ label: Share
|
|
|
+ description: The share name for the SMB share.
|
|
|
+ schema:
|
|
|
+ type: string
|
|
|
+ required: true
|
|
|
+ - variable: domain
|
|
|
+ label: Domain (Optional)
|
|
|
+ description: The domain for the SMB share.
|
|
|
+ schema:
|
|
|
+ type: string
|
|
|
+ - variable: username
|
|
|
+ label: Username
|
|
|
+ description: The username for the SMB share.
|
|
|
+ schema:
|
|
|
+ type: string
|
|
|
+ required: true
|
|
|
+ - variable: password
|
|
|
+ label: Password
|
|
|
+ description: The password for the SMB share.
|
|
|
+ schema:
|
|
|
+ type: string
|
|
|
+ required: true
|
|
|
+ private: true
|
|
|
+ - variable: size
|
|
|
+ label: Size (in Gi)
|
|
|
+ description: The size of the volume quota.
|
|
|
+ schema:
|
|
|
+ type: int
|
|
|
+ required: true
|
|
|
+ min: 1
|
|
|
+ default: 1
|
|
|
|
|
|
- - variable: extraAppVolumeMounts
|
|
|
- label: "Extra Host Path Volumes"
|
|
|
- group: "Storage"
|
|
|
+ - variable: resources
|
|
|
+ group: Resources Configuration
|
|
|
+ label: ""
|
|
|
schema:
|
|
|
- type: list
|
|
|
- items:
|
|
|
- - variable: extraAppVolume
|
|
|
- label: "Host Path Volume"
|
|
|
- description: "Add an extra host path volume for Pihole application"
|
|
|
+ type: dict
|
|
|
+ attrs:
|
|
|
+ - variable: limits
|
|
|
+ label: Limits
|
|
|
schema:
|
|
|
type: dict
|
|
|
attrs:
|
|
|
- - variable: mountPath
|
|
|
- label: "Mount Path in Pod"
|
|
|
- description: "Path where the volume will be mounted inside the pod"
|
|
|
+ - variable: cpu
|
|
|
+ label: CPU
|
|
|
+ description: CPU limit for Pi-Hole.
|
|
|
schema:
|
|
|
- type: path
|
|
|
+ type: string
|
|
|
+ max_length: 6
|
|
|
+ valid_chars: '^(0\.[1-9]|[1-9][0-9]*)(\.[0-9]|m?)$'
|
|
|
+ valid_chars_error: |
|
|
|
+ Valid CPU limit formats are</br>
|
|
|
+ - Plain Integer - eg. 1</br>
|
|
|
+ - Float - eg. 0.5</br>
|
|
|
+ - Milicpu - eg. 500m
|
|
|
+ default: "4000m"
|
|
|
required: true
|
|
|
- - variable: hostPath
|
|
|
- label: "Host Path"
|
|
|
- description: "Host path"
|
|
|
+ - variable: memory
|
|
|
+ label: Memory
|
|
|
+ description: Memory limit for Pi-Hole.
|
|
|
schema:
|
|
|
- type: hostpath
|
|
|
+ type: string
|
|
|
+ max_length: 12
|
|
|
+ valid_chars: '^[1-9][0-9]*([EPTGMK]i?|e[0-9]+)?$'
|
|
|
+ valid_chars_error: |
|
|
|
+ Valid Memory limit formats are</br>
|
|
|
+ - Suffixed with E/P/T/G/M/K - eg. 1G</br>
|
|
|
+ - Suffixed with Ei/Pi/Ti/Gi/Mi/Ki - eg. 1Gi</br>
|
|
|
+ - Plain Integer in bytes - eg. 1024</br>
|
|
|
+ - Exponent - eg. 134e6
|
|
|
+ default: "8Gi"
|
|
|
required: true
|
|
|
-
|
|
|
- - variable: enableResourceLimits
|
|
|
- label: "Enable Pod resource limits"
|
|
|
- group: "Resource Limits"
|
|
|
- schema:
|
|
|
- type: boolean
|
|
|
- default: false
|
|
|
- - variable: cpuLimit
|
|
|
- label: "CPU Limit"
|
|
|
- description: "CPU resource limit allow plain integer values with suffix m(milli) e.g 1000m, 100."
|
|
|
- group: "Resource Limits"
|
|
|
- schema:
|
|
|
- type: string
|
|
|
- show_if: [["enableResourceLimits", "=", true]]
|
|
|
- valid_chars: "^\\d+(?:\\.\\d+(?!.*m$)|m?$)"
|
|
|
- default: "4000m"
|
|
|
- - variable: memLimit
|
|
|
- label: "Memory Limit"
|
|
|
- group: "Resource Limits"
|
|
|
- description: "Memory limits is specified by number of bytes. Followed by quantity suffix like E,P,T,G,M,k and Ei,Pi,Ti,Mi,Gi,Ki can also be used. e.g 129e6, 129M, 128974848000m, 123Mi"
|
|
|
- schema:
|
|
|
- type: string
|
|
|
- show_if: [["enableResourceLimits", "=", true]]
|
|
|
- valid_chars: "^([+-]?[0-9.]+)([eEinumkKMGTP]*[-+]?[0-9]*)$"
|
|
|
- default: "8Gi"
|