app_versions.json 78 KB

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