groups: - name: "Container Image" description: "Image to be used for container" - name: "Workload Configuration" description: "Configure workload deployment" - name: "Configuration" description: "additional container configuration" - name: "Networking" description: "Configure / service for container" - name: "Storage" description: "Persist and share data that is separate from the lifecycle of the container" - name: "Resources and Devices" description: "Specify resources/devices to be allocated to workload" - name: "Reverse Proxy Configuration" description: "Reverse Proxy configuration" - name: "Advanced" description: "Advanced Configuration" - name: "WARNING" description: "WARNING" portals: web_portal: protocols: - "$kubernetes-resource_configmap_portal_protocol" host: - "$kubernetes-resource_configmap_portal_host" ports: - "$kubernetes-resource_configmap_portal_port" path: "/loleaflet/dist/admin/admin.html" questions: - variable: portal group: "Container Image" label: "Configure Portal Button" schema: type: dict hidden: true attrs: - variable: enabled label: "Enable" description: "enable the portal button" schema: hidden: true editable: false type: boolean default: true # Update Policy - variable: strategyType group: "Container Image" label: "Update Strategy" schema: type: string default: "Recreate" enum: - value: "RollingUpdate" description: "Create new pods and then kill old ones" - value: "Recreate" description: "Kill existing pods before creating new ones" # Configure Time Zone - variable: timezone group: "Container Image" label: "Timezone" schema: type: string default: "Etc/UTC" $ref: - "definitions/timezone" # environmentVariables Configuraiton - variable: env group: "Configuration" label: "Environment Variables Configuration" schema: type: dict required: true attrs: - variable: domain label: "Domains will be using collabora" description: 'Use backslash "\" before dots ".". Use pipe "|" to separate multiple domains' schema: type: string default: 'nextcloud\.domain\.tld|othernextcloud\.domain\.tld' required: true - variable: username label: "Username for WebUI" schema: type: string default: "admin" required: true - variable: password label: "Password for WebUI" schema: type: string private: true default: "" required: true - variable: dictionaries label: "Dictionaries to use, leave empty to use all" schema: type: string default: "de_DE en_GB en_US es_ES fr_FR it nl pt_BR pt_PT ru" - variable: extra_params label: "Extra Parameters to add" description: 'e.g. "–o:welcome.enable=false", See more on /etc/loolwsd/loowsd.xml. Separate params with space' schema: type: string default: "-o:welcome.enable=false -o:user_interface.mode=notebookbar -o:ssl.termination=true -o:ssl.enable=false" - variable: server_name label: "Server Name" description: "When this environment variable is set (is not “”), then its value will be used as server name in /etc/loolwsd/loolwsd.xml. Without this, CODE is not delivering a correct host for the websocket connection in case of a proxy in front of it." schema: type: string default: 'collabora\.domain\.tld' # Configure Enviroment Variables - variable: environmentVariables label: "Image environment" group: "Configuration" schema: type: list default: [] items: - variable: environmentVariable label: "Environment Variable" schema: type: dict attrs: - variable: name label: "Name" schema: type: string - variable: value label: "Value" schema: type: string # Service Configuration # Enable Host Networking - variable: hostNetwork group: "Networking" label: "Enable Host Networking" schema: type: boolean default: false - variable: services group: "Networking" label: "Configure Service" schema: type: dict attrs: - variable: main label: "Main service" description: "The Primary service on which the healthcheck runs, often the webUI" schema: type: dict attrs: - variable: enabled label: "Enable the service" schema: type: boolean default: true hidden: true - variable: type label: "Service type" description: "ClusterIP's are only internally available, nodePorts expose the container to the host node System" schema: type: string default: "ClusterIP" enum: - value: "NodePort" description: "NodePort" - value: "ClusterIP" description: "ClusterIP" - variable: port label: "Port configuration" schema: type: dict attrs: - variable: protocol label: "Port Type" schema: type: string default: "HTTP" hidden: false enum: - value: HTTP description: "HTTP" - value: "HTTPS" description: "HTTPS" - variable: port label: "container port" schema: type: int default: 9980 editable: false hidden: true - variable: targetport label: "Internal Service port" description: "When connecting internally to this App, you'll need this port" schema: type: int default: 9980 editable: false hidden: true - variable: nodePort label: "(optional) host nodePort to expose to" description: "only get used when nodePort is selected" schema: type: int min: 9000 max: 65535 default: 36004 required: true # Reverse Proxy - variable: customStorage label: "Custom app storage" group: "Storage" schema: type: list default: [] items: - variable: volumeMount label: "Custom Storage" schema: type: dict attrs: - variable: enabled label: "Enabled" schema: type: boolean default: true required: true hidden: true editable: false - variable: setPermissions label: "Automatic Permissions" description: "Automatically set permissions on install" schema: type: boolean default: true hidden: false - variable: readOnly label: "Mount as ReadOnly" description: "prevent any write from being done to the mounted volume" schema: type: boolean default: false hidden: false - variable: emptyDir label: "emptyDir" schema: type: boolean default: false hidden: true editable: false - variable: mountPath label: "Mount Path" description: "Path to mount inside the pod" schema: type: path required: true default: "" editable: true - variable: hostPath label: "Host Path" schema: type: hostpath required: true - variable: ingress label: "" group: "Reverse Proxy Configuration" schema: type: dict attrs: - variable: main label: "WebUI" schema: type: dict attrs: - variable: certType label: "Select Reverse-Proxy Type" schema: type: string default: "disabled" enum: - value: "disabled" description: "Disabled" - value: "" description: "No Encryption/TLS/Certificates" - value: "selfsigned" description: "Self-Signed Certificate" - value: "ixcert" description: "TrueNAS SCALE Certificate" - variable: type label: "Reverse Proxy Type" schema: type: string default: "HTTP" hidden: true editable: false required: true - variable: serviceName label: "Service name to proxy to" schema: hidden: true editable: false type: string default: "" - variable: entrypoint label: "Select Entrypoint" schema: show_if: [["certType", "!=", "disabled"]] type: string default: "websecure" required: true enum: - value: "websecure" description: "Websecure: HTTPS/TLS port 443" - variable: hosts label: "Hosts" schema: show_if: [["certType", "!=", "disabled"]] type: list default: [] items: - variable: host label: "Host" schema: type: dict attrs: - variable: host label: "Domain Name" required: true schema: type: string - variable: path label: "path" schema: type: string required: true hidden: true default: "/" - variable: certificate label: "Select TrueNAS SCALE Certificate" schema: type: int show_if: [["certType", "=", "ixcert"]] $ref: - "definitions/certificate" - variable: authForwardURL label: "Forward Authentication URL" schema: show_if: [["certType", "!=", "disabled"]] type: string default: ""