app_versions.json 59 KB

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