app_versions.json 51 KB

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