app_versions.json 66 KB

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