app_versions.json 50 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842
  1. {
  2. "1.0.6": {
  3. "healthy": true,
  4. "supported": true,
  5. "healthy_error": null,
  6. "location": "/__w/apps/apps/trains/community/keycloak/1.0.6",
  7. "last_update": "2025-09-02 11:33:24",
  8. "required_features": [],
  9. "human_version": "26.3.3_1.0.6",
  10. "version": "1.0.6",
  11. "app_metadata": {
  12. "app_version": "26.3.3",
  13. "capabilities": [],
  14. "categories": [
  15. "security"
  16. ],
  17. "changelog_url": "https://github.com/keycloak/keycloak/releases",
  18. "date_added": "2025-08-08",
  19. "description": "Open Source Identity and Access Management For Modern Applications and Services",
  20. "home": "https://www.keycloak.org",
  21. "host_mounts": [],
  22. "icon": "https://media.sys.truenas.net/apps/keycloak/icons/icon.svg",
  23. "keywords": [
  24. "authentication",
  25. "authorization",
  26. "sso"
  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": "keycloak",
  38. "run_as_context": [
  39. {
  40. "description": "Keycloak runs as non-root user.",
  41. "gid": 1000,
  42. "group_name": "keycloak",
  43. "uid": 1000,
  44. "user_name": "keycloak"
  45. },
  46. {
  47. "description": "Postgres runs as non-root user.",
  48. "gid": 999,
  49. "group_name": "postgres",
  50. "uid": 999,
  51. "user_name": "postgres"
  52. }
  53. ],
  54. "screenshots": [],
  55. "sources": [
  56. "https://github.com/keycloak/keycloak",
  57. "https://www.keycloak.org/server/all-config#category-database"
  58. ],
  59. "title": "Keycloak",
  60. "train": "community",
  61. "version": "1.0.6"
  62. },
  63. "schema": {
  64. "groups": [
  65. {
  66. "name": "Keycloak Configuration",
  67. "description": "Configure Keycloak"
  68. },
  69. {
  70. "name": "Network Configuration",
  71. "description": "Configure Network for Keycloak"
  72. },
  73. {
  74. "name": "Storage Configuration",
  75. "description": "Configure Storage for Keycloak"
  76. },
  77. {
  78. "name": "Labels Configuration",
  79. "description": "Configure Labels for Keycloak"
  80. },
  81. {
  82. "name": "Resources Configuration",
  83. "description": "Configure Resources for Keycloak"
  84. }
  85. ],
  86. "questions": [
  87. {
  88. "variable": "TZ",
  89. "group": "Keycloak Configuration",
  90. "label": "Timezone",
  91. "schema": {
  92. "type": "string",
  93. "default": "Etc/UTC",
  94. "required": true,
  95. "$ref": [
  96. "definitions/timezone"
  97. ]
  98. }
  99. },
  100. {
  101. "variable": "keycloak",
  102. "label": "",
  103. "group": "Keycloak Configuration",
  104. "schema": {
  105. "type": "dict",
  106. "attrs": [
  107. {
  108. "variable": "postgres_image_selector",
  109. "label": "Postgres Image (CAUTION)",
  110. "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",
  111. "schema": {
  112. "type": "string",
  113. "default": "postgres_17_image",
  114. "required": true,
  115. "enum": [
  116. {
  117. "value": "postgres_17_image",
  118. "description": "Postgres 17"
  119. }
  120. ]
  121. }
  122. },
  123. {
  124. "variable": "db_password",
  125. "label": "Database Password",
  126. "schema": {
  127. "type": "string",
  128. "default": "",
  129. "required": true,
  130. "private": true
  131. }
  132. },
  133. {
  134. "variable": "hostname",
  135. "label": "Hostname",
  136. "description": "Address at which is the server exposed.\nCan be a full URL, or just a hostname. When only hostname is provided,\nscheme, port and context path are resolved from the request.\n",
  137. "schema": {
  138. "type": "uri",
  139. "default": "",
  140. "required": true
  141. }
  142. },
  143. {
  144. "variable": "additional_envs",
  145. "label": "Additional Environment Variables",
  146. "schema": {
  147. "type": "list",
  148. "default": [],
  149. "items": [
  150. {
  151. "variable": "env",
  152. "label": "Environment Variable",
  153. "schema": {
  154. "type": "dict",
  155. "attrs": [
  156. {
  157. "variable": "name",
  158. "label": "Name",
  159. "schema": {
  160. "type": "string",
  161. "required": true
  162. }
  163. },
  164. {
  165. "variable": "value",
  166. "label": "Value",
  167. "schema": {
  168. "type": "string"
  169. }
  170. }
  171. ]
  172. }
  173. }
  174. ]
  175. }
  176. }
  177. ]
  178. }
  179. },
  180. {
  181. "variable": "network",
  182. "label": "",
  183. "group": "Network Configuration",
  184. "schema": {
  185. "type": "dict",
  186. "attrs": [
  187. {
  188. "variable": "web_port",
  189. "label": "WebUI Port",
  190. "schema": {
  191. "type": "dict",
  192. "attrs": [
  193. {
  194. "variable": "bind_mode",
  195. "label": "Port Bind Mode",
  196. "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",
  197. "schema": {
  198. "type": "string",
  199. "default": "published",
  200. "enum": [
  201. {
  202. "value": "published",
  203. "description": "Publish port on the host for external access"
  204. },
  205. {
  206. "value": "exposed",
  207. "description": "Expose port for inter-container communication"
  208. },
  209. {
  210. "value": "",
  211. "description": "None"
  212. }
  213. ]
  214. }
  215. },
  216. {
  217. "variable": "port_number",
  218. "label": "Port Number",
  219. "schema": {
  220. "type": "int",
  221. "default": 30238,
  222. "min": 1,
  223. "max": 65535,
  224. "required": true
  225. }
  226. },
  227. {
  228. "variable": "host_ips",
  229. "label": "Host IPs",
  230. "description": "IPs on the host to bind this port",
  231. "schema": {
  232. "type": "list",
  233. "show_if": [
  234. [
  235. "bind_mode",
  236. "=",
  237. "published"
  238. ]
  239. ],
  240. "default": [],
  241. "items": [
  242. {
  243. "variable": "host_ip",
  244. "label": "Host IP",
  245. "schema": {
  246. "type": "string",
  247. "required": true,
  248. "$ref": [
  249. "definitions/node_bind_ip"
  250. ]
  251. }
  252. }
  253. ]
  254. }
  255. }
  256. ]
  257. }
  258. },
  259. {
  260. "variable": "certificate_id",
  261. "label": "Certificate ID",
  262. "description": "The certificate to use for Keycloak </br>\nUsing the Rocket method for TLS setup is NOT recommended </br>\nPrefer a reverse proxy with a valid certificate\n",
  263. "schema": {
  264. "type": "int",
  265. "null": true,
  266. "$ref": [
  267. "definitions/certificate"
  268. ]
  269. }
  270. }
  271. ]
  272. }
  273. },
  274. {
  275. "variable": "storage",
  276. "label": "",
  277. "group": "Storage Configuration",
  278. "schema": {
  279. "type": "dict",
  280. "attrs": [
  281. {
  282. "variable": "postgres_data",
  283. "label": "Postgres Data Storage",
  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": "postgres_data"
  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. "variable": "auto_permissions",
  420. "label": "Automatic Permissions",
  421. "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",
  422. "schema": {
  423. "type": "boolean",
  424. "default": false,
  425. "show_if": [
  426. [
  427. "acl_enable",
  428. "=",
  429. false
  430. ]
  431. ]
  432. }
  433. }
  434. ]
  435. }
  436. }
  437. ]
  438. }
  439. },
  440. {
  441. "variable": "additional_storage",
  442. "label": "Additional Storage",
  443. "schema": {
  444. "type": "list",
  445. "default": [],
  446. "items": [
  447. {
  448. "variable": "storageEntry",
  449. "label": "Storage Entry",
  450. "schema": {
  451. "type": "dict",
  452. "attrs": [
  453. {
  454. "variable": "type",
  455. "label": "Type",
  456. "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",
  457. "schema": {
  458. "type": "string",
  459. "required": true,
  460. "default": "ix_volume",
  461. "enum": [
  462. {
  463. "value": "host_path",
  464. "description": "Host Path (Path that already exists on the system)"
  465. },
  466. {
  467. "value": "ix_volume",
  468. "description": "ixVolume (Dataset created automatically by the system)"
  469. },
  470. {
  471. "value": "cifs",
  472. "description": "SMB/CIFS Share (Mounts a volume to a SMB share)"
  473. }
  474. ]
  475. }
  476. },
  477. {
  478. "variable": "read_only",
  479. "label": "Read Only",
  480. "description": "Mount the volume as read only.",
  481. "schema": {
  482. "type": "boolean",
  483. "default": false
  484. }
  485. },
  486. {
  487. "variable": "mount_path",
  488. "label": "Mount Path",
  489. "description": "The path inside the container to mount the storage.",
  490. "schema": {
  491. "type": "path",
  492. "required": true
  493. }
  494. },
  495. {
  496. "variable": "host_path_config",
  497. "label": "Host Path Configuration",
  498. "schema": {
  499. "type": "dict",
  500. "show_if": [
  501. [
  502. "type",
  503. "=",
  504. "host_path"
  505. ]
  506. ],
  507. "attrs": [
  508. {
  509. "variable": "acl_enable",
  510. "label": "Enable ACL",
  511. "description": "Enable ACL for the storage.",
  512. "schema": {
  513. "type": "boolean",
  514. "default": false
  515. }
  516. },
  517. {
  518. "variable": "acl",
  519. "label": "ACL Configuration",
  520. "schema": {
  521. "type": "dict",
  522. "show_if": [
  523. [
  524. "acl_enable",
  525. "=",
  526. true
  527. ]
  528. ],
  529. "attrs": [],
  530. "$ref": [
  531. "normalize/acl"
  532. ]
  533. }
  534. },
  535. {
  536. "variable": "path",
  537. "label": "Host Path",
  538. "description": "The host path to use for storage.",
  539. "schema": {
  540. "type": "hostpath",
  541. "show_if": [
  542. [
  543. "acl_enable",
  544. "=",
  545. false
  546. ]
  547. ],
  548. "required": true
  549. }
  550. }
  551. ]
  552. }
  553. },
  554. {
  555. "variable": "ix_volume_config",
  556. "label": "ixVolume Configuration",
  557. "description": "The configuration for the ixVolume dataset.",
  558. "schema": {
  559. "type": "dict",
  560. "show_if": [
  561. [
  562. "type",
  563. "=",
  564. "ix_volume"
  565. ]
  566. ],
  567. "$ref": [
  568. "normalize/ix_volume"
  569. ],
  570. "attrs": [
  571. {
  572. "variable": "acl_enable",
  573. "label": "Enable ACL",
  574. "description": "Enable ACL for the storage.",
  575. "schema": {
  576. "type": "boolean",
  577. "default": false
  578. }
  579. },
  580. {
  581. "variable": "dataset_name",
  582. "label": "Dataset Name",
  583. "description": "The name of the dataset to use for storage.",
  584. "schema": {
  585. "type": "string",
  586. "required": true,
  587. "default": "storage_entry"
  588. }
  589. },
  590. {
  591. "variable": "acl_entries",
  592. "label": "ACL Configuration",
  593. "schema": {
  594. "type": "dict",
  595. "show_if": [
  596. [
  597. "acl_enable",
  598. "=",
  599. true
  600. ]
  601. ],
  602. "attrs": [],
  603. "$ref": [
  604. "normalize/acl"
  605. ]
  606. }
  607. }
  608. ]
  609. }
  610. },
  611. {
  612. "variable": "cifs_config",
  613. "label": "SMB Configuration",
  614. "description": "The configuration for the SMB dataset.",
  615. "schema": {
  616. "type": "dict",
  617. "show_if": [
  618. [
  619. "type",
  620. "=",
  621. "cifs"
  622. ]
  623. ],
  624. "attrs": [
  625. {
  626. "variable": "server",
  627. "label": "Server",
  628. "description": "The server to mount the SMB share.",
  629. "schema": {
  630. "type": "string",
  631. "required": true
  632. }
  633. },
  634. {
  635. "variable": "path",
  636. "label": "Path",
  637. "description": "The path to mount the SMB share.",
  638. "schema": {
  639. "type": "string",
  640. "required": true
  641. }
  642. },
  643. {
  644. "variable": "username",
  645. "label": "Username",
  646. "description": "The username to use for the SMB share.",
  647. "schema": {
  648. "type": "string",
  649. "required": true
  650. }
  651. },
  652. {
  653. "variable": "password",
  654. "label": "Password",
  655. "description": "The password to use for the SMB share.",
  656. "schema": {
  657. "type": "string",
  658. "required": true,
  659. "private": true
  660. }
  661. },
  662. {
  663. "variable": "domain",
  664. "label": "Domain",
  665. "description": "The domain to use for the SMB share.",
  666. "schema": {
  667. "type": "string"
  668. }
  669. }
  670. ]
  671. }
  672. }
  673. ]
  674. }
  675. }
  676. ]
  677. }
  678. }
  679. ]
  680. }
  681. },
  682. {
  683. "variable": "labels",
  684. "label": "",
  685. "group": "Labels Configuration",
  686. "schema": {
  687. "type": "list",
  688. "default": [],
  689. "items": [
  690. {
  691. "variable": "label",
  692. "label": "Label",
  693. "schema": {
  694. "type": "dict",
  695. "attrs": [
  696. {
  697. "variable": "key",
  698. "label": "Key",
  699. "schema": {
  700. "type": "string",
  701. "required": true
  702. }
  703. },
  704. {
  705. "variable": "value",
  706. "label": "Value",
  707. "schema": {
  708. "type": "string",
  709. "required": true
  710. }
  711. },
  712. {
  713. "variable": "containers",
  714. "label": "Containers",
  715. "description": "Containers where the label should be applied",
  716. "schema": {
  717. "type": "list",
  718. "items": [
  719. {
  720. "variable": "container",
  721. "label": "Container",
  722. "schema": {
  723. "type": "string",
  724. "required": true,
  725. "enum": [
  726. {
  727. "value": "keycloak",
  728. "description": "keycloak"
  729. },
  730. {
  731. "value": "postgres",
  732. "description": "postgres"
  733. }
  734. ]
  735. }
  736. }
  737. ]
  738. }
  739. }
  740. ]
  741. }
  742. }
  743. ]
  744. }
  745. },
  746. {
  747. "variable": "resources",
  748. "label": "",
  749. "group": "Resources Configuration",
  750. "schema": {
  751. "type": "dict",
  752. "attrs": [
  753. {
  754. "variable": "limits",
  755. "label": "Limits",
  756. "schema": {
  757. "type": "dict",
  758. "attrs": [
  759. {
  760. "variable": "cpus",
  761. "label": "CPUs",
  762. "description": "CPUs limit for Keycloak.",
  763. "schema": {
  764. "type": "int",
  765. "default": 2,
  766. "required": true
  767. }
  768. },
  769. {
  770. "variable": "memory",
  771. "label": "Memory (in MB)",
  772. "description": "Memory limit for Keycloak.",
  773. "schema": {
  774. "type": "int",
  775. "default": 4096,
  776. "required": true
  777. }
  778. }
  779. ]
  780. }
  781. }
  782. ]
  783. }
  784. }
  785. ]
  786. },
  787. "readme": "<h1>Keycloak</h1> <p><a href=\"https://www.keycloak.org/\">Keycloak</a> is an Open Source Identity and Access Management For Modern Applications and Services</p>",
  788. "changelog": null,
  789. "chart_metadata": {
  790. "app_version": "26.3.3",
  791. "capabilities": [],
  792. "categories": [
  793. "security"
  794. ],
  795. "changelog_url": "https://github.com/keycloak/keycloak/releases",
  796. "date_added": "2025-08-08",
  797. "description": "Open Source Identity and Access Management For Modern Applications and Services",
  798. "home": "https://www.keycloak.org",
  799. "host_mounts": [],
  800. "icon": "https://media.sys.truenas.net/apps/keycloak/icons/icon.svg",
  801. "keywords": [
  802. "authentication",
  803. "authorization",
  804. "sso"
  805. ],
  806. "lib_version": "2.1.49",
  807. "lib_version_hash": "e71e6b0122c9446fa5ea6fb07e7eb01b11fb42d549a19845426bbd7e21a42634",
  808. "maintainers": [
  809. {
  810. "email": "dev@ixsystems.com",
  811. "name": "truenas",
  812. "url": "https://www.truenas.com/"
  813. }
  814. ],
  815. "name": "keycloak",
  816. "run_as_context": [
  817. {
  818. "description": "Keycloak runs as non-root user.",
  819. "gid": 1000,
  820. "group_name": "keycloak",
  821. "uid": 1000,
  822. "user_name": "keycloak"
  823. },
  824. {
  825. "description": "Postgres runs as non-root user.",
  826. "gid": 999,
  827. "group_name": "postgres",
  828. "uid": 999,
  829. "user_name": "postgres"
  830. }
  831. ],
  832. "screenshots": [],
  833. "sources": [
  834. "https://github.com/keycloak/keycloak",
  835. "https://www.keycloak.org/server/all-config#category-database"
  836. ],
  837. "title": "Keycloak",
  838. "train": "community",
  839. "version": "1.0.6"
  840. }
  841. }
  842. }