|
@@ -0,0 +1,1673 @@
|
|
|
+{
|
|
|
+ "1.0.0": {
|
|
|
+ "healthy": true,
|
|
|
+ "supported": false,
|
|
|
+ "healthy_error": null,
|
|
|
+ "location": "/__w/charts/charts/community/invidious/1.0.0",
|
|
|
+ "last_update": "2024-01-11 11:14:35",
|
|
|
+ "required_features": [
|
|
|
+ "normalize/ixVolume",
|
|
|
+ "normalize/acl"
|
|
|
+ ],
|
|
|
+ "human_version": "latest_1.0.0",
|
|
|
+ "version": "1.0.0",
|
|
|
+ "chart_metadata": {
|
|
|
+ "name": "invidious",
|
|
|
+ "description": "Invidious is an alternative front-end to YouTube",
|
|
|
+ "annotations": {
|
|
|
+ "title": "Invidious"
|
|
|
+ },
|
|
|
+ "type": "application",
|
|
|
+ "version": "1.0.0",
|
|
|
+ "apiVersion": "v2",
|
|
|
+ "appVersion": "latest",
|
|
|
+ "kubeVersion": ">=1.16.0-0",
|
|
|
+ "maintainers": [
|
|
|
+ {
|
|
|
+ "name": "truenas",
|
|
|
+ "url": "https://www.truenas.com/",
|
|
|
+ "email": "dev@ixsystems.com"
|
|
|
+ }
|
|
|
+ ],
|
|
|
+ "dependencies": [
|
|
|
+ {
|
|
|
+ "name": "common",
|
|
|
+ "repository": "file://../../../common",
|
|
|
+ "version": "1.2.7"
|
|
|
+ }
|
|
|
+ ],
|
|
|
+ "home": "https://invidious.io/",
|
|
|
+ "icon": "https://media.sys.truenas.net/apps/invidious/icons/icon.svg",
|
|
|
+ "sources": [
|
|
|
+ "https://invidious.io/",
|
|
|
+ "https://github.com/truenas/charts/tree/master/community/invidious",
|
|
|
+ "https://quay.io/repository/invidious"
|
|
|
+ ],
|
|
|
+ "keywords": [
|
|
|
+ "youtube"
|
|
|
+ ]
|
|
|
+ },
|
|
|
+ "app_metadata": {
|
|
|
+ "runAsContext": [
|
|
|
+ {
|
|
|
+ "userName": "invidious",
|
|
|
+ "groupName": "invidious",
|
|
|
+ "gid": 1000,
|
|
|
+ "uid": 1000,
|
|
|
+ "description": "Invidious runs as non-root user"
|
|
|
+ },
|
|
|
+ {
|
|
|
+ "userName": "postgres",
|
|
|
+ "groupName": "postgres",
|
|
|
+ "gid": 999,
|
|
|
+ "uid": 999,
|
|
|
+ "description": "Postgres runs as a non-root user."
|
|
|
+ }
|
|
|
+ ],
|
|
|
+ "capabilities": [],
|
|
|
+ "hostMounts": []
|
|
|
+ },
|
|
|
+ "schema": {
|
|
|
+ "groups": [
|
|
|
+ {
|
|
|
+ "name": "Invidious Configuration",
|
|
|
+ "description": "Configure Invidious"
|
|
|
+ },
|
|
|
+ {
|
|
|
+ "name": "Network Configuration",
|
|
|
+ "description": "Configure Network for Invidious"
|
|
|
+ },
|
|
|
+ {
|
|
|
+ "name": "Storage Configuration",
|
|
|
+ "description": "Configure Storage for Invidious"
|
|
|
+ },
|
|
|
+ {
|
|
|
+ "name": "Resources Configuration",
|
|
|
+ "description": "Configure Resources for Invidious"
|
|
|
+ }
|
|
|
+ ],
|
|
|
+ "portals": {
|
|
|
+ "web_portal": {
|
|
|
+ "protocols": [
|
|
|
+ "$kubernetes-resource_configmap_portal_protocol"
|
|
|
+ ],
|
|
|
+ "host": [
|
|
|
+ "$kubernetes-resource_configmap_portal_host"
|
|
|
+ ],
|
|
|
+ "ports": [
|
|
|
+ "$kubernetes-resource_configmap_portal_port"
|
|
|
+ ],
|
|
|
+ "path": "$kubernetes-resource_configmap_portal_path"
|
|
|
+ }
|
|
|
+ },
|
|
|
+ "questions": [
|
|
|
+ {
|
|
|
+ "variable": "invidiousConfig",
|
|
|
+ "label": "",
|
|
|
+ "group": "Invidious Configuration",
|
|
|
+ "schema": {
|
|
|
+ "type": "dict",
|
|
|
+ "attrs": [
|
|
|
+ {
|
|
|
+ "variable": "admins",
|
|
|
+ "label": "Admins",
|
|
|
+ "description": "List of usernames that will be granted administrator rights.",
|
|
|
+ "schema": {
|
|
|
+ "type": "list",
|
|
|
+ "default": [],
|
|
|
+ "items": [
|
|
|
+ {
|
|
|
+ "variable": "admin",
|
|
|
+ "label": "Admin",
|
|
|
+ "schema": {
|
|
|
+ "type": "string",
|
|
|
+ "required": true
|
|
|
+ }
|
|
|
+ }
|
|
|
+ ]
|
|
|
+ }
|
|
|
+ },
|
|
|
+ {
|
|
|
+ "variable": "registrationEnabled",
|
|
|
+ "label": "Registration Enabled",
|
|
|
+ "description": "Enable registration for Invidious.",
|
|
|
+ "schema": {
|
|
|
+ "type": "boolean",
|
|
|
+ "default": true
|
|
|
+ }
|
|
|
+ },
|
|
|
+ {
|
|
|
+ "variable": "loginEnabled",
|
|
|
+ "label": "Login Enabled",
|
|
|
+ "description": "Enable login for Invidious.",
|
|
|
+ "schema": {
|
|
|
+ "type": "boolean",
|
|
|
+ "default": true
|
|
|
+ }
|
|
|
+ },
|
|
|
+ {
|
|
|
+ "variable": "captchaEnabled",
|
|
|
+ "label": "Captcha Enabled",
|
|
|
+ "description": "Enable captcha for Invidious.",
|
|
|
+ "schema": {
|
|
|
+ "type": "boolean",
|
|
|
+ "default": true
|
|
|
+ }
|
|
|
+ },
|
|
|
+ {
|
|
|
+ "variable": "additionalEnvs",
|
|
|
+ "label": "Additional Environment Variables",
|
|
|
+ "description": "Configure additional environment variables for Invidious.",
|
|
|
+ "schema": {
|
|
|
+ "type": "list",
|
|
|
+ "default": [],
|
|
|
+ "items": [
|
|
|
+ {
|
|
|
+ "variable": "env",
|
|
|
+ "label": "Environment Variable",
|
|
|
+ "schema": {
|
|
|
+ "type": "dict",
|
|
|
+ "attrs": [
|
|
|
+ {
|
|
|
+ "variable": "name",
|
|
|
+ "label": "Name",
|
|
|
+ "schema": {
|
|
|
+ "type": "string",
|
|
|
+ "required": true
|
|
|
+ }
|
|
|
+ },
|
|
|
+ {
|
|
|
+ "variable": "value",
|
|
|
+ "label": "Value",
|
|
|
+ "schema": {
|
|
|
+ "type": "string",
|
|
|
+ "required": true
|
|
|
+ }
|
|
|
+ }
|
|
|
+ ]
|
|
|
+ }
|
|
|
+ }
|
|
|
+ ]
|
|
|
+ }
|
|
|
+ }
|
|
|
+ ]
|
|
|
+ }
|
|
|
+ },
|
|
|
+ {
|
|
|
+ "variable": "invidiousNetwork",
|
|
|
+ "label": "",
|
|
|
+ "group": "Network Configuration",
|
|
|
+ "schema": {
|
|
|
+ "type": "dict",
|
|
|
+ "attrs": [
|
|
|
+ {
|
|
|
+ "variable": "webPort",
|
|
|
+ "label": "Web Port",
|
|
|
+ "description": "The port for the Invidious WebUI.",
|
|
|
+ "schema": {
|
|
|
+ "type": "int",
|
|
|
+ "default": 31008,
|
|
|
+ "min": 9000,
|
|
|
+ "max": 65535,
|
|
|
+ "required": true
|
|
|
+ }
|
|
|
+ }
|
|
|
+ ]
|
|
|
+ }
|
|
|
+ },
|
|
|
+ {
|
|
|
+ "variable": "invidiousStorage",
|
|
|
+ "label": "",
|
|
|
+ "group": "Storage Configuration",
|
|
|
+ "schema": {
|
|
|
+ "type": "dict",
|
|
|
+ "attrs": [
|
|
|
+ {
|
|
|
+ "variable": "config",
|
|
|
+ "label": "Invidious Config Storage",
|
|
|
+ "description": "The path to store Invidious Configuration.",
|
|
|
+ "schema": {
|
|
|
+ "type": "dict",
|
|
|
+ "attrs": [
|
|
|
+ {
|
|
|
+ "variable": "type",
|
|
|
+ "label": "Type",
|
|
|
+ "description": "ixVolume: Is dataset created automatically by the system.</br>\nHost Path: Is a path that already exists on the system.\n",
|
|
|
+ "schema": {
|
|
|
+ "type": "string",
|
|
|
+ "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"
|
|
|
+ ],
|
|
|
+ "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": "path",
|
|
|
+ "label": "Path",
|
|
|
+ "description": "Path to perform ACL",
|
|
|
+ "schema": {
|
|
|
+ "type": "string",
|
|
|
+ "hidden": true
|
|
|
+ }
|
|
|
+ },
|
|
|
+ {
|
|
|
+ "variable": "entries",
|
|
|
+ "label": "ACL Entries",
|
|
|
+ "description": "ACL Entries",
|
|
|
+ "schema": {
|
|
|
+ "type": "list",
|
|
|
+ "items": [
|
|
|
+ {
|
|
|
+ "variable": "aclEntry",
|
|
|
+ "label": "ACL Entry",
|
|
|
+ "schema": {
|
|
|
+ "type": "dict",
|
|
|
+ "attrs": [
|
|
|
+ {
|
|
|
+ "variable": "id_type",
|
|
|
+ "label": "ID Type",
|
|
|
+ "schema": {
|
|
|
+ "type": "string",
|
|
|
+ "enum": [
|
|
|
+ {
|
|
|
+ "value": "USER",
|
|
|
+ "description": "Entry is for a USER"
|
|
|
+ },
|
|
|
+ {
|
|
|
+ "value": "GROUP",
|
|
|
+ "description": "Entry is for a GROUP"
|
|
|
+ }
|
|
|
+ ],
|
|
|
+ "default": "USER"
|
|
|
+ }
|
|
|
+ },
|
|
|
+ {
|
|
|
+ "variable": "id",
|
|
|
+ "label": "ID",
|
|
|
+ "description": "Make sure to check the ID value is correct and aligns with RunAs user context of the application",
|
|
|
+ "schema": {
|
|
|
+ "type": "int",
|
|
|
+ "required": true,
|
|
|
+ "min": 0
|
|
|
+ }
|
|
|
+ },
|
|
|
+ {
|
|
|
+ "variable": "access",
|
|
|
+ "label": "Access",
|
|
|
+ "schema": {
|
|
|
+ "type": "string",
|
|
|
+ "enum": [
|
|
|
+ {
|
|
|
+ "value": "READ",
|
|
|
+ "description": "Read Access"
|
|
|
+ },
|
|
|
+ {
|
|
|
+ "value": "MODIFY",
|
|
|
+ "description": "Modify Access"
|
|
|
+ },
|
|
|
+ {
|
|
|
+ "value": "FULL_CONTROL",
|
|
|
+ "description": "FULL_CONTROL Access"
|
|
|
+ }
|
|
|
+ ]
|
|
|
+ }
|
|
|
+ }
|
|
|
+ ]
|
|
|
+ }
|
|
|
+ }
|
|
|
+ ]
|
|
|
+ }
|
|
|
+ }
|
|
|
+ ]
|
|
|
+ }
|
|
|
+ }
|
|
|
+ ]
|
|
|
+ }
|
|
|
+ },
|
|
|
+ {
|
|
|
+ "variable": "hostPathConfig",
|
|
|
+ "label": "Host Path Configuration",
|
|
|
+ "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": [
|
|
|
+ {
|
|
|
+ "variable": "path",
|
|
|
+ "label": "Host Path",
|
|
|
+ "description": "Host Path to perform ACL",
|
|
|
+ "schema": {
|
|
|
+ "type": "hostpath",
|
|
|
+ "required": true,
|
|
|
+ "empty": false
|
|
|
+ }
|
|
|
+ },
|
|
|
+ {
|
|
|
+ "variable": "entries",
|
|
|
+ "label": "ACL Entries",
|
|
|
+ "description": "ACL Entries",
|
|
|
+ "schema": {
|
|
|
+ "type": "list",
|
|
|
+ "items": [
|
|
|
+ {
|
|
|
+ "variable": "aclEntry",
|
|
|
+ "label": "ACL Entry",
|
|
|
+ "schema": {
|
|
|
+ "type": "dict",
|
|
|
+ "attrs": [
|
|
|
+ {
|
|
|
+ "variable": "id_type",
|
|
|
+ "label": "ID Type",
|
|
|
+ "schema": {
|
|
|
+ "type": "string",
|
|
|
+ "enum": [
|
|
|
+ {
|
|
|
+ "value": "USER",
|
|
|
+ "description": "Entry is for a USER"
|
|
|
+ },
|
|
|
+ {
|
|
|
+ "value": "GROUP",
|
|
|
+ "description": "Entry is for a GROUP"
|
|
|
+ }
|
|
|
+ ],
|
|
|
+ "default": "USER"
|
|
|
+ }
|
|
|
+ },
|
|
|
+ {
|
|
|
+ "variable": "id",
|
|
|
+ "label": "ID",
|
|
|
+ "description": "Make sure to check the ID value is correct and aligns with RunAs user context of the application",
|
|
|
+ "schema": {
|
|
|
+ "type": "int",
|
|
|
+ "required": true,
|
|
|
+ "min": 0
|
|
|
+ }
|
|
|
+ },
|
|
|
+ {
|
|
|
+ "variable": "access",
|
|
|
+ "label": "Access",
|
|
|
+ "schema": {
|
|
|
+ "type": "string",
|
|
|
+ "enum": [
|
|
|
+ {
|
|
|
+ "value": "READ",
|
|
|
+ "description": "Read Access"
|
|
|
+ },
|
|
|
+ {
|
|
|
+ "value": "MODIFY",
|
|
|
+ "description": "Modify Access"
|
|
|
+ },
|
|
|
+ {
|
|
|
+ "value": "FULL_CONTROL",
|
|
|
+ "description": "FULL_CONTROL Access"
|
|
|
+ }
|
|
|
+ ]
|
|
|
+ }
|
|
|
+ }
|
|
|
+ ]
|
|
|
+ }
|
|
|
+ }
|
|
|
+ ]
|
|
|
+ }
|
|
|
+ },
|
|
|
+ {
|
|
|
+ "variable": "options",
|
|
|
+ "label": "ACL Options",
|
|
|
+ "schema": {
|
|
|
+ "type": "dict",
|
|
|
+ "attrs": [
|
|
|
+ {
|
|
|
+ "variable": "force",
|
|
|
+ "label": "Force Flag",
|
|
|
+ "description": "Enabling `Force` applies ACL even if the path has existing data",
|
|
|
+ "schema": {
|
|
|
+ "type": "boolean",
|
|
|
+ "default": false
|
|
|
+ }
|
|
|
+ }
|
|
|
+ ]
|
|
|
+ }
|
|
|
+ }
|
|
|
+ ],
|
|
|
+ "$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": "pgData",
|
|
|
+ "label": "Invidious Postgres Data Storage",
|
|
|
+ "description": "The path to store Invidious Postgres Data.",
|
|
|
+ "schema": {
|
|
|
+ "type": "dict",
|
|
|
+ "attrs": [
|
|
|
+ {
|
|
|
+ "variable": "type",
|
|
|
+ "label": "Type",
|
|
|
+ "description": "ixVolume: Is dataset created automatically by the system.</br>\nHost Path: Is a path that already exists on the system.\n",
|
|
|
+ "schema": {
|
|
|
+ "type": "string",
|
|
|
+ "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",
|
|
|
+ "hidden": true,
|
|
|
+ "show_if": [
|
|
|
+ [
|
|
|
+ "type",
|
|
|
+ "=",
|
|
|
+ "ixVolume"
|
|
|
+ ]
|
|
|
+ ],
|
|
|
+ "$ref": [
|
|
|
+ "normalize/ixVolume"
|
|
|
+ ],
|
|
|
+ "attrs": [
|
|
|
+ {
|
|
|
+ "variable": "aclEnable",
|
|
|
+ "label": "Enable ACL",
|
|
|
+ "description": "Enable ACL for the dataset.",
|
|
|
+ "schema": {
|
|
|
+ "type": "boolean",
|
|
|
+ "hidden": true,
|
|
|
+ "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": "pgData"
|
|
|
+ }
|
|
|
+ },
|
|
|
+ {
|
|
|
+ "variable": "aclEntries",
|
|
|
+ "label": "ACL Configuration",
|
|
|
+ "schema": {
|
|
|
+ "type": "dict",
|
|
|
+ "show_if": [
|
|
|
+ [
|
|
|
+ "aclEnable",
|
|
|
+ "=",
|
|
|
+ true
|
|
|
+ ]
|
|
|
+ ],
|
|
|
+ "attrs": [
|
|
|
+ {
|
|
|
+ "variable": "path",
|
|
|
+ "label": "Path",
|
|
|
+ "description": "Path to perform ACL",
|
|
|
+ "schema": {
|
|
|
+ "type": "string",
|
|
|
+ "hidden": true
|
|
|
+ }
|
|
|
+ },
|
|
|
+ {
|
|
|
+ "variable": "entries",
|
|
|
+ "label": "ACL Entries",
|
|
|
+ "description": "ACL Entries",
|
|
|
+ "schema": {
|
|
|
+ "type": "list",
|
|
|
+ "items": [
|
|
|
+ {
|
|
|
+ "variable": "aclEntry",
|
|
|
+ "label": "ACL Entry",
|
|
|
+ "schema": {
|
|
|
+ "type": "dict",
|
|
|
+ "attrs": [
|
|
|
+ {
|
|
|
+ "variable": "id_type",
|
|
|
+ "label": "ID Type",
|
|
|
+ "schema": {
|
|
|
+ "type": "string",
|
|
|
+ "enum": [
|
|
|
+ {
|
|
|
+ "value": "USER",
|
|
|
+ "description": "Entry is for a USER"
|
|
|
+ },
|
|
|
+ {
|
|
|
+ "value": "GROUP",
|
|
|
+ "description": "Entry is for a GROUP"
|
|
|
+ }
|
|
|
+ ],
|
|
|
+ "default": "USER"
|
|
|
+ }
|
|
|
+ },
|
|
|
+ {
|
|
|
+ "variable": "id",
|
|
|
+ "label": "ID",
|
|
|
+ "description": "Make sure to check the ID value is correct and aligns with RunAs user context of the application",
|
|
|
+ "schema": {
|
|
|
+ "type": "int",
|
|
|
+ "required": true,
|
|
|
+ "min": 0
|
|
|
+ }
|
|
|
+ },
|
|
|
+ {
|
|
|
+ "variable": "access",
|
|
|
+ "label": "Access",
|
|
|
+ "schema": {
|
|
|
+ "type": "string",
|
|
|
+ "enum": [
|
|
|
+ {
|
|
|
+ "value": "READ",
|
|
|
+ "description": "Read Access"
|
|
|
+ },
|
|
|
+ {
|
|
|
+ "value": "MODIFY",
|
|
|
+ "description": "Modify Access"
|
|
|
+ },
|
|
|
+ {
|
|
|
+ "value": "FULL_CONTROL",
|
|
|
+ "description": "FULL_CONTROL Access"
|
|
|
+ }
|
|
|
+ ]
|
|
|
+ }
|
|
|
+ }
|
|
|
+ ]
|
|
|
+ }
|
|
|
+ }
|
|
|
+ ]
|
|
|
+ }
|
|
|
+ }
|
|
|
+ ]
|
|
|
+ }
|
|
|
+ }
|
|
|
+ ]
|
|
|
+ }
|
|
|
+ },
|
|
|
+ {
|
|
|
+ "variable": "hostPathConfig",
|
|
|
+ "label": "Host Path Configuration",
|
|
|
+ "schema": {
|
|
|
+ "type": "dict",
|
|
|
+ "show_if": [
|
|
|
+ [
|
|
|
+ "type",
|
|
|
+ "=",
|
|
|
+ "hostPath"
|
|
|
+ ]
|
|
|
+ ],
|
|
|
+ "attrs": [
|
|
|
+ {
|
|
|
+ "variable": "aclEnable",
|
|
|
+ "label": "Enable ACL",
|
|
|
+ "description": "Enable ACL for the dataset.",
|
|
|
+ "schema": {
|
|
|
+ "type": "boolean",
|
|
|
+ "hidden": true,
|
|
|
+ "default": false
|
|
|
+ }
|
|
|
+ },
|
|
|
+ {
|
|
|
+ "variable": "acl",
|
|
|
+ "label": "ACL Configuration",
|
|
|
+ "schema": {
|
|
|
+ "type": "dict",
|
|
|
+ "show_if": [
|
|
|
+ [
|
|
|
+ "aclEnable",
|
|
|
+ "=",
|
|
|
+ true
|
|
|
+ ]
|
|
|
+ ],
|
|
|
+ "attrs": [
|
|
|
+ {
|
|
|
+ "variable": "path",
|
|
|
+ "label": "Host Path",
|
|
|
+ "description": "Host Path to perform ACL",
|
|
|
+ "schema": {
|
|
|
+ "type": "hostpath",
|
|
|
+ "required": true,
|
|
|
+ "empty": false
|
|
|
+ }
|
|
|
+ },
|
|
|
+ {
|
|
|
+ "variable": "entries",
|
|
|
+ "label": "ACL Entries",
|
|
|
+ "description": "ACL Entries",
|
|
|
+ "schema": {
|
|
|
+ "type": "list",
|
|
|
+ "items": [
|
|
|
+ {
|
|
|
+ "variable": "aclEntry",
|
|
|
+ "label": "ACL Entry",
|
|
|
+ "schema": {
|
|
|
+ "type": "dict",
|
|
|
+ "attrs": [
|
|
|
+ {
|
|
|
+ "variable": "id_type",
|
|
|
+ "label": "ID Type",
|
|
|
+ "schema": {
|
|
|
+ "type": "string",
|
|
|
+ "enum": [
|
|
|
+ {
|
|
|
+ "value": "USER",
|
|
|
+ "description": "Entry is for a USER"
|
|
|
+ },
|
|
|
+ {
|
|
|
+ "value": "GROUP",
|
|
|
+ "description": "Entry is for a GROUP"
|
|
|
+ }
|
|
|
+ ],
|
|
|
+ "default": "USER"
|
|
|
+ }
|
|
|
+ },
|
|
|
+ {
|
|
|
+ "variable": "id",
|
|
|
+ "label": "ID",
|
|
|
+ "description": "Make sure to check the ID value is correct and aligns with RunAs user context of the application",
|
|
|
+ "schema": {
|
|
|
+ "type": "int",
|
|
|
+ "required": true,
|
|
|
+ "min": 0
|
|
|
+ }
|
|
|
+ },
|
|
|
+ {
|
|
|
+ "variable": "access",
|
|
|
+ "label": "Access",
|
|
|
+ "schema": {
|
|
|
+ "type": "string",
|
|
|
+ "enum": [
|
|
|
+ {
|
|
|
+ "value": "READ",
|
|
|
+ "description": "Read Access"
|
|
|
+ },
|
|
|
+ {
|
|
|
+ "value": "MODIFY",
|
|
|
+ "description": "Modify Access"
|
|
|
+ },
|
|
|
+ {
|
|
|
+ "value": "FULL_CONTROL",
|
|
|
+ "description": "FULL_CONTROL Access"
|
|
|
+ }
|
|
|
+ ]
|
|
|
+ }
|
|
|
+ }
|
|
|
+ ]
|
|
|
+ }
|
|
|
+ }
|
|
|
+ ]
|
|
|
+ }
|
|
|
+ },
|
|
|
+ {
|
|
|
+ "variable": "options",
|
|
|
+ "label": "ACL Options",
|
|
|
+ "schema": {
|
|
|
+ "type": "dict",
|
|
|
+ "attrs": [
|
|
|
+ {
|
|
|
+ "variable": "force",
|
|
|
+ "label": "Force Flag",
|
|
|
+ "description": "Enabling `Force` applies ACL even if the path has existing data",
|
|
|
+ "schema": {
|
|
|
+ "type": "boolean",
|
|
|
+ "default": false
|
|
|
+ }
|
|
|
+ }
|
|
|
+ ]
|
|
|
+ }
|
|
|
+ }
|
|
|
+ ],
|
|
|
+ "$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": "pgBackup",
|
|
|
+ "label": "Invidious Postgres Backup Storage",
|
|
|
+ "description": "The path to store Invidious Postgres Backup.",
|
|
|
+ "schema": {
|
|
|
+ "type": "dict",
|
|
|
+ "attrs": [
|
|
|
+ {
|
|
|
+ "variable": "type",
|
|
|
+ "label": "Type",
|
|
|
+ "description": "ixVolume: Is dataset created automatically by the system.</br>\nHost Path: Is a path that already exists on the system.\n",
|
|
|
+ "schema": {
|
|
|
+ "type": "string",
|
|
|
+ "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",
|
|
|
+ "hidden": true,
|
|
|
+ "show_if": [
|
|
|
+ [
|
|
|
+ "type",
|
|
|
+ "=",
|
|
|
+ "ixVolume"
|
|
|
+ ]
|
|
|
+ ],
|
|
|
+ "$ref": [
|
|
|
+ "normalize/ixVolume"
|
|
|
+ ],
|
|
|
+ "attrs": [
|
|
|
+ {
|
|
|
+ "variable": "aclEnable",
|
|
|
+ "label": "Enable ACL",
|
|
|
+ "description": "Enable ACL for the dataset.",
|
|
|
+ "schema": {
|
|
|
+ "type": "boolean",
|
|
|
+ "hidden": true,
|
|
|
+ "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": "pgBackup"
|
|
|
+ }
|
|
|
+ },
|
|
|
+ {
|
|
|
+ "variable": "aclEntries",
|
|
|
+ "label": "ACL Configuration",
|
|
|
+ "schema": {
|
|
|
+ "type": "dict",
|
|
|
+ "show_if": [
|
|
|
+ [
|
|
|
+ "aclEnable",
|
|
|
+ "=",
|
|
|
+ true
|
|
|
+ ]
|
|
|
+ ],
|
|
|
+ "attrs": [
|
|
|
+ {
|
|
|
+ "variable": "path",
|
|
|
+ "label": "Path",
|
|
|
+ "description": "Path to perform ACL",
|
|
|
+ "schema": {
|
|
|
+ "type": "string",
|
|
|
+ "hidden": true
|
|
|
+ }
|
|
|
+ },
|
|
|
+ {
|
|
|
+ "variable": "entries",
|
|
|
+ "label": "ACL Entries",
|
|
|
+ "description": "ACL Entries",
|
|
|
+ "schema": {
|
|
|
+ "type": "list",
|
|
|
+ "items": [
|
|
|
+ {
|
|
|
+ "variable": "aclEntry",
|
|
|
+ "label": "ACL Entry",
|
|
|
+ "schema": {
|
|
|
+ "type": "dict",
|
|
|
+ "attrs": [
|
|
|
+ {
|
|
|
+ "variable": "id_type",
|
|
|
+ "label": "ID Type",
|
|
|
+ "schema": {
|
|
|
+ "type": "string",
|
|
|
+ "enum": [
|
|
|
+ {
|
|
|
+ "value": "USER",
|
|
|
+ "description": "Entry is for a USER"
|
|
|
+ },
|
|
|
+ {
|
|
|
+ "value": "GROUP",
|
|
|
+ "description": "Entry is for a GROUP"
|
|
|
+ }
|
|
|
+ ],
|
|
|
+ "default": "USER"
|
|
|
+ }
|
|
|
+ },
|
|
|
+ {
|
|
|
+ "variable": "id",
|
|
|
+ "label": "ID",
|
|
|
+ "description": "Make sure to check the ID value is correct and aligns with RunAs user context of the application",
|
|
|
+ "schema": {
|
|
|
+ "type": "int",
|
|
|
+ "required": true,
|
|
|
+ "min": 0
|
|
|
+ }
|
|
|
+ },
|
|
|
+ {
|
|
|
+ "variable": "access",
|
|
|
+ "label": "Access",
|
|
|
+ "schema": {
|
|
|
+ "type": "string",
|
|
|
+ "enum": [
|
|
|
+ {
|
|
|
+ "value": "READ",
|
|
|
+ "description": "Read Access"
|
|
|
+ },
|
|
|
+ {
|
|
|
+ "value": "MODIFY",
|
|
|
+ "description": "Modify Access"
|
|
|
+ },
|
|
|
+ {
|
|
|
+ "value": "FULL_CONTROL",
|
|
|
+ "description": "FULL_CONTROL Access"
|
|
|
+ }
|
|
|
+ ]
|
|
|
+ }
|
|
|
+ }
|
|
|
+ ]
|
|
|
+ }
|
|
|
+ }
|
|
|
+ ]
|
|
|
+ }
|
|
|
+ }
|
|
|
+ ]
|
|
|
+ }
|
|
|
+ }
|
|
|
+ ]
|
|
|
+ }
|
|
|
+ },
|
|
|
+ {
|
|
|
+ "variable": "hostPathConfig",
|
|
|
+ "label": "Host Path Configuration",
|
|
|
+ "schema": {
|
|
|
+ "type": "dict",
|
|
|
+ "show_if": [
|
|
|
+ [
|
|
|
+ "type",
|
|
|
+ "=",
|
|
|
+ "hostPath"
|
|
|
+ ]
|
|
|
+ ],
|
|
|
+ "attrs": [
|
|
|
+ {
|
|
|
+ "variable": "aclEnable",
|
|
|
+ "label": "Enable ACL",
|
|
|
+ "description": "Enable ACL for the dataset.",
|
|
|
+ "schema": {
|
|
|
+ "type": "boolean",
|
|
|
+ "hidden": true,
|
|
|
+ "default": false
|
|
|
+ }
|
|
|
+ },
|
|
|
+ {
|
|
|
+ "variable": "acl",
|
|
|
+ "label": "ACL Configuration",
|
|
|
+ "schema": {
|
|
|
+ "type": "dict",
|
|
|
+ "show_if": [
|
|
|
+ [
|
|
|
+ "aclEnable",
|
|
|
+ "=",
|
|
|
+ true
|
|
|
+ ]
|
|
|
+ ],
|
|
|
+ "attrs": [
|
|
|
+ {
|
|
|
+ "variable": "path",
|
|
|
+ "label": "Host Path",
|
|
|
+ "description": "Host Path to perform ACL",
|
|
|
+ "schema": {
|
|
|
+ "type": "hostpath",
|
|
|
+ "required": true,
|
|
|
+ "empty": false
|
|
|
+ }
|
|
|
+ },
|
|
|
+ {
|
|
|
+ "variable": "entries",
|
|
|
+ "label": "ACL Entries",
|
|
|
+ "description": "ACL Entries",
|
|
|
+ "schema": {
|
|
|
+ "type": "list",
|
|
|
+ "items": [
|
|
|
+ {
|
|
|
+ "variable": "aclEntry",
|
|
|
+ "label": "ACL Entry",
|
|
|
+ "schema": {
|
|
|
+ "type": "dict",
|
|
|
+ "attrs": [
|
|
|
+ {
|
|
|
+ "variable": "id_type",
|
|
|
+ "label": "ID Type",
|
|
|
+ "schema": {
|
|
|
+ "type": "string",
|
|
|
+ "enum": [
|
|
|
+ {
|
|
|
+ "value": "USER",
|
|
|
+ "description": "Entry is for a USER"
|
|
|
+ },
|
|
|
+ {
|
|
|
+ "value": "GROUP",
|
|
|
+ "description": "Entry is for a GROUP"
|
|
|
+ }
|
|
|
+ ],
|
|
|
+ "default": "USER"
|
|
|
+ }
|
|
|
+ },
|
|
|
+ {
|
|
|
+ "variable": "id",
|
|
|
+ "label": "ID",
|
|
|
+ "description": "Make sure to check the ID value is correct and aligns with RunAs user context of the application",
|
|
|
+ "schema": {
|
|
|
+ "type": "int",
|
|
|
+ "required": true,
|
|
|
+ "min": 0
|
|
|
+ }
|
|
|
+ },
|
|
|
+ {
|
|
|
+ "variable": "access",
|
|
|
+ "label": "Access",
|
|
|
+ "schema": {
|
|
|
+ "type": "string",
|
|
|
+ "enum": [
|
|
|
+ {
|
|
|
+ "value": "READ",
|
|
|
+ "description": "Read Access"
|
|
|
+ },
|
|
|
+ {
|
|
|
+ "value": "MODIFY",
|
|
|
+ "description": "Modify Access"
|
|
|
+ },
|
|
|
+ {
|
|
|
+ "value": "FULL_CONTROL",
|
|
|
+ "description": "FULL_CONTROL Access"
|
|
|
+ }
|
|
|
+ ]
|
|
|
+ }
|
|
|
+ }
|
|
|
+ ]
|
|
|
+ }
|
|
|
+ }
|
|
|
+ ]
|
|
|
+ }
|
|
|
+ },
|
|
|
+ {
|
|
|
+ "variable": "options",
|
|
|
+ "label": "ACL Options",
|
|
|
+ "schema": {
|
|
|
+ "type": "dict",
|
|
|
+ "attrs": [
|
|
|
+ {
|
|
|
+ "variable": "force",
|
|
|
+ "label": "Force Flag",
|
|
|
+ "description": "Enabling `Force` applies ACL even if the path has existing data",
|
|
|
+ "schema": {
|
|
|
+ "type": "boolean",
|
|
|
+ "default": false
|
|
|
+ }
|
|
|
+ }
|
|
|
+ ]
|
|
|
+ }
|
|
|
+ }
|
|
|
+ ],
|
|
|
+ "$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": "additionalStorages",
|
|
|
+ "label": "Additional Storage",
|
|
|
+ "description": "Additional storage for Invidious.",
|
|
|
+ "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>\nHost Path: Is a path that already exists on the system.</br>\nSMB Share: Is a SMB share that is mounted to a persistent volume claim.\n",
|
|
|
+ "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 Configuration",
|
|
|
+ "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": [
|
|
|
+ {
|
|
|
+ "variable": "path",
|
|
|
+ "label": "Host Path",
|
|
|
+ "description": "Host Path to perform ACL",
|
|
|
+ "schema": {
|
|
|
+ "type": "hostpath",
|
|
|
+ "required": true,
|
|
|
+ "empty": false
|
|
|
+ }
|
|
|
+ },
|
|
|
+ {
|
|
|
+ "variable": "entries",
|
|
|
+ "label": "ACL Entries",
|
|
|
+ "description": "ACL Entries",
|
|
|
+ "schema": {
|
|
|
+ "type": "list",
|
|
|
+ "items": [
|
|
|
+ {
|
|
|
+ "variable": "aclEntry",
|
|
|
+ "label": "ACL Entry",
|
|
|
+ "schema": {
|
|
|
+ "type": "dict",
|
|
|
+ "attrs": [
|
|
|
+ {
|
|
|
+ "variable": "id_type",
|
|
|
+ "label": "ID Type",
|
|
|
+ "schema": {
|
|
|
+ "type": "string",
|
|
|
+ "enum": [
|
|
|
+ {
|
|
|
+ "value": "USER",
|
|
|
+ "description": "Entry is for a USER"
|
|
|
+ },
|
|
|
+ {
|
|
|
+ "value": "GROUP",
|
|
|
+ "description": "Entry is for a GROUP"
|
|
|
+ }
|
|
|
+ ],
|
|
|
+ "default": "USER"
|
|
|
+ }
|
|
|
+ },
|
|
|
+ {
|
|
|
+ "variable": "id",
|
|
|
+ "label": "ID",
|
|
|
+ "description": "Make sure to check the ID value is correct and aligns with RunAs user context of the application",
|
|
|
+ "schema": {
|
|
|
+ "type": "int",
|
|
|
+ "required": true,
|
|
|
+ "min": 0
|
|
|
+ }
|
|
|
+ },
|
|
|
+ {
|
|
|
+ "variable": "access",
|
|
|
+ "label": "Access",
|
|
|
+ "schema": {
|
|
|
+ "type": "string",
|
|
|
+ "enum": [
|
|
|
+ {
|
|
|
+ "value": "READ",
|
|
|
+ "description": "Read Access"
|
|
|
+ },
|
|
|
+ {
|
|
|
+ "value": "MODIFY",
|
|
|
+ "description": "Modify Access"
|
|
|
+ },
|
|
|
+ {
|
|
|
+ "value": "FULL_CONTROL",
|
|
|
+ "description": "FULL_CONTROL Access"
|
|
|
+ }
|
|
|
+ ]
|
|
|
+ }
|
|
|
+ }
|
|
|
+ ]
|
|
|
+ }
|
|
|
+ }
|
|
|
+ ]
|
|
|
+ }
|
|
|
+ },
|
|
|
+ {
|
|
|
+ "variable": "options",
|
|
|
+ "label": "ACL Options",
|
|
|
+ "schema": {
|
|
|
+ "type": "dict",
|
|
|
+ "attrs": [
|
|
|
+ {
|
|
|
+ "variable": "force",
|
|
|
+ "label": "Force Flag",
|
|
|
+ "description": "Enabling `Force` applies ACL even if the path has existing data",
|
|
|
+ "schema": {
|
|
|
+ "type": "boolean",
|
|
|
+ "default": false
|
|
|
+ }
|
|
|
+ }
|
|
|
+ ]
|
|
|
+ }
|
|
|
+ }
|
|
|
+ ],
|
|
|
+ "$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": "path",
|
|
|
+ "label": "Path",
|
|
|
+ "description": "Path to perform ACL",
|
|
|
+ "schema": {
|
|
|
+ "type": "string",
|
|
|
+ "hidden": true
|
|
|
+ }
|
|
|
+ },
|
|
|
+ {
|
|
|
+ "variable": "entries",
|
|
|
+ "label": "ACL Entries",
|
|
|
+ "description": "ACL Entries",
|
|
|
+ "schema": {
|
|
|
+ "type": "list",
|
|
|
+ "items": [
|
|
|
+ {
|
|
|
+ "variable": "aclEntry",
|
|
|
+ "label": "ACL Entry",
|
|
|
+ "schema": {
|
|
|
+ "type": "dict",
|
|
|
+ "attrs": [
|
|
|
+ {
|
|
|
+ "variable": "id_type",
|
|
|
+ "label": "ID Type",
|
|
|
+ "schema": {
|
|
|
+ "type": "string",
|
|
|
+ "enum": [
|
|
|
+ {
|
|
|
+ "value": "USER",
|
|
|
+ "description": "Entry is for a USER"
|
|
|
+ },
|
|
|
+ {
|
|
|
+ "value": "GROUP",
|
|
|
+ "description": "Entry is for a GROUP"
|
|
|
+ }
|
|
|
+ ],
|
|
|
+ "default": "USER"
|
|
|
+ }
|
|
|
+ },
|
|
|
+ {
|
|
|
+ "variable": "id",
|
|
|
+ "label": "ID",
|
|
|
+ "description": "Make sure to check the ID value is correct and aligns with RunAs user context of the application",
|
|
|
+ "schema": {
|
|
|
+ "type": "int",
|
|
|
+ "required": true,
|
|
|
+ "min": 0
|
|
|
+ }
|
|
|
+ },
|
|
|
+ {
|
|
|
+ "variable": "access",
|
|
|
+ "label": "Access",
|
|
|
+ "schema": {
|
|
|
+ "type": "string",
|
|
|
+ "enum": [
|
|
|
+ {
|
|
|
+ "value": "READ",
|
|
|
+ "description": "Read Access"
|
|
|
+ },
|
|
|
+ {
|
|
|
+ "value": "MODIFY",
|
|
|
+ "description": "Modify Access"
|
|
|
+ },
|
|
|
+ {
|
|
|
+ "value": "FULL_CONTROL",
|
|
|
+ "description": "FULL_CONTROL Access"
|
|
|
+ }
|
|
|
+ ]
|
|
|
+ }
|
|
|
+ }
|
|
|
+ ]
|
|
|
+ }
|
|
|
+ }
|
|
|
+ ]
|
|
|
+ }
|
|
|
+ }
|
|
|
+ ]
|
|
|
+ }
|
|
|
+ }
|
|
|
+ ]
|
|
|
+ }
|
|
|
+ },
|
|
|
+ {
|
|
|
+ "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": "resources",
|
|
|
+ "label": "",
|
|
|
+ "group": "Resources Configuration",
|
|
|
+ "schema": {
|
|
|
+ "type": "dict",
|
|
|
+ "attrs": [
|
|
|
+ {
|
|
|
+ "variable": "limits",
|
|
|
+ "label": "Limits",
|
|
|
+ "schema": {
|
|
|
+ "type": "dict",
|
|
|
+ "attrs": [
|
|
|
+ {
|
|
|
+ "variable": "cpu",
|
|
|
+ "label": "CPU",
|
|
|
+ "description": "CPU limit for Invidious.",
|
|
|
+ "schema": {
|
|
|
+ "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>\n- Plain Integer - eg. 1</br>\n- Float - eg. 0.5</br>\n- Milicpu - eg. 500m\n",
|
|
|
+ "default": "4000m",
|
|
|
+ "required": true
|
|
|
+ }
|
|
|
+ },
|
|
|
+ {
|
|
|
+ "variable": "memory",
|
|
|
+ "label": "Memory",
|
|
|
+ "description": "Memory limit for Invidious.",
|
|
|
+ "schema": {
|
|
|
+ "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>\n- Suffixed with E/P/T/G/M/K - eg. 1G</br>\n- Suffixed with Ei/Pi/Ti/Gi/Mi/Ki - eg. 1Gi</br>\n- Plain Integer in bytes - eg. 1024</br>\n- Exponent - eg. 134e6\n",
|
|
|
+ "default": "8Gi",
|
|
|
+ "required": true
|
|
|
+ }
|
|
|
+ }
|
|
|
+ ]
|
|
|
+ }
|
|
|
+ }
|
|
|
+ ]
|
|
|
+ }
|
|
|
+ }
|
|
|
+ ]
|
|
|
+ },
|
|
|
+ "app_readme": "<h1>Invidious</h1>\n<p><a href=\"https://invidious.io/\">Invidious</a> is an alternative front-end to YouTube.</p>\n<blockquote>\n<p>When application is installed, a container will be launched with <strong>root</strong> privileges.\nThis is required in order to apply the correct permissions to the <code>postgres</code> directories.\nAfterward, the <code>postgres</code> container will run as a <strong>non</strong>-root user (<code>999</code>).\nOn each upgrade, a container will be launched with <strong>root</strong> privileges in order to apply the correct\npermissions to the <code>postgres</code> <strong>backups</strong> directory. Container that performs the backup will run as a <strong>non</strong>-root user (<code>999</code>) afterwards.\nKeep in mind the permissions on the backup directory will be changed to <code>999:999</code> on <strong>every</strong> update.\nBut will only be changed once for the <code>postgres</code> data directories.</p>\n</blockquote>\n<p>Additional configuration can be specified</p>\n<ul>\n<li>Via <a href=\"https://github.com/iv-org/invidious/pull/1702\">environment variables</a></li>\n<li>By editing the file <code>/config/config.yaml</code> (see <a href=\"https://github.com/iv-org/invidious/blob/master/config/config.example.yml\">example</a>)</li>\n</ul>",
|
|
|
+ "detailed_readme": "<h1>Invidious</h1>\n<p><a href=\"https://invidious.io/\">Invidious</a> is an alternative front-end to YouTube.</p>\n<blockquote>\n<p>When application is installed, a container will be launched with <strong>root</strong> privileges.\nThis is required in order to apply the correct permissions to the <code>postgres</code> directories.\nAfterward, the <code>postgres</code> container will run as a <strong>non</strong>-root user (<code>999</code>).\nOn each upgrade, a container will be launched with <strong>root</strong> privileges in order to apply the correct\npermissions to the <code>postgres</code> <strong>backups</strong> directory. Container that performs the backup will run as a <strong>non</strong>-root user (<code>999</code>) afterwards.\nKeep in mind the permissions on the backup directory will be changed to <code>999:999</code> on <strong>every</strong> update.\nBut will only be changed once for the <code>postgres</code> data directories.</p>\n</blockquote>\n<p>Additional configuration can be specified</p>\n<ul>\n<li>Via <a href=\"https://github.com/iv-org/invidious/pull/1702\">environment variables</a></li>\n<li>By editing the file <code>/config/config.yaml</code> (see <a href=\"https://github.com/iv-org/invidious/blob/master/config/config.example.yml\">example</a>)</li>\n</ul>",
|
|
|
+ "changelog": null
|
|
|
+ }
|
|
|
+}
|