app_versions.json 83 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103
  1. {
  2. "1.2.8": {
  3. "healthy": true,
  4. "supported": false,
  5. "healthy_error": null,
  6. "location": "/__w/charts/charts/community/rust-desk/1.2.8",
  7. "last_update": "2025-03-05 14:27:33",
  8. "required_features": [
  9. "normalize/ixVolume",
  10. "normalize/acl"
  11. ],
  12. "human_version": "1.1.14_1.2.8",
  13. "version": "1.2.8",
  14. "chart_metadata": {
  15. "name": "rust-desk",
  16. "description": "Rust Desk is an open-source remote desktop, and alternative to TeamViewer.",
  17. "annotations": {
  18. "title": "Rust Desk"
  19. },
  20. "type": "application",
  21. "version": "1.2.8",
  22. "apiVersion": "v2",
  23. "appVersion": "1.1.14",
  24. "kubeVersion": ">=1.16.0-0",
  25. "maintainers": [
  26. {
  27. "name": "truenas",
  28. "url": "https://www.truenas.com/",
  29. "email": "dev@ixsystems.com"
  30. }
  31. ],
  32. "dependencies": [
  33. {
  34. "name": "common",
  35. "repository": "file://../../../common",
  36. "version": "1.2.9"
  37. }
  38. ],
  39. "home": "https://rustdesk.com",
  40. "icon": "https://media.sys.truenas.net/apps/rust-desk/icons/icon.png",
  41. "sources": [
  42. "https://hub.docker.com/r/rustdesk/rustdesk-server",
  43. "https://github.com/truenas/charts/tree/master/community/rust-desk",
  44. "https://github.com/rustdesk/rustdesk-server"
  45. ],
  46. "keywords": [
  47. "remote",
  48. "desktop"
  49. ]
  50. },
  51. "app_metadata": {
  52. "runAsContext": [
  53. {
  54. "userName": "rust-desk",
  55. "groupName": "rust-desk",
  56. "gid": 568,
  57. "uid": 568,
  58. "description": "Rust Desk can run as any non-root user."
  59. }
  60. ],
  61. "capabilities": [],
  62. "hostMounts": []
  63. },
  64. "schema": {
  65. "groups": [
  66. {
  67. "name": "Rust Desk Configuration",
  68. "description": "Configure Rust Desk"
  69. },
  70. {
  71. "name": "User and Group Configuration",
  72. "description": "Configure User and Group for Rust Desk"
  73. },
  74. {
  75. "name": "Network Configuration",
  76. "description": "Configure Network for Rust Desk"
  77. },
  78. {
  79. "name": "Storage Configuration",
  80. "description": "Configure Storage for Rust Desk"
  81. },
  82. {
  83. "name": "Resources Configuration",
  84. "description": "Configure Resources for Rust Desk"
  85. }
  86. ],
  87. "questions": [
  88. {
  89. "variable": "rustConfig",
  90. "label": "",
  91. "group": "Rust Desk Configuration",
  92. "schema": {
  93. "type": "dict",
  94. "attrs": [
  95. {
  96. "variable": "allowOnlyEncryptedConnections",
  97. "label": "Allow Only Encrypted Connections",
  98. "description": "Allow only encrypted connections.</br>\nClients have to use the generated key to connect to the server.\n",
  99. "schema": {
  100. "type": "boolean",
  101. "default": false
  102. }
  103. },
  104. {
  105. "variable": "additionalRelayServers",
  106. "label": "Additional Relay Servers",
  107. "description": "Configure additional relay servers for Rust Desk.</br>\nThe internal relay server will be added automatically. </br>\nFormat: </br> host:port\n",
  108. "schema": {
  109. "type": "list",
  110. "default": [],
  111. "items": [
  112. {
  113. "variable": "relayServer",
  114. "label": "Relay Server",
  115. "schema": {
  116. "type": "string",
  117. "required": true
  118. }
  119. }
  120. ]
  121. }
  122. },
  123. {
  124. "variable": "additionalEnvs",
  125. "label": "Additional Environment Variables",
  126. "description": "Configure additional environment variables for Rust Desk.",
  127. "schema": {
  128. "type": "list",
  129. "default": [],
  130. "items": [
  131. {
  132. "variable": "env",
  133. "label": "Environment Variable",
  134. "schema": {
  135. "type": "dict",
  136. "attrs": [
  137. {
  138. "variable": "name",
  139. "label": "Name",
  140. "schema": {
  141. "type": "string",
  142. "required": true
  143. }
  144. },
  145. {
  146. "variable": "value",
  147. "label": "Value",
  148. "schema": {
  149. "type": "string",
  150. "required": true
  151. }
  152. }
  153. ]
  154. }
  155. }
  156. ]
  157. }
  158. }
  159. ]
  160. }
  161. },
  162. {
  163. "variable": "rustRunAs",
  164. "label": "",
  165. "group": "User and Group Configuration",
  166. "schema": {
  167. "type": "dict",
  168. "attrs": [
  169. {
  170. "variable": "user",
  171. "label": "User ID",
  172. "description": "The user id that Rust Desk will run as.",
  173. "schema": {
  174. "type": "int",
  175. "min": 2,
  176. "default": 568,
  177. "required": true
  178. }
  179. },
  180. {
  181. "variable": "group",
  182. "label": "Group ID",
  183. "description": "The group id that Rust Desk will run as.",
  184. "schema": {
  185. "type": "int",
  186. "min": 2,
  187. "default": 568,
  188. "required": true
  189. }
  190. }
  191. ]
  192. }
  193. },
  194. {
  195. "variable": "rustNetwork",
  196. "label": "",
  197. "group": "Network Configuration",
  198. "schema": {
  199. "type": "dict",
  200. "attrs": [
  201. {
  202. "variable": "natTypeTestPort",
  203. "label": "NAT Type Test Port",
  204. "description": "The port to use for NAT type test.</br>\nInternal port will always be 21115\n",
  205. "schema": {
  206. "type": "int",
  207. "default": 21115,
  208. "min": 9000,
  209. "max": 65535,
  210. "required": true
  211. }
  212. },
  213. {
  214. "variable": "idRegHolePunchPort",
  215. "label": "ID Registration and Hole Punching Port",
  216. "description": "The port to use for ID registration and Hole punching.</br>\nInternal port will always be 21116 (TCP/UDP)\n",
  217. "schema": {
  218. "type": "int",
  219. "default": 21116,
  220. "min": 9000,
  221. "max": 65535,
  222. "required": true
  223. }
  224. },
  225. {
  226. "variable": "relayPort",
  227. "label": "Relay Port",
  228. "description": "The port to use for relay.</br>\nInternal port will always be 21117\n",
  229. "schema": {
  230. "type": "int",
  231. "default": 21117,
  232. "min": 9000,
  233. "max": 65535,
  234. "required": true
  235. }
  236. },
  237. {
  238. "variable": "enableWebClientPorts",
  239. "label": "Enable Web Client Ports",
  240. "description": "Enable web client ports.</br>\nThis is only required for web clients.</br>\n",
  241. "schema": {
  242. "type": "boolean",
  243. "default": true
  244. }
  245. },
  246. {
  247. "variable": "serverWebClientsPort",
  248. "label": "Server Web Clients Port",
  249. "description": "The port to use for server web clients.</br>\nInternal port will always be 21118\n",
  250. "schema": {
  251. "type": "int",
  252. "default": 21118,
  253. "min": 9000,
  254. "max": 65535,
  255. "required": true,
  256. "show_if": [
  257. [
  258. "enableWebClientPorts",
  259. "=",
  260. true
  261. ]
  262. ]
  263. }
  264. },
  265. {
  266. "variable": "relayWebClientsPort",
  267. "label": "Relay Web Clients Port",
  268. "description": "The port to use for relay web clients.</br>\nInternal port will always be 21119\n",
  269. "schema": {
  270. "type": "int",
  271. "default": 21119,
  272. "min": 9000,
  273. "max": 65535,
  274. "required": true,
  275. "show_if": [
  276. [
  277. "enableWebClientPorts",
  278. "=",
  279. true
  280. ]
  281. ]
  282. }
  283. },
  284. {
  285. "variable": "hostNetwork",
  286. "label": "Host Network",
  287. "description": "Bind to the host network. It's recommended to keep this disabled.</br>\n",
  288. "schema": {
  289. "type": "boolean",
  290. "default": false
  291. }
  292. }
  293. ]
  294. }
  295. },
  296. {
  297. "variable": "rustStorage",
  298. "label": "",
  299. "group": "Storage Configuration",
  300. "schema": {
  301. "type": "dict",
  302. "attrs": [
  303. {
  304. "variable": "data",
  305. "label": "Rust Desk Data Storage",
  306. "description": "The path to store Rust Desk Data.",
  307. "schema": {
  308. "type": "dict",
  309. "attrs": [
  310. {
  311. "variable": "type",
  312. "label": "Type",
  313. "description": "ixVolume: Is dataset created automatically by the system.</br>\nHost Path: Is a path that already exists on the system.\n",
  314. "schema": {
  315. "type": "string",
  316. "required": true,
  317. "immutable": true,
  318. "default": "ixVolume",
  319. "enum": [
  320. {
  321. "value": "hostPath",
  322. "description": "Host Path (Path that already exists on the system)"
  323. },
  324. {
  325. "value": "ixVolume",
  326. "description": "ixVolume (Dataset created automatically by the system)"
  327. }
  328. ]
  329. }
  330. },
  331. {
  332. "variable": "ixVolumeConfig",
  333. "label": "ixVolume Configuration",
  334. "description": "The configuration for the ixVolume dataset.",
  335. "schema": {
  336. "type": "dict",
  337. "show_if": [
  338. [
  339. "type",
  340. "=",
  341. "ixVolume"
  342. ]
  343. ],
  344. "$ref": [
  345. "normalize/ixVolume"
  346. ],
  347. "attrs": [
  348. {
  349. "variable": "aclEnable",
  350. "label": "Enable ACL",
  351. "description": "Enable ACL for the dataset.",
  352. "schema": {
  353. "type": "boolean",
  354. "default": false
  355. }
  356. },
  357. {
  358. "variable": "datasetName",
  359. "label": "Dataset Name",
  360. "description": "The name of the dataset to use for storage.",
  361. "schema": {
  362. "type": "string",
  363. "required": true,
  364. "immutable": true,
  365. "hidden": true,
  366. "default": "data"
  367. }
  368. },
  369. {
  370. "variable": "aclEntries",
  371. "label": "ACL Configuration",
  372. "schema": {
  373. "type": "dict",
  374. "show_if": [
  375. [
  376. "aclEnable",
  377. "=",
  378. true
  379. ]
  380. ],
  381. "attrs": [
  382. {
  383. "variable": "path",
  384. "label": "Path",
  385. "description": "Path to perform ACL",
  386. "schema": {
  387. "type": "string",
  388. "hidden": true
  389. }
  390. },
  391. {
  392. "variable": "entries",
  393. "label": "ACL Entries",
  394. "description": "ACL Entries",
  395. "schema": {
  396. "type": "list",
  397. "items": [
  398. {
  399. "variable": "aclEntry",
  400. "label": "ACL Entry",
  401. "schema": {
  402. "type": "dict",
  403. "attrs": [
  404. {
  405. "variable": "id_type",
  406. "label": "ID Type",
  407. "schema": {
  408. "type": "string",
  409. "enum": [
  410. {
  411. "value": "USER",
  412. "description": "Entry is for a USER"
  413. },
  414. {
  415. "value": "GROUP",
  416. "description": "Entry is for a GROUP"
  417. }
  418. ],
  419. "default": "USER"
  420. }
  421. },
  422. {
  423. "variable": "id",
  424. "label": "ID",
  425. "description": "Make sure to check the ID value is correct and aligns with RunAs user context of the application",
  426. "schema": {
  427. "type": "int",
  428. "required": true,
  429. "min": 0
  430. }
  431. },
  432. {
  433. "variable": "access",
  434. "label": "Access",
  435. "schema": {
  436. "type": "string",
  437. "enum": [
  438. {
  439. "value": "READ",
  440. "description": "Read Access"
  441. },
  442. {
  443. "value": "MODIFY",
  444. "description": "Modify Access"
  445. },
  446. {
  447. "value": "FULL_CONTROL",
  448. "description": "FULL_CONTROL Access"
  449. }
  450. ]
  451. }
  452. }
  453. ]
  454. }
  455. }
  456. ]
  457. }
  458. }
  459. ]
  460. }
  461. }
  462. ]
  463. }
  464. },
  465. {
  466. "variable": "hostPathConfig",
  467. "label": "Host Path Configuration",
  468. "schema": {
  469. "type": "dict",
  470. "show_if": [
  471. [
  472. "type",
  473. "=",
  474. "hostPath"
  475. ]
  476. ],
  477. "attrs": [
  478. {
  479. "variable": "aclEnable",
  480. "label": "Enable ACL",
  481. "description": "Enable ACL for the dataset.",
  482. "schema": {
  483. "type": "boolean",
  484. "default": false
  485. }
  486. },
  487. {
  488. "variable": "acl",
  489. "label": "ACL Configuration",
  490. "schema": {
  491. "type": "dict",
  492. "show_if": [
  493. [
  494. "aclEnable",
  495. "=",
  496. true
  497. ]
  498. ],
  499. "attrs": [
  500. {
  501. "variable": "path",
  502. "label": "Host Path",
  503. "description": "Host Path to perform ACL",
  504. "schema": {
  505. "type": "hostpath",
  506. "required": true,
  507. "empty": false
  508. }
  509. },
  510. {
  511. "variable": "entries",
  512. "label": "ACL Entries",
  513. "description": "ACL Entries",
  514. "schema": {
  515. "type": "list",
  516. "items": [
  517. {
  518. "variable": "aclEntry",
  519. "label": "ACL Entry",
  520. "schema": {
  521. "type": "dict",
  522. "attrs": [
  523. {
  524. "variable": "id_type",
  525. "label": "ID Type",
  526. "schema": {
  527. "type": "string",
  528. "enum": [
  529. {
  530. "value": "USER",
  531. "description": "Entry is for a USER"
  532. },
  533. {
  534. "value": "GROUP",
  535. "description": "Entry is for a GROUP"
  536. }
  537. ],
  538. "default": "USER"
  539. }
  540. },
  541. {
  542. "variable": "id",
  543. "label": "ID",
  544. "description": "Make sure to check the ID value is correct and aligns with RunAs user context of the application",
  545. "schema": {
  546. "type": "int",
  547. "required": true,
  548. "min": 0
  549. }
  550. },
  551. {
  552. "variable": "access",
  553. "label": "Access",
  554. "schema": {
  555. "type": "string",
  556. "enum": [
  557. {
  558. "value": "READ",
  559. "description": "Read Access"
  560. },
  561. {
  562. "value": "MODIFY",
  563. "description": "Modify Access"
  564. },
  565. {
  566. "value": "FULL_CONTROL",
  567. "description": "FULL_CONTROL Access"
  568. }
  569. ]
  570. }
  571. }
  572. ]
  573. }
  574. }
  575. ]
  576. }
  577. },
  578. {
  579. "variable": "options",
  580. "label": "ACL Options",
  581. "schema": {
  582. "type": "dict",
  583. "attrs": [
  584. {
  585. "variable": "force",
  586. "label": "Force Flag",
  587. "description": "Enabling `Force` applies ACL even if the path has existing data",
  588. "schema": {
  589. "type": "boolean",
  590. "default": false
  591. }
  592. }
  593. ]
  594. }
  595. }
  596. ],
  597. "$ref": [
  598. "normalize/acl"
  599. ]
  600. }
  601. },
  602. {
  603. "variable": "hostPath",
  604. "label": "Host Path",
  605. "description": "The host path to use for storage.",
  606. "schema": {
  607. "type": "hostpath",
  608. "show_if": [
  609. [
  610. "aclEnable",
  611. "=",
  612. false
  613. ]
  614. ],
  615. "required": true
  616. }
  617. }
  618. ]
  619. }
  620. }
  621. ]
  622. }
  623. },
  624. {
  625. "variable": "additionalStorages",
  626. "label": "Additional Storage",
  627. "description": "Additional storage for Rust Desk.",
  628. "schema": {
  629. "type": "list",
  630. "default": [],
  631. "items": [
  632. {
  633. "variable": "storageEntry",
  634. "label": "Storage Entry",
  635. "schema": {
  636. "type": "dict",
  637. "attrs": [
  638. {
  639. "variable": "type",
  640. "label": "Type",
  641. "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",
  642. "schema": {
  643. "type": "string",
  644. "required": true,
  645. "default": "ixVolume",
  646. "immutable": true,
  647. "enum": [
  648. {
  649. "value": "hostPath",
  650. "description": "Host Path (Path that already exists on the system)"
  651. },
  652. {
  653. "value": "ixVolume",
  654. "description": "ixVolume (Dataset created automatically by the system)"
  655. },
  656. {
  657. "value": "smb-pv-pvc",
  658. "description": "SMB Share (Mounts a persistent volume claim to a SMB share)"
  659. }
  660. ]
  661. }
  662. },
  663. {
  664. "variable": "readOnly",
  665. "label": "Read Only",
  666. "description": "Mount the volume as read only.",
  667. "schema": {
  668. "type": "boolean",
  669. "default": false
  670. }
  671. },
  672. {
  673. "variable": "mountPath",
  674. "label": "Mount Path",
  675. "description": "The path inside the container to mount the storage.",
  676. "schema": {
  677. "type": "path",
  678. "required": true
  679. }
  680. },
  681. {
  682. "variable": "hostPathConfig",
  683. "label": "Host Path Configuration",
  684. "schema": {
  685. "type": "dict",
  686. "show_if": [
  687. [
  688. "type",
  689. "=",
  690. "hostPath"
  691. ]
  692. ],
  693. "attrs": [
  694. {
  695. "variable": "aclEnable",
  696. "label": "Enable ACL",
  697. "description": "Enable ACL for the dataset.",
  698. "schema": {
  699. "type": "boolean",
  700. "default": false
  701. }
  702. },
  703. {
  704. "variable": "acl",
  705. "label": "ACL Configuration",
  706. "schema": {
  707. "type": "dict",
  708. "show_if": [
  709. [
  710. "aclEnable",
  711. "=",
  712. true
  713. ]
  714. ],
  715. "attrs": [
  716. {
  717. "variable": "path",
  718. "label": "Host Path",
  719. "description": "Host Path to perform ACL",
  720. "schema": {
  721. "type": "hostpath",
  722. "required": true,
  723. "empty": false
  724. }
  725. },
  726. {
  727. "variable": "entries",
  728. "label": "ACL Entries",
  729. "description": "ACL Entries",
  730. "schema": {
  731. "type": "list",
  732. "items": [
  733. {
  734. "variable": "aclEntry",
  735. "label": "ACL Entry",
  736. "schema": {
  737. "type": "dict",
  738. "attrs": [
  739. {
  740. "variable": "id_type",
  741. "label": "ID Type",
  742. "schema": {
  743. "type": "string",
  744. "enum": [
  745. {
  746. "value": "USER",
  747. "description": "Entry is for a USER"
  748. },
  749. {
  750. "value": "GROUP",
  751. "description": "Entry is for a GROUP"
  752. }
  753. ],
  754. "default": "USER"
  755. }
  756. },
  757. {
  758. "variable": "id",
  759. "label": "ID",
  760. "description": "Make sure to check the ID value is correct and aligns with RunAs user context of the application",
  761. "schema": {
  762. "type": "int",
  763. "required": true,
  764. "min": 0
  765. }
  766. },
  767. {
  768. "variable": "access",
  769. "label": "Access",
  770. "schema": {
  771. "type": "string",
  772. "enum": [
  773. {
  774. "value": "READ",
  775. "description": "Read Access"
  776. },
  777. {
  778. "value": "MODIFY",
  779. "description": "Modify Access"
  780. },
  781. {
  782. "value": "FULL_CONTROL",
  783. "description": "FULL_CONTROL Access"
  784. }
  785. ]
  786. }
  787. }
  788. ]
  789. }
  790. }
  791. ]
  792. }
  793. },
  794. {
  795. "variable": "options",
  796. "label": "ACL Options",
  797. "schema": {
  798. "type": "dict",
  799. "attrs": [
  800. {
  801. "variable": "force",
  802. "label": "Force Flag",
  803. "description": "Enabling `Force` applies ACL even if the path has existing data",
  804. "schema": {
  805. "type": "boolean",
  806. "default": false
  807. }
  808. }
  809. ]
  810. }
  811. }
  812. ],
  813. "$ref": [
  814. "normalize/acl"
  815. ]
  816. }
  817. },
  818. {
  819. "variable": "hostPath",
  820. "label": "Host Path",
  821. "description": "The host path to use for storage.",
  822. "schema": {
  823. "type": "hostpath",
  824. "show_if": [
  825. [
  826. "aclEnable",
  827. "=",
  828. false
  829. ]
  830. ],
  831. "required": true
  832. }
  833. }
  834. ]
  835. }
  836. },
  837. {
  838. "variable": "ixVolumeConfig",
  839. "label": "ixVolume Configuration",
  840. "description": "The configuration for the ixVolume dataset.",
  841. "schema": {
  842. "type": "dict",
  843. "show_if": [
  844. [
  845. "type",
  846. "=",
  847. "ixVolume"
  848. ]
  849. ],
  850. "$ref": [
  851. "normalize/ixVolume"
  852. ],
  853. "attrs": [
  854. {
  855. "variable": "aclEnable",
  856. "label": "Enable ACL",
  857. "description": "Enable ACL for the dataset.",
  858. "schema": {
  859. "type": "boolean",
  860. "default": false
  861. }
  862. },
  863. {
  864. "variable": "datasetName",
  865. "label": "Dataset Name",
  866. "description": "The name of the dataset to use for storage.",
  867. "schema": {
  868. "type": "string",
  869. "required": true,
  870. "immutable": true,
  871. "default": "storage_entry"
  872. }
  873. },
  874. {
  875. "variable": "aclEntries",
  876. "label": "ACL Configuration",
  877. "schema": {
  878. "type": "dict",
  879. "show_if": [
  880. [
  881. "aclEnable",
  882. "=",
  883. true
  884. ]
  885. ],
  886. "attrs": [
  887. {
  888. "variable": "path",
  889. "label": "Path",
  890. "description": "Path to perform ACL",
  891. "schema": {
  892. "type": "string",
  893. "hidden": true
  894. }
  895. },
  896. {
  897. "variable": "entries",
  898. "label": "ACL Entries",
  899. "description": "ACL Entries",
  900. "schema": {
  901. "type": "list",
  902. "items": [
  903. {
  904. "variable": "aclEntry",
  905. "label": "ACL Entry",
  906. "schema": {
  907. "type": "dict",
  908. "attrs": [
  909. {
  910. "variable": "id_type",
  911. "label": "ID Type",
  912. "schema": {
  913. "type": "string",
  914. "enum": [
  915. {
  916. "value": "USER",
  917. "description": "Entry is for a USER"
  918. },
  919. {
  920. "value": "GROUP",
  921. "description": "Entry is for a GROUP"
  922. }
  923. ],
  924. "default": "USER"
  925. }
  926. },
  927. {
  928. "variable": "id",
  929. "label": "ID",
  930. "description": "Make sure to check the ID value is correct and aligns with RunAs user context of the application",
  931. "schema": {
  932. "type": "int",
  933. "required": true,
  934. "min": 0
  935. }
  936. },
  937. {
  938. "variable": "access",
  939. "label": "Access",
  940. "schema": {
  941. "type": "string",
  942. "enum": [
  943. {
  944. "value": "READ",
  945. "description": "Read Access"
  946. },
  947. {
  948. "value": "MODIFY",
  949. "description": "Modify Access"
  950. },
  951. {
  952. "value": "FULL_CONTROL",
  953. "description": "FULL_CONTROL Access"
  954. }
  955. ]
  956. }
  957. }
  958. ]
  959. }
  960. }
  961. ]
  962. }
  963. }
  964. ]
  965. }
  966. }
  967. ]
  968. }
  969. },
  970. {
  971. "variable": "smbConfig",
  972. "label": "SMB Share Configuration",
  973. "description": "The configuration for the SMB Share.",
  974. "schema": {
  975. "type": "dict",
  976. "show_if": [
  977. [
  978. "type",
  979. "=",
  980. "smb-pv-pvc"
  981. ]
  982. ],
  983. "attrs": [
  984. {
  985. "variable": "server",
  986. "label": "Server",
  987. "description": "The server for the SMB share.",
  988. "schema": {
  989. "type": "string",
  990. "required": true
  991. }
  992. },
  993. {
  994. "variable": "share",
  995. "label": "Share",
  996. "description": "The share name for the SMB share.",
  997. "schema": {
  998. "type": "string",
  999. "required": true
  1000. }
  1001. },
  1002. {
  1003. "variable": "domain",
  1004. "label": "Domain (Optional)",
  1005. "description": "The domain for the SMB share.",
  1006. "schema": {
  1007. "type": "string"
  1008. }
  1009. },
  1010. {
  1011. "variable": "username",
  1012. "label": "Username",
  1013. "description": "The username for the SMB share.",
  1014. "schema": {
  1015. "type": "string",
  1016. "required": true
  1017. }
  1018. },
  1019. {
  1020. "variable": "password",
  1021. "label": "Password",
  1022. "description": "The password for the SMB share.",
  1023. "schema": {
  1024. "type": "string",
  1025. "required": true,
  1026. "private": true
  1027. }
  1028. },
  1029. {
  1030. "variable": "size",
  1031. "label": "Size (in Gi)",
  1032. "description": "The size of the volume quota.",
  1033. "schema": {
  1034. "type": "int",
  1035. "required": true,
  1036. "min": 1,
  1037. "default": 1
  1038. }
  1039. }
  1040. ]
  1041. }
  1042. }
  1043. ]
  1044. }
  1045. }
  1046. ]
  1047. }
  1048. }
  1049. ]
  1050. }
  1051. },
  1052. {
  1053. "variable": "resources",
  1054. "group": "Resources Configuration",
  1055. "label": "",
  1056. "schema": {
  1057. "type": "dict",
  1058. "attrs": [
  1059. {
  1060. "variable": "limits",
  1061. "label": "Limits",
  1062. "schema": {
  1063. "type": "dict",
  1064. "attrs": [
  1065. {
  1066. "variable": "cpu",
  1067. "label": "CPU",
  1068. "description": "CPU limit for Rust Desk.",
  1069. "schema": {
  1070. "type": "string",
  1071. "max_length": 6,
  1072. "valid_chars": "^(0\\.[1-9]|[1-9][0-9]*)(\\.[0-9]|m?)$",
  1073. "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",
  1074. "default": "4000m",
  1075. "required": true
  1076. }
  1077. },
  1078. {
  1079. "variable": "memory",
  1080. "label": "Memory",
  1081. "description": "Memory limit for Rust Desk.",
  1082. "schema": {
  1083. "type": "string",
  1084. "max_length": 12,
  1085. "valid_chars": "^[1-9][0-9]*([EPTGMK]i?|e[0-9]+)?$",
  1086. "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",
  1087. "default": "8Gi",
  1088. "required": true
  1089. }
  1090. }
  1091. ]
  1092. }
  1093. }
  1094. ]
  1095. }
  1096. }
  1097. ]
  1098. },
  1099. "app_readme": "<h1>Rust Desk</h1>\n<p><a href=\"https://rustdesk.com\">Rust Desk</a> is an open-source remote desktop, and alternative to TeamViewer.</p>\n<blockquote>\n<p>When application is installed, a container will be launched with <strong>root</strong> privileges.\nThis is required in order to apply the correct permissions to the <code>Rust Desk</code> directories.\nAfterward, the <code>Rust Desk</code> container will run as a <strong>non</strong>-root user (Default: <code>568</code>).\nAll mounted storage(s) will be <code>chown</code>ed only if the parent directory does not match the configured user.</p>\n</blockquote>",
  1100. "detailed_readme": "<h1>Rust Desk</h1>\n<p><a href=\"https://rustdesk.com\">Rust Desk</a> is an open-source remote desktop, and alternative to TeamViewer.</p>\n<blockquote>\n<p>When application is installed, a container will be launched with <strong>root</strong> privileges.\nThis is required in order to apply the correct permissions to the <code>Rust Desk</code> directories.\nAfterward, the <code>Rust Desk</code> container will run as a <strong>non</strong>-root user (Default: <code>568</code>).\nAll mounted storage(s) will be <code>chown</code>ed only if the parent directory does not match the configured user.</p>\n</blockquote>",
  1101. "changelog": null
  1102. }
  1103. }