app_versions.json 66 KB

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