app_versions.json 49 KB

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