app_versions.json 101 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561156215631564156515661567156815691570
  1. {
  2. "1.2.7": {
  3. "healthy": true,
  4. "supported": true,
  5. "healthy_error": null,
  6. "location": "/__w/apps/apps/trains/community/sftpgo/1.2.7",
  7. "last_update": "2025-09-02 11:33:24",
  8. "required_features": [],
  9. "human_version": "v2.6.6_1.2.7",
  10. "version": "1.2.7",
  11. "app_metadata": {
  12. "annotations": {
  13. "min_scale_version": "24.10.2.2"
  14. },
  15. "app_version": "v2.6.6",
  16. "capabilities": [],
  17. "categories": [
  18. "storage"
  19. ],
  20. "changelog_url": "https://github.com/drakkan/sftpgo/releases",
  21. "date_added": "2024-09-16",
  22. "description": "SFTPGo is a fully featured and highly configurable SFTP server with optional HTTP/S, FTP/S and WebDAV support - S3, Google Cloud Storage, Azure Blob",
  23. "home": "https://github.com/drakkan/sftpgo",
  24. "host_mounts": [],
  25. "icon": "https://media.sys.truenas.net/apps/sftpgo/icons/icon.png",
  26. "keywords": [
  27. "sftp"
  28. ],
  29. "lib_version": "2.1.49",
  30. "lib_version_hash": "e71e6b0122c9446fa5ea6fb07e7eb01b11fb42d549a19845426bbd7e21a42634",
  31. "maintainers": [
  32. {
  33. "email": "dev@ixsystems.com",
  34. "name": "truenas",
  35. "url": "https://www.truenas.com/"
  36. }
  37. ],
  38. "name": "sftpgo",
  39. "run_as_context": [
  40. {
  41. "description": "SFTPGo runs as any non-root user.",
  42. "gid": 568,
  43. "group_name": "sftpgo",
  44. "uid": 568,
  45. "user_name": "sftpgo"
  46. }
  47. ],
  48. "screenshots": [],
  49. "sources": [
  50. "https://hub.docker.com/r/drakkan/sftpgo",
  51. "https://github.com/drakkan/sftpgo"
  52. ],
  53. "title": "SFTPGo",
  54. "train": "community",
  55. "version": "1.2.7"
  56. },
  57. "schema": {
  58. "groups": [
  59. {
  60. "name": "SFTPGo Configuration",
  61. "description": "Configure SFTPGo"
  62. },
  63. {
  64. "name": "User and Group Configuration",
  65. "description": "Configure User and Group for SFTPGo"
  66. },
  67. {
  68. "name": "Network Configuration",
  69. "description": "Configure Network for SFTPGo"
  70. },
  71. {
  72. "name": "Storage Configuration",
  73. "description": "Configure Storage for SFTPGo"
  74. },
  75. {
  76. "name": "Labels Configuration",
  77. "description": "Configure Labels for SFTPGo"
  78. },
  79. {
  80. "name": "Resources Configuration",
  81. "description": "Configure Resources for SFTPGo"
  82. }
  83. ],
  84. "questions": [
  85. {
  86. "variable": "sftpgo",
  87. "label": "",
  88. "group": "SFTPGo Configuration",
  89. "schema": {
  90. "type": "dict",
  91. "attrs": [
  92. {
  93. "variable": "image_selector",
  94. "label": "Image",
  95. "description": "The image to use for SFTPGo.",
  96. "schema": {
  97. "type": "string",
  98. "default": "image",
  99. "required": true,
  100. "enum": [
  101. {
  102. "value": "image",
  103. "description": "Normal Image"
  104. },
  105. {
  106. "value": "plugins_image",
  107. "description": "Plugins Image"
  108. }
  109. ]
  110. }
  111. },
  112. {
  113. "variable": "stop_grace_period",
  114. "label": "Stop Grace Period",
  115. "description": "The time in seconds given to SFTPGo to stop before it is killed.",
  116. "schema": {
  117. "type": "int",
  118. "min": 1,
  119. "default": 60,
  120. "required": true
  121. }
  122. },
  123. {
  124. "variable": "additional_envs",
  125. "label": "Additional Environment Variables",
  126. "schema": {
  127. "type": "list",
  128. "default": [],
  129. "items": [
  130. {
  131. "variable": "env",
  132. "label": "Environment Variable",
  133. "schema": {
  134. "type": "dict",
  135. "attrs": [
  136. {
  137. "variable": "name",
  138. "label": "Name",
  139. "schema": {
  140. "type": "string",
  141. "required": true
  142. }
  143. },
  144. {
  145. "variable": "value",
  146. "label": "Value",
  147. "schema": {
  148. "type": "string"
  149. }
  150. }
  151. ]
  152. }
  153. }
  154. ]
  155. }
  156. }
  157. ]
  158. }
  159. },
  160. {
  161. "variable": "run_as",
  162. "label": "",
  163. "group": "User and Group Configuration",
  164. "schema": {
  165. "type": "dict",
  166. "attrs": [
  167. {
  168. "variable": "user",
  169. "label": "User ID",
  170. "description": "The user id that SFTPGo files will be owned by.",
  171. "schema": {
  172. "type": "int",
  173. "min": 568,
  174. "default": 568,
  175. "required": true
  176. }
  177. },
  178. {
  179. "variable": "group",
  180. "label": "Group ID",
  181. "description": "The group id that SFTPGo files will be owned by.",
  182. "schema": {
  183. "type": "int",
  184. "min": 568,
  185. "default": 568,
  186. "required": true
  187. }
  188. }
  189. ]
  190. }
  191. },
  192. {
  193. "variable": "network",
  194. "label": "",
  195. "group": "Network Configuration",
  196. "schema": {
  197. "type": "dict",
  198. "attrs": [
  199. {
  200. "variable": "web_port",
  201. "label": "WebUI Port",
  202. "schema": {
  203. "type": "dict",
  204. "attrs": [
  205. {
  206. "variable": "bind_mode",
  207. "label": "Port Bind Mode",
  208. "description": "The port bind mode.</br>\n- Publish: The port will be published on the host for external access.</br>\n- Expose: The port will be exposed for inter-container communication.</br>\n- None: The port will not be exposed or published.</br>\nNote: If the Dockerfile defines an EXPOSE directive,\nthe port will still be exposed for inter-container communication regardless of this setting.\n",
  209. "schema": {
  210. "type": "string",
  211. "default": "published",
  212. "enum": [
  213. {
  214. "value": "published",
  215. "description": "Publish port on the host for external access"
  216. },
  217. {
  218. "value": "exposed",
  219. "description": "Expose port for inter-container communication"
  220. },
  221. {
  222. "value": "",
  223. "description": "None"
  224. }
  225. ]
  226. }
  227. },
  228. {
  229. "variable": "port_number",
  230. "label": "Port Number",
  231. "schema": {
  232. "type": "int",
  233. "default": 30112,
  234. "min": 1,
  235. "max": 65535,
  236. "required": true
  237. }
  238. },
  239. {
  240. "variable": "host_ips",
  241. "label": "Host IPs",
  242. "description": "IPs on the host to bind this port",
  243. "schema": {
  244. "type": "list",
  245. "show_if": [
  246. [
  247. "bind_mode",
  248. "=",
  249. "published"
  250. ]
  251. ],
  252. "default": [],
  253. "items": [
  254. {
  255. "variable": "host_ip",
  256. "label": "Host IP",
  257. "schema": {
  258. "type": "string",
  259. "required": true,
  260. "$ref": [
  261. "definitions/node_bind_ip"
  262. ]
  263. }
  264. }
  265. ]
  266. }
  267. }
  268. ]
  269. }
  270. },
  271. {
  272. "variable": "telemetry_port",
  273. "label": "Telemetry Port",
  274. "schema": {
  275. "type": "dict",
  276. "attrs": [
  277. {
  278. "variable": "bind_mode",
  279. "label": "Port Bind Mode",
  280. "description": "The port bind mode.</br>\n- Publish: The port will be published on the host for external access.</br>\n- Expose: The port will be exposed for inter-container communication.</br>\n- None: The port will not be exposed or published.</br>\nNote: If the Dockerfile defines an EXPOSE directive,\nthe port will still be exposed for inter-container communication regardless of this setting.\n",
  281. "schema": {
  282. "type": "string",
  283. "default": "",
  284. "enum": [
  285. {
  286. "value": "published",
  287. "description": "Publish port on the host for external access"
  288. },
  289. {
  290. "value": "exposed",
  291. "description": "Expose port for inter-container communication"
  292. },
  293. {
  294. "value": "",
  295. "description": "None"
  296. }
  297. ]
  298. }
  299. },
  300. {
  301. "variable": "port_number",
  302. "label": "Port Number",
  303. "schema": {
  304. "type": "int",
  305. "default": 30126,
  306. "min": 1,
  307. "max": 65535,
  308. "required": true
  309. }
  310. },
  311. {
  312. "variable": "host_ips",
  313. "label": "Host IPs",
  314. "description": "IPs on the host to bind this port",
  315. "schema": {
  316. "type": "list",
  317. "show_if": [
  318. [
  319. "bind_mode",
  320. "=",
  321. "published"
  322. ]
  323. ],
  324. "default": [],
  325. "items": [
  326. {
  327. "variable": "host_ip",
  328. "label": "Host IP",
  329. "schema": {
  330. "type": "string",
  331. "required": true,
  332. "$ref": [
  333. "definitions/node_bind_ip"
  334. ]
  335. }
  336. }
  337. ]
  338. }
  339. }
  340. ]
  341. }
  342. },
  343. {
  344. "variable": "host_network",
  345. "label": "Host Network",
  346. "description": "Bind to the host network. It's recommended to keep this disabled.\n",
  347. "schema": {
  348. "type": "boolean",
  349. "default": false
  350. }
  351. },
  352. {
  353. "variable": "certificate_id",
  354. "label": "Certificate ID",
  355. "description": "The certificate id to use for SFTPGo.",
  356. "schema": {
  357. "type": "int",
  358. "null": true,
  359. "$ref": [
  360. "definitions/certificate"
  361. ]
  362. }
  363. },
  364. {
  365. "variable": "sftpd_services",
  366. "label": "SFTPD Services",
  367. "description": "Enable one or more SFTPd services.",
  368. "schema": {
  369. "type": "list",
  370. "default": [],
  371. "items": [
  372. {
  373. "variable": "sftpd_entry",
  374. "label": "SFTPD Entry",
  375. "schema": {
  376. "type": "dict",
  377. "attrs": [
  378. {
  379. "variable": "enabled",
  380. "label": "Enabled",
  381. "description": "Enable the service.",
  382. "schema": {
  383. "type": "boolean",
  384. "default": true
  385. }
  386. },
  387. {
  388. "variable": "port",
  389. "label": "Port",
  390. "description": "The port for the service.</br>\nPort set here will be used both inside and outside the container.\n",
  391. "schema": {
  392. "type": "dict",
  393. "attrs": [
  394. {
  395. "variable": "bind_mode",
  396. "label": "Port Bind Mode",
  397. "description": "The port bind mode.</br>\n- Publish: The port will be published on the host for external access.</br>\n- Expose: The port will be exposed for inter-container communication.</br>\n- None: The port will not be exposed or published.</br>\nNote: If the Dockerfile defines an EXPOSE directive,\nthe port will still be exposed for inter-container communication regardless of this setting.\n",
  398. "schema": {
  399. "type": "string",
  400. "default": "published",
  401. "enum": [
  402. {
  403. "value": "published",
  404. "description": "Publish port on the host for external access"
  405. },
  406. {
  407. "value": "exposed",
  408. "description": "Expose port for inter-container communication"
  409. },
  410. {
  411. "value": "",
  412. "description": "None"
  413. }
  414. ]
  415. }
  416. },
  417. {
  418. "variable": "port_number",
  419. "label": "Port Number",
  420. "schema": {
  421. "type": "int",
  422. "required": true,
  423. "$ref": [
  424. "definitions/port"
  425. ]
  426. }
  427. },
  428. {
  429. "variable": "host_ips",
  430. "label": "Host IPs",
  431. "description": "IPs on the host to bind this port",
  432. "schema": {
  433. "type": "list",
  434. "default": [],
  435. "items": [
  436. {
  437. "variable": "host_ip",
  438. "label": "Host IP",
  439. "schema": {
  440. "type": "string",
  441. "required": true,
  442. "$ref": [
  443. "definitions/node_bind_ip"
  444. ]
  445. }
  446. }
  447. ]
  448. }
  449. }
  450. ]
  451. }
  452. }
  453. ]
  454. }
  455. }
  456. ]
  457. }
  458. },
  459. {
  460. "variable": "webdavd_services",
  461. "label": "WebDAVD Services",
  462. "description": "Enable one or more WebDAVD services.",
  463. "schema": {
  464. "type": "list",
  465. "default": [],
  466. "items": [
  467. {
  468. "variable": "webdavd_entry",
  469. "label": "WebDAVD Entry",
  470. "schema": {
  471. "type": "dict",
  472. "attrs": [
  473. {
  474. "variable": "enabled",
  475. "label": "Enabled",
  476. "description": "Enable the service.",
  477. "schema": {
  478. "type": "boolean",
  479. "default": true
  480. }
  481. },
  482. {
  483. "variable": "port",
  484. "label": "Port",
  485. "description": "The port for the service.</br>\nPort set here will be used both inside and outside the container.\n",
  486. "schema": {
  487. "type": "dict",
  488. "attrs": [
  489. {
  490. "variable": "bind_mode",
  491. "label": "Port Bind Mode",
  492. "description": "The port bind mode.</br>\n- Publish: The port will be published on the host for external access.</br>\n- Expose: The port will be exposed for inter-container communication.</br>\n- None: The port will not be exposed or published.</br>\nNote: If the Dockerfile defines an EXPOSE directive,\nthe port will still be exposed for inter-container communication regardless of this setting.\n",
  493. "schema": {
  494. "type": "string",
  495. "default": "published",
  496. "enum": [
  497. {
  498. "value": "published",
  499. "description": "Publish port on the host for external access"
  500. },
  501. {
  502. "value": "exposed",
  503. "description": "Expose port for inter-container communication"
  504. },
  505. {
  506. "value": "",
  507. "description": "None"
  508. }
  509. ]
  510. }
  511. },
  512. {
  513. "variable": "port_number",
  514. "label": "Port Number",
  515. "schema": {
  516. "type": "int",
  517. "required": true,
  518. "$ref": [
  519. "definitions/port"
  520. ]
  521. }
  522. },
  523. {
  524. "variable": "host_ips",
  525. "label": "Host IPs",
  526. "description": "IPs on the host to bind this port",
  527. "schema": {
  528. "type": "list",
  529. "default": [],
  530. "items": [
  531. {
  532. "variable": "host_ip",
  533. "label": "Host IP",
  534. "schema": {
  535. "type": "string",
  536. "required": true,
  537. "$ref": [
  538. "definitions/node_bind_ip"
  539. ]
  540. }
  541. }
  542. ]
  543. }
  544. }
  545. ]
  546. }
  547. }
  548. ]
  549. }
  550. }
  551. ]
  552. }
  553. },
  554. {
  555. "variable": "ftpd_services",
  556. "label": "FTPD Services",
  557. "description": "Enable one or more FTPD services.",
  558. "schema": {
  559. "type": "list",
  560. "default": [],
  561. "items": [
  562. {
  563. "variable": "ftpd_entry",
  564. "label": "FTPD Entry",
  565. "schema": {
  566. "type": "dict",
  567. "attrs": [
  568. {
  569. "variable": "enabled",
  570. "label": "Enabled",
  571. "description": "Enable the service.",
  572. "schema": {
  573. "type": "boolean",
  574. "default": true
  575. }
  576. },
  577. {
  578. "variable": "port",
  579. "label": "Port",
  580. "description": "The port for the service.</br>\nPort set here will be used both inside and outside the container.\n",
  581. "schema": {
  582. "type": "dict",
  583. "attrs": [
  584. {
  585. "variable": "bind_mode",
  586. "label": "Port Bind Mode",
  587. "description": "The port bind mode.</br>\n- Publish: The port will be published on the host for external access.</br>\n- Expose: The port will be exposed for inter-container communication.</br>\n- None: The port will not be exposed or published.</br>\nNote: If the Dockerfile defines an EXPOSE directive,\nthe port will still be exposed for inter-container communication regardless of this setting.\n",
  588. "schema": {
  589. "type": "string",
  590. "default": "published",
  591. "enum": [
  592. {
  593. "value": "published",
  594. "description": "Publish port on the host for external access"
  595. },
  596. {
  597. "value": "exposed",
  598. "description": "Expose port for inter-container communication"
  599. },
  600. {
  601. "value": "",
  602. "description": "None"
  603. }
  604. ]
  605. }
  606. },
  607. {
  608. "variable": "port_number",
  609. "label": "Port Number",
  610. "schema": {
  611. "type": "int",
  612. "required": true,
  613. "$ref": [
  614. "definitions/port"
  615. ]
  616. }
  617. },
  618. {
  619. "variable": "host_ips",
  620. "label": "Host IPs",
  621. "description": "IPs on the host to bind this port",
  622. "schema": {
  623. "type": "list",
  624. "default": [],
  625. "items": [
  626. {
  627. "variable": "host_ip",
  628. "label": "Host IP",
  629. "schema": {
  630. "type": "string",
  631. "required": true,
  632. "$ref": [
  633. "definitions/node_bind_ip"
  634. ]
  635. }
  636. }
  637. ]
  638. }
  639. }
  640. ]
  641. }
  642. }
  643. ]
  644. }
  645. }
  646. ]
  647. }
  648. },
  649. {
  650. "variable": "ftpd_passive_port_range",
  651. "label": "FTPD Passive Port Range",
  652. "description": "The range of ports for passive FTPD services.</br>\nNote that you have to make sure that ports\nwithin the range are not used by other services.\n",
  653. "schema": {
  654. "type": "dict",
  655. "show_if": [
  656. [
  657. "ftpd_services",
  658. "!=",
  659. []
  660. ]
  661. ],
  662. "attrs": [
  663. {
  664. "variable": "bind_mode",
  665. "label": "Port Bind Mode",
  666. "description": "The port bind mode.</br>\n- Publish: The port will be published on the host for external access.</br>\n- Expose: The port will be exposed for inter-container communication.</br>\nNote: If the Dockerfile defines an EXPOSE directive,\nthe port will still be exposed for inter-container communication regardless of this setting.\n",
  667. "schema": {
  668. "type": "string",
  669. "default": "published",
  670. "enum": [
  671. {
  672. "value": "published",
  673. "description": "Publish port on the host for external access"
  674. },
  675. {
  676. "value": "exposed",
  677. "description": "Expose port for inter-container communication"
  678. }
  679. ]
  680. }
  681. },
  682. {
  683. "variable": "start",
  684. "label": "Start",
  685. "description": "The start of the range.",
  686. "schema": {
  687. "type": "int",
  688. "min": 1,
  689. "max": 65535,
  690. "required": true
  691. }
  692. },
  693. {
  694. "variable": "end",
  695. "label": "End",
  696. "description": "The end of the range.",
  697. "schema": {
  698. "type": "int",
  699. "min": 1,
  700. "max": 65535,
  701. "required": true
  702. }
  703. },
  704. {
  705. "variable": "host_ips",
  706. "label": "Host IPs",
  707. "description": "IPs on the host to bind this port",
  708. "schema": {
  709. "type": "list",
  710. "show_if": [
  711. [
  712. "bind_mode",
  713. "=",
  714. "published"
  715. ]
  716. ],
  717. "default": [],
  718. "items": [
  719. {
  720. "variable": "host_ip",
  721. "label": "Host IP",
  722. "schema": {
  723. "type": "string",
  724. "required": true,
  725. "$ref": [
  726. "definitions/node_bind_ip"
  727. ]
  728. }
  729. }
  730. ]
  731. }
  732. }
  733. ]
  734. }
  735. }
  736. ]
  737. }
  738. },
  739. {
  740. "variable": "storage",
  741. "label": "",
  742. "group": "Storage Configuration",
  743. "schema": {
  744. "type": "dict",
  745. "attrs": [
  746. {
  747. "variable": "config",
  748. "label": "SFTPGo Config Storage",
  749. "description": "The path to store SFTPGo Config.",
  750. "schema": {
  751. "type": "dict",
  752. "attrs": [
  753. {
  754. "variable": "type",
  755. "label": "Type",
  756. "description": "ixVolume: Is dataset created automatically by the system.</br>\nHost Path: Is a path that already exists on the system.\n",
  757. "schema": {
  758. "type": "string",
  759. "required": true,
  760. "default": "ix_volume",
  761. "enum": [
  762. {
  763. "value": "host_path",
  764. "description": "Host Path (Path that already exists on the system)"
  765. },
  766. {
  767. "value": "ix_volume",
  768. "description": "ixVolume (Dataset created automatically by the system)"
  769. }
  770. ]
  771. }
  772. },
  773. {
  774. "variable": "ix_volume_config",
  775. "label": "ixVolume Configuration",
  776. "description": "The configuration for the ixVolume dataset.",
  777. "schema": {
  778. "type": "dict",
  779. "show_if": [
  780. [
  781. "type",
  782. "=",
  783. "ix_volume"
  784. ]
  785. ],
  786. "$ref": [
  787. "normalize/ix_volume"
  788. ],
  789. "attrs": [
  790. {
  791. "variable": "acl_enable",
  792. "label": "Enable ACL",
  793. "description": "Enable ACL for the storage.",
  794. "schema": {
  795. "type": "boolean",
  796. "default": false
  797. }
  798. },
  799. {
  800. "variable": "dataset_name",
  801. "label": "Dataset Name",
  802. "description": "The name of the dataset to use for storage.",
  803. "schema": {
  804. "type": "string",
  805. "required": true,
  806. "hidden": true,
  807. "default": "config"
  808. }
  809. },
  810. {
  811. "variable": "acl_entries",
  812. "label": "ACL Configuration",
  813. "schema": {
  814. "type": "dict",
  815. "show_if": [
  816. [
  817. "acl_enable",
  818. "=",
  819. true
  820. ]
  821. ],
  822. "attrs": []
  823. }
  824. }
  825. ]
  826. }
  827. },
  828. {
  829. "variable": "host_path_config",
  830. "label": "Host Path Configuration",
  831. "schema": {
  832. "type": "dict",
  833. "show_if": [
  834. [
  835. "type",
  836. "=",
  837. "host_path"
  838. ]
  839. ],
  840. "attrs": [
  841. {
  842. "variable": "acl_enable",
  843. "label": "Enable ACL",
  844. "description": "Enable ACL for the storage.",
  845. "schema": {
  846. "type": "boolean",
  847. "default": false
  848. }
  849. },
  850. {
  851. "variable": "acl",
  852. "label": "ACL Configuration",
  853. "schema": {
  854. "type": "dict",
  855. "show_if": [
  856. [
  857. "acl_enable",
  858. "=",
  859. true
  860. ]
  861. ],
  862. "attrs": [],
  863. "$ref": [
  864. "normalize/acl"
  865. ]
  866. }
  867. },
  868. {
  869. "variable": "path",
  870. "label": "Host Path",
  871. "description": "The host path to use for storage.",
  872. "schema": {
  873. "type": "hostpath",
  874. "show_if": [
  875. [
  876. "acl_enable",
  877. "=",
  878. false
  879. ]
  880. ],
  881. "required": true
  882. }
  883. }
  884. ]
  885. }
  886. }
  887. ]
  888. }
  889. },
  890. {
  891. "variable": "data",
  892. "label": "SFTPGo Data Storage",
  893. "description": "The path to store SFTPGo Data.",
  894. "schema": {
  895. "type": "dict",
  896. "attrs": [
  897. {
  898. "variable": "type",
  899. "label": "Type",
  900. "description": "ixVolume: Is dataset created automatically by the system.</br>\nHost Path: Is a path that already exists on the system.\n",
  901. "schema": {
  902. "type": "string",
  903. "required": true,
  904. "default": "ix_volume",
  905. "enum": [
  906. {
  907. "value": "host_path",
  908. "description": "Host Path (Path that already exists on the system)"
  909. },
  910. {
  911. "value": "ix_volume",
  912. "description": "ixVolume (Dataset created automatically by the system)"
  913. }
  914. ]
  915. }
  916. },
  917. {
  918. "variable": "ix_volume_config",
  919. "label": "ixVolume Configuration",
  920. "description": "The configuration for the ixVolume dataset.",
  921. "schema": {
  922. "type": "dict",
  923. "show_if": [
  924. [
  925. "type",
  926. "=",
  927. "ix_volume"
  928. ]
  929. ],
  930. "$ref": [
  931. "normalize/ix_volume"
  932. ],
  933. "attrs": [
  934. {
  935. "variable": "acl_enable",
  936. "label": "Enable ACL",
  937. "description": "Enable ACL for the storage.",
  938. "schema": {
  939. "type": "boolean",
  940. "default": false
  941. }
  942. },
  943. {
  944. "variable": "dataset_name",
  945. "label": "Dataset Name",
  946. "description": "The name of the dataset to use for storage.",
  947. "schema": {
  948. "type": "string",
  949. "required": true,
  950. "hidden": true,
  951. "default": "data"
  952. }
  953. },
  954. {
  955. "variable": "acl_entries",
  956. "label": "ACL Configuration",
  957. "schema": {
  958. "type": "dict",
  959. "show_if": [
  960. [
  961. "acl_enable",
  962. "=",
  963. true
  964. ]
  965. ],
  966. "attrs": []
  967. }
  968. }
  969. ]
  970. }
  971. },
  972. {
  973. "variable": "host_path_config",
  974. "label": "Host Path Configuration",
  975. "schema": {
  976. "type": "dict",
  977. "show_if": [
  978. [
  979. "type",
  980. "=",
  981. "host_path"
  982. ]
  983. ],
  984. "attrs": [
  985. {
  986. "variable": "acl_enable",
  987. "label": "Enable ACL",
  988. "description": "Enable ACL for the storage.",
  989. "schema": {
  990. "type": "boolean",
  991. "default": false
  992. }
  993. },
  994. {
  995. "variable": "acl",
  996. "label": "ACL Configuration",
  997. "schema": {
  998. "type": "dict",
  999. "show_if": [
  1000. [
  1001. "acl_enable",
  1002. "=",
  1003. true
  1004. ]
  1005. ],
  1006. "attrs": [],
  1007. "$ref": [
  1008. "normalize/acl"
  1009. ]
  1010. }
  1011. },
  1012. {
  1013. "variable": "path",
  1014. "label": "Host Path",
  1015. "description": "The host path to use for storage.",
  1016. "schema": {
  1017. "type": "hostpath",
  1018. "show_if": [
  1019. [
  1020. "acl_enable",
  1021. "=",
  1022. false
  1023. ]
  1024. ],
  1025. "required": true
  1026. }
  1027. }
  1028. ]
  1029. }
  1030. }
  1031. ]
  1032. }
  1033. },
  1034. {
  1035. "variable": "backups",
  1036. "label": "SFTPGo Backups Storage",
  1037. "description": "The path to store SFTPGo Backups.",
  1038. "schema": {
  1039. "type": "dict",
  1040. "attrs": [
  1041. {
  1042. "variable": "type",
  1043. "label": "Type",
  1044. "description": "ixVolume: Is dataset created automatically by the system.</br>\nHost Path: Is a path that already exists on the system.\n",
  1045. "schema": {
  1046. "type": "string",
  1047. "required": true,
  1048. "default": "ix_volume",
  1049. "enum": [
  1050. {
  1051. "value": "host_path",
  1052. "description": "Host Path (Path that already exists on the system)"
  1053. },
  1054. {
  1055. "value": "ix_volume",
  1056. "description": "ixVolume (Dataset created automatically by the system)"
  1057. }
  1058. ]
  1059. }
  1060. },
  1061. {
  1062. "variable": "ix_volume_config",
  1063. "label": "ixVolume Configuration",
  1064. "description": "The configuration for the ixVolume dataset.",
  1065. "schema": {
  1066. "type": "dict",
  1067. "show_if": [
  1068. [
  1069. "type",
  1070. "=",
  1071. "ix_volume"
  1072. ]
  1073. ],
  1074. "$ref": [
  1075. "normalize/ix_volume"
  1076. ],
  1077. "attrs": [
  1078. {
  1079. "variable": "acl_enable",
  1080. "label": "Enable ACL",
  1081. "description": "Enable ACL for the storage.",
  1082. "schema": {
  1083. "type": "boolean",
  1084. "default": false
  1085. }
  1086. },
  1087. {
  1088. "variable": "dataset_name",
  1089. "label": "Dataset Name",
  1090. "description": "The name of the dataset to use for storage.",
  1091. "schema": {
  1092. "type": "string",
  1093. "required": true,
  1094. "hidden": true,
  1095. "default": "data"
  1096. }
  1097. },
  1098. {
  1099. "variable": "acl_entries",
  1100. "label": "ACL Configuration",
  1101. "schema": {
  1102. "type": "dict",
  1103. "show_if": [
  1104. [
  1105. "acl_enable",
  1106. "=",
  1107. true
  1108. ]
  1109. ],
  1110. "attrs": []
  1111. }
  1112. }
  1113. ]
  1114. }
  1115. },
  1116. {
  1117. "variable": "host_path_config",
  1118. "label": "Host Path Configuration",
  1119. "schema": {
  1120. "type": "dict",
  1121. "show_if": [
  1122. [
  1123. "type",
  1124. "=",
  1125. "host_path"
  1126. ]
  1127. ],
  1128. "attrs": [
  1129. {
  1130. "variable": "acl_enable",
  1131. "label": "Enable ACL",
  1132. "description": "Enable ACL for the storage.",
  1133. "schema": {
  1134. "type": "boolean",
  1135. "default": false
  1136. }
  1137. },
  1138. {
  1139. "variable": "acl",
  1140. "label": "ACL Configuration",
  1141. "schema": {
  1142. "type": "dict",
  1143. "show_if": [
  1144. [
  1145. "acl_enable",
  1146. "=",
  1147. true
  1148. ]
  1149. ],
  1150. "attrs": [],
  1151. "$ref": [
  1152. "normalize/acl"
  1153. ]
  1154. }
  1155. },
  1156. {
  1157. "variable": "path",
  1158. "label": "Host Path",
  1159. "description": "The host path to use for storage.",
  1160. "schema": {
  1161. "type": "hostpath",
  1162. "show_if": [
  1163. [
  1164. "acl_enable",
  1165. "=",
  1166. false
  1167. ]
  1168. ],
  1169. "required": true
  1170. }
  1171. }
  1172. ]
  1173. }
  1174. }
  1175. ]
  1176. }
  1177. },
  1178. {
  1179. "variable": "additional_storage",
  1180. "label": "Additional Storage",
  1181. "schema": {
  1182. "type": "list",
  1183. "default": [],
  1184. "items": [
  1185. {
  1186. "variable": "storageEntry",
  1187. "label": "Storage Entry",
  1188. "schema": {
  1189. "type": "dict",
  1190. "attrs": [
  1191. {
  1192. "variable": "type",
  1193. "label": "Type",
  1194. "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 as a volume.\n",
  1195. "schema": {
  1196. "type": "string",
  1197. "required": true,
  1198. "default": "ix_volume",
  1199. "enum": [
  1200. {
  1201. "value": "host_path",
  1202. "description": "Host Path (Path that already exists on the system)"
  1203. },
  1204. {
  1205. "value": "ix_volume",
  1206. "description": "ixVolume (Dataset created automatically by the system)"
  1207. },
  1208. {
  1209. "value": "cifs",
  1210. "description": "SMB/CIFS Share (Mounts a volume to a SMB share)"
  1211. }
  1212. ]
  1213. }
  1214. },
  1215. {
  1216. "variable": "read_only",
  1217. "label": "Read Only",
  1218. "description": "Mount the volume as read only.",
  1219. "schema": {
  1220. "type": "boolean",
  1221. "default": false
  1222. }
  1223. },
  1224. {
  1225. "variable": "mount_path",
  1226. "label": "Mount Path",
  1227. "description": "The path inside the container to mount the storage.",
  1228. "schema": {
  1229. "type": "path",
  1230. "required": true
  1231. }
  1232. },
  1233. {
  1234. "variable": "host_path_config",
  1235. "label": "Host Path Configuration",
  1236. "schema": {
  1237. "type": "dict",
  1238. "show_if": [
  1239. [
  1240. "type",
  1241. "=",
  1242. "host_path"
  1243. ]
  1244. ],
  1245. "attrs": [
  1246. {
  1247. "variable": "acl_enable",
  1248. "label": "Enable ACL",
  1249. "description": "Enable ACL for the storage.",
  1250. "schema": {
  1251. "type": "boolean",
  1252. "default": false
  1253. }
  1254. },
  1255. {
  1256. "variable": "acl",
  1257. "label": "ACL Configuration",
  1258. "schema": {
  1259. "type": "dict",
  1260. "show_if": [
  1261. [
  1262. "acl_enable",
  1263. "=",
  1264. true
  1265. ]
  1266. ],
  1267. "attrs": [],
  1268. "$ref": [
  1269. "normalize/acl"
  1270. ]
  1271. }
  1272. },
  1273. {
  1274. "variable": "path",
  1275. "label": "Host Path",
  1276. "description": "The host path to use for storage.",
  1277. "schema": {
  1278. "type": "hostpath",
  1279. "show_if": [
  1280. [
  1281. "acl_enable",
  1282. "=",
  1283. false
  1284. ]
  1285. ],
  1286. "required": true
  1287. }
  1288. }
  1289. ]
  1290. }
  1291. },
  1292. {
  1293. "variable": "ix_volume_config",
  1294. "label": "ixVolume Configuration",
  1295. "description": "The configuration for the ixVolume dataset.",
  1296. "schema": {
  1297. "type": "dict",
  1298. "show_if": [
  1299. [
  1300. "type",
  1301. "=",
  1302. "ix_volume"
  1303. ]
  1304. ],
  1305. "$ref": [
  1306. "normalize/ix_volume"
  1307. ],
  1308. "attrs": [
  1309. {
  1310. "variable": "acl_enable",
  1311. "label": "Enable ACL",
  1312. "description": "Enable ACL for the storage.",
  1313. "schema": {
  1314. "type": "boolean",
  1315. "default": false
  1316. }
  1317. },
  1318. {
  1319. "variable": "dataset_name",
  1320. "label": "Dataset Name",
  1321. "description": "The name of the dataset to use for storage.",
  1322. "schema": {
  1323. "type": "string",
  1324. "required": true,
  1325. "default": "storage_entry"
  1326. }
  1327. },
  1328. {
  1329. "variable": "acl_entries",
  1330. "label": "ACL Configuration",
  1331. "schema": {
  1332. "type": "dict",
  1333. "show_if": [
  1334. [
  1335. "acl_enable",
  1336. "=",
  1337. true
  1338. ]
  1339. ],
  1340. "attrs": [],
  1341. "$ref": [
  1342. "normalize/acl"
  1343. ]
  1344. }
  1345. }
  1346. ]
  1347. }
  1348. },
  1349. {
  1350. "variable": "cifs_config",
  1351. "label": "SMB Configuration",
  1352. "description": "The configuration for the SMB dataset.",
  1353. "schema": {
  1354. "type": "dict",
  1355. "show_if": [
  1356. [
  1357. "type",
  1358. "=",
  1359. "cifs"
  1360. ]
  1361. ],
  1362. "attrs": [
  1363. {
  1364. "variable": "server",
  1365. "label": "Server",
  1366. "description": "The server to mount the SMB share.",
  1367. "schema": {
  1368. "type": "string",
  1369. "required": true
  1370. }
  1371. },
  1372. {
  1373. "variable": "path",
  1374. "label": "Path",
  1375. "description": "The path to mount the SMB share.",
  1376. "schema": {
  1377. "type": "string",
  1378. "required": true
  1379. }
  1380. },
  1381. {
  1382. "variable": "username",
  1383. "label": "Username",
  1384. "description": "The username to use for the SMB share.",
  1385. "schema": {
  1386. "type": "string",
  1387. "required": true
  1388. }
  1389. },
  1390. {
  1391. "variable": "password",
  1392. "label": "Password",
  1393. "description": "The password to use for the SMB share.",
  1394. "schema": {
  1395. "type": "string",
  1396. "required": true,
  1397. "private": true
  1398. }
  1399. },
  1400. {
  1401. "variable": "domain",
  1402. "label": "Domain",
  1403. "description": "The domain to use for the SMB share.",
  1404. "schema": {
  1405. "type": "string"
  1406. }
  1407. }
  1408. ]
  1409. }
  1410. }
  1411. ]
  1412. }
  1413. }
  1414. ]
  1415. }
  1416. }
  1417. ]
  1418. }
  1419. },
  1420. {
  1421. "variable": "labels",
  1422. "label": "",
  1423. "group": "Labels Configuration",
  1424. "schema": {
  1425. "type": "list",
  1426. "default": [],
  1427. "items": [
  1428. {
  1429. "variable": "label",
  1430. "label": "Label",
  1431. "schema": {
  1432. "type": "dict",
  1433. "attrs": [
  1434. {
  1435. "variable": "key",
  1436. "label": "Key",
  1437. "schema": {
  1438. "type": "string",
  1439. "required": true
  1440. }
  1441. },
  1442. {
  1443. "variable": "value",
  1444. "label": "Value",
  1445. "schema": {
  1446. "type": "string",
  1447. "required": true
  1448. }
  1449. },
  1450. {
  1451. "variable": "containers",
  1452. "label": "Containers",
  1453. "description": "Containers where the label should be applied",
  1454. "schema": {
  1455. "type": "list",
  1456. "items": [
  1457. {
  1458. "variable": "container",
  1459. "label": "Container",
  1460. "schema": {
  1461. "type": "string",
  1462. "required": true,
  1463. "enum": [
  1464. {
  1465. "value": "sftpgo",
  1466. "description": "sftpgo"
  1467. }
  1468. ]
  1469. }
  1470. }
  1471. ]
  1472. }
  1473. }
  1474. ]
  1475. }
  1476. }
  1477. ]
  1478. }
  1479. },
  1480. {
  1481. "variable": "resources",
  1482. "label": "",
  1483. "group": "Resources Configuration",
  1484. "schema": {
  1485. "type": "dict",
  1486. "attrs": [
  1487. {
  1488. "variable": "limits",
  1489. "label": "Limits",
  1490. "schema": {
  1491. "type": "dict",
  1492. "attrs": [
  1493. {
  1494. "variable": "cpus",
  1495. "label": "CPUs",
  1496. "description": "CPUs limit for SFTPGo.",
  1497. "schema": {
  1498. "type": "int",
  1499. "default": 2,
  1500. "required": true
  1501. }
  1502. },
  1503. {
  1504. "variable": "memory",
  1505. "label": "Memory (in MB)",
  1506. "description": "Memory limit for SFTPGo.",
  1507. "schema": {
  1508. "type": "int",
  1509. "default": 4096,
  1510. "required": true
  1511. }
  1512. }
  1513. ]
  1514. }
  1515. }
  1516. ]
  1517. }
  1518. }
  1519. ]
  1520. },
  1521. "readme": "<h1>SFTPGo</h1> <p><a href=\"https://github.com/drakkan/sftpgo\">SFTPGo</a> is a fully featured and highly configurable SFTP server with optional HTTP/S, FTP/S and WebDAV support - S3, Google Cloud Storage, Azure Blob</p>",
  1522. "changelog": null,
  1523. "chart_metadata": {
  1524. "annotations": {
  1525. "min_scale_version": "24.10.2.2"
  1526. },
  1527. "app_version": "v2.6.6",
  1528. "capabilities": [],
  1529. "categories": [
  1530. "storage"
  1531. ],
  1532. "changelog_url": "https://github.com/drakkan/sftpgo/releases",
  1533. "date_added": "2024-09-16",
  1534. "description": "SFTPGo is a fully featured and highly configurable SFTP server with optional HTTP/S, FTP/S and WebDAV support - S3, Google Cloud Storage, Azure Blob",
  1535. "home": "https://github.com/drakkan/sftpgo",
  1536. "host_mounts": [],
  1537. "icon": "https://media.sys.truenas.net/apps/sftpgo/icons/icon.png",
  1538. "keywords": [
  1539. "sftp"
  1540. ],
  1541. "lib_version": "2.1.49",
  1542. "lib_version_hash": "e71e6b0122c9446fa5ea6fb07e7eb01b11fb42d549a19845426bbd7e21a42634",
  1543. "maintainers": [
  1544. {
  1545. "email": "dev@ixsystems.com",
  1546. "name": "truenas",
  1547. "url": "https://www.truenas.com/"
  1548. }
  1549. ],
  1550. "name": "sftpgo",
  1551. "run_as_context": [
  1552. {
  1553. "description": "SFTPGo runs as any non-root user.",
  1554. "gid": 568,
  1555. "group_name": "sftpgo",
  1556. "uid": 568,
  1557. "user_name": "sftpgo"
  1558. }
  1559. ],
  1560. "screenshots": [],
  1561. "sources": [
  1562. "https://hub.docker.com/r/drakkan/sftpgo",
  1563. "https://github.com/drakkan/sftpgo"
  1564. ],
  1565. "title": "SFTPGo",
  1566. "train": "community",
  1567. "version": "1.2.7"
  1568. }
  1569. }
  1570. }