app_versions.json 54 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927
  1. {
  2. "1.0.13": {
  3. "healthy": true,
  4. "supported": true,
  5. "healthy_error": null,
  6. "location": "/__w/apps/apps/trains/community/heimdall/1.0.13",
  7. "last_update": "2025-09-02 11:33:24",
  8. "required_features": [],
  9. "human_version": "2.7.4_1.0.13",
  10. "version": "1.0.13",
  11. "app_metadata": {
  12. "app_version": "2.7.4",
  13. "capabilities": [
  14. {
  15. "description": "Heimdall is able to change file ownership arbitrarily",
  16. "name": "CHOWN"
  17. },
  18. {
  19. "description": "Heimdall is able to bypass file permission checks",
  20. "name": "DAC_OVERRIDE"
  21. },
  22. {
  23. "description": "Heimdall is able to bypass permission checks for file operations",
  24. "name": "FOWNER"
  25. },
  26. {
  27. "description": "Heimdall is able to change group ID of processes",
  28. "name": "SETGID"
  29. },
  30. {
  31. "description": "Heimdall is able to change user ID of processes",
  32. "name": "SETUID"
  33. }
  34. ],
  35. "categories": [
  36. "productivity"
  37. ],
  38. "changelog_url": "https://github.com/linuxserver/Heimdall/releases/",
  39. "date_added": "2025-02-05",
  40. "description": "An Application dashboard and launcher",
  41. "home": "https://heimdall.site/",
  42. "host_mounts": [],
  43. "icon": "https://media.sys.truenas.net/apps/heimdall/icons/icon.png",
  44. "keywords": [
  45. "dashboard"
  46. ],
  47. "lib_version": "2.1.49",
  48. "lib_version_hash": "e71e6b0122c9446fa5ea6fb07e7eb01b11fb42d549a19845426bbd7e21a42634",
  49. "maintainers": [
  50. {
  51. "email": "dev@ixsystems.com",
  52. "name": "truenas",
  53. "url": "https://www.truenas.com/"
  54. }
  55. ],
  56. "name": "heimdall",
  57. "run_as_context": [
  58. {
  59. "description": "Heimdall runs as root user.",
  60. "gid": 0,
  61. "group_name": "root",
  62. "uid": 0,
  63. "user_name": "root"
  64. }
  65. ],
  66. "screenshots": [],
  67. "sources": [
  68. "https://github.com/linuxserver/Heimdall",
  69. "https://github.com/linuxserver/docker-heimdall"
  70. ],
  71. "title": "Heimdall",
  72. "train": "community",
  73. "version": "1.0.13"
  74. },
  75. "schema": {
  76. "groups": [
  77. {
  78. "name": "Heimdall Configuration",
  79. "description": "Configure Heimdall"
  80. },
  81. {
  82. "name": "User and Group Configuration",
  83. "description": "Configure User and Group for Heimdall"
  84. },
  85. {
  86. "name": "Network Configuration",
  87. "description": "Configure Network for Heimdall"
  88. },
  89. {
  90. "name": "Storage Configuration",
  91. "description": "Configure Storage for Heimdall"
  92. },
  93. {
  94. "name": "Labels Configuration",
  95. "description": "Configure Labels for Heimdall"
  96. },
  97. {
  98. "name": "Resources Configuration",
  99. "description": "Configure Resources for Heimdall"
  100. }
  101. ],
  102. "questions": [
  103. {
  104. "variable": "TZ",
  105. "group": "Heimdall Configuration",
  106. "label": "Timezone",
  107. "schema": {
  108. "type": "string",
  109. "default": "Etc/UTC",
  110. "required": true,
  111. "$ref": [
  112. "definitions/timezone"
  113. ]
  114. }
  115. },
  116. {
  117. "variable": "heimdall",
  118. "label": "",
  119. "group": "Heimdall Configuration",
  120. "schema": {
  121. "type": "dict",
  122. "attrs": [
  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 Heimdall 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 Heimdall 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": "http_port",
  201. "label": "HTTP 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. "show_if": [
  234. [
  235. "bind_mode",
  236. "=",
  237. "published"
  238. ]
  239. ],
  240. "default": 30119,
  241. "min": 1,
  242. "max": 65535,
  243. "required": true
  244. }
  245. },
  246. {
  247. "variable": "host_ips",
  248. "label": "Host IPs",
  249. "description": "IPs on the host to bind this port",
  250. "schema": {
  251. "type": "list",
  252. "show_if": [
  253. [
  254. "bind_mode",
  255. "=",
  256. "published"
  257. ]
  258. ],
  259. "default": [],
  260. "items": [
  261. {
  262. "variable": "host_ip",
  263. "label": "Host IP",
  264. "schema": {
  265. "type": "string",
  266. "required": true,
  267. "$ref": [
  268. "definitions/node_bind_ip"
  269. ]
  270. }
  271. }
  272. ]
  273. }
  274. }
  275. ]
  276. }
  277. },
  278. {
  279. "variable": "https_port",
  280. "label": "HTTPS Port",
  281. "schema": {
  282. "type": "dict",
  283. "attrs": [
  284. {
  285. "variable": "bind_mode",
  286. "label": "Port Bind Mode",
  287. "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",
  288. "schema": {
  289. "type": "string",
  290. "default": "published",
  291. "enum": [
  292. {
  293. "value": "published",
  294. "description": "Publish port on the host for external access"
  295. },
  296. {
  297. "value": "exposed",
  298. "description": "Expose port for inter-container communication"
  299. },
  300. {
  301. "value": "",
  302. "description": "None"
  303. }
  304. ]
  305. }
  306. },
  307. {
  308. "variable": "port_number",
  309. "label": "Port Number",
  310. "schema": {
  311. "type": "int",
  312. "show_if": [
  313. [
  314. "bind_mode",
  315. "=",
  316. "published"
  317. ]
  318. ],
  319. "default": 30120,
  320. "min": 1,
  321. "max": 65535,
  322. "required": true
  323. }
  324. },
  325. {
  326. "variable": "host_ips",
  327. "label": "Host IPs",
  328. "description": "IPs on the host to bind this port",
  329. "schema": {
  330. "type": "list",
  331. "show_if": [
  332. [
  333. "bind_mode",
  334. "=",
  335. "published"
  336. ]
  337. ],
  338. "default": [],
  339. "items": [
  340. {
  341. "variable": "host_ip",
  342. "label": "Host IP",
  343. "schema": {
  344. "type": "string",
  345. "required": true,
  346. "$ref": [
  347. "definitions/node_bind_ip"
  348. ]
  349. }
  350. }
  351. ]
  352. }
  353. }
  354. ]
  355. }
  356. },
  357. {
  358. "variable": "host_network",
  359. "label": "Host Network",
  360. "description": "Bind to the host network. It's recommended to keep this disabled.\n",
  361. "schema": {
  362. "type": "boolean",
  363. "default": false
  364. }
  365. }
  366. ]
  367. }
  368. },
  369. {
  370. "variable": "storage",
  371. "label": "",
  372. "group": "Storage Configuration",
  373. "schema": {
  374. "type": "dict",
  375. "attrs": [
  376. {
  377. "variable": "config",
  378. "label": "Heimdall Config Storage",
  379. "description": "The path to store Heimdall Config.",
  380. "schema": {
  381. "type": "dict",
  382. "attrs": [
  383. {
  384. "variable": "type",
  385. "label": "Type",
  386. "description": "ixVolume: Is dataset created automatically by the system.</br>\nHost Path: Is a path that already exists on the system.\n",
  387. "schema": {
  388. "type": "string",
  389. "required": true,
  390. "default": "ix_volume",
  391. "enum": [
  392. {
  393. "value": "host_path",
  394. "description": "Host Path (Path that already exists on the system)"
  395. },
  396. {
  397. "value": "ix_volume",
  398. "description": "ixVolume (Dataset created automatically by the system)"
  399. }
  400. ]
  401. }
  402. },
  403. {
  404. "variable": "ix_volume_config",
  405. "label": "ixVolume Configuration",
  406. "description": "The configuration for the ixVolume dataset.",
  407. "schema": {
  408. "type": "dict",
  409. "show_if": [
  410. [
  411. "type",
  412. "=",
  413. "ix_volume"
  414. ]
  415. ],
  416. "$ref": [
  417. "normalize/ix_volume"
  418. ],
  419. "attrs": [
  420. {
  421. "variable": "acl_enable",
  422. "label": "Enable ACL",
  423. "description": "Enable ACL for the storage.",
  424. "schema": {
  425. "type": "boolean",
  426. "default": false
  427. }
  428. },
  429. {
  430. "variable": "dataset_name",
  431. "label": "Dataset Name",
  432. "description": "The name of the dataset to use for storage.",
  433. "schema": {
  434. "type": "string",
  435. "required": true,
  436. "hidden": true,
  437. "default": "config"
  438. }
  439. },
  440. {
  441. "variable": "acl_entries",
  442. "label": "ACL Configuration",
  443. "schema": {
  444. "type": "dict",
  445. "show_if": [
  446. [
  447. "acl_enable",
  448. "=",
  449. true
  450. ]
  451. ],
  452. "attrs": []
  453. }
  454. }
  455. ]
  456. }
  457. },
  458. {
  459. "variable": "host_path_config",
  460. "label": "Host Path Configuration",
  461. "schema": {
  462. "type": "dict",
  463. "show_if": [
  464. [
  465. "type",
  466. "=",
  467. "host_path"
  468. ]
  469. ],
  470. "attrs": [
  471. {
  472. "variable": "acl_enable",
  473. "label": "Enable ACL",
  474. "description": "Enable ACL for the storage.",
  475. "schema": {
  476. "type": "boolean",
  477. "default": false
  478. }
  479. },
  480. {
  481. "variable": "acl",
  482. "label": "ACL Configuration",
  483. "schema": {
  484. "type": "dict",
  485. "show_if": [
  486. [
  487. "acl_enable",
  488. "=",
  489. true
  490. ]
  491. ],
  492. "attrs": [],
  493. "$ref": [
  494. "normalize/acl"
  495. ]
  496. }
  497. },
  498. {
  499. "variable": "path",
  500. "label": "Host Path",
  501. "description": "The host path to use for storage.",
  502. "schema": {
  503. "type": "hostpath",
  504. "show_if": [
  505. [
  506. "acl_enable",
  507. "=",
  508. false
  509. ]
  510. ],
  511. "required": true
  512. }
  513. }
  514. ]
  515. }
  516. }
  517. ]
  518. }
  519. },
  520. {
  521. "variable": "additional_storage",
  522. "label": "Additional Storage",
  523. "schema": {
  524. "type": "list",
  525. "default": [],
  526. "items": [
  527. {
  528. "variable": "storageEntry",
  529. "label": "Storage Entry",
  530. "schema": {
  531. "type": "dict",
  532. "attrs": [
  533. {
  534. "variable": "type",
  535. "label": "Type",
  536. "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",
  537. "schema": {
  538. "type": "string",
  539. "required": true,
  540. "default": "ix_volume",
  541. "enum": [
  542. {
  543. "value": "host_path",
  544. "description": "Host Path (Path that already exists on the system)"
  545. },
  546. {
  547. "value": "ix_volume",
  548. "description": "ixVolume (Dataset created automatically by the system)"
  549. },
  550. {
  551. "value": "cifs",
  552. "description": "SMB/CIFS Share (Mounts a volume to a SMB share)"
  553. }
  554. ]
  555. }
  556. },
  557. {
  558. "variable": "read_only",
  559. "label": "Read Only",
  560. "description": "Mount the volume as read only.",
  561. "schema": {
  562. "type": "boolean",
  563. "default": false
  564. }
  565. },
  566. {
  567. "variable": "mount_path",
  568. "label": "Mount Path",
  569. "description": "The path inside the container to mount the storage.",
  570. "schema": {
  571. "type": "path",
  572. "required": true
  573. }
  574. },
  575. {
  576. "variable": "host_path_config",
  577. "label": "Host Path Configuration",
  578. "schema": {
  579. "type": "dict",
  580. "show_if": [
  581. [
  582. "type",
  583. "=",
  584. "host_path"
  585. ]
  586. ],
  587. "attrs": [
  588. {
  589. "variable": "acl_enable",
  590. "label": "Enable ACL",
  591. "description": "Enable ACL for the storage.",
  592. "schema": {
  593. "type": "boolean",
  594. "default": false
  595. }
  596. },
  597. {
  598. "variable": "acl",
  599. "label": "ACL Configuration",
  600. "schema": {
  601. "type": "dict",
  602. "show_if": [
  603. [
  604. "acl_enable",
  605. "=",
  606. true
  607. ]
  608. ],
  609. "attrs": [],
  610. "$ref": [
  611. "normalize/acl"
  612. ]
  613. }
  614. },
  615. {
  616. "variable": "path",
  617. "label": "Host Path",
  618. "description": "The host path to use for storage.",
  619. "schema": {
  620. "type": "hostpath",
  621. "show_if": [
  622. [
  623. "acl_enable",
  624. "=",
  625. false
  626. ]
  627. ],
  628. "required": true
  629. }
  630. }
  631. ]
  632. }
  633. },
  634. {
  635. "variable": "ix_volume_config",
  636. "label": "ixVolume Configuration",
  637. "description": "The configuration for the ixVolume dataset.",
  638. "schema": {
  639. "type": "dict",
  640. "show_if": [
  641. [
  642. "type",
  643. "=",
  644. "ix_volume"
  645. ]
  646. ],
  647. "$ref": [
  648. "normalize/ix_volume"
  649. ],
  650. "attrs": [
  651. {
  652. "variable": "acl_enable",
  653. "label": "Enable ACL",
  654. "description": "Enable ACL for the storage.",
  655. "schema": {
  656. "type": "boolean",
  657. "default": false
  658. }
  659. },
  660. {
  661. "variable": "dataset_name",
  662. "label": "Dataset Name",
  663. "description": "The name of the dataset to use for storage.",
  664. "schema": {
  665. "type": "string",
  666. "required": true,
  667. "default": "storage_entry"
  668. }
  669. },
  670. {
  671. "variable": "acl_entries",
  672. "label": "ACL Configuration",
  673. "schema": {
  674. "type": "dict",
  675. "show_if": [
  676. [
  677. "acl_enable",
  678. "=",
  679. true
  680. ]
  681. ],
  682. "attrs": []
  683. }
  684. }
  685. ]
  686. }
  687. },
  688. {
  689. "variable": "cifs_config",
  690. "label": "SMB Configuration",
  691. "description": "The configuration for the SMB dataset.",
  692. "schema": {
  693. "type": "dict",
  694. "show_if": [
  695. [
  696. "type",
  697. "=",
  698. "cifs"
  699. ]
  700. ],
  701. "attrs": [
  702. {
  703. "variable": "server",
  704. "label": "Server",
  705. "description": "The server to mount the SMB share.",
  706. "schema": {
  707. "type": "string",
  708. "required": true
  709. }
  710. },
  711. {
  712. "variable": "path",
  713. "label": "Path",
  714. "description": "The path to mount the SMB share.",
  715. "schema": {
  716. "type": "string",
  717. "required": true
  718. }
  719. },
  720. {
  721. "variable": "username",
  722. "label": "Username",
  723. "description": "The username to use for the SMB share.",
  724. "schema": {
  725. "type": "string",
  726. "required": true
  727. }
  728. },
  729. {
  730. "variable": "password",
  731. "label": "Password",
  732. "description": "The password to use for the SMB share.",
  733. "schema": {
  734. "type": "string",
  735. "required": true,
  736. "private": true
  737. }
  738. },
  739. {
  740. "variable": "domain",
  741. "label": "Domain",
  742. "description": "The domain to use for the SMB share.",
  743. "schema": {
  744. "type": "string"
  745. }
  746. }
  747. ]
  748. }
  749. }
  750. ]
  751. }
  752. }
  753. ]
  754. }
  755. }
  756. ]
  757. }
  758. },
  759. {
  760. "variable": "labels",
  761. "label": "",
  762. "group": "Labels Configuration",
  763. "schema": {
  764. "type": "list",
  765. "default": [],
  766. "items": [
  767. {
  768. "variable": "label",
  769. "label": "Label",
  770. "schema": {
  771. "type": "dict",
  772. "attrs": [
  773. {
  774. "variable": "key",
  775. "label": "Key",
  776. "schema": {
  777. "type": "string",
  778. "required": true
  779. }
  780. },
  781. {
  782. "variable": "value",
  783. "label": "Value",
  784. "schema": {
  785. "type": "string",
  786. "required": true
  787. }
  788. },
  789. {
  790. "variable": "containers",
  791. "label": "Containers",
  792. "description": "Containers where the label should be applied",
  793. "schema": {
  794. "type": "list",
  795. "items": [
  796. {
  797. "variable": "container",
  798. "label": "Container",
  799. "schema": {
  800. "type": "string",
  801. "required": true,
  802. "enum": [
  803. {
  804. "value": "heimdall",
  805. "description": "heimdall"
  806. }
  807. ]
  808. }
  809. }
  810. ]
  811. }
  812. }
  813. ]
  814. }
  815. }
  816. ]
  817. }
  818. },
  819. {
  820. "variable": "resources",
  821. "label": "",
  822. "group": "Resources Configuration",
  823. "schema": {
  824. "type": "dict",
  825. "attrs": [
  826. {
  827. "variable": "limits",
  828. "label": "Limits",
  829. "schema": {
  830. "type": "dict",
  831. "attrs": [
  832. {
  833. "variable": "cpus",
  834. "label": "CPUs",
  835. "description": "CPUs limit for Heimdall.",
  836. "schema": {
  837. "type": "int",
  838. "default": 2,
  839. "required": true
  840. }
  841. },
  842. {
  843. "variable": "memory",
  844. "label": "Memory (in MB)",
  845. "description": "Memory limit for Heimdall.",
  846. "schema": {
  847. "type": "int",
  848. "default": 4096,
  849. "required": true
  850. }
  851. }
  852. ]
  853. }
  854. }
  855. ]
  856. }
  857. }
  858. ]
  859. },
  860. "readme": "<h1>Heimdall</h1> <p><a href=\"https://heimdall.site\">Heimdall</a> is an Application dashboard and launcher.</p>",
  861. "changelog": null,
  862. "chart_metadata": {
  863. "app_version": "2.7.4",
  864. "capabilities": [
  865. {
  866. "description": "Heimdall is able to change file ownership arbitrarily",
  867. "name": "CHOWN"
  868. },
  869. {
  870. "description": "Heimdall is able to bypass file permission checks",
  871. "name": "DAC_OVERRIDE"
  872. },
  873. {
  874. "description": "Heimdall is able to bypass permission checks for file operations",
  875. "name": "FOWNER"
  876. },
  877. {
  878. "description": "Heimdall is able to change group ID of processes",
  879. "name": "SETGID"
  880. },
  881. {
  882. "description": "Heimdall is able to change user ID of processes",
  883. "name": "SETUID"
  884. }
  885. ],
  886. "categories": [
  887. "productivity"
  888. ],
  889. "changelog_url": "https://github.com/linuxserver/Heimdall/releases/",
  890. "date_added": "2025-02-05",
  891. "description": "An Application dashboard and launcher",
  892. "home": "https://heimdall.site/",
  893. "host_mounts": [],
  894. "icon": "https://media.sys.truenas.net/apps/heimdall/icons/icon.png",
  895. "keywords": [
  896. "dashboard"
  897. ],
  898. "lib_version": "2.1.49",
  899. "lib_version_hash": "e71e6b0122c9446fa5ea6fb07e7eb01b11fb42d549a19845426bbd7e21a42634",
  900. "maintainers": [
  901. {
  902. "email": "dev@ixsystems.com",
  903. "name": "truenas",
  904. "url": "https://www.truenas.com/"
  905. }
  906. ],
  907. "name": "heimdall",
  908. "run_as_context": [
  909. {
  910. "description": "Heimdall runs as root user.",
  911. "gid": 0,
  912. "group_name": "root",
  913. "uid": 0,
  914. "user_name": "root"
  915. }
  916. ],
  917. "screenshots": [],
  918. "sources": [
  919. "https://github.com/linuxserver/Heimdall",
  920. "https://github.com/linuxserver/docker-heimdall"
  921. ],
  922. "title": "Heimdall",
  923. "train": "community",
  924. "version": "1.0.13"
  925. }
  926. }
  927. }