400 lines
16 KiB
YAML
400 lines
16 KiB
YAML
|
groups:
|
||
|
- name: Container Image
|
||
|
description: Image to be used for container
|
||
|
- name: General Settings
|
||
|
description: General Deployment Settings
|
||
|
- name: App Configuration
|
||
|
description: App Specific Config Options
|
||
|
- name: Networking and Services
|
||
|
description: Configure Network and Services for Container
|
||
|
- name: Storage and Persistence
|
||
|
description: Persist and Share Data that is Separate from the Container
|
||
|
- name: Ingress
|
||
|
description: Ingress Configuration
|
||
|
- name: Security and Permissions
|
||
|
description: Configure Security Context and Permissions
|
||
|
- name: Resources and Devices
|
||
|
description: "Specify Resources/Devices to be Allocated to Workload"
|
||
|
- name: Middlewares
|
||
|
description: Traefik Middlewares
|
||
|
- name: Metrics
|
||
|
description: Metrics
|
||
|
- name: VPN
|
||
|
description: VPN
|
||
|
- name: Addons
|
||
|
description: Addon Configuration
|
||
|
- name: Advanced
|
||
|
description: Advanced Configuration
|
||
|
- name: Documentation
|
||
|
description: Documentation
|
||
|
portals:
|
||
|
open:
|
||
|
protocols:
|
||
|
- "$kubernetes-resource_configmap_portal_protocol"
|
||
|
host:
|
||
|
- "$kubernetes-resource_configmap_portal_host"
|
||
|
ports:
|
||
|
- "$kubernetes-resource_configmap_portal_port"
|
||
|
questions:
|
||
|
- variable: global
|
||
|
label: Global Settings
|
||
|
group: "General Settings"
|
||
|
schema:
|
||
|
type: dict
|
||
|
hidden: true
|
||
|
attrs:
|
||
|
- variable: isSCALE
|
||
|
label: Flag this is SCALE
|
||
|
schema:
|
||
|
type: boolean
|
||
|
default: true
|
||
|
hidden: true
|
||
|
- variable: service
|
||
|
group: Networking and Services
|
||
|
label: Configure Service(s)
|
||
|
schema:
|
||
|
additional_attrs: true
|
||
|
type: dict
|
||
|
attrs:
|
||
|
- variable: main
|
||
|
label: "Main Service"
|
||
|
description: "The Primary service on which the healthcheck runs, often the webUI"
|
||
|
schema:
|
||
|
additional_attrs: true
|
||
|
type: dict
|
||
|
attrs:
|
||
|
- variable: enabled
|
||
|
label: "Enable the service"
|
||
|
schema:
|
||
|
type: boolean
|
||
|
default: true
|
||
|
hidden: true
|
||
|
- variable: type
|
||
|
label: "Service Type"
|
||
|
description: "ExternalIP gets connected to using an IP and port, ExternalName gets connected to using a domain name"
|
||
|
schema:
|
||
|
type: string
|
||
|
default: "ExternalIP"
|
||
|
enum:
|
||
|
- value: "ExternalName"
|
||
|
description: "ExternalName"
|
||
|
- value: "ExternalIP"
|
||
|
description: "ExternalIP"
|
||
|
- variable: externalName
|
||
|
label: "External Service Domainname"
|
||
|
description: "Domainname of External service"
|
||
|
schema:
|
||
|
show_if: [["type", "=", "ExternalName"]]
|
||
|
type: string
|
||
|
default: "google.com"
|
||
|
- variable: externalIP
|
||
|
label: "External Service IP"
|
||
|
description: "IP of External service"
|
||
|
schema:
|
||
|
show_if: [["type", "=", "ExternalIP"]]
|
||
|
type: string
|
||
|
default: "1.1.1.1"
|
||
|
- variable: ports
|
||
|
label: "Service's Port(s) Configuration"
|
||
|
schema:
|
||
|
additional_attrs: true
|
||
|
type: dict
|
||
|
attrs:
|
||
|
- variable: main
|
||
|
label: "Main Service Port Configuration"
|
||
|
schema:
|
||
|
additional_attrs: true
|
||
|
type: dict
|
||
|
attrs:
|
||
|
- variable: enabled
|
||
|
label: "Enable the port"
|
||
|
schema:
|
||
|
type: boolean
|
||
|
default: true
|
||
|
hidden: true
|
||
|
- variable: protocol
|
||
|
label: "Port Type"
|
||
|
schema:
|
||
|
type: string
|
||
|
default: "HTTP"
|
||
|
enum:
|
||
|
- value: HTTP
|
||
|
description: "HTTP"
|
||
|
- value: "HTTPS"
|
||
|
description: "HTTPS"
|
||
|
- value: TCP
|
||
|
description: "TCP"
|
||
|
- value: "UDP"
|
||
|
description: "UDP"
|
||
|
- variable: port
|
||
|
label: "Service Port"
|
||
|
description: "Both the external service port and internal service port will be the same"
|
||
|
schema:
|
||
|
type: int
|
||
|
default: 10003
|
||
|
- variable: ingress
|
||
|
label: ""
|
||
|
group: Ingress
|
||
|
schema:
|
||
|
additional_attrs: true
|
||
|
type: dict
|
||
|
attrs:
|
||
|
- variable: main
|
||
|
label: "Main Ingress"
|
||
|
schema:
|
||
|
additional_attrs: true
|
||
|
type: dict
|
||
|
attrs:
|
||
|
- variable: enabled
|
||
|
label: "Enable Ingress"
|
||
|
schema:
|
||
|
type: boolean
|
||
|
default: false
|
||
|
show_subquestions_if: true
|
||
|
subquestions:
|
||
|
- variable: annotations
|
||
|
label: "annoations"
|
||
|
schema:
|
||
|
type: dict
|
||
|
hidden: true
|
||
|
attrs:
|
||
|
- variable: traefik.frontend.passHostHeader
|
||
|
label: "passHostHeader"
|
||
|
schema:
|
||
|
type: string
|
||
|
default: "false"
|
||
|
hidden: true
|
||
|
- variable: hosts
|
||
|
label: "Hosts"
|
||
|
schema:
|
||
|
type: list
|
||
|
default: []
|
||
|
items:
|
||
|
- variable: hostEntry
|
||
|
label: "Host"
|
||
|
schema:
|
||
|
additional_attrs: true
|
||
|
type: dict
|
||
|
attrs:
|
||
|
- variable: host
|
||
|
label: "HostName"
|
||
|
schema:
|
||
|
type: string
|
||
|
default: ""
|
||
|
required: true
|
||
|
- variable: paths
|
||
|
label: "Paths"
|
||
|
schema:
|
||
|
type: list
|
||
|
default: []
|
||
|
items:
|
||
|
- variable: pathEntry
|
||
|
label: "Host"
|
||
|
schema:
|
||
|
additional_attrs: true
|
||
|
type: dict
|
||
|
attrs:
|
||
|
- variable: path
|
||
|
label: "path"
|
||
|
schema:
|
||
|
type: string
|
||
|
required: true
|
||
|
default: "/"
|
||
|
- variable: pathType
|
||
|
label: "pathType"
|
||
|
schema:
|
||
|
type: string
|
||
|
required: true
|
||
|
default: "Prefix"
|
||
|
- variable: tls
|
||
|
label: TLS-Settings
|
||
|
schema:
|
||
|
type: list
|
||
|
default: []
|
||
|
items:
|
||
|
- variable: tlsEntry
|
||
|
label: Host
|
||
|
schema:
|
||
|
additional_attrs: true
|
||
|
type: dict
|
||
|
attrs:
|
||
|
- variable: hosts
|
||
|
label: Certificate Hosts
|
||
|
schema:
|
||
|
type: list
|
||
|
default: []
|
||
|
items:
|
||
|
- variable: host
|
||
|
label: Host
|
||
|
schema:
|
||
|
type: string
|
||
|
default: ""
|
||
|
required: true
|
||
|
- variable: scaleCert
|
||
|
label: Select TrueNAS SCALE Certificate
|
||
|
schema:
|
||
|
type: int
|
||
|
$ref:
|
||
|
- "definitions/certificate"
|
||
|
- variable: entrypoint
|
||
|
label: (Advanced) Traefik Entrypoint
|
||
|
description: Entrypoint used by Traefik when using Traefik as Ingress Provider
|
||
|
schema:
|
||
|
type: string
|
||
|
default: websecure
|
||
|
required: true
|
||
|
- variable: ingressClassName
|
||
|
label: (Advanced/Optional) IngressClass Name
|
||
|
schema:
|
||
|
type: string
|
||
|
default: ""
|
||
|
- variable: middlewares
|
||
|
label: Traefik Middlewares
|
||
|
description: Add previously created Traefik Middlewares to this Ingress
|
||
|
schema:
|
||
|
type: list
|
||
|
default: []
|
||
|
items:
|
||
|
- variable: name
|
||
|
label: Name
|
||
|
schema:
|
||
|
type: string
|
||
|
default: ""
|
||
|
required: true
|
||
|
- variable: ingressList
|
||
|
label: Add Manual Custom Ingresses
|
||
|
group: Ingress
|
||
|
schema:
|
||
|
type: list
|
||
|
default: []
|
||
|
items:
|
||
|
- variable: ingressListEntry
|
||
|
label: Custom Ingress
|
||
|
schema:
|
||
|
additional_attrs: true
|
||
|
type: dict
|
||
|
attrs:
|
||
|
- variable: enabled
|
||
|
label: Enable Ingress
|
||
|
schema:
|
||
|
type: boolean
|
||
|
default: true
|
||
|
hidden: true
|
||
|
- variable: name
|
||
|
label: Name
|
||
|
schema:
|
||
|
type: string
|
||
|
default: ""
|
||
|
- variable: ingressClassName
|
||
|
label: IngressClass Name
|
||
|
schema:
|
||
|
type: string
|
||
|
default: ""
|
||
|
- variable: hosts
|
||
|
label: Hosts
|
||
|
schema:
|
||
|
type: list
|
||
|
default: []
|
||
|
items:
|
||
|
- variable: hostEntry
|
||
|
label: Host
|
||
|
schema:
|
||
|
additional_attrs: true
|
||
|
type: dict
|
||
|
attrs:
|
||
|
- variable: host
|
||
|
label: HostName
|
||
|
schema:
|
||
|
type: string
|
||
|
default: ""
|
||
|
required: true
|
||
|
- variable: paths
|
||
|
label: Paths
|
||
|
schema:
|
||
|
type: list
|
||
|
default: []
|
||
|
items:
|
||
|
- variable: pathEntry
|
||
|
label: Host
|
||
|
schema:
|
||
|
additional_attrs: true
|
||
|
type: dict
|
||
|
attrs:
|
||
|
- variable: path
|
||
|
label: Path
|
||
|
schema:
|
||
|
type: string
|
||
|
required: true
|
||
|
default: "/"
|
||
|
- variable: pathType
|
||
|
label: Path Type
|
||
|
schema:
|
||
|
type: string
|
||
|
required: true
|
||
|
default: Prefix
|
||
|
- variable: service
|
||
|
label: Linked Service
|
||
|
schema:
|
||
|
additional_attrs: true
|
||
|
type: dict
|
||
|
attrs:
|
||
|
- variable: name
|
||
|
label: Service Name
|
||
|
schema:
|
||
|
type: string
|
||
|
default: ""
|
||
|
- variable: port
|
||
|
label: Service Port
|
||
|
schema:
|
||
|
type: int
|
||
|
- variable: tls
|
||
|
label: TLS-Settings
|
||
|
schema:
|
||
|
type: list
|
||
|
default: []
|
||
|
items:
|
||
|
- variable: tlsEntry
|
||
|
label: Host
|
||
|
schema:
|
||
|
additional_attrs: true
|
||
|
type: dict
|
||
|
attrs:
|
||
|
- variable: hosts
|
||
|
label: Certificate Hosts
|
||
|
schema:
|
||
|
type: list
|
||
|
default: []
|
||
|
items:
|
||
|
- variable: host
|
||
|
label: Host
|
||
|
schema:
|
||
|
type: string
|
||
|
default: ""
|
||
|
required: true
|
||
|
- variable: scaleCert
|
||
|
label: Select TrueNAS SCALE Certificate
|
||
|
schema:
|
||
|
type: int
|
||
|
$ref:
|
||
|
- "definitions/certificate"
|
||
|
- variable: entrypoint
|
||
|
label: Traefik Entrypoint
|
||
|
description: Entrypoint used by Traefik when using Traefik as Ingress Provider
|
||
|
schema:
|
||
|
type: string
|
||
|
default: websecure
|
||
|
required: true
|
||
|
- variable: middlewares
|
||
|
label: Traefik Middlewares
|
||
|
description: Add previously created Traefik Middlewares to this Ingress
|
||
|
schema:
|
||
|
type: list
|
||
|
default: []
|
||
|
items:
|
||
|
- variable: name
|
||
|
label: Name
|
||
|
schema:
|
||
|
type: string
|
||
|
default: ""
|
||
|
required: true
|