app_versions.json 134 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478147914801481148214831484148514861487148814891490149114921493149414951496149714981499150015011502150315041505150615071508150915101511151215131514151515161517151815191520152115221523152415251526152715281529153015311532153315341535153615371538153915401541154215431544154515461547154815491550155115521553155415551556155715581559156015611562156315641565156615671568156915701571157215731574157515761577157815791580158115821583158415851586158715881589159015911592159315941595159615971598159916001601160216031604160516061607160816091610161116121613161416151616161716181619162016211622162316241625162616271628162916301631163216331634163516361637163816391640164116421643164416451646164716481649165016511652165316541655165616571658165916601661166216631664166516661667166816691670167116721673167416751676167716781679168016811682168316841685168616871688168916901691169216931694169516961697169816991700170117021703170417051706170717081709171017111712171317141715171617171718
  1. {
  2. "1.2.3": {
  3. "healthy": true,
  4. "supported": false,
  5. "healthy_error": null,
  6. "location": "/__w/charts/charts/community/n8n/1.2.3",
  7. "last_update": "2023-12-01 12:59:34",
  8. "required_features": [
  9. "definitions/certificate",
  10. "normalize/acl",
  11. "definitions/nodeIP",
  12. "normalize/ixVolume"
  13. ],
  14. "human_version": "1.18.1_1.2.3",
  15. "version": "1.2.3",
  16. "chart_metadata": {
  17. "name": "n8n",
  18. "description": "n8n is an extendable workflow automation tool.",
  19. "annotations": {
  20. "title": "n8n"
  21. },
  22. "type": "application",
  23. "version": "1.2.3",
  24. "apiVersion": "v2",
  25. "appVersion": "1.18.1",
  26. "kubeVersion": ">=1.16.0-0",
  27. "maintainers": [
  28. {
  29. "name": "truenas",
  30. "url": "https://www.truenas.com/",
  31. "email": "dev@ixsystems.com"
  32. }
  33. ],
  34. "dependencies": [
  35. {
  36. "name": "common",
  37. "repository": "file://../../../common",
  38. "version": "1.2.3"
  39. }
  40. ],
  41. "home": "https://n8n.io/",
  42. "icon": "https://media.sys.truenas.net/apps/n8n/icons/icon.png",
  43. "sources": [
  44. "https://github.com/n8n-io/n8n",
  45. "https://github.com/truenas/charts/tree/master/community/n8n",
  46. "https://hub.docker.com/r/n8nio/n8n"
  47. ],
  48. "keywords": [
  49. "workflows",
  50. "automation"
  51. ]
  52. },
  53. "app_metadata": {
  54. "runAsContext": [
  55. {
  56. "userName": "n8n",
  57. "groupName": "n8n",
  58. "gid": 568,
  59. "uid": 568,
  60. "description": "n8n runs as any non-root user"
  61. },
  62. {
  63. "userName": "postgres",
  64. "groupName": "postgres",
  65. "gid": 999,
  66. "uid": 999,
  67. "description": "Postgres runs as a non-root user."
  68. },
  69. {
  70. "userName": "redis",
  71. "groupName": "redis",
  72. "gid": 1001,
  73. "uid": 0,
  74. "description": "Redis runs as a non-root user and root group."
  75. }
  76. ],
  77. "capabilities": [],
  78. "hostMounts": []
  79. },
  80. "schema": {
  81. "groups": [
  82. {
  83. "name": "n8n Configuration",
  84. "description": "Configure n8n"
  85. },
  86. {
  87. "name": "User and Group Configuration",
  88. "description": "Configure User and Group for n8n"
  89. },
  90. {
  91. "name": "Network Configuration",
  92. "description": "Configure Network for n8n"
  93. },
  94. {
  95. "name": "Storage Configuration",
  96. "description": "Configure Storage for n8n"
  97. },
  98. {
  99. "name": "Resources Configuration",
  100. "description": "Configure Resources for n8n"
  101. }
  102. ],
  103. "portals": {
  104. "web_portal": {
  105. "protocols": [
  106. "$kubernetes-resource_configmap_portal_protocol"
  107. ],
  108. "host": [
  109. "$kubernetes-resource_configmap_portal_host"
  110. ],
  111. "ports": [
  112. "$kubernetes-resource_configmap_portal_port"
  113. ],
  114. "path": "$kubernetes-resource_configmap_portal_path"
  115. }
  116. },
  117. "questions": [
  118. {
  119. "variable": "n8nConfig",
  120. "label": "",
  121. "group": "n8n Configuration",
  122. "schema": {
  123. "type": "dict",
  124. "attrs": [
  125. {
  126. "variable": "webHost",
  127. "label": "n8n Host",
  128. "description": "The host address.</br>\nExamples:</br>\nn8n.example.com </br>\n192.168.1.100\n",
  129. "schema": {
  130. "type": "string",
  131. "default": "192.168.0.10",
  132. "required": true,
  133. "$ref": [
  134. "definitions/nodeIP"
  135. ]
  136. }
  137. },
  138. {
  139. "variable": "additionalEnvs",
  140. "label": "Additional Environment Variables",
  141. "description": "Configure additional environment variables for n8n.",
  142. "schema": {
  143. "type": "list",
  144. "default": [],
  145. "items": [
  146. {
  147. "variable": "env",
  148. "label": "Environment Variable",
  149. "schema": {
  150. "type": "dict",
  151. "attrs": [
  152. {
  153. "variable": "name",
  154. "label": "Name",
  155. "schema": {
  156. "type": "string",
  157. "required": true
  158. }
  159. },
  160. {
  161. "variable": "value",
  162. "label": "Value",
  163. "schema": {
  164. "type": "string",
  165. "required": true
  166. }
  167. }
  168. ]
  169. }
  170. }
  171. ]
  172. }
  173. }
  174. ]
  175. }
  176. },
  177. {
  178. "variable": "n8nRunAs",
  179. "label": "",
  180. "group": "User and Group Configuration",
  181. "schema": {
  182. "type": "dict",
  183. "attrs": [
  184. {
  185. "variable": "user",
  186. "label": "User ID",
  187. "description": "The user id that n8n will run as.",
  188. "schema": {
  189. "type": "int",
  190. "min": 2,
  191. "default": 568,
  192. "required": true
  193. }
  194. },
  195. {
  196. "variable": "group",
  197. "label": "Group ID",
  198. "description": "The group id that n8n will run as.",
  199. "schema": {
  200. "type": "int",
  201. "min": 2,
  202. "default": 568,
  203. "required": true
  204. }
  205. }
  206. ]
  207. }
  208. },
  209. {
  210. "variable": "n8nNetwork",
  211. "label": "",
  212. "group": "Network Configuration",
  213. "schema": {
  214. "type": "dict",
  215. "attrs": [
  216. {
  217. "variable": "webPort",
  218. "label": "Web Port",
  219. "description": "The port for the n8n WebUI.",
  220. "schema": {
  221. "type": "int",
  222. "default": 30068,
  223. "min": 9000,
  224. "max": 65535,
  225. "required": true
  226. }
  227. },
  228. {
  229. "variable": "hostNetwork",
  230. "label": "Host Network",
  231. "description": "Bind to the host network. It's recommended to keep this disabled.\n",
  232. "schema": {
  233. "type": "boolean",
  234. "default": false
  235. }
  236. },
  237. {
  238. "variable": "certificateID",
  239. "label": "Certificate",
  240. "description": "The certificate to use for n8n",
  241. "schema": {
  242. "type": "int",
  243. "null": true,
  244. "$ref": [
  245. "definitions/certificate"
  246. ],
  247. "enum": [
  248. {
  249. "value": null,
  250. "description": "No Certificate"
  251. }
  252. ],
  253. "default": null
  254. }
  255. }
  256. ]
  257. }
  258. },
  259. {
  260. "variable": "n8nStorage",
  261. "label": "",
  262. "group": "Storage Configuration",
  263. "schema": {
  264. "type": "dict",
  265. "attrs": [
  266. {
  267. "variable": "data",
  268. "label": "n8n Data Storage",
  269. "description": "The path to store n8n data.",
  270. "schema": {
  271. "type": "dict",
  272. "attrs": [
  273. {
  274. "variable": "type",
  275. "label": "Type",
  276. "description": "ixVolume: Is dataset created automatically by the system.</br>\nHost Path: Is a path that already exists on the system.\n",
  277. "schema": {
  278. "type": "string",
  279. "required": true,
  280. "immutable": true,
  281. "default": "ixVolume",
  282. "enum": [
  283. {
  284. "value": "hostPath",
  285. "description": "Host Path (Path that already exists on the system)"
  286. },
  287. {
  288. "value": "ixVolume",
  289. "description": "ixVolume (Dataset created automatically by the system)"
  290. }
  291. ]
  292. }
  293. },
  294. {
  295. "variable": "ixVolumeConfig",
  296. "label": "ixVolume Configuration",
  297. "description": "The configuration for the ixVolume dataset.",
  298. "schema": {
  299. "type": "dict",
  300. "show_if": [
  301. [
  302. "type",
  303. "=",
  304. "ixVolume"
  305. ]
  306. ],
  307. "$ref": [
  308. "normalize/ixVolume"
  309. ],
  310. "attrs": [
  311. {
  312. "variable": "aclEnable",
  313. "label": "Enable ACL",
  314. "description": "Enable ACL for the dataset.",
  315. "schema": {
  316. "type": "boolean",
  317. "default": false
  318. }
  319. },
  320. {
  321. "variable": "datasetName",
  322. "label": "Dataset Name",
  323. "description": "The name of the dataset to use for storage.",
  324. "schema": {
  325. "type": "string",
  326. "required": true,
  327. "immutable": true,
  328. "hidden": true,
  329. "default": "data"
  330. }
  331. },
  332. {
  333. "variable": "aclEntries",
  334. "label": "ACL Configuration",
  335. "schema": {
  336. "type": "dict",
  337. "show_if": [
  338. [
  339. "aclEnable",
  340. "=",
  341. true
  342. ]
  343. ],
  344. "attrs": [
  345. {
  346. "variable": "path",
  347. "label": "Path",
  348. "description": "Path to perform ACL",
  349. "schema": {
  350. "type": "string",
  351. "hidden": true
  352. }
  353. },
  354. {
  355. "variable": "entries",
  356. "label": "ACL Entries",
  357. "description": "ACL Entries",
  358. "schema": {
  359. "type": "list",
  360. "items": [
  361. {
  362. "variable": "aclEntry",
  363. "label": "ACL Entry",
  364. "schema": {
  365. "type": "dict",
  366. "attrs": [
  367. {
  368. "variable": "id_type",
  369. "label": "ID Type",
  370. "schema": {
  371. "type": "string",
  372. "enum": [
  373. {
  374. "value": "USER",
  375. "description": "Entry is for a USER"
  376. },
  377. {
  378. "value": "GROUP",
  379. "description": "Entry is for a GROUP"
  380. }
  381. ],
  382. "default": "USER"
  383. }
  384. },
  385. {
  386. "variable": "id",
  387. "label": "ID",
  388. "description": "Make sure to check the ID value is correct and aligns with RunAs user context of the application",
  389. "schema": {
  390. "type": "int",
  391. "required": true,
  392. "min": 0
  393. }
  394. },
  395. {
  396. "variable": "access",
  397. "label": "Access",
  398. "schema": {
  399. "type": "string",
  400. "enum": [
  401. {
  402. "value": "READ",
  403. "description": "Read Access"
  404. },
  405. {
  406. "value": "MODIFY",
  407. "description": "Modify Access"
  408. },
  409. {
  410. "value": "FULL_CONTROL",
  411. "description": "FULL_CONTROL Access"
  412. }
  413. ]
  414. }
  415. }
  416. ]
  417. }
  418. }
  419. ]
  420. }
  421. }
  422. ]
  423. }
  424. }
  425. ]
  426. }
  427. },
  428. {
  429. "variable": "hostPathConfig",
  430. "label": "Host Path Configuration",
  431. "schema": {
  432. "type": "dict",
  433. "show_if": [
  434. [
  435. "type",
  436. "=",
  437. "hostPath"
  438. ]
  439. ],
  440. "attrs": [
  441. {
  442. "variable": "aclEnable",
  443. "label": "Enable ACL",
  444. "description": "Enable ACL for the dataset.",
  445. "schema": {
  446. "type": "boolean",
  447. "default": false
  448. }
  449. },
  450. {
  451. "variable": "acl",
  452. "label": "ACL Configuration",
  453. "schema": {
  454. "type": "dict",
  455. "show_if": [
  456. [
  457. "aclEnable",
  458. "=",
  459. true
  460. ]
  461. ],
  462. "attrs": [
  463. {
  464. "variable": "path",
  465. "label": "Host Path",
  466. "description": "Host Path to perform ACL",
  467. "schema": {
  468. "type": "hostpath",
  469. "required": true,
  470. "empty": false
  471. }
  472. },
  473. {
  474. "variable": "entries",
  475. "label": "ACL Entries",
  476. "description": "ACL Entries",
  477. "schema": {
  478. "type": "list",
  479. "items": [
  480. {
  481. "variable": "aclEntry",
  482. "label": "ACL Entry",
  483. "schema": {
  484. "type": "dict",
  485. "attrs": [
  486. {
  487. "variable": "id_type",
  488. "label": "ID Type",
  489. "schema": {
  490. "type": "string",
  491. "enum": [
  492. {
  493. "value": "USER",
  494. "description": "Entry is for a USER"
  495. },
  496. {
  497. "value": "GROUP",
  498. "description": "Entry is for a GROUP"
  499. }
  500. ],
  501. "default": "USER"
  502. }
  503. },
  504. {
  505. "variable": "id",
  506. "label": "ID",
  507. "description": "Make sure to check the ID value is correct and aligns with RunAs user context of the application",
  508. "schema": {
  509. "type": "int",
  510. "required": true,
  511. "min": 0
  512. }
  513. },
  514. {
  515. "variable": "access",
  516. "label": "Access",
  517. "schema": {
  518. "type": "string",
  519. "enum": [
  520. {
  521. "value": "READ",
  522. "description": "Read Access"
  523. },
  524. {
  525. "value": "MODIFY",
  526. "description": "Modify Access"
  527. },
  528. {
  529. "value": "FULL_CONTROL",
  530. "description": "FULL_CONTROL Access"
  531. }
  532. ]
  533. }
  534. }
  535. ]
  536. }
  537. }
  538. ]
  539. }
  540. },
  541. {
  542. "variable": "options",
  543. "label": "ACL Options",
  544. "schema": {
  545. "type": "dict",
  546. "attrs": [
  547. {
  548. "variable": "force",
  549. "label": "Force Flag",
  550. "description": "Enabling `Force` applies ACL even if the path has existing data",
  551. "schema": {
  552. "type": "boolean",
  553. "default": false
  554. }
  555. }
  556. ]
  557. }
  558. }
  559. ],
  560. "$ref": [
  561. "normalize/acl"
  562. ]
  563. }
  564. },
  565. {
  566. "variable": "hostPath",
  567. "label": "Host Path",
  568. "description": "The host path to use for storage.",
  569. "schema": {
  570. "type": "hostpath",
  571. "show_if": [
  572. [
  573. "aclEnable",
  574. "=",
  575. false
  576. ]
  577. ],
  578. "immutable": true,
  579. "required": true
  580. }
  581. }
  582. ]
  583. }
  584. }
  585. ]
  586. }
  587. },
  588. {
  589. "variable": "pgData",
  590. "label": "n8n Postgres Data Storage",
  591. "description": "The path to store n8n Postgres Data.",
  592. "schema": {
  593. "type": "dict",
  594. "attrs": [
  595. {
  596. "variable": "type",
  597. "label": "Type",
  598. "description": "ixVolume: Is dataset created automatically by the system.</br>\nHost Path: Is a path that already exists on the system.\n",
  599. "schema": {
  600. "type": "string",
  601. "required": true,
  602. "immutable": true,
  603. "default": "ixVolume",
  604. "enum": [
  605. {
  606. "value": "hostPath",
  607. "description": "Host Path (Path that already exists on the system)"
  608. },
  609. {
  610. "value": "ixVolume",
  611. "description": "ixVolume (Dataset created automatically by the system)"
  612. }
  613. ]
  614. }
  615. },
  616. {
  617. "variable": "ixVolumeConfig",
  618. "label": "ixVolume Configuration",
  619. "description": "The configuration for the ixVolume dataset.",
  620. "schema": {
  621. "type": "dict",
  622. "hidden": true,
  623. "show_if": [
  624. [
  625. "type",
  626. "=",
  627. "ixVolume"
  628. ]
  629. ],
  630. "$ref": [
  631. "normalize/ixVolume"
  632. ],
  633. "attrs": [
  634. {
  635. "variable": "aclEnable",
  636. "label": "Enable ACL",
  637. "description": "Enable ACL for the dataset.",
  638. "schema": {
  639. "type": "boolean",
  640. "hidden": true,
  641. "default": false
  642. }
  643. },
  644. {
  645. "variable": "datasetName",
  646. "label": "Dataset Name",
  647. "description": "The name of the dataset to use for storage.",
  648. "schema": {
  649. "type": "string",
  650. "required": true,
  651. "immutable": true,
  652. "hidden": true,
  653. "default": "pgData"
  654. }
  655. },
  656. {
  657. "variable": "aclEntries",
  658. "label": "ACL Configuration",
  659. "schema": {
  660. "type": "dict",
  661. "show_if": [
  662. [
  663. "aclEnable",
  664. "=",
  665. true
  666. ]
  667. ],
  668. "attrs": [
  669. {
  670. "variable": "path",
  671. "label": "Path",
  672. "description": "Path to perform ACL",
  673. "schema": {
  674. "type": "string",
  675. "hidden": true
  676. }
  677. },
  678. {
  679. "variable": "entries",
  680. "label": "ACL Entries",
  681. "description": "ACL Entries",
  682. "schema": {
  683. "type": "list",
  684. "items": [
  685. {
  686. "variable": "aclEntry",
  687. "label": "ACL Entry",
  688. "schema": {
  689. "type": "dict",
  690. "attrs": [
  691. {
  692. "variable": "id_type",
  693. "label": "ID Type",
  694. "schema": {
  695. "type": "string",
  696. "enum": [
  697. {
  698. "value": "USER",
  699. "description": "Entry is for a USER"
  700. },
  701. {
  702. "value": "GROUP",
  703. "description": "Entry is for a GROUP"
  704. }
  705. ],
  706. "default": "USER"
  707. }
  708. },
  709. {
  710. "variable": "id",
  711. "label": "ID",
  712. "description": "Make sure to check the ID value is correct and aligns with RunAs user context of the application",
  713. "schema": {
  714. "type": "int",
  715. "required": true,
  716. "min": 0
  717. }
  718. },
  719. {
  720. "variable": "access",
  721. "label": "Access",
  722. "schema": {
  723. "type": "string",
  724. "enum": [
  725. {
  726. "value": "READ",
  727. "description": "Read Access"
  728. },
  729. {
  730. "value": "MODIFY",
  731. "description": "Modify Access"
  732. },
  733. {
  734. "value": "FULL_CONTROL",
  735. "description": "FULL_CONTROL Access"
  736. }
  737. ]
  738. }
  739. }
  740. ]
  741. }
  742. }
  743. ]
  744. }
  745. }
  746. ]
  747. }
  748. }
  749. ]
  750. }
  751. },
  752. {
  753. "variable": "hostPathConfig",
  754. "label": "Host Path Configuration",
  755. "schema": {
  756. "type": "dict",
  757. "show_if": [
  758. [
  759. "type",
  760. "=",
  761. "hostPath"
  762. ]
  763. ],
  764. "attrs": [
  765. {
  766. "variable": "aclEnable",
  767. "label": "Enable ACL",
  768. "description": "Enable ACL for the dataset.",
  769. "schema": {
  770. "type": "boolean",
  771. "hidden": true,
  772. "default": false
  773. }
  774. },
  775. {
  776. "variable": "acl",
  777. "label": "ACL Configuration",
  778. "schema": {
  779. "type": "dict",
  780. "show_if": [
  781. [
  782. "aclEnable",
  783. "=",
  784. true
  785. ]
  786. ],
  787. "attrs": [
  788. {
  789. "variable": "path",
  790. "label": "Host Path",
  791. "description": "Host Path to perform ACL",
  792. "schema": {
  793. "type": "hostpath",
  794. "required": true,
  795. "empty": false
  796. }
  797. },
  798. {
  799. "variable": "entries",
  800. "label": "ACL Entries",
  801. "description": "ACL Entries",
  802. "schema": {
  803. "type": "list",
  804. "items": [
  805. {
  806. "variable": "aclEntry",
  807. "label": "ACL Entry",
  808. "schema": {
  809. "type": "dict",
  810. "attrs": [
  811. {
  812. "variable": "id_type",
  813. "label": "ID Type",
  814. "schema": {
  815. "type": "string",
  816. "enum": [
  817. {
  818. "value": "USER",
  819. "description": "Entry is for a USER"
  820. },
  821. {
  822. "value": "GROUP",
  823. "description": "Entry is for a GROUP"
  824. }
  825. ],
  826. "default": "USER"
  827. }
  828. },
  829. {
  830. "variable": "id",
  831. "label": "ID",
  832. "description": "Make sure to check the ID value is correct and aligns with RunAs user context of the application",
  833. "schema": {
  834. "type": "int",
  835. "required": true,
  836. "min": 0
  837. }
  838. },
  839. {
  840. "variable": "access",
  841. "label": "Access",
  842. "schema": {
  843. "type": "string",
  844. "enum": [
  845. {
  846. "value": "READ",
  847. "description": "Read Access"
  848. },
  849. {
  850. "value": "MODIFY",
  851. "description": "Modify Access"
  852. },
  853. {
  854. "value": "FULL_CONTROL",
  855. "description": "FULL_CONTROL Access"
  856. }
  857. ]
  858. }
  859. }
  860. ]
  861. }
  862. }
  863. ]
  864. }
  865. },
  866. {
  867. "variable": "options",
  868. "label": "ACL Options",
  869. "schema": {
  870. "type": "dict",
  871. "attrs": [
  872. {
  873. "variable": "force",
  874. "label": "Force Flag",
  875. "description": "Enabling `Force` applies ACL even if the path has existing data",
  876. "schema": {
  877. "type": "boolean",
  878. "default": false
  879. }
  880. }
  881. ]
  882. }
  883. }
  884. ],
  885. "$ref": [
  886. "normalize/acl"
  887. ]
  888. }
  889. },
  890. {
  891. "variable": "hostPath",
  892. "label": "Host Path",
  893. "description": "The host path to use for storage.",
  894. "schema": {
  895. "type": "hostpath",
  896. "show_if": [
  897. [
  898. "aclEnable",
  899. "=",
  900. false
  901. ]
  902. ],
  903. "immutable": true,
  904. "required": true
  905. }
  906. }
  907. ]
  908. }
  909. }
  910. ]
  911. }
  912. },
  913. {
  914. "variable": "pgBackup",
  915. "label": "n8n Postgres Backup Storage",
  916. "description": "The path to store n8n Postgres Backup.",
  917. "schema": {
  918. "type": "dict",
  919. "attrs": [
  920. {
  921. "variable": "type",
  922. "label": "Type",
  923. "description": "ixVolume: Is dataset created automatically by the system.</br>\nHost Path: Is a path that already exists on the system.\n",
  924. "schema": {
  925. "type": "string",
  926. "required": true,
  927. "immutable": true,
  928. "default": "ixVolume",
  929. "enum": [
  930. {
  931. "value": "hostPath",
  932. "description": "Host Path (Path that already exists on the system)"
  933. },
  934. {
  935. "value": "ixVolume",
  936. "description": "ixVolume (Dataset created automatically by the system)"
  937. }
  938. ]
  939. }
  940. },
  941. {
  942. "variable": "ixVolumeConfig",
  943. "label": "ixVolume Configuration",
  944. "description": "The configuration for the ixVolume dataset.",
  945. "schema": {
  946. "type": "dict",
  947. "hidden": true,
  948. "show_if": [
  949. [
  950. "type",
  951. "=",
  952. "ixVolume"
  953. ]
  954. ],
  955. "$ref": [
  956. "normalize/ixVolume"
  957. ],
  958. "attrs": [
  959. {
  960. "variable": "aclEnable",
  961. "label": "Enable ACL",
  962. "description": "Enable ACL for the dataset.",
  963. "schema": {
  964. "type": "boolean",
  965. "hidden": true,
  966. "default": false
  967. }
  968. },
  969. {
  970. "variable": "datasetName",
  971. "label": "Dataset Name",
  972. "description": "The name of the dataset to use for storage.",
  973. "schema": {
  974. "type": "string",
  975. "required": true,
  976. "immutable": true,
  977. "hidden": true,
  978. "default": "pgBackup"
  979. }
  980. },
  981. {
  982. "variable": "aclEntries",
  983. "label": "ACL Configuration",
  984. "schema": {
  985. "type": "dict",
  986. "show_if": [
  987. [
  988. "aclEnable",
  989. "=",
  990. true
  991. ]
  992. ],
  993. "attrs": [
  994. {
  995. "variable": "path",
  996. "label": "Path",
  997. "description": "Path to perform ACL",
  998. "schema": {
  999. "type": "string",
  1000. "hidden": true
  1001. }
  1002. },
  1003. {
  1004. "variable": "entries",
  1005. "label": "ACL Entries",
  1006. "description": "ACL Entries",
  1007. "schema": {
  1008. "type": "list",
  1009. "items": [
  1010. {
  1011. "variable": "aclEntry",
  1012. "label": "ACL Entry",
  1013. "schema": {
  1014. "type": "dict",
  1015. "attrs": [
  1016. {
  1017. "variable": "id_type",
  1018. "label": "ID Type",
  1019. "schema": {
  1020. "type": "string",
  1021. "enum": [
  1022. {
  1023. "value": "USER",
  1024. "description": "Entry is for a USER"
  1025. },
  1026. {
  1027. "value": "GROUP",
  1028. "description": "Entry is for a GROUP"
  1029. }
  1030. ],
  1031. "default": "USER"
  1032. }
  1033. },
  1034. {
  1035. "variable": "id",
  1036. "label": "ID",
  1037. "description": "Make sure to check the ID value is correct and aligns with RunAs user context of the application",
  1038. "schema": {
  1039. "type": "int",
  1040. "required": true,
  1041. "min": 0
  1042. }
  1043. },
  1044. {
  1045. "variable": "access",
  1046. "label": "Access",
  1047. "schema": {
  1048. "type": "string",
  1049. "enum": [
  1050. {
  1051. "value": "READ",
  1052. "description": "Read Access"
  1053. },
  1054. {
  1055. "value": "MODIFY",
  1056. "description": "Modify Access"
  1057. },
  1058. {
  1059. "value": "FULL_CONTROL",
  1060. "description": "FULL_CONTROL Access"
  1061. }
  1062. ]
  1063. }
  1064. }
  1065. ]
  1066. }
  1067. }
  1068. ]
  1069. }
  1070. }
  1071. ]
  1072. }
  1073. }
  1074. ]
  1075. }
  1076. },
  1077. {
  1078. "variable": "hostPathConfig",
  1079. "label": "Host Path Configuration",
  1080. "schema": {
  1081. "type": "dict",
  1082. "show_if": [
  1083. [
  1084. "type",
  1085. "=",
  1086. "hostPath"
  1087. ]
  1088. ],
  1089. "attrs": [
  1090. {
  1091. "variable": "aclEnable",
  1092. "label": "Enable ACL",
  1093. "description": "Enable ACL for the dataset.",
  1094. "schema": {
  1095. "type": "boolean",
  1096. "hidden": true,
  1097. "default": false
  1098. }
  1099. },
  1100. {
  1101. "variable": "acl",
  1102. "label": "ACL Configuration",
  1103. "schema": {
  1104. "type": "dict",
  1105. "show_if": [
  1106. [
  1107. "aclEnable",
  1108. "=",
  1109. true
  1110. ]
  1111. ],
  1112. "attrs": [
  1113. {
  1114. "variable": "path",
  1115. "label": "Host Path",
  1116. "description": "Host Path to perform ACL",
  1117. "schema": {
  1118. "type": "hostpath",
  1119. "required": true,
  1120. "empty": false
  1121. }
  1122. },
  1123. {
  1124. "variable": "entries",
  1125. "label": "ACL Entries",
  1126. "description": "ACL Entries",
  1127. "schema": {
  1128. "type": "list",
  1129. "items": [
  1130. {
  1131. "variable": "aclEntry",
  1132. "label": "ACL Entry",
  1133. "schema": {
  1134. "type": "dict",
  1135. "attrs": [
  1136. {
  1137. "variable": "id_type",
  1138. "label": "ID Type",
  1139. "schema": {
  1140. "type": "string",
  1141. "enum": [
  1142. {
  1143. "value": "USER",
  1144. "description": "Entry is for a USER"
  1145. },
  1146. {
  1147. "value": "GROUP",
  1148. "description": "Entry is for a GROUP"
  1149. }
  1150. ],
  1151. "default": "USER"
  1152. }
  1153. },
  1154. {
  1155. "variable": "id",
  1156. "label": "ID",
  1157. "description": "Make sure to check the ID value is correct and aligns with RunAs user context of the application",
  1158. "schema": {
  1159. "type": "int",
  1160. "required": true,
  1161. "min": 0
  1162. }
  1163. },
  1164. {
  1165. "variable": "access",
  1166. "label": "Access",
  1167. "schema": {
  1168. "type": "string",
  1169. "enum": [
  1170. {
  1171. "value": "READ",
  1172. "description": "Read Access"
  1173. },
  1174. {
  1175. "value": "MODIFY",
  1176. "description": "Modify Access"
  1177. },
  1178. {
  1179. "value": "FULL_CONTROL",
  1180. "description": "FULL_CONTROL Access"
  1181. }
  1182. ]
  1183. }
  1184. }
  1185. ]
  1186. }
  1187. }
  1188. ]
  1189. }
  1190. },
  1191. {
  1192. "variable": "options",
  1193. "label": "ACL Options",
  1194. "schema": {
  1195. "type": "dict",
  1196. "attrs": [
  1197. {
  1198. "variable": "force",
  1199. "label": "Force Flag",
  1200. "description": "Enabling `Force` applies ACL even if the path has existing data",
  1201. "schema": {
  1202. "type": "boolean",
  1203. "default": false
  1204. }
  1205. }
  1206. ]
  1207. }
  1208. }
  1209. ],
  1210. "$ref": [
  1211. "normalize/acl"
  1212. ]
  1213. }
  1214. },
  1215. {
  1216. "variable": "hostPath",
  1217. "label": "Host Path",
  1218. "description": "The host path to use for storage.",
  1219. "schema": {
  1220. "type": "hostpath",
  1221. "show_if": [
  1222. [
  1223. "aclEnable",
  1224. "=",
  1225. false
  1226. ]
  1227. ],
  1228. "immutable": true,
  1229. "required": true
  1230. }
  1231. }
  1232. ]
  1233. }
  1234. }
  1235. ]
  1236. }
  1237. },
  1238. {
  1239. "variable": "additionalStorages",
  1240. "label": "Additional Storage",
  1241. "description": "Additional storage for n8n.",
  1242. "schema": {
  1243. "type": "list",
  1244. "default": [],
  1245. "items": [
  1246. {
  1247. "variable": "storageEntry",
  1248. "label": "Storage Entry",
  1249. "schema": {
  1250. "type": "dict",
  1251. "attrs": [
  1252. {
  1253. "variable": "type",
  1254. "label": "Type",
  1255. "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",
  1256. "schema": {
  1257. "type": "string",
  1258. "required": true,
  1259. "default": "ixVolume",
  1260. "immutable": true,
  1261. "enum": [
  1262. {
  1263. "value": "hostPath",
  1264. "description": "Host Path (Path that already exists on the system)"
  1265. },
  1266. {
  1267. "value": "ixVolume",
  1268. "description": "ixVolume (Dataset created automatically by the system)"
  1269. },
  1270. {
  1271. "value": "smb-pv-pvc",
  1272. "description": "SMB Share (Mounts a persistent volume claim to a SMB share)"
  1273. }
  1274. ]
  1275. }
  1276. },
  1277. {
  1278. "variable": "readOnly",
  1279. "label": "Read Only",
  1280. "description": "Mount the volume as read only.",
  1281. "schema": {
  1282. "type": "boolean",
  1283. "default": false
  1284. }
  1285. },
  1286. {
  1287. "variable": "mountPath",
  1288. "label": "Mount Path",
  1289. "description": "The path inside the container to mount the storage.",
  1290. "schema": {
  1291. "type": "path",
  1292. "required": true
  1293. }
  1294. },
  1295. {
  1296. "variable": "hostPathConfig",
  1297. "label": "Host Path Configuration",
  1298. "schema": {
  1299. "type": "dict",
  1300. "show_if": [
  1301. [
  1302. "type",
  1303. "=",
  1304. "hostPath"
  1305. ]
  1306. ],
  1307. "attrs": [
  1308. {
  1309. "variable": "aclEnable",
  1310. "label": "Enable ACL",
  1311. "description": "Enable ACL for the dataset.",
  1312. "schema": {
  1313. "type": "boolean",
  1314. "default": false
  1315. }
  1316. },
  1317. {
  1318. "variable": "acl",
  1319. "label": "ACL Configuration",
  1320. "schema": {
  1321. "type": "dict",
  1322. "show_if": [
  1323. [
  1324. "aclEnable",
  1325. "=",
  1326. true
  1327. ]
  1328. ],
  1329. "attrs": [
  1330. {
  1331. "variable": "path",
  1332. "label": "Host Path",
  1333. "description": "Host Path to perform ACL",
  1334. "schema": {
  1335. "type": "hostpath",
  1336. "required": true,
  1337. "empty": false
  1338. }
  1339. },
  1340. {
  1341. "variable": "entries",
  1342. "label": "ACL Entries",
  1343. "description": "ACL Entries",
  1344. "schema": {
  1345. "type": "list",
  1346. "items": [
  1347. {
  1348. "variable": "aclEntry",
  1349. "label": "ACL Entry",
  1350. "schema": {
  1351. "type": "dict",
  1352. "attrs": [
  1353. {
  1354. "variable": "id_type",
  1355. "label": "ID Type",
  1356. "schema": {
  1357. "type": "string",
  1358. "enum": [
  1359. {
  1360. "value": "USER",
  1361. "description": "Entry is for a USER"
  1362. },
  1363. {
  1364. "value": "GROUP",
  1365. "description": "Entry is for a GROUP"
  1366. }
  1367. ],
  1368. "default": "USER"
  1369. }
  1370. },
  1371. {
  1372. "variable": "id",
  1373. "label": "ID",
  1374. "description": "Make sure to check the ID value is correct and aligns with RunAs user context of the application",
  1375. "schema": {
  1376. "type": "int",
  1377. "required": true,
  1378. "min": 0
  1379. }
  1380. },
  1381. {
  1382. "variable": "access",
  1383. "label": "Access",
  1384. "schema": {
  1385. "type": "string",
  1386. "enum": [
  1387. {
  1388. "value": "READ",
  1389. "description": "Read Access"
  1390. },
  1391. {
  1392. "value": "MODIFY",
  1393. "description": "Modify Access"
  1394. },
  1395. {
  1396. "value": "FULL_CONTROL",
  1397. "description": "FULL_CONTROL Access"
  1398. }
  1399. ]
  1400. }
  1401. }
  1402. ]
  1403. }
  1404. }
  1405. ]
  1406. }
  1407. },
  1408. {
  1409. "variable": "options",
  1410. "label": "ACL Options",
  1411. "schema": {
  1412. "type": "dict",
  1413. "attrs": [
  1414. {
  1415. "variable": "force",
  1416. "label": "Force Flag",
  1417. "description": "Enabling `Force` applies ACL even if the path has existing data",
  1418. "schema": {
  1419. "type": "boolean",
  1420. "default": false
  1421. }
  1422. }
  1423. ]
  1424. }
  1425. }
  1426. ],
  1427. "$ref": [
  1428. "normalize/acl"
  1429. ]
  1430. }
  1431. },
  1432. {
  1433. "variable": "hostPath",
  1434. "label": "Host Path",
  1435. "description": "The host path to use for storage.",
  1436. "schema": {
  1437. "type": "hostpath",
  1438. "show_if": [
  1439. [
  1440. "aclEnable",
  1441. "=",
  1442. false
  1443. ]
  1444. ],
  1445. "immutable": true,
  1446. "required": true
  1447. }
  1448. }
  1449. ]
  1450. }
  1451. },
  1452. {
  1453. "variable": "ixVolumeConfig",
  1454. "label": "ixVolume Configuration",
  1455. "description": "The configuration for the ixVolume dataset.",
  1456. "schema": {
  1457. "type": "dict",
  1458. "show_if": [
  1459. [
  1460. "type",
  1461. "=",
  1462. "ixVolume"
  1463. ]
  1464. ],
  1465. "$ref": [
  1466. "normalize/ixVolume"
  1467. ],
  1468. "attrs": [
  1469. {
  1470. "variable": "aclEnable",
  1471. "label": "Enable ACL",
  1472. "description": "Enable ACL for the dataset.",
  1473. "schema": {
  1474. "type": "boolean",
  1475. "default": false
  1476. }
  1477. },
  1478. {
  1479. "variable": "datasetName",
  1480. "label": "Dataset Name",
  1481. "description": "The name of the dataset to use for storage.",
  1482. "schema": {
  1483. "type": "string",
  1484. "required": true,
  1485. "immutable": true,
  1486. "default": "storage_entry"
  1487. }
  1488. },
  1489. {
  1490. "variable": "aclEntries",
  1491. "label": "ACL Configuration",
  1492. "schema": {
  1493. "type": "dict",
  1494. "show_if": [
  1495. [
  1496. "aclEnable",
  1497. "=",
  1498. true
  1499. ]
  1500. ],
  1501. "attrs": [
  1502. {
  1503. "variable": "path",
  1504. "label": "Path",
  1505. "description": "Path to perform ACL",
  1506. "schema": {
  1507. "type": "string",
  1508. "hidden": true
  1509. }
  1510. },
  1511. {
  1512. "variable": "entries",
  1513. "label": "ACL Entries",
  1514. "description": "ACL Entries",
  1515. "schema": {
  1516. "type": "list",
  1517. "items": [
  1518. {
  1519. "variable": "aclEntry",
  1520. "label": "ACL Entry",
  1521. "schema": {
  1522. "type": "dict",
  1523. "attrs": [
  1524. {
  1525. "variable": "id_type",
  1526. "label": "ID Type",
  1527. "schema": {
  1528. "type": "string",
  1529. "enum": [
  1530. {
  1531. "value": "USER",
  1532. "description": "Entry is for a USER"
  1533. },
  1534. {
  1535. "value": "GROUP",
  1536. "description": "Entry is for a GROUP"
  1537. }
  1538. ],
  1539. "default": "USER"
  1540. }
  1541. },
  1542. {
  1543. "variable": "id",
  1544. "label": "ID",
  1545. "description": "Make sure to check the ID value is correct and aligns with RunAs user context of the application",
  1546. "schema": {
  1547. "type": "int",
  1548. "required": true,
  1549. "min": 0
  1550. }
  1551. },
  1552. {
  1553. "variable": "access",
  1554. "label": "Access",
  1555. "schema": {
  1556. "type": "string",
  1557. "enum": [
  1558. {
  1559. "value": "READ",
  1560. "description": "Read Access"
  1561. },
  1562. {
  1563. "value": "MODIFY",
  1564. "description": "Modify Access"
  1565. },
  1566. {
  1567. "value": "FULL_CONTROL",
  1568. "description": "FULL_CONTROL Access"
  1569. }
  1570. ]
  1571. }
  1572. }
  1573. ]
  1574. }
  1575. }
  1576. ]
  1577. }
  1578. }
  1579. ]
  1580. }
  1581. }
  1582. ]
  1583. }
  1584. },
  1585. {
  1586. "variable": "smbConfig",
  1587. "label": "SMB Share Configuration",
  1588. "description": "The configuration for the SMB Share.",
  1589. "schema": {
  1590. "type": "dict",
  1591. "show_if": [
  1592. [
  1593. "type",
  1594. "=",
  1595. "smb-pv-pvc"
  1596. ]
  1597. ],
  1598. "attrs": [
  1599. {
  1600. "variable": "server",
  1601. "label": "Server",
  1602. "description": "The server for the SMB share.",
  1603. "schema": {
  1604. "type": "string",
  1605. "required": true
  1606. }
  1607. },
  1608. {
  1609. "variable": "share",
  1610. "label": "Share",
  1611. "description": "The share name for the SMB share.",
  1612. "schema": {
  1613. "type": "string",
  1614. "required": true
  1615. }
  1616. },
  1617. {
  1618. "variable": "domain",
  1619. "label": "Domain (Optional)",
  1620. "description": "The domain for the SMB share.",
  1621. "schema": {
  1622. "type": "string"
  1623. }
  1624. },
  1625. {
  1626. "variable": "username",
  1627. "label": "Username",
  1628. "description": "The username for the SMB share.",
  1629. "schema": {
  1630. "type": "string",
  1631. "required": true
  1632. }
  1633. },
  1634. {
  1635. "variable": "password",
  1636. "label": "Password",
  1637. "description": "The password for the SMB share.",
  1638. "schema": {
  1639. "type": "string",
  1640. "required": true,
  1641. "private": true
  1642. }
  1643. },
  1644. {
  1645. "variable": "size",
  1646. "label": "Size (in Gi)",
  1647. "description": "The size of the volume quota.",
  1648. "schema": {
  1649. "type": "int",
  1650. "required": true,
  1651. "min": 1,
  1652. "default": 1
  1653. }
  1654. }
  1655. ]
  1656. }
  1657. }
  1658. ]
  1659. }
  1660. }
  1661. ]
  1662. }
  1663. }
  1664. ]
  1665. }
  1666. },
  1667. {
  1668. "variable": "resources",
  1669. "label": "",
  1670. "group": "Resources Configuration",
  1671. "schema": {
  1672. "type": "dict",
  1673. "attrs": [
  1674. {
  1675. "variable": "limits",
  1676. "label": "Limits",
  1677. "schema": {
  1678. "type": "dict",
  1679. "attrs": [
  1680. {
  1681. "variable": "cpu",
  1682. "label": "CPU",
  1683. "description": "CPU limit for n8n.",
  1684. "schema": {
  1685. "type": "string",
  1686. "max_length": 6,
  1687. "valid_chars": "^(0\\.[1-9]|[1-9][0-9]*)(\\.[0-9]|m?)$",
  1688. "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",
  1689. "default": "4000m",
  1690. "required": true
  1691. }
  1692. },
  1693. {
  1694. "variable": "memory",
  1695. "label": "Memory",
  1696. "description": "Memory limit for n8n.",
  1697. "schema": {
  1698. "type": "string",
  1699. "max_length": 12,
  1700. "valid_chars": "^[1-9][0-9]*([EPTGMK]i?|e[0-9]+)?$",
  1701. "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",
  1702. "default": "8Gi",
  1703. "required": true
  1704. }
  1705. }
  1706. ]
  1707. }
  1708. }
  1709. ]
  1710. }
  1711. }
  1712. ]
  1713. },
  1714. "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>",
  1715. "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>",
  1716. "changelog": null
  1717. }
  1718. }