app_versions.json 139 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478147914801481148214831484148514861487148814891490149114921493149414951496149714981499150015011502150315041505150615071508150915101511151215131514151515161517151815191520152115221523152415251526152715281529153015311532153315341535153615371538153915401541154215431544154515461547154815491550155115521553155415551556155715581559156015611562156315641565156615671568156915701571157215731574157515761577157815791580158115821583158415851586158715881589159015911592159315941595159615971598159916001601160216031604160516061607160816091610161116121613161416151616161716181619162016211622162316241625162616271628162916301631163216331634163516361637163816391640164116421643164416451646164716481649165016511652165316541655165616571658165916601661166216631664166516661667166816691670167116721673167416751676167716781679168016811682168316841685168616871688168916901691169216931694169516961697169816991700170117021703170417051706170717081709171017111712171317141715171617171718171917201721172217231724172517261727172817291730173117321733173417351736173717381739174017411742174317441745174617471748174917501751175217531754175517561757175817591760176117621763176417651766176717681769177017711772177317741775177617771778
  1. {
  2. "1.1.1": {
  3. "healthy": true,
  4. "supported": false,
  5. "healthy_error": null,
  6. "location": "/__w/charts/charts/community/vaultwarden/1.1.1",
  7. "last_update": "2023-12-01 12:58:12",
  8. "required_features": [
  9. "definitions/certificate",
  10. "normalize/acl",
  11. "definitions/timezone",
  12. "normalize/ixVolume"
  13. ],
  14. "human_version": "1.30.1_1.1.1",
  15. "version": "1.1.1",
  16. "chart_metadata": {
  17. "name": "vaultwarden",
  18. "description": "Alternative implementation of the Bitwarden server API written in Rust and compatible with upstream Bitwarden clients.",
  19. "annotations": {
  20. "title": "Vaultwarden"
  21. },
  22. "type": "application",
  23. "version": "1.1.1",
  24. "apiVersion": "v2",
  25. "appVersion": "1.30.1",
  26. "kubeVersion": ">=1.16.0-0",
  27. "maintainers": [
  28. {
  29. "name": "truenas",
  30. "url": "https://www.truenas.com/",
  31. "email": "dev@ixsystems.com"
  32. }
  33. ],
  34. "dependencies": [
  35. {
  36. "name": "common",
  37. "repository": "file://../../../common",
  38. "version": "1.2.3"
  39. }
  40. ],
  41. "home": "https://github.com/dani-garcia/vaultwarden",
  42. "icon": "https://media.sys.truenas.net/apps/vaultwarden/icons/icon.png",
  43. "sources": [
  44. "https://github.com/dani-garcia/vaultwarden",
  45. "https://github.com/truenas/charts/tree/master/community/vaultwarden"
  46. ],
  47. "keywords": [
  48. "password",
  49. "manager"
  50. ]
  51. },
  52. "app_metadata": {
  53. "runAsContext": [
  54. {
  55. "userName": "vaultwarden",
  56. "groupName": "vaultwarden",
  57. "gid": 568,
  58. "uid": 568,
  59. "description": "Vaultwarden can run as any non-root user."
  60. },
  61. {
  62. "userName": "postgres",
  63. "groupName": "postgres",
  64. "gid": 999,
  65. "uid": 999,
  66. "description": "Postgres runs as a non-root user."
  67. }
  68. ],
  69. "capabilities": [],
  70. "hostMounts": []
  71. },
  72. "schema": {
  73. "groups": [
  74. {
  75. "name": "Vaultwarden Configuration",
  76. "description": "Configure Vaultwarden"
  77. },
  78. {
  79. "name": "User and Group Configuration",
  80. "description": "Configure User and Group for Vaultwarden"
  81. },
  82. {
  83. "name": "Network Configuration",
  84. "description": "Configure Network for Vaultwarden"
  85. },
  86. {
  87. "name": "Storage Configuration",
  88. "description": "Configure Storage for Vaultwarden"
  89. },
  90. {
  91. "name": "Resources Configuration",
  92. "description": "Configure Resources for Vaultwarden"
  93. }
  94. ],
  95. "portals": {
  96. "web_portal": {
  97. "protocols": [
  98. "$kubernetes-resource_configmap_portal_protocol"
  99. ],
  100. "host": [
  101. "$kubernetes-resource_configmap_portal_host"
  102. ],
  103. "ports": [
  104. "$kubernetes-resource_configmap_portal_port"
  105. ],
  106. "path": "$kubernetes-resource_configmap_portal_path"
  107. },
  108. "admin_portal": {
  109. "protocols": [
  110. "$kubernetes-resource_configmap_portal_protocol"
  111. ],
  112. "host": [
  113. "$kubernetes-resource_configmap_portal_host"
  114. ],
  115. "ports": [
  116. "$kubernetes-resource_configmap_portal_port"
  117. ],
  118. "path": "$kubernetes-resource_configmap_portal_admin_path"
  119. }
  120. },
  121. "questions": [
  122. {
  123. "variable": "TZ",
  124. "group": "Vaultwarden Configuration",
  125. "label": "Timezone",
  126. "schema": {
  127. "type": "string",
  128. "default": "America/Los_Angeles",
  129. "required": true,
  130. "$ref": [
  131. "definitions/timezone"
  132. ],
  133. "enum": [
  134. {
  135. "value": "Asia/Damascus",
  136. "description": "'Asia/Damascus' timezone"
  137. },
  138. {
  139. "value": "Asia/Saigon",
  140. "description": "'Asia/Saigon' timezone"
  141. }
  142. ]
  143. }
  144. },
  145. {
  146. "variable": "vaultwardenConfig",
  147. "label": "",
  148. "group": "Vaultwarden Configuration",
  149. "schema": {
  150. "type": "dict",
  151. "attrs": [
  152. {
  153. "variable": "adminToken",
  154. "label": "Admin Token",
  155. "description": "Setting this, will enable the admin portal",
  156. "schema": {
  157. "type": "string",
  158. "private": true,
  159. "default": ""
  160. }
  161. },
  162. {
  163. "variable": "additionalEnvs",
  164. "label": "Additional Environment Variables",
  165. "description": "Configure additional environment variables for Vaultwarden.",
  166. "schema": {
  167. "type": "list",
  168. "default": [],
  169. "items": [
  170. {
  171. "variable": "env",
  172. "label": "Environment Variable",
  173. "schema": {
  174. "type": "dict",
  175. "attrs": [
  176. {
  177. "variable": "name",
  178. "label": "Name",
  179. "schema": {
  180. "type": "string",
  181. "required": true
  182. }
  183. },
  184. {
  185. "variable": "value",
  186. "label": "Value",
  187. "schema": {
  188. "type": "string",
  189. "required": true
  190. }
  191. }
  192. ]
  193. }
  194. }
  195. ]
  196. }
  197. }
  198. ]
  199. }
  200. },
  201. {
  202. "variable": "vaultwardenRunAs",
  203. "label": "",
  204. "group": "User and Group Configuration",
  205. "schema": {
  206. "type": "dict",
  207. "attrs": [
  208. {
  209. "variable": "user",
  210. "label": "User ID",
  211. "description": "The user id that Vaultwarden will run as.",
  212. "schema": {
  213. "type": "int",
  214. "min": 568,
  215. "default": 568,
  216. "required": true
  217. }
  218. },
  219. {
  220. "variable": "group",
  221. "label": "Group ID",
  222. "description": "The group id that Vaultwarden will run as.",
  223. "schema": {
  224. "type": "int",
  225. "min": 568,
  226. "default": 568,
  227. "required": true
  228. }
  229. }
  230. ]
  231. }
  232. },
  233. {
  234. "variable": "vaultwardenNetwork",
  235. "label": "",
  236. "group": "Network Configuration",
  237. "schema": {
  238. "type": "dict",
  239. "attrs": [
  240. {
  241. "variable": "webPort",
  242. "label": "Web Port",
  243. "description": "The port for the Vaultwarden Web UI.",
  244. "schema": {
  245. "type": "int",
  246. "default": 30032,
  247. "min": 9000,
  248. "max": 65535,
  249. "required": true
  250. }
  251. },
  252. {
  253. "variable": "wsEnabled",
  254. "label": "Enable Websocket",
  255. "schema": {
  256. "type": "boolean",
  257. "default": true
  258. }
  259. },
  260. {
  261. "variable": "wsPort",
  262. "label": "Websocket Port",
  263. "description": "The port for the Vaultwarden Websocket.",
  264. "schema": {
  265. "type": "int",
  266. "show_if": [
  267. [
  268. "wsEnabled",
  269. "=",
  270. true
  271. ]
  272. ],
  273. "default": 30033,
  274. "min": 9000,
  275. "max": 65535,
  276. "required": true
  277. }
  278. },
  279. {
  280. "variable": "hostNetwork",
  281. "label": "Host Network",
  282. "description": "Bind to the host network. It's recommended to keep this disabled.</br>\n",
  283. "schema": {
  284. "type": "boolean",
  285. "default": false
  286. }
  287. },
  288. {
  289. "variable": "domain",
  290. "label": "Domain",
  291. "description": "The domain to use for Vaultwarden </br>\nFormat is: https://sub.domain.tld:port\n",
  292. "schema": {
  293. "type": "string",
  294. "default": ""
  295. }
  296. },
  297. {
  298. "variable": "certificateID",
  299. "label": "Certificate",
  300. "description": "The certificate to use for Vaultwarden </br>\nUsing the Rocket method for TLS setup is NOT recommended </br>\nPrefer a reverse proxy with a valid certificate </br>\n",
  301. "schema": {
  302. "type": "int",
  303. "null": true,
  304. "$ref": [
  305. "definitions/certificate"
  306. ],
  307. "enum": [
  308. {
  309. "value": null,
  310. "description": "No Certificate"
  311. }
  312. ],
  313. "default": null
  314. }
  315. }
  316. ]
  317. }
  318. },
  319. {
  320. "variable": "vaultwardenStorage",
  321. "label": "",
  322. "group": "Storage Configuration",
  323. "schema": {
  324. "type": "dict",
  325. "attrs": [
  326. {
  327. "variable": "data",
  328. "label": "Vaultwarden Data Storage",
  329. "description": "The path to store Vaultwarden attachments, icons, etc.",
  330. "schema": {
  331. "type": "dict",
  332. "attrs": [
  333. {
  334. "variable": "type",
  335. "label": "Type",
  336. "description": "ixVolume: Is dataset created automatically by the system.</br>\nHost Path: Is a path that already exists on the system.\n",
  337. "schema": {
  338. "type": "string",
  339. "required": true,
  340. "immutable": true,
  341. "default": "ixVolume",
  342. "enum": [
  343. {
  344. "value": "hostPath",
  345. "description": "Host Path (Path that already exists on the system)"
  346. },
  347. {
  348. "value": "ixVolume",
  349. "description": "ixVolume (Dataset created automatically by the system)"
  350. }
  351. ]
  352. }
  353. },
  354. {
  355. "variable": "ixVolumeConfig",
  356. "label": "ixVolume Configuration",
  357. "description": "The configuration for the ixVolume dataset.",
  358. "schema": {
  359. "type": "dict",
  360. "show_if": [
  361. [
  362. "type",
  363. "=",
  364. "ixVolume"
  365. ]
  366. ],
  367. "$ref": [
  368. "normalize/ixVolume"
  369. ],
  370. "attrs": [
  371. {
  372. "variable": "aclEnable",
  373. "label": "Enable ACL",
  374. "description": "Enable ACL for the dataset.",
  375. "schema": {
  376. "type": "boolean",
  377. "default": false
  378. }
  379. },
  380. {
  381. "variable": "datasetName",
  382. "label": "Dataset Name",
  383. "description": "The name of the dataset to use for storage.",
  384. "schema": {
  385. "type": "string",
  386. "required": true,
  387. "immutable": true,
  388. "hidden": true,
  389. "default": "data"
  390. }
  391. },
  392. {
  393. "variable": "aclEntries",
  394. "label": "ACL Configuration",
  395. "schema": {
  396. "type": "dict",
  397. "show_if": [
  398. [
  399. "aclEnable",
  400. "=",
  401. true
  402. ]
  403. ],
  404. "attrs": [
  405. {
  406. "variable": "path",
  407. "label": "Path",
  408. "description": "Path to perform ACL",
  409. "schema": {
  410. "type": "string",
  411. "hidden": true
  412. }
  413. },
  414. {
  415. "variable": "entries",
  416. "label": "ACL Entries",
  417. "description": "ACL Entries",
  418. "schema": {
  419. "type": "list",
  420. "items": [
  421. {
  422. "variable": "aclEntry",
  423. "label": "ACL Entry",
  424. "schema": {
  425. "type": "dict",
  426. "attrs": [
  427. {
  428. "variable": "id_type",
  429. "label": "ID Type",
  430. "schema": {
  431. "type": "string",
  432. "enum": [
  433. {
  434. "value": "USER",
  435. "description": "Entry is for a USER"
  436. },
  437. {
  438. "value": "GROUP",
  439. "description": "Entry is for a GROUP"
  440. }
  441. ],
  442. "default": "USER"
  443. }
  444. },
  445. {
  446. "variable": "id",
  447. "label": "ID",
  448. "description": "Make sure to check the ID value is correct and aligns with RunAs user context of the application",
  449. "schema": {
  450. "type": "int",
  451. "required": true,
  452. "min": 0
  453. }
  454. },
  455. {
  456. "variable": "access",
  457. "label": "Access",
  458. "schema": {
  459. "type": "string",
  460. "enum": [
  461. {
  462. "value": "READ",
  463. "description": "Read Access"
  464. },
  465. {
  466. "value": "MODIFY",
  467. "description": "Modify Access"
  468. },
  469. {
  470. "value": "FULL_CONTROL",
  471. "description": "FULL_CONTROL Access"
  472. }
  473. ]
  474. }
  475. }
  476. ]
  477. }
  478. }
  479. ]
  480. }
  481. }
  482. ]
  483. }
  484. }
  485. ]
  486. }
  487. },
  488. {
  489. "variable": "hostPathConfig",
  490. "label": "Host Path Configuration",
  491. "schema": {
  492. "type": "dict",
  493. "show_if": [
  494. [
  495. "type",
  496. "=",
  497. "hostPath"
  498. ]
  499. ],
  500. "attrs": [
  501. {
  502. "variable": "aclEnable",
  503. "label": "Enable ACL",
  504. "description": "Enable ACL for the dataset.",
  505. "schema": {
  506. "type": "boolean",
  507. "default": false
  508. }
  509. },
  510. {
  511. "variable": "acl",
  512. "label": "ACL Configuration",
  513. "schema": {
  514. "type": "dict",
  515. "show_if": [
  516. [
  517. "aclEnable",
  518. "=",
  519. true
  520. ]
  521. ],
  522. "attrs": [
  523. {
  524. "variable": "path",
  525. "label": "Host Path",
  526. "description": "Host Path to perform ACL",
  527. "schema": {
  528. "type": "hostpath",
  529. "required": true,
  530. "empty": false
  531. }
  532. },
  533. {
  534. "variable": "entries",
  535. "label": "ACL Entries",
  536. "description": "ACL Entries",
  537. "schema": {
  538. "type": "list",
  539. "items": [
  540. {
  541. "variable": "aclEntry",
  542. "label": "ACL Entry",
  543. "schema": {
  544. "type": "dict",
  545. "attrs": [
  546. {
  547. "variable": "id_type",
  548. "label": "ID Type",
  549. "schema": {
  550. "type": "string",
  551. "enum": [
  552. {
  553. "value": "USER",
  554. "description": "Entry is for a USER"
  555. },
  556. {
  557. "value": "GROUP",
  558. "description": "Entry is for a GROUP"
  559. }
  560. ],
  561. "default": "USER"
  562. }
  563. },
  564. {
  565. "variable": "id",
  566. "label": "ID",
  567. "description": "Make sure to check the ID value is correct and aligns with RunAs user context of the application",
  568. "schema": {
  569. "type": "int",
  570. "required": true,
  571. "min": 0
  572. }
  573. },
  574. {
  575. "variable": "access",
  576. "label": "Access",
  577. "schema": {
  578. "type": "string",
  579. "enum": [
  580. {
  581. "value": "READ",
  582. "description": "Read Access"
  583. },
  584. {
  585. "value": "MODIFY",
  586. "description": "Modify Access"
  587. },
  588. {
  589. "value": "FULL_CONTROL",
  590. "description": "FULL_CONTROL Access"
  591. }
  592. ]
  593. }
  594. }
  595. ]
  596. }
  597. }
  598. ]
  599. }
  600. },
  601. {
  602. "variable": "options",
  603. "label": "ACL Options",
  604. "schema": {
  605. "type": "dict",
  606. "attrs": [
  607. {
  608. "variable": "force",
  609. "label": "Force Flag",
  610. "description": "Enabling `Force` applies ACL even if the path has existing data",
  611. "schema": {
  612. "type": "boolean",
  613. "default": false
  614. }
  615. }
  616. ]
  617. }
  618. }
  619. ],
  620. "$ref": [
  621. "normalize/acl"
  622. ]
  623. }
  624. },
  625. {
  626. "variable": "hostPath",
  627. "label": "Host Path",
  628. "description": "The host path to use for storage.",
  629. "schema": {
  630. "type": "hostpath",
  631. "show_if": [
  632. [
  633. "aclEnable",
  634. "=",
  635. false
  636. ]
  637. ],
  638. "immutable": true,
  639. "required": true
  640. }
  641. }
  642. ]
  643. }
  644. }
  645. ]
  646. }
  647. },
  648. {
  649. "variable": "pgData",
  650. "label": "Vaultwarden Postgres Data Storage",
  651. "description": "The path to store Vaultwarden Postgres Data.",
  652. "schema": {
  653. "type": "dict",
  654. "attrs": [
  655. {
  656. "variable": "type",
  657. "label": "Type",
  658. "description": "ixVolume: Is dataset created automatically by the system.</br>\nHost Path: Is a path that already exists on the system.\n",
  659. "schema": {
  660. "type": "string",
  661. "required": true,
  662. "immutable": true,
  663. "default": "ixVolume",
  664. "enum": [
  665. {
  666. "value": "hostPath",
  667. "description": "Host Path (Path that already exists on the system)"
  668. },
  669. {
  670. "value": "ixVolume",
  671. "description": "ixVolume (Dataset created automatically by the system)"
  672. }
  673. ]
  674. }
  675. },
  676. {
  677. "variable": "ixVolumeConfig",
  678. "label": "ixVolume Configuration",
  679. "description": "The configuration for the ixVolume dataset.",
  680. "schema": {
  681. "type": "dict",
  682. "hidden": true,
  683. "show_if": [
  684. [
  685. "type",
  686. "=",
  687. "ixVolume"
  688. ]
  689. ],
  690. "$ref": [
  691. "normalize/ixVolume"
  692. ],
  693. "attrs": [
  694. {
  695. "variable": "aclEnable",
  696. "label": "Enable ACL",
  697. "description": "Enable ACL for the dataset.",
  698. "schema": {
  699. "type": "boolean",
  700. "hidden": true,
  701. "default": false
  702. }
  703. },
  704. {
  705. "variable": "datasetName",
  706. "label": "Dataset Name",
  707. "description": "The name of the dataset to use for storage.",
  708. "schema": {
  709. "type": "string",
  710. "required": true,
  711. "immutable": true,
  712. "hidden": true,
  713. "default": "pgData"
  714. }
  715. },
  716. {
  717. "variable": "aclEntries",
  718. "label": "ACL Configuration",
  719. "schema": {
  720. "type": "dict",
  721. "show_if": [
  722. [
  723. "aclEnable",
  724. "=",
  725. true
  726. ]
  727. ],
  728. "attrs": [
  729. {
  730. "variable": "path",
  731. "label": "Path",
  732. "description": "Path to perform ACL",
  733. "schema": {
  734. "type": "string",
  735. "hidden": true
  736. }
  737. },
  738. {
  739. "variable": "entries",
  740. "label": "ACL Entries",
  741. "description": "ACL Entries",
  742. "schema": {
  743. "type": "list",
  744. "items": [
  745. {
  746. "variable": "aclEntry",
  747. "label": "ACL Entry",
  748. "schema": {
  749. "type": "dict",
  750. "attrs": [
  751. {
  752. "variable": "id_type",
  753. "label": "ID Type",
  754. "schema": {
  755. "type": "string",
  756. "enum": [
  757. {
  758. "value": "USER",
  759. "description": "Entry is for a USER"
  760. },
  761. {
  762. "value": "GROUP",
  763. "description": "Entry is for a GROUP"
  764. }
  765. ],
  766. "default": "USER"
  767. }
  768. },
  769. {
  770. "variable": "id",
  771. "label": "ID",
  772. "description": "Make sure to check the ID value is correct and aligns with RunAs user context of the application",
  773. "schema": {
  774. "type": "int",
  775. "required": true,
  776. "min": 0
  777. }
  778. },
  779. {
  780. "variable": "access",
  781. "label": "Access",
  782. "schema": {
  783. "type": "string",
  784. "enum": [
  785. {
  786. "value": "READ",
  787. "description": "Read Access"
  788. },
  789. {
  790. "value": "MODIFY",
  791. "description": "Modify Access"
  792. },
  793. {
  794. "value": "FULL_CONTROL",
  795. "description": "FULL_CONTROL Access"
  796. }
  797. ]
  798. }
  799. }
  800. ]
  801. }
  802. }
  803. ]
  804. }
  805. }
  806. ]
  807. }
  808. }
  809. ]
  810. }
  811. },
  812. {
  813. "variable": "hostPathConfig",
  814. "label": "Host Path Configuration",
  815. "schema": {
  816. "type": "dict",
  817. "show_if": [
  818. [
  819. "type",
  820. "=",
  821. "hostPath"
  822. ]
  823. ],
  824. "attrs": [
  825. {
  826. "variable": "aclEnable",
  827. "label": "Enable ACL",
  828. "description": "Enable ACL for the dataset.",
  829. "schema": {
  830. "type": "boolean",
  831. "hidden": true,
  832. "default": false
  833. }
  834. },
  835. {
  836. "variable": "acl",
  837. "label": "ACL Configuration",
  838. "schema": {
  839. "type": "dict",
  840. "show_if": [
  841. [
  842. "aclEnable",
  843. "=",
  844. true
  845. ]
  846. ],
  847. "attrs": [
  848. {
  849. "variable": "path",
  850. "label": "Host Path",
  851. "description": "Host Path to perform ACL",
  852. "schema": {
  853. "type": "hostpath",
  854. "required": true,
  855. "empty": false
  856. }
  857. },
  858. {
  859. "variable": "entries",
  860. "label": "ACL Entries",
  861. "description": "ACL Entries",
  862. "schema": {
  863. "type": "list",
  864. "items": [
  865. {
  866. "variable": "aclEntry",
  867. "label": "ACL Entry",
  868. "schema": {
  869. "type": "dict",
  870. "attrs": [
  871. {
  872. "variable": "id_type",
  873. "label": "ID Type",
  874. "schema": {
  875. "type": "string",
  876. "enum": [
  877. {
  878. "value": "USER",
  879. "description": "Entry is for a USER"
  880. },
  881. {
  882. "value": "GROUP",
  883. "description": "Entry is for a GROUP"
  884. }
  885. ],
  886. "default": "USER"
  887. }
  888. },
  889. {
  890. "variable": "id",
  891. "label": "ID",
  892. "description": "Make sure to check the ID value is correct and aligns with RunAs user context of the application",
  893. "schema": {
  894. "type": "int",
  895. "required": true,
  896. "min": 0
  897. }
  898. },
  899. {
  900. "variable": "access",
  901. "label": "Access",
  902. "schema": {
  903. "type": "string",
  904. "enum": [
  905. {
  906. "value": "READ",
  907. "description": "Read Access"
  908. },
  909. {
  910. "value": "MODIFY",
  911. "description": "Modify Access"
  912. },
  913. {
  914. "value": "FULL_CONTROL",
  915. "description": "FULL_CONTROL Access"
  916. }
  917. ]
  918. }
  919. }
  920. ]
  921. }
  922. }
  923. ]
  924. }
  925. },
  926. {
  927. "variable": "options",
  928. "label": "ACL Options",
  929. "schema": {
  930. "type": "dict",
  931. "attrs": [
  932. {
  933. "variable": "force",
  934. "label": "Force Flag",
  935. "description": "Enabling `Force` applies ACL even if the path has existing data",
  936. "schema": {
  937. "type": "boolean",
  938. "default": false
  939. }
  940. }
  941. ]
  942. }
  943. }
  944. ],
  945. "$ref": [
  946. "normalize/acl"
  947. ]
  948. }
  949. },
  950. {
  951. "variable": "hostPath",
  952. "label": "Host Path",
  953. "description": "The host path to use for storage.",
  954. "schema": {
  955. "type": "hostpath",
  956. "show_if": [
  957. [
  958. "aclEnable",
  959. "=",
  960. false
  961. ]
  962. ],
  963. "immutable": true,
  964. "required": true
  965. }
  966. }
  967. ]
  968. }
  969. }
  970. ]
  971. }
  972. },
  973. {
  974. "variable": "pgBackup",
  975. "label": "Vaultwarden Postgres Backup Storage",
  976. "description": "The path to store Vaultwarden Postgres Backup.",
  977. "schema": {
  978. "type": "dict",
  979. "attrs": [
  980. {
  981. "variable": "type",
  982. "label": "Type",
  983. "description": "ixVolume: Is dataset created automatically by the system.</br>\nHost Path: Is a path that already exists on the system.\n",
  984. "schema": {
  985. "type": "string",
  986. "required": true,
  987. "immutable": true,
  988. "default": "ixVolume",
  989. "enum": [
  990. {
  991. "value": "hostPath",
  992. "description": "Host Path (Path that already exists on the system)"
  993. },
  994. {
  995. "value": "ixVolume",
  996. "description": "ixVolume (Dataset created automatically by the system)"
  997. }
  998. ]
  999. }
  1000. },
  1001. {
  1002. "variable": "ixVolumeConfig",
  1003. "label": "ixVolume Configuration",
  1004. "description": "The configuration for the ixVolume dataset.",
  1005. "schema": {
  1006. "type": "dict",
  1007. "hidden": true,
  1008. "show_if": [
  1009. [
  1010. "type",
  1011. "=",
  1012. "ixVolume"
  1013. ]
  1014. ],
  1015. "$ref": [
  1016. "normalize/ixVolume"
  1017. ],
  1018. "attrs": [
  1019. {
  1020. "variable": "aclEnable",
  1021. "label": "Enable ACL",
  1022. "description": "Enable ACL for the dataset.",
  1023. "schema": {
  1024. "type": "boolean",
  1025. "hidden": true,
  1026. "default": false
  1027. }
  1028. },
  1029. {
  1030. "variable": "datasetName",
  1031. "label": "Dataset Name",
  1032. "description": "The name of the dataset to use for storage.",
  1033. "schema": {
  1034. "type": "string",
  1035. "required": true,
  1036. "immutable": true,
  1037. "hidden": true,
  1038. "default": "pgBackup"
  1039. }
  1040. },
  1041. {
  1042. "variable": "aclEntries",
  1043. "label": "ACL Configuration",
  1044. "schema": {
  1045. "type": "dict",
  1046. "show_if": [
  1047. [
  1048. "aclEnable",
  1049. "=",
  1050. true
  1051. ]
  1052. ],
  1053. "attrs": [
  1054. {
  1055. "variable": "path",
  1056. "label": "Path",
  1057. "description": "Path to perform ACL",
  1058. "schema": {
  1059. "type": "string",
  1060. "hidden": true
  1061. }
  1062. },
  1063. {
  1064. "variable": "entries",
  1065. "label": "ACL Entries",
  1066. "description": "ACL Entries",
  1067. "schema": {
  1068. "type": "list",
  1069. "items": [
  1070. {
  1071. "variable": "aclEntry",
  1072. "label": "ACL Entry",
  1073. "schema": {
  1074. "type": "dict",
  1075. "attrs": [
  1076. {
  1077. "variable": "id_type",
  1078. "label": "ID Type",
  1079. "schema": {
  1080. "type": "string",
  1081. "enum": [
  1082. {
  1083. "value": "USER",
  1084. "description": "Entry is for a USER"
  1085. },
  1086. {
  1087. "value": "GROUP",
  1088. "description": "Entry is for a GROUP"
  1089. }
  1090. ],
  1091. "default": "USER"
  1092. }
  1093. },
  1094. {
  1095. "variable": "id",
  1096. "label": "ID",
  1097. "description": "Make sure to check the ID value is correct and aligns with RunAs user context of the application",
  1098. "schema": {
  1099. "type": "int",
  1100. "required": true,
  1101. "min": 0
  1102. }
  1103. },
  1104. {
  1105. "variable": "access",
  1106. "label": "Access",
  1107. "schema": {
  1108. "type": "string",
  1109. "enum": [
  1110. {
  1111. "value": "READ",
  1112. "description": "Read Access"
  1113. },
  1114. {
  1115. "value": "MODIFY",
  1116. "description": "Modify Access"
  1117. },
  1118. {
  1119. "value": "FULL_CONTROL",
  1120. "description": "FULL_CONTROL Access"
  1121. }
  1122. ]
  1123. }
  1124. }
  1125. ]
  1126. }
  1127. }
  1128. ]
  1129. }
  1130. }
  1131. ]
  1132. }
  1133. }
  1134. ]
  1135. }
  1136. },
  1137. {
  1138. "variable": "hostPathConfig",
  1139. "label": "Host Path Configuration",
  1140. "schema": {
  1141. "type": "dict",
  1142. "show_if": [
  1143. [
  1144. "type",
  1145. "=",
  1146. "hostPath"
  1147. ]
  1148. ],
  1149. "attrs": [
  1150. {
  1151. "variable": "aclEnable",
  1152. "label": "Enable ACL",
  1153. "description": "Enable ACL for the dataset.",
  1154. "schema": {
  1155. "type": "boolean",
  1156. "hidden": true,
  1157. "default": false
  1158. }
  1159. },
  1160. {
  1161. "variable": "acl",
  1162. "label": "ACL Configuration",
  1163. "schema": {
  1164. "type": "dict",
  1165. "show_if": [
  1166. [
  1167. "aclEnable",
  1168. "=",
  1169. true
  1170. ]
  1171. ],
  1172. "attrs": [
  1173. {
  1174. "variable": "path",
  1175. "label": "Host Path",
  1176. "description": "Host Path to perform ACL",
  1177. "schema": {
  1178. "type": "hostpath",
  1179. "required": true,
  1180. "empty": false
  1181. }
  1182. },
  1183. {
  1184. "variable": "entries",
  1185. "label": "ACL Entries",
  1186. "description": "ACL Entries",
  1187. "schema": {
  1188. "type": "list",
  1189. "items": [
  1190. {
  1191. "variable": "aclEntry",
  1192. "label": "ACL Entry",
  1193. "schema": {
  1194. "type": "dict",
  1195. "attrs": [
  1196. {
  1197. "variable": "id_type",
  1198. "label": "ID Type",
  1199. "schema": {
  1200. "type": "string",
  1201. "enum": [
  1202. {
  1203. "value": "USER",
  1204. "description": "Entry is for a USER"
  1205. },
  1206. {
  1207. "value": "GROUP",
  1208. "description": "Entry is for a GROUP"
  1209. }
  1210. ],
  1211. "default": "USER"
  1212. }
  1213. },
  1214. {
  1215. "variable": "id",
  1216. "label": "ID",
  1217. "description": "Make sure to check the ID value is correct and aligns with RunAs user context of the application",
  1218. "schema": {
  1219. "type": "int",
  1220. "required": true,
  1221. "min": 0
  1222. }
  1223. },
  1224. {
  1225. "variable": "access",
  1226. "label": "Access",
  1227. "schema": {
  1228. "type": "string",
  1229. "enum": [
  1230. {
  1231. "value": "READ",
  1232. "description": "Read Access"
  1233. },
  1234. {
  1235. "value": "MODIFY",
  1236. "description": "Modify Access"
  1237. },
  1238. {
  1239. "value": "FULL_CONTROL",
  1240. "description": "FULL_CONTROL Access"
  1241. }
  1242. ]
  1243. }
  1244. }
  1245. ]
  1246. }
  1247. }
  1248. ]
  1249. }
  1250. },
  1251. {
  1252. "variable": "options",
  1253. "label": "ACL Options",
  1254. "schema": {
  1255. "type": "dict",
  1256. "attrs": [
  1257. {
  1258. "variable": "force",
  1259. "label": "Force Flag",
  1260. "description": "Enabling `Force` applies ACL even if the path has existing data",
  1261. "schema": {
  1262. "type": "boolean",
  1263. "default": false
  1264. }
  1265. }
  1266. ]
  1267. }
  1268. }
  1269. ],
  1270. "$ref": [
  1271. "normalize/acl"
  1272. ]
  1273. }
  1274. },
  1275. {
  1276. "variable": "hostPath",
  1277. "label": "Host Path",
  1278. "description": "The host path to use for storage.",
  1279. "schema": {
  1280. "type": "hostpath",
  1281. "show_if": [
  1282. [
  1283. "aclEnable",
  1284. "=",
  1285. false
  1286. ]
  1287. ],
  1288. "immutable": true,
  1289. "required": true
  1290. }
  1291. }
  1292. ]
  1293. }
  1294. }
  1295. ]
  1296. }
  1297. },
  1298. {
  1299. "variable": "additionalStorages",
  1300. "label": "Additional Storage",
  1301. "description": "Additional storage for Vaultwarden.",
  1302. "schema": {
  1303. "type": "list",
  1304. "default": [],
  1305. "items": [
  1306. {
  1307. "variable": "storageEntry",
  1308. "label": "Storage Entry",
  1309. "schema": {
  1310. "type": "dict",
  1311. "attrs": [
  1312. {
  1313. "variable": "type",
  1314. "label": "Type",
  1315. "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 a persistent volume claim.\n",
  1316. "schema": {
  1317. "type": "string",
  1318. "required": true,
  1319. "default": "ixVolume",
  1320. "immutable": true,
  1321. "enum": [
  1322. {
  1323. "value": "hostPath",
  1324. "description": "Host Path (Path that already exists on the system)"
  1325. },
  1326. {
  1327. "value": "ixVolume",
  1328. "description": "ixVolume (Dataset created automatically by the system)"
  1329. },
  1330. {
  1331. "value": "smb-pv-pvc",
  1332. "description": "SMB Share (Mounts a persistent volume claim to a SMB share)"
  1333. }
  1334. ]
  1335. }
  1336. },
  1337. {
  1338. "variable": "readOnly",
  1339. "label": "Read Only",
  1340. "description": "Mount the volume as read only.",
  1341. "schema": {
  1342. "type": "boolean",
  1343. "default": false
  1344. }
  1345. },
  1346. {
  1347. "variable": "mountPath",
  1348. "label": "Mount Path",
  1349. "description": "The path inside the container to mount the storage.",
  1350. "schema": {
  1351. "type": "path",
  1352. "required": true
  1353. }
  1354. },
  1355. {
  1356. "variable": "hostPathConfig",
  1357. "label": "Host Path Configuration",
  1358. "schema": {
  1359. "type": "dict",
  1360. "show_if": [
  1361. [
  1362. "type",
  1363. "=",
  1364. "hostPath"
  1365. ]
  1366. ],
  1367. "attrs": [
  1368. {
  1369. "variable": "aclEnable",
  1370. "label": "Enable ACL",
  1371. "description": "Enable ACL for the dataset.",
  1372. "schema": {
  1373. "type": "boolean",
  1374. "default": false
  1375. }
  1376. },
  1377. {
  1378. "variable": "acl",
  1379. "label": "ACL Configuration",
  1380. "schema": {
  1381. "type": "dict",
  1382. "show_if": [
  1383. [
  1384. "aclEnable",
  1385. "=",
  1386. true
  1387. ]
  1388. ],
  1389. "attrs": [
  1390. {
  1391. "variable": "path",
  1392. "label": "Host Path",
  1393. "description": "Host Path to perform ACL",
  1394. "schema": {
  1395. "type": "hostpath",
  1396. "required": true,
  1397. "empty": false
  1398. }
  1399. },
  1400. {
  1401. "variable": "entries",
  1402. "label": "ACL Entries",
  1403. "description": "ACL Entries",
  1404. "schema": {
  1405. "type": "list",
  1406. "items": [
  1407. {
  1408. "variable": "aclEntry",
  1409. "label": "ACL Entry",
  1410. "schema": {
  1411. "type": "dict",
  1412. "attrs": [
  1413. {
  1414. "variable": "id_type",
  1415. "label": "ID Type",
  1416. "schema": {
  1417. "type": "string",
  1418. "enum": [
  1419. {
  1420. "value": "USER",
  1421. "description": "Entry is for a USER"
  1422. },
  1423. {
  1424. "value": "GROUP",
  1425. "description": "Entry is for a GROUP"
  1426. }
  1427. ],
  1428. "default": "USER"
  1429. }
  1430. },
  1431. {
  1432. "variable": "id",
  1433. "label": "ID",
  1434. "description": "Make sure to check the ID value is correct and aligns with RunAs user context of the application",
  1435. "schema": {
  1436. "type": "int",
  1437. "required": true,
  1438. "min": 0
  1439. }
  1440. },
  1441. {
  1442. "variable": "access",
  1443. "label": "Access",
  1444. "schema": {
  1445. "type": "string",
  1446. "enum": [
  1447. {
  1448. "value": "READ",
  1449. "description": "Read Access"
  1450. },
  1451. {
  1452. "value": "MODIFY",
  1453. "description": "Modify Access"
  1454. },
  1455. {
  1456. "value": "FULL_CONTROL",
  1457. "description": "FULL_CONTROL Access"
  1458. }
  1459. ]
  1460. }
  1461. }
  1462. ]
  1463. }
  1464. }
  1465. ]
  1466. }
  1467. },
  1468. {
  1469. "variable": "options",
  1470. "label": "ACL Options",
  1471. "schema": {
  1472. "type": "dict",
  1473. "attrs": [
  1474. {
  1475. "variable": "force",
  1476. "label": "Force Flag",
  1477. "description": "Enabling `Force` applies ACL even if the path has existing data",
  1478. "schema": {
  1479. "type": "boolean",
  1480. "default": false
  1481. }
  1482. }
  1483. ]
  1484. }
  1485. }
  1486. ],
  1487. "$ref": [
  1488. "normalize/acl"
  1489. ]
  1490. }
  1491. },
  1492. {
  1493. "variable": "hostPath",
  1494. "label": "Host Path",
  1495. "description": "The host path to use for storage.",
  1496. "schema": {
  1497. "type": "hostpath",
  1498. "show_if": [
  1499. [
  1500. "aclEnable",
  1501. "=",
  1502. false
  1503. ]
  1504. ],
  1505. "immutable": true,
  1506. "required": true
  1507. }
  1508. }
  1509. ]
  1510. }
  1511. },
  1512. {
  1513. "variable": "ixVolumeConfig",
  1514. "label": "ixVolume Configuration",
  1515. "description": "The configuration for the ixVolume dataset.",
  1516. "schema": {
  1517. "type": "dict",
  1518. "show_if": [
  1519. [
  1520. "type",
  1521. "=",
  1522. "ixVolume"
  1523. ]
  1524. ],
  1525. "$ref": [
  1526. "normalize/ixVolume"
  1527. ],
  1528. "attrs": [
  1529. {
  1530. "variable": "aclEnable",
  1531. "label": "Enable ACL",
  1532. "description": "Enable ACL for the dataset.",
  1533. "schema": {
  1534. "type": "boolean",
  1535. "default": false
  1536. }
  1537. },
  1538. {
  1539. "variable": "datasetName",
  1540. "label": "Dataset Name",
  1541. "description": "The name of the dataset to use for storage.",
  1542. "schema": {
  1543. "type": "string",
  1544. "required": true,
  1545. "immutable": true,
  1546. "default": "storage_entry"
  1547. }
  1548. },
  1549. {
  1550. "variable": "aclEntries",
  1551. "label": "ACL Configuration",
  1552. "schema": {
  1553. "type": "dict",
  1554. "show_if": [
  1555. [
  1556. "aclEnable",
  1557. "=",
  1558. true
  1559. ]
  1560. ],
  1561. "attrs": [
  1562. {
  1563. "variable": "path",
  1564. "label": "Path",
  1565. "description": "Path to perform ACL",
  1566. "schema": {
  1567. "type": "string",
  1568. "hidden": true
  1569. }
  1570. },
  1571. {
  1572. "variable": "entries",
  1573. "label": "ACL Entries",
  1574. "description": "ACL Entries",
  1575. "schema": {
  1576. "type": "list",
  1577. "items": [
  1578. {
  1579. "variable": "aclEntry",
  1580. "label": "ACL Entry",
  1581. "schema": {
  1582. "type": "dict",
  1583. "attrs": [
  1584. {
  1585. "variable": "id_type",
  1586. "label": "ID Type",
  1587. "schema": {
  1588. "type": "string",
  1589. "enum": [
  1590. {
  1591. "value": "USER",
  1592. "description": "Entry is for a USER"
  1593. },
  1594. {
  1595. "value": "GROUP",
  1596. "description": "Entry is for a GROUP"
  1597. }
  1598. ],
  1599. "default": "USER"
  1600. }
  1601. },
  1602. {
  1603. "variable": "id",
  1604. "label": "ID",
  1605. "description": "Make sure to check the ID value is correct and aligns with RunAs user context of the application",
  1606. "schema": {
  1607. "type": "int",
  1608. "required": true,
  1609. "min": 0
  1610. }
  1611. },
  1612. {
  1613. "variable": "access",
  1614. "label": "Access",
  1615. "schema": {
  1616. "type": "string",
  1617. "enum": [
  1618. {
  1619. "value": "READ",
  1620. "description": "Read Access"
  1621. },
  1622. {
  1623. "value": "MODIFY",
  1624. "description": "Modify Access"
  1625. },
  1626. {
  1627. "value": "FULL_CONTROL",
  1628. "description": "FULL_CONTROL Access"
  1629. }
  1630. ]
  1631. }
  1632. }
  1633. ]
  1634. }
  1635. }
  1636. ]
  1637. }
  1638. }
  1639. ]
  1640. }
  1641. }
  1642. ]
  1643. }
  1644. },
  1645. {
  1646. "variable": "smbConfig",
  1647. "label": "SMB Share Configuration",
  1648. "description": "The configuration for the SMB Share.",
  1649. "schema": {
  1650. "type": "dict",
  1651. "show_if": [
  1652. [
  1653. "type",
  1654. "=",
  1655. "smb-pv-pvc"
  1656. ]
  1657. ],
  1658. "attrs": [
  1659. {
  1660. "variable": "server",
  1661. "label": "Server",
  1662. "description": "The server for the SMB share.",
  1663. "schema": {
  1664. "type": "string",
  1665. "required": true
  1666. }
  1667. },
  1668. {
  1669. "variable": "share",
  1670. "label": "Share",
  1671. "description": "The share name for the SMB share.",
  1672. "schema": {
  1673. "type": "string",
  1674. "required": true
  1675. }
  1676. },
  1677. {
  1678. "variable": "domain",
  1679. "label": "Domain (Optional)",
  1680. "description": "The domain for the SMB share.",
  1681. "schema": {
  1682. "type": "string"
  1683. }
  1684. },
  1685. {
  1686. "variable": "username",
  1687. "label": "Username",
  1688. "description": "The username for the SMB share.",
  1689. "schema": {
  1690. "type": "string",
  1691. "required": true
  1692. }
  1693. },
  1694. {
  1695. "variable": "password",
  1696. "label": "Password",
  1697. "description": "The password for the SMB share.",
  1698. "schema": {
  1699. "type": "string",
  1700. "required": true,
  1701. "private": true
  1702. }
  1703. },
  1704. {
  1705. "variable": "size",
  1706. "label": "Size (in Gi)",
  1707. "description": "The size of the volume quota.",
  1708. "schema": {
  1709. "type": "int",
  1710. "required": true,
  1711. "min": 1,
  1712. "default": 1
  1713. }
  1714. }
  1715. ]
  1716. }
  1717. }
  1718. ]
  1719. }
  1720. }
  1721. ]
  1722. }
  1723. }
  1724. ]
  1725. }
  1726. },
  1727. {
  1728. "variable": "resources",
  1729. "label": "",
  1730. "group": "Resources Configuration",
  1731. "schema": {
  1732. "type": "dict",
  1733. "attrs": [
  1734. {
  1735. "variable": "limits",
  1736. "label": "Limits",
  1737. "schema": {
  1738. "type": "dict",
  1739. "attrs": [
  1740. {
  1741. "variable": "cpu",
  1742. "label": "CPU",
  1743. "description": "CPU limit for Vaultwarden.",
  1744. "schema": {
  1745. "type": "string",
  1746. "max_length": 6,
  1747. "valid_chars": "^(0\\.[1-9]|[1-9][0-9]*)(\\.[0-9]|m?)$",
  1748. "valid_chars_error": "Valid CPU limit formats are</br>\n- Plain Integer - eg. 1</br>\n- Float - eg. 0.5</br>\n- Milicpu - eg. 500m\n",
  1749. "default": "4000m",
  1750. "required": true
  1751. }
  1752. },
  1753. {
  1754. "variable": "memory",
  1755. "label": "Memory",
  1756. "description": "Memory limit for Vaultwarden.",
  1757. "schema": {
  1758. "type": "string",
  1759. "max_length": 12,
  1760. "valid_chars": "^[1-9][0-9]*([EPTGMK]i?|e[0-9]+)?$",
  1761. "valid_chars_error": "Valid Memory limit formats are</br>\n- Suffixed with E/P/T/G/M/K - eg. 1G</br>\n- Suffixed with Ei/Pi/Ti/Gi/Mi/Ki - eg. 1Gi</br>\n- Plain Integer in bytes - eg. 1024</br>\n- Exponent - eg. 134e6\n",
  1762. "default": "8Gi",
  1763. "required": true
  1764. }
  1765. }
  1766. ]
  1767. }
  1768. }
  1769. ]
  1770. }
  1771. }
  1772. ]
  1773. },
  1774. "app_readme": "<h1>Vaultwarden</h1>\n<p><a href=\"https://github.com/dani-garcia/vaultwarden\">Vaultwarden</a> Alternative implementation of the <code>Bitwarden</code> server API written in Rust and compatible with upstream Bitwarden clients</p>\n<blockquote>\n<p>During the installation process, a container will be launched with <strong>root</strong> privileges. This is required\nin order to apply the correct permissions to the <code>Vaultwarden</code> data directory. Afterward, the <code>Vaultwarden</code> container\nwill run as a <strong>non</strong>-root user (default <code>568</code>).\nSame applies to the <code>postgres</code> container. This will run afterwards as a <strong>non</strong>-root user (<code>999</code>).\nOn each upgrade, a container will be launched with <strong>root</strong> privileges in order to apply the correct\npermissions to the <code>postgres</code> <strong>backups</strong> directory. Container that performs the backup will run as a <strong>non</strong>-root user (<code>999</code>) afterwards.\nKeep in mind the permissions on the backup directory will be changed to <code>999:999</code> on <strong>every</strong> update.\nBut will only be changed once for the <code>Vaultwarden</code> and <code>postgres</code> data directories.</p>\n</blockquote>\n<p>While the option to use <code>Rocket</code> for TLS is there, it is not\n<a href=\"https://github.com/dani-garcia/vaultwarden/wiki/Enabling-HTTPS#via-rocket\">recommended</a>.\nInstead, use a reverse proxy to handle TLS termination.</p>\n<p>Using <code>HTTPS</code> is <strong>required</strong> for the most of the features to work (correctly).</p>",
  1775. "detailed_readme": "<h1>Vaultwarden</h1>\n<p><a href=\"https://github.com/dani-garcia/vaultwarden\">Vaultwarden</a> Alternative implementation of the <code>Bitwarden</code> server API written in Rust and compatible with upstream Bitwarden clients</p>\n<blockquote>\n<p>During the installation process, a container will be launched with <strong>root</strong> privileges. This is required\nin order to apply the correct permissions to the <code>Vaultwarden</code> data directory. Afterward, the <code>Vaultwarden</code> container\nwill run as a <strong>non</strong>-root user (default <code>568</code>).\nSame applies to the <code>postgres</code> container. This will run afterwards as a <strong>non</strong>-root user (<code>999</code>).\nOn each upgrade, a container will be launched with <strong>root</strong> privileges in order to apply the correct\npermissions to the <code>postgres</code> <strong>backups</strong> directory. Container that performs the backup will run as a <strong>non</strong>-root user (<code>999</code>) afterwards.\nKeep in mind the permissions on the backup directory will be changed to <code>999:999</code> on <strong>every</strong> update.\nBut will only be changed once for the <code>Vaultwarden</code> and <code>postgres</code> data directories.</p>\n</blockquote>\n<p>While the option to use <code>Rocket</code> for TLS is there, it is not\n<a href=\"https://github.com/dani-garcia/vaultwarden/wiki/Enabling-HTTPS#via-rocket\">recommended</a>.\nInstead, use a reverse proxy to handle TLS termination.</p>\n<p>Using <code>HTTPS</code> is <strong>required</strong> for the most of the features to work (correctly).</p>",
  1776. "changelog": null
  1777. }
  1778. }