app_versions.json 71 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156
  1. {
  2. "1.0.6": {
  3. "healthy": true,
  4. "supported": true,
  5. "healthy_error": null,
  6. "location": "/__w/apps/apps/trains/community/hoppscotch/1.0.6",
  7. "last_update": "2025-09-03 12:56:43",
  8. "required_features": [],
  9. "human_version": "2025.8.1_1.0.6",
  10. "version": "1.0.6",
  11. "app_metadata": {
  12. "app_version": "2025.8.1",
  13. "capabilities": [],
  14. "categories": [
  15. "development"
  16. ],
  17. "changelog_url": "https://github.com/hoppscotch/hoppscotch/releases",
  18. "date_added": "2025-08-04",
  19. "description": "Hoppscotch is a lightweight, web-based API development suite.",
  20. "home": "https://hoppscotch.io/",
  21. "host_mounts": [],
  22. "icon": "https://media.sys.truenas.net/apps/hoppscotch/icons/icon.svg",
  23. "keywords": [
  24. "api",
  25. "development",
  26. "postman"
  27. ],
  28. "lib_version": "2.1.49",
  29. "lib_version_hash": "e71e6b0122c9446fa5ea6fb07e7eb01b11fb42d549a19845426bbd7e21a42634",
  30. "maintainers": [
  31. {
  32. "email": "dev@ixsystems.com",
  33. "name": "truenas",
  34. "url": "https://www.truenas.com/"
  35. }
  36. ],
  37. "name": "hoppscotch",
  38. "run_as_context": [
  39. {
  40. "description": "Hoppscotch Frontend runs as root user.",
  41. "gid": 0,
  42. "group_name": "root",
  43. "uid": 0,
  44. "user_name": "root"
  45. },
  46. {
  47. "description": "Hoppscotch Backend runs as root user.",
  48. "gid": 0,
  49. "group_name": "root",
  50. "uid": 0,
  51. "user_name": "root"
  52. },
  53. {
  54. "description": "Hoppscotch Admin runs as root user.",
  55. "gid": 0,
  56. "group_name": "root",
  57. "uid": 0,
  58. "user_name": "root"
  59. },
  60. {
  61. "description": "Postgres runs as a non-root user.",
  62. "gid": 999,
  63. "group_name": "postgres",
  64. "uid": 999,
  65. "user_name": "postgres"
  66. }
  67. ],
  68. "screenshots": [],
  69. "sources": [
  70. "https://hoppscotch.com",
  71. "https://hoppscotch.io",
  72. "https://github.com/hoppscotch/hoppscotch",
  73. "https://hub.docker.com/r/hoppscotch/hoppscotch-frontend",
  74. "https://hub.docker.com/r/hoppscotch/hoppscotch-backend",
  75. "https://hub.docker.com/r/hoppscotch/hoppscotch-admin"
  76. ],
  77. "title": "Hoppscotch",
  78. "train": "community",
  79. "version": "1.0.6"
  80. },
  81. "schema": {
  82. "groups": [
  83. {
  84. "name": "Hoppscotch Configuration",
  85. "description": "Configure Hoppscotch"
  86. },
  87. {
  88. "name": "Network Configuration",
  89. "description": "Configure Network for Hoppscotch"
  90. },
  91. {
  92. "name": "Storage Configuration",
  93. "description": "Configure Storage for Hoppscotch"
  94. },
  95. {
  96. "name": "Labels Configuration",
  97. "description": "Configure Labels for Hoppscotch"
  98. },
  99. {
  100. "name": "Resources Configuration",
  101. "description": "Configure Resources for Hoppscotch"
  102. }
  103. ],
  104. "questions": [
  105. {
  106. "variable": "hoppscotch",
  107. "label": "",
  108. "group": "Hoppscotch Configuration",
  109. "schema": {
  110. "type": "dict",
  111. "attrs": [
  112. {
  113. "variable": "postgres_image_selector",
  114. "label": "Postgres Image (CAUTION)",
  115. "description": "If you are changing this after the postgres directory has been initialized,</br>\nSTOP! and make sure you have a backup of your data.</br>\nChanging this will trigger an one way database upgrade.</br>\nYou can only select newer versions of postgres.</br>\nSelecting an older version will refuse to start.</br>\nIf something goes wrong, you will have to restore from backup.\n",
  116. "schema": {
  117. "type": "string",
  118. "default": "postgres_17_image",
  119. "required": true,
  120. "enum": [
  121. {
  122. "value": "postgres_17_image",
  123. "description": "Postgres 17"
  124. }
  125. ]
  126. }
  127. },
  128. {
  129. "variable": "db_password",
  130. "label": "Database Password",
  131. "description": "The password for Hoppscotch.",
  132. "schema": {
  133. "type": "string",
  134. "default": "",
  135. "required": true,
  136. "private": true
  137. }
  138. },
  139. {
  140. "variable": "data_encryption_key",
  141. "label": "Data encryption key",
  142. "description": "Key to encrypt \"sensitive\" data.",
  143. "schema": {
  144. "type": "string",
  145. "default": "",
  146. "min_length": 32,
  147. "max_length": 32,
  148. "required": true,
  149. "private": true
  150. }
  151. },
  152. {
  153. "variable": "urls",
  154. "label": "",
  155. "schema": {
  156. "type": "dict",
  157. "attrs": [
  158. {
  159. "variable": "frontend",
  160. "label": "Frontend URL",
  161. "description": "The URL the frontend will be accessible from.</br>\nFormat: http(s)://(sub.)domain.tld(:port)</br>\nIf your NOT using a reverse proxy (like nginx) you need to\nspecify the same port as below!</br>\nExamples:</br>\nhttps://example.com:33000</br>\nhttps://frontend.hopp.example.com</br>\nhttps://frontend.hopp.example.com:33000\n",
  162. "schema": {
  163. "type": "uri",
  164. "default": "",
  165. "required": true
  166. }
  167. },
  168. {
  169. "variable": "backend",
  170. "label": "Backend URL",
  171. "description": "The URL the backend will be accessible from.</br>\nFormat: http(s)://(sub.)domain.tld(:port)</br>\nIf your NOT using a reverse proxy (like nginx) you need to\nspecify the same port as below!</br>\nExamples:</br>\nhttps://example.com:33170</br>\nhttps://backend.hopp.example.com</br>\nhttps://backend.hopp.example.com:33170\n",
  172. "schema": {
  173. "type": "uri",
  174. "default": "",
  175. "required": true
  176. }
  177. },
  178. {
  179. "variable": "admin",
  180. "label": "Admin URL",
  181. "description": "The URL the admin panel will be accessible from.</br>\nFormat: http(s)://(sub.)domain.tld(:port)</br>\nIf your NOT using a reverse proxy (like nginx) you need to\nspecify the same port as below!</br>\nExamples:</br>\nhttps://example.com:3300</br>\nhttps://backend.hopp.example.com</br>\nhttps://backend.hopp.example.com:3300\n",
  182. "schema": {
  183. "type": "uri",
  184. "default": "",
  185. "required": true
  186. }
  187. },
  188. {
  189. "variable": "app_bundle",
  190. "label": "App Bundle URL",
  191. "description": "The URL the app bundle will be accessible from.</br>\nFormat: http(s)://(sub.)domain.tld(:port)</br>\nIf your NOT using a reverse proxy (like nginx) you need to\nspecify the same port as below!</br>\nExamples:</br>\nhttps://example.com:33200</br>\nhttps://app.hopp.example.com</br>\nhttps://app.hopp.example.com:33200\n",
  192. "schema": {
  193. "type": "uri",
  194. "default": "",
  195. "required": true
  196. }
  197. }
  198. ]
  199. }
  200. },
  201. {
  202. "variable": "additional_envs",
  203. "label": "Additional Environment Variables",
  204. "schema": {
  205. "type": "list",
  206. "default": [],
  207. "items": [
  208. {
  209. "variable": "env",
  210. "label": "Environment Variable",
  211. "schema": {
  212. "type": "dict",
  213. "attrs": [
  214. {
  215. "variable": "name",
  216. "label": "Name",
  217. "schema": {
  218. "type": "string",
  219. "required": true
  220. }
  221. },
  222. {
  223. "variable": "value",
  224. "label": "Value",
  225. "schema": {
  226. "type": "string"
  227. }
  228. }
  229. ]
  230. }
  231. }
  232. ]
  233. }
  234. }
  235. ]
  236. }
  237. },
  238. {
  239. "variable": "network",
  240. "label": "",
  241. "group": "Network Configuration",
  242. "schema": {
  243. "type": "dict",
  244. "attrs": [
  245. {
  246. "variable": "frontend_web_port",
  247. "label": "WebUI Port",
  248. "schema": {
  249. "type": "dict",
  250. "attrs": [
  251. {
  252. "variable": "bind_mode",
  253. "label": "Port Bind Mode",
  254. "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",
  255. "schema": {
  256. "type": "string",
  257. "default": "published",
  258. "enum": [
  259. {
  260. "value": "published",
  261. "description": "Publish port on the host for external access"
  262. },
  263. {
  264. "value": "exposed",
  265. "description": "Expose port for inter-container communication"
  266. },
  267. {
  268. "value": "",
  269. "description": "None"
  270. }
  271. ]
  272. }
  273. },
  274. {
  275. "variable": "port_number",
  276. "label": "Port Number",
  277. "schema": {
  278. "type": "int",
  279. "default": 33000,
  280. "show_if": [
  281. [
  282. "bind_mode",
  283. "=",
  284. "published"
  285. ]
  286. ],
  287. "min": 1,
  288. "max": 65535,
  289. "required": true
  290. }
  291. },
  292. {
  293. "variable": "host_ips",
  294. "label": "Host IPs",
  295. "description": "IPs on the host to bind this port",
  296. "schema": {
  297. "type": "list",
  298. "show_if": [
  299. [
  300. "bind_mode",
  301. "=",
  302. "published"
  303. ]
  304. ],
  305. "default": [],
  306. "items": [
  307. {
  308. "variable": "host_ip",
  309. "label": "Host IP",
  310. "schema": {
  311. "type": "string",
  312. "required": true,
  313. "$ref": [
  314. "definitions/node_bind_ip"
  315. ]
  316. }
  317. }
  318. ]
  319. }
  320. }
  321. ]
  322. }
  323. },
  324. {
  325. "variable": "backend_web_port",
  326. "label": "Backend Port",
  327. "schema": {
  328. "type": "dict",
  329. "attrs": [
  330. {
  331. "variable": "bind_mode",
  332. "label": "Port Bind Mode",
  333. "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",
  334. "schema": {
  335. "type": "string",
  336. "default": "published",
  337. "enum": [
  338. {
  339. "value": "published",
  340. "description": "Publish port on the host for external access"
  341. },
  342. {
  343. "value": "exposed",
  344. "description": "Expose port for inter-container communication"
  345. },
  346. {
  347. "value": "",
  348. "description": "None"
  349. }
  350. ]
  351. }
  352. },
  353. {
  354. "variable": "port_number",
  355. "label": "Port Number",
  356. "schema": {
  357. "type": "int",
  358. "default": 33170,
  359. "show_if": [
  360. [
  361. "bind_mode",
  362. "=",
  363. "published"
  364. ]
  365. ],
  366. "min": 1,
  367. "max": 65535,
  368. "required": true
  369. }
  370. },
  371. {
  372. "variable": "host_ips",
  373. "label": "Host IPs",
  374. "description": "IPs on the host to bind this port",
  375. "schema": {
  376. "type": "list",
  377. "show_if": [
  378. [
  379. "bind_mode",
  380. "=",
  381. "published"
  382. ]
  383. ],
  384. "default": [],
  385. "items": [
  386. {
  387. "variable": "host_ip",
  388. "label": "Host IP",
  389. "schema": {
  390. "type": "string",
  391. "required": true,
  392. "$ref": [
  393. "definitions/node_bind_ip"
  394. ]
  395. }
  396. }
  397. ]
  398. }
  399. }
  400. ]
  401. }
  402. },
  403. {
  404. "variable": "admin_web_port",
  405. "label": "Admin WebUI Port",
  406. "schema": {
  407. "type": "dict",
  408. "attrs": [
  409. {
  410. "variable": "bind_mode",
  411. "label": "Port Bind Mode",
  412. "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",
  413. "schema": {
  414. "type": "string",
  415. "default": "published",
  416. "enum": [
  417. {
  418. "value": "published",
  419. "description": "Publish port on the host for external access"
  420. },
  421. {
  422. "value": "exposed",
  423. "description": "Expose port for inter-container communication"
  424. },
  425. {
  426. "value": "",
  427. "description": "None"
  428. }
  429. ]
  430. }
  431. },
  432. {
  433. "variable": "port_number",
  434. "label": "Port Number",
  435. "schema": {
  436. "type": "int",
  437. "default": 33100,
  438. "show_if": [
  439. [
  440. "bind_mode",
  441. "=",
  442. "published"
  443. ]
  444. ],
  445. "min": 1,
  446. "max": 65535,
  447. "required": true
  448. }
  449. },
  450. {
  451. "variable": "host_ips",
  452. "label": "Host IPs",
  453. "description": "IPs on the host to bind this port",
  454. "schema": {
  455. "type": "list",
  456. "show_if": [
  457. [
  458. "bind_mode",
  459. "=",
  460. "published"
  461. ]
  462. ],
  463. "default": [],
  464. "items": [
  465. {
  466. "variable": "host_ip",
  467. "label": "Host IP",
  468. "schema": {
  469. "type": "string",
  470. "required": true,
  471. "$ref": [
  472. "definitions/node_bind_ip"
  473. ]
  474. }
  475. }
  476. ]
  477. }
  478. }
  479. ]
  480. }
  481. },
  482. {
  483. "variable": "app_bundle_port",
  484. "label": "App Bundle Port",
  485. "schema": {
  486. "type": "dict",
  487. "attrs": [
  488. {
  489. "variable": "bind_mode",
  490. "label": "Port Bind Mode",
  491. "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",
  492. "schema": {
  493. "type": "string",
  494. "default": "published",
  495. "enum": [
  496. {
  497. "value": "published",
  498. "description": "Publish port on the host for external access"
  499. },
  500. {
  501. "value": "exposed",
  502. "description": "Expose port for inter-container communication"
  503. },
  504. {
  505. "value": "",
  506. "description": "None"
  507. }
  508. ]
  509. }
  510. },
  511. {
  512. "variable": "port_number",
  513. "label": "Port Number",
  514. "schema": {
  515. "type": "int",
  516. "default": 33200,
  517. "show_if": [
  518. [
  519. "bind_mode",
  520. "=",
  521. "published"
  522. ]
  523. ],
  524. "min": 1,
  525. "max": 65535,
  526. "required": true
  527. }
  528. },
  529. {
  530. "variable": "host_ips",
  531. "label": "Host IPs",
  532. "description": "IPs on the host to bind this port",
  533. "schema": {
  534. "type": "list",
  535. "show_if": [
  536. [
  537. "bind_mode",
  538. "=",
  539. "published"
  540. ]
  541. ],
  542. "default": [],
  543. "items": [
  544. {
  545. "variable": "host_ip",
  546. "label": "Host IP",
  547. "schema": {
  548. "type": "string",
  549. "required": true,
  550. "$ref": [
  551. "definitions/node_bind_ip"
  552. ]
  553. }
  554. }
  555. ]
  556. }
  557. }
  558. ]
  559. }
  560. }
  561. ]
  562. }
  563. },
  564. {
  565. "variable": "storage",
  566. "label": "",
  567. "group": "Storage Configuration",
  568. "schema": {
  569. "type": "dict",
  570. "attrs": [
  571. {
  572. "variable": "postgres_data",
  573. "label": "Hoppscotch Data Storage",
  574. "description": "The path to store Hoppscotch Postgres Data.",
  575. "schema": {
  576. "type": "dict",
  577. "attrs": [
  578. {
  579. "variable": "type",
  580. "label": "Type",
  581. "description": "ixVolume: Is dataset created automatically by the system.</br>\nHost Path: Is a path that already exists on the system.\n",
  582. "schema": {
  583. "type": "string",
  584. "required": true,
  585. "default": "ix_volume",
  586. "enum": [
  587. {
  588. "value": "host_path",
  589. "description": "Host Path (Path that already exists on the system)"
  590. },
  591. {
  592. "value": "ix_volume",
  593. "description": "ixVolume (Dataset created automatically by the system)"
  594. }
  595. ]
  596. }
  597. },
  598. {
  599. "variable": "ix_volume_config",
  600. "label": "ixVolume Configuration",
  601. "description": "The configuration for the ixVolume dataset.",
  602. "schema": {
  603. "type": "dict",
  604. "show_if": [
  605. [
  606. "type",
  607. "=",
  608. "ix_volume"
  609. ]
  610. ],
  611. "$ref": [
  612. "normalize/ix_volume"
  613. ],
  614. "attrs": [
  615. {
  616. "variable": "acl_enable",
  617. "label": "Enable ACL",
  618. "description": "Enable ACL for the storage.",
  619. "schema": {
  620. "type": "boolean",
  621. "default": false
  622. }
  623. },
  624. {
  625. "variable": "dataset_name",
  626. "label": "Dataset Name",
  627. "description": "The name of the dataset to use for storage.",
  628. "schema": {
  629. "type": "string",
  630. "required": true,
  631. "hidden": true,
  632. "default": "postgres_data"
  633. }
  634. },
  635. {
  636. "variable": "acl_entries",
  637. "label": "ACL Configuration",
  638. "schema": {
  639. "type": "dict",
  640. "show_if": [
  641. [
  642. "acl_enable",
  643. "=",
  644. true
  645. ]
  646. ],
  647. "attrs": []
  648. }
  649. }
  650. ]
  651. }
  652. },
  653. {
  654. "variable": "host_path_config",
  655. "label": "Host Path Configuration",
  656. "schema": {
  657. "type": "dict",
  658. "show_if": [
  659. [
  660. "type",
  661. "=",
  662. "host_path"
  663. ]
  664. ],
  665. "attrs": [
  666. {
  667. "variable": "acl_enable",
  668. "label": "Enable ACL",
  669. "description": "Enable ACL for the storage.",
  670. "schema": {
  671. "type": "boolean",
  672. "default": false
  673. }
  674. },
  675. {
  676. "variable": "acl",
  677. "label": "ACL Configuration",
  678. "schema": {
  679. "type": "dict",
  680. "show_if": [
  681. [
  682. "acl_enable",
  683. "=",
  684. true
  685. ]
  686. ],
  687. "attrs": [],
  688. "$ref": [
  689. "normalize/acl"
  690. ]
  691. }
  692. },
  693. {
  694. "variable": "path",
  695. "label": "Host Path",
  696. "description": "The host path to use for storage.",
  697. "schema": {
  698. "type": "hostpath",
  699. "show_if": [
  700. [
  701. "acl_enable",
  702. "=",
  703. false
  704. ]
  705. ],
  706. "required": true
  707. }
  708. },
  709. {
  710. "variable": "auto_permissions",
  711. "label": "Automatic Permissions",
  712. "description": "Automatically set permissions for the host path.\nEnabling this, will check the top level directory,</br>\nIf it finds incorrect permissions, it will `chown` the\nhost path to the user and group required for the\npostgres container.\n",
  713. "schema": {
  714. "type": "boolean",
  715. "default": false,
  716. "show_if": [
  717. [
  718. "acl_enable",
  719. "=",
  720. false
  721. ]
  722. ]
  723. }
  724. }
  725. ]
  726. }
  727. }
  728. ]
  729. }
  730. },
  731. {
  732. "variable": "additional_storage",
  733. "label": "Additional Storage",
  734. "schema": {
  735. "type": "list",
  736. "default": [],
  737. "items": [
  738. {
  739. "variable": "storageEntry",
  740. "label": "Storage Entry",
  741. "schema": {
  742. "type": "dict",
  743. "attrs": [
  744. {
  745. "variable": "type",
  746. "label": "Type",
  747. "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",
  748. "schema": {
  749. "type": "string",
  750. "required": true,
  751. "default": "ix_volume",
  752. "enum": [
  753. {
  754. "value": "host_path",
  755. "description": "Host Path (Path that already exists on the system)"
  756. },
  757. {
  758. "value": "ix_volume",
  759. "description": "ixVolume (Dataset created automatically by the system)"
  760. },
  761. {
  762. "value": "cifs",
  763. "description": "SMB/CIFS Share (Mounts a volume to a SMB share)"
  764. }
  765. ]
  766. }
  767. },
  768. {
  769. "variable": "read_only",
  770. "label": "Read Only",
  771. "description": "Mount the volume as read only.",
  772. "schema": {
  773. "type": "boolean",
  774. "default": false
  775. }
  776. },
  777. {
  778. "variable": "mount_path",
  779. "label": "Mount Path",
  780. "description": "The path inside the container to mount the storage.",
  781. "schema": {
  782. "type": "path",
  783. "required": true
  784. }
  785. },
  786. {
  787. "variable": "host_path_config",
  788. "label": "Host Path Configuration",
  789. "schema": {
  790. "type": "dict",
  791. "show_if": [
  792. [
  793. "type",
  794. "=",
  795. "host_path"
  796. ]
  797. ],
  798. "attrs": [
  799. {
  800. "variable": "acl_enable",
  801. "label": "Enable ACL",
  802. "description": "Enable ACL for the storage.",
  803. "schema": {
  804. "type": "boolean",
  805. "default": false
  806. }
  807. },
  808. {
  809. "variable": "acl",
  810. "label": "ACL Configuration",
  811. "schema": {
  812. "type": "dict",
  813. "show_if": [
  814. [
  815. "acl_enable",
  816. "=",
  817. true
  818. ]
  819. ],
  820. "attrs": [],
  821. "$ref": [
  822. "normalize/acl"
  823. ]
  824. }
  825. },
  826. {
  827. "variable": "path",
  828. "label": "Host Path",
  829. "description": "The host path to use for storage.",
  830. "schema": {
  831. "type": "hostpath",
  832. "show_if": [
  833. [
  834. "acl_enable",
  835. "=",
  836. false
  837. ]
  838. ],
  839. "required": true
  840. }
  841. }
  842. ]
  843. }
  844. },
  845. {
  846. "variable": "ix_volume_config",
  847. "label": "ixVolume Configuration",
  848. "description": "The configuration for the ixVolume dataset.",
  849. "schema": {
  850. "type": "dict",
  851. "show_if": [
  852. [
  853. "type",
  854. "=",
  855. "ix_volume"
  856. ]
  857. ],
  858. "$ref": [
  859. "normalize/ix_volume"
  860. ],
  861. "attrs": [
  862. {
  863. "variable": "acl_enable",
  864. "label": "Enable ACL",
  865. "description": "Enable ACL for the storage.",
  866. "schema": {
  867. "type": "boolean",
  868. "default": false
  869. }
  870. },
  871. {
  872. "variable": "dataset_name",
  873. "label": "Dataset Name",
  874. "description": "The name of the dataset to use for storage.",
  875. "schema": {
  876. "type": "string",
  877. "required": true,
  878. "default": "storage_entry"
  879. }
  880. },
  881. {
  882. "variable": "acl_entries",
  883. "label": "ACL Configuration",
  884. "schema": {
  885. "type": "dict",
  886. "show_if": [
  887. [
  888. "acl_enable",
  889. "=",
  890. true
  891. ]
  892. ],
  893. "attrs": []
  894. }
  895. }
  896. ]
  897. }
  898. },
  899. {
  900. "variable": "cifs_config",
  901. "label": "SMB Configuration",
  902. "description": "The configuration for the SMB dataset.",
  903. "schema": {
  904. "type": "dict",
  905. "show_if": [
  906. [
  907. "type",
  908. "=",
  909. "cifs"
  910. ]
  911. ],
  912. "attrs": [
  913. {
  914. "variable": "server",
  915. "label": "Server",
  916. "description": "The server to mount the SMB share.",
  917. "schema": {
  918. "type": "string",
  919. "required": true
  920. }
  921. },
  922. {
  923. "variable": "path",
  924. "label": "Path",
  925. "description": "The path to mount the SMB share.",
  926. "schema": {
  927. "type": "string",
  928. "required": true
  929. }
  930. },
  931. {
  932. "variable": "username",
  933. "label": "Username",
  934. "description": "The username to use for the SMB share.",
  935. "schema": {
  936. "type": "string",
  937. "required": true
  938. }
  939. },
  940. {
  941. "variable": "password",
  942. "label": "Password",
  943. "description": "The password to use for the SMB share.",
  944. "schema": {
  945. "type": "string",
  946. "required": true,
  947. "private": true
  948. }
  949. },
  950. {
  951. "variable": "domain",
  952. "label": "Domain",
  953. "description": "The domain to use for the SMB share.",
  954. "schema": {
  955. "type": "string"
  956. }
  957. }
  958. ]
  959. }
  960. }
  961. ]
  962. }
  963. }
  964. ]
  965. }
  966. }
  967. ]
  968. }
  969. },
  970. {
  971. "variable": "labels",
  972. "label": "",
  973. "group": "Labels Configuration",
  974. "schema": {
  975. "type": "list",
  976. "default": [],
  977. "items": [
  978. {
  979. "variable": "label",
  980. "label": "Label",
  981. "schema": {
  982. "type": "dict",
  983. "attrs": [
  984. {
  985. "variable": "key",
  986. "label": "Key",
  987. "schema": {
  988. "type": "string",
  989. "required": true
  990. }
  991. },
  992. {
  993. "variable": "value",
  994. "label": "Value",
  995. "schema": {
  996. "type": "string",
  997. "required": true
  998. }
  999. },
  1000. {
  1001. "variable": "containers",
  1002. "label": "Containers",
  1003. "description": "Containers where the label should be applied",
  1004. "schema": {
  1005. "type": "list",
  1006. "items": [
  1007. {
  1008. "variable": "container",
  1009. "label": "Container",
  1010. "schema": {
  1011. "type": "string",
  1012. "required": true,
  1013. "enum": [
  1014. {
  1015. "value": "backend",
  1016. "description": "backend"
  1017. },
  1018. {
  1019. "value": "frontend",
  1020. "description": "frontend"
  1021. },
  1022. {
  1023. "value": "admin",
  1024. "description": "admin"
  1025. },
  1026. {
  1027. "value": "postgres",
  1028. "description": "postgres"
  1029. }
  1030. ]
  1031. }
  1032. }
  1033. ]
  1034. }
  1035. }
  1036. ]
  1037. }
  1038. }
  1039. ]
  1040. }
  1041. },
  1042. {
  1043. "variable": "resources",
  1044. "label": "",
  1045. "group": "Resources Configuration",
  1046. "schema": {
  1047. "type": "dict",
  1048. "attrs": [
  1049. {
  1050. "variable": "limits",
  1051. "label": "Limits",
  1052. "schema": {
  1053. "type": "dict",
  1054. "attrs": [
  1055. {
  1056. "variable": "cpus",
  1057. "label": "CPUs",
  1058. "description": "CPUs limit for Hoppscotch.",
  1059. "schema": {
  1060. "type": "int",
  1061. "default": 2,
  1062. "required": true
  1063. }
  1064. },
  1065. {
  1066. "variable": "memory",
  1067. "label": "Memory (in MB)",
  1068. "description": "Memory limit for Hoppscotch.",
  1069. "schema": {
  1070. "type": "int",
  1071. "default": 4096,
  1072. "required": true
  1073. }
  1074. }
  1075. ]
  1076. }
  1077. }
  1078. ]
  1079. }
  1080. }
  1081. ]
  1082. },
  1083. "readme": "<h1>Hoppscotch</h1> <p><a href=\"https://hoppscotch.io\">Hoppscotch</a> is a lightweight, web-based API development suite.</p>",
  1084. "changelog": null,
  1085. "chart_metadata": {
  1086. "app_version": "2025.8.1",
  1087. "capabilities": [],
  1088. "categories": [
  1089. "development"
  1090. ],
  1091. "changelog_url": "https://github.com/hoppscotch/hoppscotch/releases",
  1092. "date_added": "2025-08-04",
  1093. "description": "Hoppscotch is a lightweight, web-based API development suite.",
  1094. "home": "https://hoppscotch.io/",
  1095. "host_mounts": [],
  1096. "icon": "https://media.sys.truenas.net/apps/hoppscotch/icons/icon.svg",
  1097. "keywords": [
  1098. "api",
  1099. "development",
  1100. "postman"
  1101. ],
  1102. "lib_version": "2.1.49",
  1103. "lib_version_hash": "e71e6b0122c9446fa5ea6fb07e7eb01b11fb42d549a19845426bbd7e21a42634",
  1104. "maintainers": [
  1105. {
  1106. "email": "dev@ixsystems.com",
  1107. "name": "truenas",
  1108. "url": "https://www.truenas.com/"
  1109. }
  1110. ],
  1111. "name": "hoppscotch",
  1112. "run_as_context": [
  1113. {
  1114. "description": "Hoppscotch Frontend runs as root user.",
  1115. "gid": 0,
  1116. "group_name": "root",
  1117. "uid": 0,
  1118. "user_name": "root"
  1119. },
  1120. {
  1121. "description": "Hoppscotch Backend runs as root user.",
  1122. "gid": 0,
  1123. "group_name": "root",
  1124. "uid": 0,
  1125. "user_name": "root"
  1126. },
  1127. {
  1128. "description": "Hoppscotch Admin runs as root user.",
  1129. "gid": 0,
  1130. "group_name": "root",
  1131. "uid": 0,
  1132. "user_name": "root"
  1133. },
  1134. {
  1135. "description": "Postgres runs as a non-root user.",
  1136. "gid": 999,
  1137. "group_name": "postgres",
  1138. "uid": 999,
  1139. "user_name": "postgres"
  1140. }
  1141. ],
  1142. "screenshots": [],
  1143. "sources": [
  1144. "https://hoppscotch.com",
  1145. "https://hoppscotch.io",
  1146. "https://github.com/hoppscotch/hoppscotch",
  1147. "https://hub.docker.com/r/hoppscotch/hoppscotch-frontend",
  1148. "https://hub.docker.com/r/hoppscotch/hoppscotch-backend",
  1149. "https://hub.docker.com/r/hoppscotch/hoppscotch-admin"
  1150. ],
  1151. "title": "Hoppscotch",
  1152. "train": "community",
  1153. "version": "1.0.6"
  1154. }
  1155. }
  1156. }