app_versions.json 58 KB

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