|
@@ -1,84 +1,93 @@
|
|
|
groups:
|
|
|
- - name: Configuration
|
|
|
- description: WG-Easy application configuration
|
|
|
- - name: Storage
|
|
|
- description: Configure storage for WG-Easy
|
|
|
- - name: Networking
|
|
|
- description: Networking Configuration for WG-Easy
|
|
|
- - name: Advanced DNS Settings
|
|
|
- description: Configure DNS settings
|
|
|
- - name: Resource Limits
|
|
|
- description: Set CPU/memory limits for Kubernetes Pod
|
|
|
+ - name: WG-Easy Configuration
|
|
|
+ description: Configure WG-Easy
|
|
|
+ - name: Advanced Pod Configuration
|
|
|
+ description: Configure Advanced Pod Options for WG-Easy
|
|
|
+ - name: Network Configuration
|
|
|
+ description: Configure Network for WG-Easy
|
|
|
+ - name: Storage Configuration
|
|
|
+ description: Configure Storage for WG-Easy
|
|
|
+ - name: Resources Configuration
|
|
|
+ description: Configure Resources for WG-Easy
|
|
|
|
|
|
portals:
|
|
|
web_portal:
|
|
|
protocols:
|
|
|
- - http
|
|
|
+ - "$kubernetes-resource_configmap_portal_protocol"
|
|
|
host:
|
|
|
- - $node_ip
|
|
|
+ - "$kubernetes-resource_configmap_portal_host"
|
|
|
ports:
|
|
|
- - $variable-webUIPort
|
|
|
- path: /
|
|
|
+ - "$kubernetes-resource_configmap_portal_port"
|
|
|
+ path: "$kubernetes-resource_configmap_portal_path"
|
|
|
|
|
|
questions:
|
|
|
- - variable: wgUDPPort
|
|
|
- label: WireGuard UDP Node Port for WG-Easy
|
|
|
- group: Networking
|
|
|
+ - variable: wgNetwork
|
|
|
+ label: ""
|
|
|
+ group: Network Configuration
|
|
|
schema:
|
|
|
- type: int
|
|
|
- min: 9000
|
|
|
- max: 65535
|
|
|
- default: 20920
|
|
|
- required: true
|
|
|
- - variable: webUIPort
|
|
|
- label: WebUI Node Port for WG-Easy
|
|
|
- group: Networking
|
|
|
- schema:
|
|
|
- type: int
|
|
|
- min: 9000
|
|
|
- max: 65535
|
|
|
- default: 20921
|
|
|
- required: true
|
|
|
- - variable: hostNetwork
|
|
|
- label: Host Network
|
|
|
- group: Networking
|
|
|
- schema:
|
|
|
- type: boolean
|
|
|
- default: true
|
|
|
+ type: dict
|
|
|
+ attrs:
|
|
|
+ - variable: udpPort
|
|
|
+ label: Web Port
|
|
|
+ description: The port for the WG-Easy Wireguard service.
|
|
|
+ schema:
|
|
|
+ type: int
|
|
|
+ default: 30057
|
|
|
+ min: 9000
|
|
|
+ max: 65535
|
|
|
+ required: true
|
|
|
+ - variable: webPort
|
|
|
+ label: Web Port
|
|
|
+ description: The port for the WG-Easy Web UI.
|
|
|
+ schema:
|
|
|
+ type: int
|
|
|
+ default: 30058
|
|
|
+ min: 9000
|
|
|
+ max: 65535
|
|
|
+ required: true
|
|
|
+ - variable: hostNetwork
|
|
|
+ label: Host Network
|
|
|
+ schema:
|
|
|
+ type: boolean
|
|
|
+ default: true
|
|
|
|
|
|
- - variable: dnsConfig
|
|
|
- label: DNS Configuration
|
|
|
- group: Advanced DNS Settings
|
|
|
+ - variable: podOptions
|
|
|
+ label: ""
|
|
|
+ group: Advanced Pod Configuration
|
|
|
schema:
|
|
|
type: dict
|
|
|
attrs:
|
|
|
- - variable: options
|
|
|
- label: DNS Options
|
|
|
+ - variable: dnsConfig
|
|
|
+ label: Advanced DNS Configuration
|
|
|
schema:
|
|
|
- type: list
|
|
|
- items:
|
|
|
- - variable: optionsEntry
|
|
|
- label: Option Entry Configuration
|
|
|
+ type: dict
|
|
|
+ attrs:
|
|
|
+ - variable: options
|
|
|
+ label: DNS Options
|
|
|
schema:
|
|
|
- type: dict
|
|
|
- attrs:
|
|
|
- - variable: name
|
|
|
- label: Option Name
|
|
|
+ type: list
|
|
|
+ items:
|
|
|
+ - variable: optionsEntry
|
|
|
+ label: DNS Option Entry
|
|
|
schema:
|
|
|
- type: string
|
|
|
- required: true
|
|
|
- - variable: value
|
|
|
- label: Option Value
|
|
|
- schema:
|
|
|
- type: string
|
|
|
- required: true
|
|
|
+ type: dict
|
|
|
+ attrs:
|
|
|
+ - variable: name
|
|
|
+ label: Option Name
|
|
|
+ schema:
|
|
|
+ type: string
|
|
|
+ required: true
|
|
|
+ - variable: value
|
|
|
+ label: Option Value
|
|
|
+ schema:
|
|
|
+ type: string
|
|
|
+ required: true
|
|
|
|
|
|
- - variable: wgeasy
|
|
|
- label: WG-Easy Configuration
|
|
|
- group: Configuration
|
|
|
+ - variable: wgConfig
|
|
|
+ label: ""
|
|
|
+ group: WG-Easy Configuration
|
|
|
schema:
|
|
|
type: dict
|
|
|
- additional_attrs: true
|
|
|
attrs:
|
|
|
- variable: host
|
|
|
label: Hostname or IP
|
|
@@ -95,35 +104,35 @@ questions:
|
|
|
type: string
|
|
|
private: true
|
|
|
default: ""
|
|
|
- - variable: keep_alive
|
|
|
+ - variable: keepAlive
|
|
|
label: Persistent Keep Alive
|
|
|
description: Value in seconds to keep the "connection" open. If this value is 0, then connections won't be kept alive.
|
|
|
schema:
|
|
|
type: int
|
|
|
required: true
|
|
|
default: 0
|
|
|
- - variable: client_mtu
|
|
|
+ - variable: clientMTU
|
|
|
label: Clients MTU
|
|
|
description: The MTU the clients will use.
|
|
|
schema:
|
|
|
type: int
|
|
|
required: true
|
|
|
default: 1420
|
|
|
- - variable: client_address_range
|
|
|
+ - variable: clientAddressRange
|
|
|
label: Clients IP Address Range
|
|
|
description: Clients IP address range.
|
|
|
schema:
|
|
|
type: string
|
|
|
required: true
|
|
|
default: 10.8.0.x
|
|
|
- - variable: client_dns_server
|
|
|
+ - variable: clientDNSServer
|
|
|
label: Clients DNS Server
|
|
|
description: Clients DNS Server.
|
|
|
schema:
|
|
|
type: string
|
|
|
required: true
|
|
|
default: "1.1.1.1"
|
|
|
- - variable: allowed_ips
|
|
|
+ - variable: allowedIPs
|
|
|
label: Allowed IPs
|
|
|
description: Allowed IPs clients will use. If none provided, <0.0.0.0/0,::/0> will be used.
|
|
|
schema:
|
|
@@ -136,125 +145,296 @@ questions:
|
|
|
type: string
|
|
|
required: true
|
|
|
default: ""
|
|
|
-
|
|
|
- - variable: environmentVariables
|
|
|
- label: WG-Easy Environment
|
|
|
- group: Configuration
|
|
|
- schema:
|
|
|
- type: list
|
|
|
- default: []
|
|
|
- items:
|
|
|
- - variable: environmentVariable
|
|
|
- label: Environment Variable
|
|
|
+ - variable: additionalEnvs
|
|
|
+ label: Additional Environment Variables
|
|
|
+ description: Configure additional environment variables for WG-Easy.
|
|
|
schema:
|
|
|
- type: dict
|
|
|
- attrs:
|
|
|
- - variable: name
|
|
|
- label: Name
|
|
|
- schema:
|
|
|
- type: string
|
|
|
- required: true
|
|
|
- default: ""
|
|
|
- - variable: value
|
|
|
- label: Value
|
|
|
+ type: list
|
|
|
+ default: []
|
|
|
+ items:
|
|
|
+ - variable: env
|
|
|
+ label: Environment Variable
|
|
|
schema:
|
|
|
- type: string
|
|
|
- default: ""
|
|
|
- required: true
|
|
|
+ type: dict
|
|
|
+ attrs:
|
|
|
+ - variable: name
|
|
|
+ label: Name
|
|
|
+ schema:
|
|
|
+ type: string
|
|
|
+ required: true
|
|
|
+ - variable: value
|
|
|
+ label: Value
|
|
|
+ schema:
|
|
|
+ type: string
|
|
|
+ required: true
|
|
|
|
|
|
- - variable: appVolumeMounts
|
|
|
- label: WG-Easy Storage
|
|
|
- group: Storage
|
|
|
+ - variable: wgStorage
|
|
|
+ label: ""
|
|
|
+ group: Storage Configuration
|
|
|
schema:
|
|
|
type: dict
|
|
|
attrs:
|
|
|
- variable: config
|
|
|
- label: Configuration Volume
|
|
|
+ label: WG-Easy Config Storage
|
|
|
+ description: The path to store WG-Easy 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
|
|
|
- $ref:
|
|
|
- - normalize/ixVolume
|
|
|
- show_if: [["hostPathEnabled", "=", false]]
|
|
|
- default: ix-wg-easy_config
|
|
|
- editable: false
|
|
|
- - variable: mountPath
|
|
|
- label: Configuration Mount Path
|
|
|
- description: Path where the volume will be mounted inside the pod
|
|
|
+ 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: path
|
|
|
- hidden: true
|
|
|
- editable: true
|
|
|
- default: /etc/wireguard
|
|
|
- - variable: hostPathEnabled
|
|
|
- label: Enable Custom Host Path for WG-Easy Configuration Volume
|
|
|
+ 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
|
|
|
+ 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 WG-Easy Configuration Volume
|
|
|
+ label: Host Path
|
|
|
+ description: The host path to use for storage.
|
|
|
schema:
|
|
|
type: hostpath
|
|
|
+ show_if: [["aclEnable", "=", false]]
|
|
|
+ immutable: true
|
|
|
required: true
|
|
|
+ - variable: additionalStorages
|
|
|
+ label: Additional Storage
|
|
|
+ description: Additional storage for WG-Easy.
|
|
|
+ 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]]
|
|
|
+ immutable: true
|
|
|
+ required: true
|
|
|
+ - variable: ixVolumeConfig
|
|
|
+ label: ixVolume Configuration
|
|
|
+ description: The configuration for the ixVolume dataset.
|
|
|
+ schema:
|
|
|
+ type: dict
|
|
|
+ show_if: [["type", "=", "ixVolume"]]
|
|
|
$ref:
|
|
|
- - validations/lockedHostPath
|
|
|
+ - "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 WG-Easy 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 WG-Easy.
|
|
|
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 WG-Easy.
|
|
|
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
|
|
|
- $ref:
|
|
|
- - validations/lockedHostPath
|
|
|
-
|
|
|
- - variable: enableResourceLimits
|
|
|
- label: Enable Pod resource limits
|
|
|
- group: Resource Limits
|
|
|
- schema:
|
|
|
- type: boolean
|
|
|
- default: false
|
|
|
- - variable: cpuLimit
|
|
|
- label: CPU Limit resource limits
|
|
|
- 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
|