app_versions.json 48 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811
  1. {
  2. "1.0.6": {
  3. "healthy": true,
  4. "supported": true,
  5. "healthy_error": null,
  6. "location": "/__w/apps/apps/trains/community/electrs/1.0.6",
  7. "last_update": "2025-09-02 11:33:24",
  8. "required_features": [],
  9. "human_version": "v0.10.9_1.0.6",
  10. "version": "1.0.6",
  11. "app_metadata": {
  12. "app_version": "v0.10.9",
  13. "capabilities": [],
  14. "categories": [
  15. "financial"
  16. ],
  17. "changelog_url": "https://github.com/romanz/electrs/blob/master/RELEASE-NOTES.md",
  18. "date_added": "2025-04-24",
  19. "description": "An efficient re-implementation of Electrum Server in Rust.",
  20. "home": "https://github.com/romanz/electrs/",
  21. "host_mounts": [],
  22. "icon": "https://media.sys.truenas.net/apps/electrs/icons/icon.svg",
  23. "keywords": [
  24. "bitcoin",
  25. "electrum",
  26. "cryptocurrency",
  27. "blockchain"
  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": "electrs",
  39. "run_as_context": [
  40. {
  41. "description": "Electrs runs as non-root user.",
  42. "gid": 1000,
  43. "group_name": "electrs",
  44. "uid": 1000,
  45. "user_name": "electrs"
  46. }
  47. ],
  48. "screenshots": [],
  49. "sources": [
  50. "https://github.com/romanz/electrs",
  51. "https://github.com/getumbrel/docker-electrs"
  52. ],
  53. "title": "Electrs",
  54. "train": "community",
  55. "version": "1.0.6"
  56. },
  57. "schema": {
  58. "groups": [
  59. {
  60. "name": "Electrs Configuration",
  61. "description": "Configure Electrs"
  62. },
  63. {
  64. "name": "Network Configuration",
  65. "description": "Configure Network for Electrs"
  66. },
  67. {
  68. "name": "Storage Configuration",
  69. "description": "Configure Storage for Electrs"
  70. },
  71. {
  72. "name": "Labels Configuration",
  73. "description": "Configure Labels for Electrs"
  74. },
  75. {
  76. "name": "Resources Configuration",
  77. "description": "Configure Resources for Electrs"
  78. }
  79. ],
  80. "questions": [
  81. {
  82. "variable": "TZ",
  83. "group": "Electrs Configuration",
  84. "label": "Timezone",
  85. "schema": {
  86. "type": "string",
  87. "default": "Etc/UTC",
  88. "required": true,
  89. "$ref": [
  90. "definitions/timezone"
  91. ]
  92. }
  93. },
  94. {
  95. "variable": "electrs",
  96. "label": "",
  97. "group": "Electrs Configuration",
  98. "schema": {
  99. "type": "dict",
  100. "attrs": [
  101. {
  102. "variable": "use_installed_bitcoin_app",
  103. "label": "Connect to Installed Bitcoin Node App",
  104. "description": "Enabling this option will attempt to connect to the installed Bitcoin Node TrueNAS app.\nElectrs won't work if your node is pruned.\n",
  105. "schema": {
  106. "type": "boolean",
  107. "default": true
  108. }
  109. },
  110. {
  111. "variable": "external_bitcoind_ip",
  112. "label": "External Bitcoin Node RPC IP",
  113. "schema": {
  114. "type": "ipaddr",
  115. "required": true,
  116. "show_if": [
  117. [
  118. "use_installed_bitcoin_app",
  119. "=",
  120. false
  121. ]
  122. ]
  123. }
  124. },
  125. {
  126. "variable": "bitcoind_p2p_port",
  127. "label": "Bitcoin Node P2P Port",
  128. "schema": {
  129. "type": "int",
  130. "min": 1,
  131. "max": 65535,
  132. "default": 8333,
  133. "required": true
  134. }
  135. },
  136. {
  137. "variable": "bitcoind_rpc_port",
  138. "label": "Bitcoin Node RPC Port",
  139. "schema": {
  140. "type": "int",
  141. "min": 1,
  142. "max": 65535,
  143. "default": 8332,
  144. "required": true
  145. }
  146. },
  147. {
  148. "variable": "bitcoind_rpc_user",
  149. "label": "Bitcoin Node RPC User",
  150. "schema": {
  151. "type": "string",
  152. "default": "truenas",
  153. "required": true
  154. }
  155. },
  156. {
  157. "variable": "bitcoind_rpc_password",
  158. "label": "Bitcoin Node RPC Password",
  159. "schema": {
  160. "type": "string",
  161. "required": true
  162. }
  163. },
  164. {
  165. "variable": "additional_flags",
  166. "label": "Additional flags",
  167. "description": "Additional commands can be provided here.\nIf you are unsure, leave this blank.\n",
  168. "schema": {
  169. "type": "list",
  170. "items": [
  171. {
  172. "variable": "flag",
  173. "label": "Flag",
  174. "schema": {
  175. "type": "string",
  176. "required": true
  177. }
  178. }
  179. ]
  180. }
  181. }
  182. ]
  183. }
  184. },
  185. {
  186. "variable": "network",
  187. "label": "",
  188. "group": "Network Configuration",
  189. "schema": {
  190. "type": "dict",
  191. "attrs": [
  192. {
  193. "variable": "rpc_port",
  194. "label": "RPC Port",
  195. "description": "This port can be used by other apps to communicate with Electrs.\n",
  196. "schema": {
  197. "type": "dict",
  198. "attrs": [
  199. {
  200. "variable": "bind_mode",
  201. "label": "Port Bind Mode",
  202. "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",
  203. "schema": {
  204. "type": "string",
  205. "default": "published",
  206. "enum": [
  207. {
  208. "value": "published",
  209. "description": "Publish port on the host for external access"
  210. },
  211. {
  212. "value": "exposed",
  213. "description": "Expose port for inter-container communication"
  214. },
  215. {
  216. "value": "",
  217. "description": "None"
  218. }
  219. ]
  220. }
  221. },
  222. {
  223. "variable": "port_number",
  224. "label": "Port Number",
  225. "schema": {
  226. "type": "int",
  227. "default": 50001,
  228. "min": 1,
  229. "max": 65535,
  230. "required": true
  231. }
  232. },
  233. {
  234. "variable": "host_ips",
  235. "label": "Host IPs",
  236. "description": "IPs on the host to bind this port",
  237. "schema": {
  238. "type": "list",
  239. "show_if": [
  240. [
  241. "bind_mode",
  242. "=",
  243. "published"
  244. ]
  245. ],
  246. "default": [],
  247. "items": [
  248. {
  249. "variable": "host_ip",
  250. "label": "Host IP",
  251. "schema": {
  252. "type": "string",
  253. "required": true,
  254. "$ref": [
  255. "definitions/node_bind_ip"
  256. ]
  257. }
  258. }
  259. ]
  260. }
  261. }
  262. ]
  263. }
  264. }
  265. ]
  266. }
  267. },
  268. {
  269. "variable": "storage",
  270. "label": "",
  271. "group": "Storage Configuration",
  272. "schema": {
  273. "type": "dict",
  274. "attrs": [
  275. {
  276. "variable": "data",
  277. "label": "Electrs Data Storage Location",
  278. "description": "We recommend at least 70GB of free space.\n",
  279. "schema": {
  280. "type": "dict",
  281. "attrs": [
  282. {
  283. "variable": "type",
  284. "label": "Type",
  285. "description": "ixVolume: Is dataset created automatically by the system.</br>\nHost Path: Is a path that already exists on the system.\n",
  286. "schema": {
  287. "type": "string",
  288. "required": true,
  289. "default": "ix_volume",
  290. "enum": [
  291. {
  292. "value": "host_path",
  293. "description": "Host Path (Path that already exists on the system)"
  294. },
  295. {
  296. "value": "ix_volume",
  297. "description": "ixVolume (Dataset created automatically by the system)"
  298. }
  299. ]
  300. }
  301. },
  302. {
  303. "variable": "ix_volume_config",
  304. "label": "ixVolume Configuration",
  305. "description": "The configuration for the ixVolume dataset.",
  306. "schema": {
  307. "type": "dict",
  308. "show_if": [
  309. [
  310. "type",
  311. "=",
  312. "ix_volume"
  313. ]
  314. ],
  315. "$ref": [
  316. "normalize/ix_volume"
  317. ],
  318. "attrs": [
  319. {
  320. "variable": "acl_enable",
  321. "label": "Enable ACL",
  322. "description": "Enable ACL for the storage.",
  323. "schema": {
  324. "type": "boolean",
  325. "default": false
  326. }
  327. },
  328. {
  329. "variable": "dataset_name",
  330. "label": "Dataset Name",
  331. "description": "The name of the dataset to use for storage.",
  332. "schema": {
  333. "type": "string",
  334. "required": true,
  335. "hidden": true,
  336. "default": "data"
  337. }
  338. },
  339. {
  340. "variable": "acl_entries",
  341. "label": "ACL Configuration",
  342. "schema": {
  343. "type": "dict",
  344. "show_if": [
  345. [
  346. "acl_enable",
  347. "=",
  348. true
  349. ]
  350. ],
  351. "attrs": []
  352. }
  353. }
  354. ]
  355. }
  356. },
  357. {
  358. "variable": "host_path_config",
  359. "label": "Host Path Configuration",
  360. "schema": {
  361. "type": "dict",
  362. "show_if": [
  363. [
  364. "type",
  365. "=",
  366. "host_path"
  367. ]
  368. ],
  369. "attrs": [
  370. {
  371. "variable": "acl_enable",
  372. "label": "Enable ACL",
  373. "description": "Enable ACL for the storage.",
  374. "schema": {
  375. "type": "boolean",
  376. "default": false
  377. }
  378. },
  379. {
  380. "variable": "acl",
  381. "label": "ACL Configuration",
  382. "schema": {
  383. "type": "dict",
  384. "show_if": [
  385. [
  386. "acl_enable",
  387. "=",
  388. true
  389. ]
  390. ],
  391. "attrs": [],
  392. "$ref": [
  393. "normalize/acl"
  394. ]
  395. }
  396. },
  397. {
  398. "variable": "path",
  399. "label": "Host Path",
  400. "description": "The host path to use for storage.",
  401. "schema": {
  402. "type": "hostpath",
  403. "show_if": [
  404. [
  405. "acl_enable",
  406. "=",
  407. false
  408. ]
  409. ],
  410. "required": true
  411. }
  412. }
  413. ]
  414. }
  415. }
  416. ]
  417. }
  418. },
  419. {
  420. "variable": "additional_storage",
  421. "label": "Additional Storage",
  422. "schema": {
  423. "type": "list",
  424. "default": [],
  425. "items": [
  426. {
  427. "variable": "storageEntry",
  428. "label": "Storage Entry",
  429. "schema": {
  430. "type": "dict",
  431. "attrs": [
  432. {
  433. "variable": "type",
  434. "label": "Type",
  435. "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",
  436. "schema": {
  437. "type": "string",
  438. "required": true,
  439. "default": "ix_volume",
  440. "enum": [
  441. {
  442. "value": "host_path",
  443. "description": "Host Path (Path that already exists on the system)"
  444. },
  445. {
  446. "value": "ix_volume",
  447. "description": "ixVolume (Dataset created automatically by the system)"
  448. },
  449. {
  450. "value": "cifs",
  451. "description": "SMB/CIFS Share (Mounts a volume to a SMB share)"
  452. }
  453. ]
  454. }
  455. },
  456. {
  457. "variable": "read_only",
  458. "label": "Read Only",
  459. "description": "Mount the volume as read only.",
  460. "schema": {
  461. "type": "boolean",
  462. "default": false
  463. }
  464. },
  465. {
  466. "variable": "mount_path",
  467. "label": "Mount Path",
  468. "description": "The path inside the container to mount the storage.",
  469. "schema": {
  470. "type": "path",
  471. "required": true
  472. }
  473. },
  474. {
  475. "variable": "host_path_config",
  476. "label": "Host Path Configuration",
  477. "schema": {
  478. "type": "dict",
  479. "show_if": [
  480. [
  481. "type",
  482. "=",
  483. "host_path"
  484. ]
  485. ],
  486. "attrs": [
  487. {
  488. "variable": "acl_enable",
  489. "label": "Enable ACL",
  490. "description": "Enable ACL for the storage.",
  491. "schema": {
  492. "type": "boolean",
  493. "default": false
  494. }
  495. },
  496. {
  497. "variable": "acl",
  498. "label": "ACL Configuration",
  499. "schema": {
  500. "type": "dict",
  501. "show_if": [
  502. [
  503. "acl_enable",
  504. "=",
  505. true
  506. ]
  507. ],
  508. "attrs": [],
  509. "$ref": [
  510. "normalize/acl"
  511. ]
  512. }
  513. },
  514. {
  515. "variable": "path",
  516. "label": "Host Path",
  517. "description": "The host path to use for storage.",
  518. "schema": {
  519. "type": "hostpath",
  520. "show_if": [
  521. [
  522. "acl_enable",
  523. "=",
  524. false
  525. ]
  526. ],
  527. "required": true
  528. }
  529. }
  530. ]
  531. }
  532. },
  533. {
  534. "variable": "ix_volume_config",
  535. "label": "ixVolume Configuration",
  536. "description": "The configuration for the ixVolume dataset.",
  537. "schema": {
  538. "type": "dict",
  539. "show_if": [
  540. [
  541. "type",
  542. "=",
  543. "ix_volume"
  544. ]
  545. ],
  546. "$ref": [
  547. "normalize/ix_volume"
  548. ],
  549. "attrs": [
  550. {
  551. "variable": "acl_enable",
  552. "label": "Enable ACL",
  553. "description": "Enable ACL for the storage.",
  554. "schema": {
  555. "type": "boolean",
  556. "default": false
  557. }
  558. },
  559. {
  560. "variable": "dataset_name",
  561. "label": "Dataset Name",
  562. "description": "The name of the dataset to use for storage.",
  563. "schema": {
  564. "type": "string",
  565. "required": true,
  566. "default": "storage_entry"
  567. }
  568. },
  569. {
  570. "variable": "acl_entries",
  571. "label": "ACL Configuration",
  572. "schema": {
  573. "type": "dict",
  574. "show_if": [
  575. [
  576. "acl_enable",
  577. "=",
  578. true
  579. ]
  580. ],
  581. "attrs": [],
  582. "$ref": [
  583. "normalize/acl"
  584. ]
  585. }
  586. }
  587. ]
  588. }
  589. },
  590. {
  591. "variable": "cifs_config",
  592. "label": "SMB Configuration",
  593. "description": "The configuration for the SMB dataset.",
  594. "schema": {
  595. "type": "dict",
  596. "show_if": [
  597. [
  598. "type",
  599. "=",
  600. "cifs"
  601. ]
  602. ],
  603. "attrs": [
  604. {
  605. "variable": "server",
  606. "label": "Server",
  607. "description": "The server to mount the SMB share.",
  608. "schema": {
  609. "type": "string",
  610. "required": true
  611. }
  612. },
  613. {
  614. "variable": "path",
  615. "label": "Path",
  616. "description": "The path to mount the SMB share.",
  617. "schema": {
  618. "type": "string",
  619. "required": true
  620. }
  621. },
  622. {
  623. "variable": "username",
  624. "label": "Username",
  625. "description": "The username to use for the SMB share.",
  626. "schema": {
  627. "type": "string",
  628. "required": true
  629. }
  630. },
  631. {
  632. "variable": "password",
  633. "label": "Password",
  634. "description": "The password to use for the SMB share.",
  635. "schema": {
  636. "type": "string",
  637. "required": true,
  638. "private": true
  639. }
  640. },
  641. {
  642. "variable": "domain",
  643. "label": "Domain",
  644. "description": "The domain to use for the SMB share.",
  645. "schema": {
  646. "type": "string"
  647. }
  648. }
  649. ]
  650. }
  651. }
  652. ]
  653. }
  654. }
  655. ]
  656. }
  657. }
  658. ]
  659. }
  660. },
  661. {
  662. "variable": "labels",
  663. "label": "",
  664. "group": "Labels Configuration",
  665. "schema": {
  666. "type": "list",
  667. "default": [],
  668. "items": [
  669. {
  670. "variable": "label",
  671. "label": "Label",
  672. "schema": {
  673. "type": "dict",
  674. "attrs": [
  675. {
  676. "variable": "key",
  677. "label": "Key",
  678. "schema": {
  679. "type": "string",
  680. "required": true
  681. }
  682. },
  683. {
  684. "variable": "value",
  685. "label": "Value",
  686. "schema": {
  687. "type": "string",
  688. "required": true
  689. }
  690. },
  691. {
  692. "variable": "containers",
  693. "label": "Containers",
  694. "description": "Containers where the label should be applied",
  695. "schema": {
  696. "type": "list",
  697. "items": [
  698. {
  699. "variable": "container",
  700. "label": "Container",
  701. "schema": {
  702. "type": "string",
  703. "required": true,
  704. "enum": [
  705. {
  706. "value": "electrs",
  707. "description": "electrs"
  708. }
  709. ]
  710. }
  711. }
  712. ]
  713. }
  714. }
  715. ]
  716. }
  717. }
  718. ]
  719. }
  720. },
  721. {
  722. "variable": "resources",
  723. "label": "",
  724. "group": "Resources Configuration",
  725. "schema": {
  726. "type": "dict",
  727. "attrs": [
  728. {
  729. "variable": "limits",
  730. "label": "Limits",
  731. "schema": {
  732. "type": "dict",
  733. "attrs": [
  734. {
  735. "variable": "cpus",
  736. "label": "CPUs",
  737. "description": "CPUs limit for Electrs.",
  738. "schema": {
  739. "type": "int",
  740. "default": 2,
  741. "required": true
  742. }
  743. },
  744. {
  745. "variable": "memory",
  746. "label": "Memory (in MB)",
  747. "description": "Memory limit for Electrs.",
  748. "schema": {
  749. "type": "int",
  750. "default": 4096,
  751. "required": true
  752. }
  753. }
  754. ]
  755. }
  756. }
  757. ]
  758. }
  759. }
  760. ]
  761. },
  762. "readme": "<h1>Electrs</h1> <p><a href=\"https://github.com/romanz/electrs\">Electrs</a> is an efficient re-implementation of Electrum Server in Rust.</p>",
  763. "changelog": null,
  764. "chart_metadata": {
  765. "app_version": "v0.10.9",
  766. "capabilities": [],
  767. "categories": [
  768. "financial"
  769. ],
  770. "changelog_url": "https://github.com/romanz/electrs/blob/master/RELEASE-NOTES.md",
  771. "date_added": "2025-04-24",
  772. "description": "An efficient re-implementation of Electrum Server in Rust.",
  773. "home": "https://github.com/romanz/electrs/",
  774. "host_mounts": [],
  775. "icon": "https://media.sys.truenas.net/apps/electrs/icons/icon.svg",
  776. "keywords": [
  777. "bitcoin",
  778. "electrum",
  779. "cryptocurrency",
  780. "blockchain"
  781. ],
  782. "lib_version": "2.1.49",
  783. "lib_version_hash": "e71e6b0122c9446fa5ea6fb07e7eb01b11fb42d549a19845426bbd7e21a42634",
  784. "maintainers": [
  785. {
  786. "email": "dev@ixsystems.com",
  787. "name": "truenas",
  788. "url": "https://www.truenas.com/"
  789. }
  790. ],
  791. "name": "electrs",
  792. "run_as_context": [
  793. {
  794. "description": "Electrs runs as non-root user.",
  795. "gid": 1000,
  796. "group_name": "electrs",
  797. "uid": 1000,
  798. "user_name": "electrs"
  799. }
  800. ],
  801. "screenshots": [],
  802. "sources": [
  803. "https://github.com/romanz/electrs",
  804. "https://github.com/getumbrel/docker-electrs"
  805. ],
  806. "title": "Electrs",
  807. "train": "community",
  808. "version": "1.0.6"
  809. }
  810. }
  811. }