app_versions.json 92 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478147914801481148214831484148514861487148814891490149114921493149414951496149714981499150015011502150315041505150615071508150915101511151215131514151515161517151815191520
  1. {
  2. "1.0.35": {
  3. "healthy": true,
  4. "supported": true,
  5. "healthy_error": null,
  6. "location": "/__w/apps/apps/trains/community/authentik/1.0.35",
  7. "last_update": "2025-09-02 11:33:24",
  8. "required_features": [],
  9. "human_version": "2025.8.1_1.0.35",
  10. "version": "1.0.35",
  11. "app_metadata": {
  12. "app_version": "2025.8.1",
  13. "capabilities": [],
  14. "categories": [
  15. "authentication"
  16. ],
  17. "changelog_url": "https://docs.goauthentik.io/docs/releases/",
  18. "date_added": "2025-03-25",
  19. "description": "The authentication glue you need.",
  20. "home": "https://goauthentik.io/",
  21. "host_mounts": [
  22. {
  23. "description": "Docker socket",
  24. "host_path": "/var/run/docker.sock"
  25. }
  26. ],
  27. "icon": "https://media.sys.truenas.net/apps/authentik/icons/icon.svg",
  28. "keywords": [
  29. "authentik",
  30. "auth"
  31. ],
  32. "lib_version": "2.1.49",
  33. "lib_version_hash": "e71e6b0122c9446fa5ea6fb07e7eb01b11fb42d549a19845426bbd7e21a42634",
  34. "maintainers": [
  35. {
  36. "email": "dev@ixsystems.com",
  37. "name": "truenas",
  38. "url": "https://www.truenas.com/"
  39. }
  40. ],
  41. "name": "authentik",
  42. "run_as_context": [
  43. {
  44. "description": "Authentik runs as any non-root user.",
  45. "gid": 568,
  46. "group_name": "authentik",
  47. "uid": 568,
  48. "user_name": "authentik"
  49. },
  50. {
  51. "description": "Postgres runs as non-root user.",
  52. "gid": 999,
  53. "group_name": "postgres",
  54. "uid": 999,
  55. "user_name": "postgres"
  56. },
  57. {
  58. "description": "Redis runs as any non-root user.",
  59. "gid": 568,
  60. "group_name": "redis",
  61. "uid": 568,
  62. "user_name": "redis"
  63. }
  64. ],
  65. "screenshots": [
  66. "https://media.sys.truenas.net/apps/authentik/screenshots/screenshot1.png",
  67. "https://media.sys.truenas.net/apps/authentik/screenshots/screenshot2.png",
  68. "https://media.sys.truenas.net/apps/authentik/screenshots/screenshot3.png",
  69. "https://media.sys.truenas.net/apps/authentik/screenshots/screenshot4.png"
  70. ],
  71. "sources": [
  72. "https://goauthentik.io/",
  73. "https://github.com/goauthentik/authentik"
  74. ],
  75. "title": "Authentik",
  76. "train": "community",
  77. "version": "1.0.35"
  78. },
  79. "schema": {
  80. "groups": [
  81. {
  82. "name": "Authentik Configuration",
  83. "description": "Configure Authentik"
  84. },
  85. {
  86. "name": "User and Group Configuration",
  87. "description": "Configure User and Group for Authentik"
  88. },
  89. {
  90. "name": "Network Configuration",
  91. "description": "Configure Network for Authentik"
  92. },
  93. {
  94. "name": "Storage Configuration",
  95. "description": "Configure Storage for Authentik"
  96. },
  97. {
  98. "name": "Labels Configuration",
  99. "description": "Configure Labels for Authentik"
  100. },
  101. {
  102. "name": "Resources Configuration",
  103. "description": "Configure Resources for Authentik"
  104. }
  105. ],
  106. "questions": [
  107. {
  108. "variable": "TZ",
  109. "group": "Authentik Configuration",
  110. "label": "Timezone",
  111. "schema": {
  112. "type": "string",
  113. "default": "Etc/UTC",
  114. "required": true,
  115. "$ref": [
  116. "definitions/timezone"
  117. ]
  118. }
  119. },
  120. {
  121. "variable": "authentik",
  122. "label": "",
  123. "group": "Authentik Configuration",
  124. "schema": {
  125. "type": "dict",
  126. "attrs": [
  127. {
  128. "variable": "postgres_image_selector",
  129. "label": "Postgres Image (CAUTION)",
  130. "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",
  131. "schema": {
  132. "type": "string",
  133. "default": "postgres_17_image",
  134. "required": true,
  135. "enum": [
  136. {
  137. "value": "postgres_17_image",
  138. "description": "Postgres 17"
  139. }
  140. ]
  141. }
  142. },
  143. {
  144. "variable": "db_password",
  145. "label": "Database Password",
  146. "description": "The password for Authelia.",
  147. "schema": {
  148. "type": "string",
  149. "default": "",
  150. "required": true,
  151. "private": true
  152. }
  153. },
  154. {
  155. "variable": "redis_password",
  156. "label": "Redis Password",
  157. "description": "The password for Redis.",
  158. "schema": {
  159. "type": "string",
  160. "default": "",
  161. "required": true,
  162. "private": true
  163. }
  164. },
  165. {
  166. "variable": "secret_key",
  167. "label": "Secret Key",
  168. "schema": {
  169. "type": "string",
  170. "required": true,
  171. "private": true
  172. }
  173. },
  174. {
  175. "variable": "mount_docker_socket",
  176. "label": "Mount Docker Socket",
  177. "description": "Mount the Docker socket inside the Authentik container.</br>\nOnly needed if you want to allow Authentik to deploy and manage outposts.\n",
  178. "schema": {
  179. "type": "boolean",
  180. "default": false
  181. }
  182. },
  183. {
  184. "variable": "setup_email",
  185. "label": "Setup Email",
  186. "description": "Setup email for Authentik.\n",
  187. "schema": {
  188. "type": "boolean",
  189. "default": false
  190. }
  191. },
  192. {
  193. "variable": "email",
  194. "label": "Email Configuration",
  195. "description": "Configure email for Authentik.",
  196. "schema": {
  197. "type": "dict",
  198. "show_if": [
  199. [
  200. "setup_email",
  201. "=",
  202. true
  203. ]
  204. ],
  205. "attrs": [
  206. {
  207. "variable": "host",
  208. "label": "SMTP Host",
  209. "schema": {
  210. "type": "string",
  211. "required": true
  212. }
  213. },
  214. {
  215. "variable": "port",
  216. "label": "SMTP Port",
  217. "schema": {
  218. "type": "int",
  219. "min": 1,
  220. "max": 65535,
  221. "required": true,
  222. "default": 587
  223. }
  224. },
  225. {
  226. "variable": "from",
  227. "label": "SMTP From",
  228. "schema": {
  229. "type": "string",
  230. "required": true
  231. }
  232. },
  233. {
  234. "variable": "username",
  235. "label": "SMTP Username",
  236. "schema": {
  237. "type": "string",
  238. "required": true
  239. }
  240. },
  241. {
  242. "variable": "password",
  243. "label": "SMTP Password",
  244. "schema": {
  245. "type": "string",
  246. "required": true,
  247. "private": true
  248. }
  249. },
  250. {
  251. "variable": "security",
  252. "label": "SMTP Security",
  253. "schema": {
  254. "type": "string",
  255. "required": true,
  256. "default": "tls",
  257. "enum": [
  258. {
  259. "value": "tls",
  260. "description": "TLS"
  261. },
  262. {
  263. "value": "ssl",
  264. "description": "SSL"
  265. }
  266. ]
  267. }
  268. }
  269. ]
  270. }
  271. },
  272. {
  273. "variable": "additional_envs",
  274. "label": "Additional Environment Variables",
  275. "schema": {
  276. "type": "list",
  277. "default": [],
  278. "items": [
  279. {
  280. "variable": "env",
  281. "label": "Environment Variable",
  282. "schema": {
  283. "type": "dict",
  284. "attrs": [
  285. {
  286. "variable": "name",
  287. "label": "Name",
  288. "schema": {
  289. "type": "string",
  290. "required": true
  291. }
  292. },
  293. {
  294. "variable": "value",
  295. "label": "Value",
  296. "schema": {
  297. "type": "string"
  298. }
  299. }
  300. ]
  301. }
  302. }
  303. ]
  304. }
  305. }
  306. ]
  307. }
  308. },
  309. {
  310. "variable": "run_as",
  311. "label": "",
  312. "group": "User and Group Configuration",
  313. "schema": {
  314. "type": "dict",
  315. "attrs": [
  316. {
  317. "variable": "user",
  318. "label": "User ID",
  319. "description": "The user id that Authentik files will be owned by.",
  320. "schema": {
  321. "type": "int",
  322. "min": 568,
  323. "default": 568,
  324. "required": true
  325. }
  326. },
  327. {
  328. "variable": "group",
  329. "label": "Group ID",
  330. "description": "The group id that Authentik files will be owned by.",
  331. "schema": {
  332. "type": "int",
  333. "min": 568,
  334. "default": 568,
  335. "required": true
  336. }
  337. }
  338. ]
  339. }
  340. },
  341. {
  342. "variable": "network",
  343. "label": "",
  344. "group": "Network Configuration",
  345. "schema": {
  346. "type": "dict",
  347. "attrs": [
  348. {
  349. "variable": "http_port",
  350. "label": "HTTP Port",
  351. "schema": {
  352. "type": "dict",
  353. "attrs": [
  354. {
  355. "variable": "bind_mode",
  356. "label": "Port Bind Mode",
  357. "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",
  358. "schema": {
  359. "type": "string",
  360. "default": "published",
  361. "enum": [
  362. {
  363. "value": "published",
  364. "description": "Publish port on the host for external access"
  365. },
  366. {
  367. "value": "exposed",
  368. "description": "Expose port for inter-container communication"
  369. },
  370. {
  371. "value": "",
  372. "description": "None"
  373. }
  374. ]
  375. }
  376. },
  377. {
  378. "variable": "port_number",
  379. "label": "Port Number",
  380. "schema": {
  381. "type": "int",
  382. "default": 30140,
  383. "min": 1,
  384. "max": 65535,
  385. "required": true
  386. }
  387. },
  388. {
  389. "variable": "host_ips",
  390. "label": "Host IPs",
  391. "description": "IPs on the host to bind this port",
  392. "schema": {
  393. "type": "list",
  394. "show_if": [
  395. [
  396. "bind_mode",
  397. "=",
  398. "published"
  399. ]
  400. ],
  401. "default": [],
  402. "items": [
  403. {
  404. "variable": "host_ip",
  405. "label": "Host IP",
  406. "schema": {
  407. "type": "string",
  408. "required": true,
  409. "$ref": [
  410. "definitions/node_bind_ip"
  411. ]
  412. }
  413. }
  414. ]
  415. }
  416. }
  417. ]
  418. }
  419. },
  420. {
  421. "variable": "https_port",
  422. "label": "HTTPS Port",
  423. "schema": {
  424. "type": "dict",
  425. "attrs": [
  426. {
  427. "variable": "bind_mode",
  428. "label": "Port Bind Mode",
  429. "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",
  430. "schema": {
  431. "type": "string",
  432. "default": "published",
  433. "enum": [
  434. {
  435. "value": "published",
  436. "description": "Publish port on the host for external access"
  437. },
  438. {
  439. "value": "exposed",
  440. "description": "Expose port for inter-container communication"
  441. },
  442. {
  443. "value": "",
  444. "description": "None"
  445. }
  446. ]
  447. }
  448. },
  449. {
  450. "variable": "port_number",
  451. "label": "Port Number",
  452. "schema": {
  453. "type": "int",
  454. "default": 30141,
  455. "min": 1,
  456. "max": 65535,
  457. "required": true
  458. }
  459. },
  460. {
  461. "variable": "host_ips",
  462. "label": "Host IPs",
  463. "description": "IPs on the host to bind this port",
  464. "schema": {
  465. "type": "list",
  466. "show_if": [
  467. [
  468. "bind_mode",
  469. "=",
  470. "published"
  471. ]
  472. ],
  473. "default": [],
  474. "items": [
  475. {
  476. "variable": "host_ip",
  477. "label": "Host IP",
  478. "schema": {
  479. "type": "string",
  480. "required": true,
  481. "$ref": [
  482. "definitions/node_bind_ip"
  483. ]
  484. }
  485. }
  486. ]
  487. }
  488. }
  489. ]
  490. }
  491. }
  492. ]
  493. }
  494. },
  495. {
  496. "variable": "storage",
  497. "label": "",
  498. "group": "Storage Configuration",
  499. "schema": {
  500. "type": "dict",
  501. "attrs": [
  502. {
  503. "variable": "media",
  504. "label": "Authentik Media Storage",
  505. "description": "The path to store Authentik Media.",
  506. "schema": {
  507. "type": "dict",
  508. "attrs": [
  509. {
  510. "variable": "type",
  511. "label": "Type",
  512. "description": "ixVolume: Is dataset created automatically by the system.</br>\nHost Path: Is a path that already exists on the system.\n",
  513. "schema": {
  514. "type": "string",
  515. "required": true,
  516. "default": "ix_volume",
  517. "enum": [
  518. {
  519. "value": "host_path",
  520. "description": "Host Path (Path that already exists on the system)"
  521. },
  522. {
  523. "value": "ix_volume",
  524. "description": "ixVolume (Dataset created automatically by the system)"
  525. }
  526. ]
  527. }
  528. },
  529. {
  530. "variable": "ix_volume_config",
  531. "label": "ixVolume Configuration",
  532. "description": "The configuration for the ixVolume dataset.",
  533. "schema": {
  534. "type": "dict",
  535. "show_if": [
  536. [
  537. "type",
  538. "=",
  539. "ix_volume"
  540. ]
  541. ],
  542. "$ref": [
  543. "normalize/ix_volume"
  544. ],
  545. "attrs": [
  546. {
  547. "variable": "acl_enable",
  548. "label": "Enable ACL",
  549. "description": "Enable ACL for the storage.",
  550. "schema": {
  551. "type": "boolean",
  552. "default": false
  553. }
  554. },
  555. {
  556. "variable": "dataset_name",
  557. "label": "Dataset Name",
  558. "description": "The name of the dataset to use for storage.",
  559. "schema": {
  560. "type": "string",
  561. "required": true,
  562. "hidden": true,
  563. "default": "media"
  564. }
  565. },
  566. {
  567. "variable": "acl_entries",
  568. "label": "ACL Configuration",
  569. "schema": {
  570. "type": "dict",
  571. "show_if": [
  572. [
  573. "acl_enable",
  574. "=",
  575. true
  576. ]
  577. ],
  578. "attrs": []
  579. }
  580. }
  581. ]
  582. }
  583. },
  584. {
  585. "variable": "host_path_config",
  586. "label": "Host Path Configuration",
  587. "schema": {
  588. "type": "dict",
  589. "show_if": [
  590. [
  591. "type",
  592. "=",
  593. "host_path"
  594. ]
  595. ],
  596. "attrs": [
  597. {
  598. "variable": "acl_enable",
  599. "label": "Enable ACL",
  600. "description": "Enable ACL for the storage.",
  601. "schema": {
  602. "type": "boolean",
  603. "default": false
  604. }
  605. },
  606. {
  607. "variable": "acl",
  608. "label": "ACL Configuration",
  609. "schema": {
  610. "type": "dict",
  611. "show_if": [
  612. [
  613. "acl_enable",
  614. "=",
  615. true
  616. ]
  617. ],
  618. "attrs": [],
  619. "$ref": [
  620. "normalize/acl"
  621. ]
  622. }
  623. },
  624. {
  625. "variable": "path",
  626. "label": "Host Path",
  627. "description": "The host path to use for storage.",
  628. "schema": {
  629. "type": "hostpath",
  630. "show_if": [
  631. [
  632. "acl_enable",
  633. "=",
  634. false
  635. ]
  636. ],
  637. "required": true
  638. }
  639. }
  640. ]
  641. }
  642. }
  643. ]
  644. }
  645. },
  646. {
  647. "variable": "templates",
  648. "label": "Authentik Templates Storage",
  649. "description": "The path to store Authentik Templates.",
  650. "schema": {
  651. "type": "dict",
  652. "attrs": [
  653. {
  654. "variable": "type",
  655. "label": "Type",
  656. "description": "ixVolume: Is dataset created automatically by the system.</br>\nHost Path: Is a path that already exists on the system.\n",
  657. "schema": {
  658. "type": "string",
  659. "required": true,
  660. "default": "ix_volume",
  661. "enum": [
  662. {
  663. "value": "host_path",
  664. "description": "Host Path (Path that already exists on the system)"
  665. },
  666. {
  667. "value": "ix_volume",
  668. "description": "ixVolume (Dataset created automatically by the system)"
  669. }
  670. ]
  671. }
  672. },
  673. {
  674. "variable": "ix_volume_config",
  675. "label": "ixVolume Configuration",
  676. "description": "The configuration for the ixVolume dataset.",
  677. "schema": {
  678. "type": "dict",
  679. "show_if": [
  680. [
  681. "type",
  682. "=",
  683. "ix_volume"
  684. ]
  685. ],
  686. "$ref": [
  687. "normalize/ix_volume"
  688. ],
  689. "attrs": [
  690. {
  691. "variable": "acl_enable",
  692. "label": "Enable ACL",
  693. "description": "Enable ACL for the storage.",
  694. "schema": {
  695. "type": "boolean",
  696. "default": false
  697. }
  698. },
  699. {
  700. "variable": "dataset_name",
  701. "label": "Dataset Name",
  702. "description": "The name of the dataset to use for storage.",
  703. "schema": {
  704. "type": "string",
  705. "required": true,
  706. "hidden": true,
  707. "default": "templates"
  708. }
  709. },
  710. {
  711. "variable": "acl_entries",
  712. "label": "ACL Configuration",
  713. "schema": {
  714. "type": "dict",
  715. "show_if": [
  716. [
  717. "acl_enable",
  718. "=",
  719. true
  720. ]
  721. ],
  722. "attrs": []
  723. }
  724. }
  725. ]
  726. }
  727. },
  728. {
  729. "variable": "host_path_config",
  730. "label": "Host Path Configuration",
  731. "schema": {
  732. "type": "dict",
  733. "show_if": [
  734. [
  735. "type",
  736. "=",
  737. "host_path"
  738. ]
  739. ],
  740. "attrs": [
  741. {
  742. "variable": "acl_enable",
  743. "label": "Enable ACL",
  744. "description": "Enable ACL for the storage.",
  745. "schema": {
  746. "type": "boolean",
  747. "default": false
  748. }
  749. },
  750. {
  751. "variable": "acl",
  752. "label": "ACL Configuration",
  753. "schema": {
  754. "type": "dict",
  755. "show_if": [
  756. [
  757. "acl_enable",
  758. "=",
  759. true
  760. ]
  761. ],
  762. "attrs": [],
  763. "$ref": [
  764. "normalize/acl"
  765. ]
  766. }
  767. },
  768. {
  769. "variable": "path",
  770. "label": "Host Path",
  771. "description": "The host path to use for storage.",
  772. "schema": {
  773. "type": "hostpath",
  774. "show_if": [
  775. [
  776. "acl_enable",
  777. "=",
  778. false
  779. ]
  780. ],
  781. "required": true
  782. }
  783. }
  784. ]
  785. }
  786. }
  787. ]
  788. }
  789. },
  790. {
  791. "variable": "certs",
  792. "label": "Authentik Certs Storage",
  793. "description": "The path to store Authentik Certs.",
  794. "schema": {
  795. "type": "dict",
  796. "attrs": [
  797. {
  798. "variable": "type",
  799. "label": "Type",
  800. "description": "ixVolume: Is dataset created automatically by the system.</br>\nHost Path: Is a path that already exists on the system.\n",
  801. "schema": {
  802. "type": "string",
  803. "required": true,
  804. "default": "ix_volume",
  805. "enum": [
  806. {
  807. "value": "host_path",
  808. "description": "Host Path (Path that already exists on the system)"
  809. },
  810. {
  811. "value": "ix_volume",
  812. "description": "ixVolume (Dataset created automatically by the system)"
  813. }
  814. ]
  815. }
  816. },
  817. {
  818. "variable": "ix_volume_config",
  819. "label": "ixVolume Configuration",
  820. "description": "The configuration for the ixVolume dataset.",
  821. "schema": {
  822. "type": "dict",
  823. "show_if": [
  824. [
  825. "type",
  826. "=",
  827. "ix_volume"
  828. ]
  829. ],
  830. "$ref": [
  831. "normalize/ix_volume"
  832. ],
  833. "attrs": [
  834. {
  835. "variable": "acl_enable",
  836. "label": "Enable ACL",
  837. "description": "Enable ACL for the storage.",
  838. "schema": {
  839. "type": "boolean",
  840. "default": false
  841. }
  842. },
  843. {
  844. "variable": "dataset_name",
  845. "label": "Dataset Name",
  846. "description": "The name of the dataset to use for storage.",
  847. "schema": {
  848. "type": "string",
  849. "required": true,
  850. "hidden": true,
  851. "default": "certs"
  852. }
  853. },
  854. {
  855. "variable": "acl_entries",
  856. "label": "ACL Configuration",
  857. "schema": {
  858. "type": "dict",
  859. "show_if": [
  860. [
  861. "acl_enable",
  862. "=",
  863. true
  864. ]
  865. ],
  866. "attrs": []
  867. }
  868. }
  869. ]
  870. }
  871. },
  872. {
  873. "variable": "host_path_config",
  874. "label": "Host Path Configuration",
  875. "schema": {
  876. "type": "dict",
  877. "show_if": [
  878. [
  879. "type",
  880. "=",
  881. "host_path"
  882. ]
  883. ],
  884. "attrs": [
  885. {
  886. "variable": "acl_enable",
  887. "label": "Enable ACL",
  888. "description": "Enable ACL for the storage.",
  889. "schema": {
  890. "type": "boolean",
  891. "default": false
  892. }
  893. },
  894. {
  895. "variable": "acl",
  896. "label": "ACL Configuration",
  897. "schema": {
  898. "type": "dict",
  899. "show_if": [
  900. [
  901. "acl_enable",
  902. "=",
  903. true
  904. ]
  905. ],
  906. "attrs": [],
  907. "$ref": [
  908. "normalize/acl"
  909. ]
  910. }
  911. },
  912. {
  913. "variable": "path",
  914. "label": "Host Path",
  915. "description": "The host path to use for storage.",
  916. "schema": {
  917. "type": "hostpath",
  918. "show_if": [
  919. [
  920. "acl_enable",
  921. "=",
  922. false
  923. ]
  924. ],
  925. "required": true
  926. }
  927. }
  928. ]
  929. }
  930. }
  931. ]
  932. }
  933. },
  934. {
  935. "variable": "postgres_data",
  936. "label": "Postgres Data Storage",
  937. "description": "The path to store Postgres Data.",
  938. "schema": {
  939. "type": "dict",
  940. "attrs": [
  941. {
  942. "variable": "type",
  943. "label": "Type",
  944. "description": "ixVolume: Is dataset created automatically by the system.</br>\nHost Path: Is a path that already exists on the system.\n",
  945. "schema": {
  946. "type": "string",
  947. "required": true,
  948. "default": "ix_volume",
  949. "enum": [
  950. {
  951. "value": "host_path",
  952. "description": "Host Path (Path that already exists on the system)"
  953. },
  954. {
  955. "value": "ix_volume",
  956. "description": "ixVolume (Dataset created automatically by the system)"
  957. }
  958. ]
  959. }
  960. },
  961. {
  962. "variable": "ix_volume_config",
  963. "label": "ixVolume Configuration",
  964. "description": "The configuration for the ixVolume dataset.",
  965. "schema": {
  966. "type": "dict",
  967. "show_if": [
  968. [
  969. "type",
  970. "=",
  971. "ix_volume"
  972. ]
  973. ],
  974. "$ref": [
  975. "normalize/ix_volume"
  976. ],
  977. "attrs": [
  978. {
  979. "variable": "acl_enable",
  980. "label": "Enable ACL",
  981. "description": "Enable ACL for the storage.",
  982. "schema": {
  983. "type": "boolean",
  984. "default": false
  985. }
  986. },
  987. {
  988. "variable": "dataset_name",
  989. "label": "Dataset Name",
  990. "description": "The name of the dataset to use for storage.",
  991. "schema": {
  992. "type": "string",
  993. "required": true,
  994. "hidden": true,
  995. "default": "pg_data"
  996. }
  997. },
  998. {
  999. "variable": "acl_entries",
  1000. "label": "ACL Configuration",
  1001. "schema": {
  1002. "type": "dict",
  1003. "show_if": [
  1004. [
  1005. "acl_enable",
  1006. "=",
  1007. true
  1008. ]
  1009. ],
  1010. "attrs": []
  1011. }
  1012. }
  1013. ]
  1014. }
  1015. },
  1016. {
  1017. "variable": "host_path_config",
  1018. "label": "Host Path Configuration",
  1019. "schema": {
  1020. "type": "dict",
  1021. "show_if": [
  1022. [
  1023. "type",
  1024. "=",
  1025. "host_path"
  1026. ]
  1027. ],
  1028. "attrs": [
  1029. {
  1030. "variable": "acl_enable",
  1031. "label": "Enable ACL",
  1032. "description": "Enable ACL for the storage.",
  1033. "schema": {
  1034. "type": "boolean",
  1035. "default": false
  1036. }
  1037. },
  1038. {
  1039. "variable": "acl",
  1040. "label": "ACL Configuration",
  1041. "schema": {
  1042. "type": "dict",
  1043. "show_if": [
  1044. [
  1045. "acl_enable",
  1046. "=",
  1047. true
  1048. ]
  1049. ],
  1050. "attrs": [],
  1051. "$ref": [
  1052. "normalize/acl"
  1053. ]
  1054. }
  1055. },
  1056. {
  1057. "variable": "path",
  1058. "label": "Host Path",
  1059. "description": "The host path to use for storage.",
  1060. "schema": {
  1061. "type": "hostpath",
  1062. "show_if": [
  1063. [
  1064. "acl_enable",
  1065. "=",
  1066. false
  1067. ]
  1068. ],
  1069. "required": true
  1070. }
  1071. },
  1072. {
  1073. "variable": "auto_permissions",
  1074. "label": "Automatic Permissions",
  1075. "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",
  1076. "schema": {
  1077. "type": "boolean",
  1078. "default": false,
  1079. "show_if": [
  1080. [
  1081. "acl_enable",
  1082. "=",
  1083. false
  1084. ]
  1085. ]
  1086. }
  1087. }
  1088. ]
  1089. }
  1090. }
  1091. ]
  1092. }
  1093. },
  1094. {
  1095. "variable": "additional_storage",
  1096. "label": "Additional Storage",
  1097. "schema": {
  1098. "type": "list",
  1099. "default": [],
  1100. "items": [
  1101. {
  1102. "variable": "storageEntry",
  1103. "label": "Storage Entry",
  1104. "schema": {
  1105. "type": "dict",
  1106. "attrs": [
  1107. {
  1108. "variable": "type",
  1109. "label": "Type",
  1110. "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",
  1111. "schema": {
  1112. "type": "string",
  1113. "required": true,
  1114. "default": "ix_volume",
  1115. "enum": [
  1116. {
  1117. "value": "host_path",
  1118. "description": "Host Path (Path that already exists on the system)"
  1119. },
  1120. {
  1121. "value": "ix_volume",
  1122. "description": "ixVolume (Dataset created automatically by the system)"
  1123. },
  1124. {
  1125. "value": "cifs",
  1126. "description": "SMB/CIFS Share (Mounts a volume to a SMB share)"
  1127. }
  1128. ]
  1129. }
  1130. },
  1131. {
  1132. "variable": "read_only",
  1133. "label": "Read Only",
  1134. "description": "Mount the volume as read only.",
  1135. "schema": {
  1136. "type": "boolean",
  1137. "default": false
  1138. }
  1139. },
  1140. {
  1141. "variable": "mount_path",
  1142. "label": "Mount Path",
  1143. "description": "The path inside the container to mount the storage.",
  1144. "schema": {
  1145. "type": "path",
  1146. "required": true
  1147. }
  1148. },
  1149. {
  1150. "variable": "host_path_config",
  1151. "label": "Host Path Configuration",
  1152. "schema": {
  1153. "type": "dict",
  1154. "show_if": [
  1155. [
  1156. "type",
  1157. "=",
  1158. "host_path"
  1159. ]
  1160. ],
  1161. "attrs": [
  1162. {
  1163. "variable": "acl_enable",
  1164. "label": "Enable ACL",
  1165. "description": "Enable ACL for the storage.",
  1166. "schema": {
  1167. "type": "boolean",
  1168. "default": false
  1169. }
  1170. },
  1171. {
  1172. "variable": "acl",
  1173. "label": "ACL Configuration",
  1174. "schema": {
  1175. "type": "dict",
  1176. "show_if": [
  1177. [
  1178. "acl_enable",
  1179. "=",
  1180. true
  1181. ]
  1182. ],
  1183. "attrs": [],
  1184. "$ref": [
  1185. "normalize/acl"
  1186. ]
  1187. }
  1188. },
  1189. {
  1190. "variable": "path",
  1191. "label": "Host Path",
  1192. "description": "The host path to use for storage.",
  1193. "schema": {
  1194. "type": "hostpath",
  1195. "show_if": [
  1196. [
  1197. "acl_enable",
  1198. "=",
  1199. false
  1200. ]
  1201. ],
  1202. "required": true
  1203. }
  1204. }
  1205. ]
  1206. }
  1207. },
  1208. {
  1209. "variable": "ix_volume_config",
  1210. "label": "ixVolume Configuration",
  1211. "description": "The configuration for the ixVolume dataset.",
  1212. "schema": {
  1213. "type": "dict",
  1214. "show_if": [
  1215. [
  1216. "type",
  1217. "=",
  1218. "ix_volume"
  1219. ]
  1220. ],
  1221. "$ref": [
  1222. "normalize/ix_volume"
  1223. ],
  1224. "attrs": [
  1225. {
  1226. "variable": "acl_enable",
  1227. "label": "Enable ACL",
  1228. "description": "Enable ACL for the storage.",
  1229. "schema": {
  1230. "type": "boolean",
  1231. "default": false
  1232. }
  1233. },
  1234. {
  1235. "variable": "dataset_name",
  1236. "label": "Dataset Name",
  1237. "description": "The name of the dataset to use for storage.",
  1238. "schema": {
  1239. "type": "string",
  1240. "required": true,
  1241. "default": "storage_entry"
  1242. }
  1243. },
  1244. {
  1245. "variable": "acl_entries",
  1246. "label": "ACL Configuration",
  1247. "schema": {
  1248. "type": "dict",
  1249. "show_if": [
  1250. [
  1251. "acl_enable",
  1252. "=",
  1253. true
  1254. ]
  1255. ],
  1256. "attrs": [],
  1257. "$ref": [
  1258. "normalize/acl"
  1259. ]
  1260. }
  1261. }
  1262. ]
  1263. }
  1264. },
  1265. {
  1266. "variable": "cifs_config",
  1267. "label": "SMB Configuration",
  1268. "description": "The configuration for the SMB dataset.",
  1269. "schema": {
  1270. "type": "dict",
  1271. "show_if": [
  1272. [
  1273. "type",
  1274. "=",
  1275. "cifs"
  1276. ]
  1277. ],
  1278. "attrs": [
  1279. {
  1280. "variable": "server",
  1281. "label": "Server",
  1282. "description": "The server to mount the SMB share.",
  1283. "schema": {
  1284. "type": "string",
  1285. "required": true
  1286. }
  1287. },
  1288. {
  1289. "variable": "path",
  1290. "label": "Path",
  1291. "description": "The path to mount the SMB share.",
  1292. "schema": {
  1293. "type": "string",
  1294. "required": true
  1295. }
  1296. },
  1297. {
  1298. "variable": "username",
  1299. "label": "Username",
  1300. "description": "The username to use for the SMB share.",
  1301. "schema": {
  1302. "type": "string",
  1303. "required": true
  1304. }
  1305. },
  1306. {
  1307. "variable": "password",
  1308. "label": "Password",
  1309. "description": "The password to use for the SMB share.",
  1310. "schema": {
  1311. "type": "string",
  1312. "required": true,
  1313. "private": true
  1314. }
  1315. },
  1316. {
  1317. "variable": "domain",
  1318. "label": "Domain",
  1319. "description": "The domain to use for the SMB share.",
  1320. "schema": {
  1321. "type": "string"
  1322. }
  1323. }
  1324. ]
  1325. }
  1326. }
  1327. ]
  1328. }
  1329. }
  1330. ]
  1331. }
  1332. }
  1333. ]
  1334. }
  1335. },
  1336. {
  1337. "variable": "labels",
  1338. "label": "",
  1339. "group": "Labels Configuration",
  1340. "schema": {
  1341. "type": "list",
  1342. "default": [],
  1343. "items": [
  1344. {
  1345. "variable": "label",
  1346. "label": "Label",
  1347. "schema": {
  1348. "type": "dict",
  1349. "attrs": [
  1350. {
  1351. "variable": "key",
  1352. "label": "Key",
  1353. "schema": {
  1354. "type": "string",
  1355. "required": true
  1356. }
  1357. },
  1358. {
  1359. "variable": "value",
  1360. "label": "Value",
  1361. "schema": {
  1362. "type": "string",
  1363. "required": true
  1364. }
  1365. },
  1366. {
  1367. "variable": "containers",
  1368. "label": "Containers",
  1369. "description": "Containers where the label should be applied",
  1370. "schema": {
  1371. "type": "list",
  1372. "items": [
  1373. {
  1374. "variable": "container",
  1375. "label": "Container",
  1376. "schema": {
  1377. "type": "string",
  1378. "required": true,
  1379. "enum": [
  1380. {
  1381. "value": "authentik-server",
  1382. "description": "authentik-server"
  1383. },
  1384. {
  1385. "value": "authentik-worker",
  1386. "description": "authentik-worker"
  1387. },
  1388. {
  1389. "value": "postgres",
  1390. "description": "postgres"
  1391. },
  1392. {
  1393. "value": "redis",
  1394. "description": "redis"
  1395. }
  1396. ]
  1397. }
  1398. }
  1399. ]
  1400. }
  1401. }
  1402. ]
  1403. }
  1404. }
  1405. ]
  1406. }
  1407. },
  1408. {
  1409. "variable": "resources",
  1410. "label": "",
  1411. "group": "Resources Configuration",
  1412. "schema": {
  1413. "type": "dict",
  1414. "attrs": [
  1415. {
  1416. "variable": "limits",
  1417. "label": "Limits",
  1418. "schema": {
  1419. "type": "dict",
  1420. "attrs": [
  1421. {
  1422. "variable": "cpus",
  1423. "label": "CPUs",
  1424. "description": "CPUs limit for Authentik.",
  1425. "schema": {
  1426. "type": "int",
  1427. "default": 2,
  1428. "required": true
  1429. }
  1430. },
  1431. {
  1432. "variable": "memory",
  1433. "label": "Memory (in MB)",
  1434. "description": "Memory limit for Authentik.",
  1435. "schema": {
  1436. "type": "int",
  1437. "default": 4096,
  1438. "required": true
  1439. }
  1440. }
  1441. ]
  1442. }
  1443. }
  1444. ]
  1445. }
  1446. }
  1447. ]
  1448. },
  1449. "readme": "<h1>Authentik</h1> <p><a href=\"https://goauthentik.io/\">Authentik</a> is an open-source Identity Provider that emphasizes flexibility and versatility, with support for a wide set of protocols.</p>",
  1450. "changelog": null,
  1451. "chart_metadata": {
  1452. "app_version": "2025.8.1",
  1453. "capabilities": [],
  1454. "categories": [
  1455. "authentication"
  1456. ],
  1457. "changelog_url": "https://docs.goauthentik.io/docs/releases/",
  1458. "date_added": "2025-03-25",
  1459. "description": "The authentication glue you need.",
  1460. "home": "https://goauthentik.io/",
  1461. "host_mounts": [
  1462. {
  1463. "description": "Docker socket",
  1464. "host_path": "/var/run/docker.sock"
  1465. }
  1466. ],
  1467. "icon": "https://media.sys.truenas.net/apps/authentik/icons/icon.svg",
  1468. "keywords": [
  1469. "authentik",
  1470. "auth"
  1471. ],
  1472. "lib_version": "2.1.49",
  1473. "lib_version_hash": "e71e6b0122c9446fa5ea6fb07e7eb01b11fb42d549a19845426bbd7e21a42634",
  1474. "maintainers": [
  1475. {
  1476. "email": "dev@ixsystems.com",
  1477. "name": "truenas",
  1478. "url": "https://www.truenas.com/"
  1479. }
  1480. ],
  1481. "name": "authentik",
  1482. "run_as_context": [
  1483. {
  1484. "description": "Authentik runs as any non-root user.",
  1485. "gid": 568,
  1486. "group_name": "authentik",
  1487. "uid": 568,
  1488. "user_name": "authentik"
  1489. },
  1490. {
  1491. "description": "Postgres runs as non-root user.",
  1492. "gid": 999,
  1493. "group_name": "postgres",
  1494. "uid": 999,
  1495. "user_name": "postgres"
  1496. },
  1497. {
  1498. "description": "Redis runs as any non-root user.",
  1499. "gid": 568,
  1500. "group_name": "redis",
  1501. "uid": 568,
  1502. "user_name": "redis"
  1503. }
  1504. ],
  1505. "screenshots": [
  1506. "https://media.sys.truenas.net/apps/authentik/screenshots/screenshot1.png",
  1507. "https://media.sys.truenas.net/apps/authentik/screenshots/screenshot2.png",
  1508. "https://media.sys.truenas.net/apps/authentik/screenshots/screenshot3.png",
  1509. "https://media.sys.truenas.net/apps/authentik/screenshots/screenshot4.png"
  1510. ],
  1511. "sources": [
  1512. "https://goauthentik.io/",
  1513. "https://github.com/goauthentik/authentik"
  1514. ],
  1515. "title": "Authentik",
  1516. "train": "community",
  1517. "version": "1.0.35"
  1518. }
  1519. }
  1520. }