1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561156215631564156515661567156815691570157115721573157415751576157715781579158015811582158315841585158615871588158915901591159215931594159515961597159815991600160116021603160416051606160716081609161016111612161316141615161616171618161916201621162216231624162516261627162816291630163116321633163416351636163716381639164016411642164316441645164616471648164916501651165216531654165516561657165816591660166116621663166416651666166716681669167016711672167316741675167616771678167916801681168216831684168516861687168816891690169116921693169416951696169716981699170017011702170317041705170617071708170917101711171217131714 |
- {
- "1.2.115": {
- "healthy": true,
- "supported": false,
- "healthy_error": null,
- "location": "/__w/charts/charts/community/n8n/1.2.115",
- "last_update": "2025-03-05 14:29:05",
- "required_features": [
- "definitions/nodeIP",
- "definitions/certificate",
- "normalize/ixVolume",
- "normalize/acl"
- ],
- "human_version": "1.82.1_1.2.115",
- "version": "1.2.115",
- "chart_metadata": {
- "name": "n8n",
- "description": "n8n is an extendable workflow automation tool.",
- "annotations": {
- "title": "n8n"
- },
- "type": "application",
- "version": "1.2.115",
- "apiVersion": "v2",
- "appVersion": "1.82.1",
- "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.9"
- }
- ],
- "home": "https://n8n.io/",
- "icon": "https://media.sys.truenas.net/apps/n8n/icons/icon.png",
- "sources": [
- "https://github.com/n8n-io/n8n",
- "https://github.com/truenas/charts/tree/master/community/n8n",
- "https://hub.docker.com/r/n8nio/n8n"
- ],
- "keywords": [
- "workflows",
- "automation"
- ]
- },
- "app_metadata": {
- "runAsContext": [
- {
- "userName": "n8n",
- "groupName": "n8n",
- "gid": 568,
- "uid": 568,
- "description": "n8n runs as any non-root user"
- },
- {
- "userName": "postgres",
- "groupName": "postgres",
- "gid": 999,
- "uid": 999,
- "description": "Postgres runs as a non-root user."
- },
- {
- "userName": "redis",
- "groupName": "redis",
- "gid": 1001,
- "uid": 0,
- "description": "Redis runs as a non-root user and root group."
- }
- ],
- "capabilities": [],
- "hostMounts": []
- },
- "schema": {
- "groups": [
- {
- "name": "n8n Configuration",
- "description": "Configure n8n"
- },
- {
- "name": "User and Group Configuration",
- "description": "Configure User and Group for n8n"
- },
- {
- "name": "Network Configuration",
- "description": "Configure Network for n8n"
- },
- {
- "name": "Storage Configuration",
- "description": "Configure Storage for n8n"
- },
- {
- "name": "Resources Configuration",
- "description": "Configure Resources for n8n"
- }
- ],
- "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": "n8nConfig",
- "label": "",
- "group": "n8n Configuration",
- "schema": {
- "type": "dict",
- "attrs": [
- {
- "variable": "webHost",
- "label": "n8n Host",
- "description": "The host address.</br>\nExamples:</br>\nn8n.example.com </br>\n192.168.1.100\n",
- "schema": {
- "type": "string",
- "default": "192.168.0.10",
- "required": true,
- "$ref": [
- "definitions/nodeIP"
- ]
- }
- },
- {
- "variable": "additionalEnvs",
- "label": "Additional Environment Variables",
- "description": "Configure additional environment variables for n8n.",
- "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": "n8nRunAs",
- "label": "",
- "group": "User and Group Configuration",
- "schema": {
- "type": "dict",
- "attrs": [
- {
- "variable": "user",
- "label": "User ID",
- "description": "The user id that n8n will run as.",
- "schema": {
- "type": "int",
- "min": 2,
- "default": 568,
- "required": true
- }
- },
- {
- "variable": "group",
- "label": "Group ID",
- "description": "The group id that n8n will run as.",
- "schema": {
- "type": "int",
- "min": 2,
- "default": 568,
- "required": true
- }
- }
- ]
- }
- },
- {
- "variable": "n8nNetwork",
- "label": "",
- "group": "Network Configuration",
- "schema": {
- "type": "dict",
- "attrs": [
- {
- "variable": "webPort",
- "label": "Web Port",
- "description": "The port for the n8n WebUI.",
- "schema": {
- "type": "int",
- "default": 30068,
- "min": 9000,
- "max": 65535,
- "required": true
- }
- },
- {
- "variable": "hostNetwork",
- "label": "Host Network",
- "description": "Bind to the host network. It's recommended to keep this disabled.\n",
- "schema": {
- "type": "boolean",
- "default": false
- }
- },
- {
- "variable": "certificateID",
- "label": "Certificate",
- "description": "The certificate to use for n8n",
- "schema": {
- "type": "int",
- "null": true,
- "$ref": [
- "definitions/certificate"
- ],
- "enum": [
- {
- "value": null,
- "description": "No Certificate"
- }
- ],
- "default": null
- }
- }
- ]
- }
- },
- {
- "variable": "n8nStorage",
- "label": "",
- "group": "Storage Configuration",
- "schema": {
- "type": "dict",
- "attrs": [
- {
- "variable": "data",
- "label": "n8n Data Storage",
- "description": "The path to store n8n 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",
- "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": "data"
- }
- },
- {
- "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": "n8n Postgres Data Storage",
- "description": "The path to store n8n 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": "n8n Postgres Backup Storage",
- "description": "The path to store n8n 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 n8n.",
- "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 n8n.",
- "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 n8n.",
- "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>n8n</h1>\n<p><a href=\"https://n8n.io/\">n8n</a> is an extendable workflow automation tool.</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>",
- "detailed_readme": "<h1>n8n</h1>\n<p><a href=\"https://n8n.io/\">n8n</a> is an extendable workflow automation tool.</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>",
- "changelog": null
- }
- }
|