app_versions.json 112 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561156215631564156515661567156815691570157115721573157415751576157715781579158015811582158315841585158615871588158915901591159215931594159515961597159815991600160116021603160416051606160716081609161016111612161316141615161616171618161916201621162216231624162516261627162816291630163116321633163416351636163716381639164016411642164316441645164616471648164916501651165216531654165516561657165816591660166116621663166416651666166716681669167016711672167316741675167616771678167916801681168216831684168516861687168816891690169116921693169416951696169716981699170017011702170317041705170617071708170917101711171217131714171517161717171817191720172117221723172417251726172717281729173017311732173317341735173617371738173917401741174217431744174517461747174817491750175117521753175417551756175717581759176017611762176317641765176617671768176917701771177217731774177517761777177817791780178117821783178417851786178717881789179017911792179317941795179617971798179918001801180218031804180518061807180818091810181118121813
  1. {
  2. "1.3.8": {
  3. "healthy": true,
  4. "supported": true,
  5. "healthy_error": null,
  6. "location": "/__w/apps/apps/trains/community/omada-controller/1.3.8",
  7. "last_update": "2025-09-02 11:33:24",
  8. "required_features": [],
  9. "human_version": "5.15.24.19_1.3.8",
  10. "version": "1.3.8",
  11. "app_metadata": {
  12. "annotations": {
  13. "min_scale_version": "24.10.2.2"
  14. },
  15. "app_version": "5.15.24.19",
  16. "capabilities": [
  17. {
  18. "description": "Omada Controller is able to change file ownership arbitrarily",
  19. "name": "CHOWN"
  20. },
  21. {
  22. "description": "Omada Controller is able to bypass file permission checks",
  23. "name": "DAC_OVERRIDE"
  24. },
  25. {
  26. "description": "Omada Controller is able to bypass permission checks for file operations",
  27. "name": "FOWNER"
  28. },
  29. {
  30. "description": "Omada Controller is able to change group ID of processes",
  31. "name": "SETGID"
  32. },
  33. {
  34. "description": "Omada Controller is able to change user ID of processes",
  35. "name": "SETUID"
  36. }
  37. ],
  38. "categories": [
  39. "networking"
  40. ],
  41. "changelog_url": "https://github.com/mbentley/docker-omada-controller/releases",
  42. "date_added": "2024-08-02",
  43. "description": "Omada Controller (TP-Link) is a network management controller for TP-Link Omada Equipment",
  44. "home": "https://github.com/mbentley/docker-omada-controller",
  45. "host_mounts": [],
  46. "icon": "https://media.sys.truenas.net/apps/omada-controller/icons/icon.svg",
  47. "keywords": [
  48. "network",
  49. "controller",
  50. "omada",
  51. "tp-link"
  52. ],
  53. "lib_version": "2.1.49",
  54. "lib_version_hash": "e71e6b0122c9446fa5ea6fb07e7eb01b11fb42d549a19845426bbd7e21a42634",
  55. "maintainers": [
  56. {
  57. "email": "dev@ixsystems.com",
  58. "name": "truenas",
  59. "url": "https://www.truenas.com/"
  60. }
  61. ],
  62. "name": "omada-controller",
  63. "run_as_context": [
  64. {
  65. "description": "Omada Controller runs as root user.",
  66. "gid": 0,
  67. "group_name": "root",
  68. "uid": 0,
  69. "user_name": "root"
  70. }
  71. ],
  72. "screenshots": [],
  73. "sources": [
  74. "https://github.com/mbentley/docker-omada-controller",
  75. "https://hub.docker.com/r/mbentley/omada-controller"
  76. ],
  77. "title": "Omada Controller",
  78. "train": "community",
  79. "version": "1.3.8"
  80. },
  81. "schema": {
  82. "groups": [
  83. {
  84. "name": "Omada Controller Configuration",
  85. "description": "Configure Omada Controller"
  86. },
  87. {
  88. "name": "User and Group Configuration",
  89. "description": "Configure User and Group for Omada Controller"
  90. },
  91. {
  92. "name": "Network Configuration",
  93. "description": "Configure Network for Omada Controller"
  94. },
  95. {
  96. "name": "Storage Configuration",
  97. "description": "Configure Storage for Omada Controller"
  98. },
  99. {
  100. "name": "Labels Configuration",
  101. "description": "Configure Labels for Omada Controller"
  102. },
  103. {
  104. "name": "Resources Configuration",
  105. "description": "Configure Resources for Omada Controller"
  106. }
  107. ],
  108. "questions": [
  109. {
  110. "variable": "TZ",
  111. "group": "Omada Controller Configuration",
  112. "label": "Timezone",
  113. "schema": {
  114. "type": "string",
  115. "default": "Etc/UTC",
  116. "required": true,
  117. "$ref": [
  118. "definitions/timezone"
  119. ]
  120. }
  121. },
  122. {
  123. "variable": "omada",
  124. "label": "",
  125. "group": "Omada Controller Configuration",
  126. "schema": {
  127. "type": "dict",
  128. "attrs": [
  129. {
  130. "variable": "additional_envs",
  131. "label": "Additional Environment Variables",
  132. "schema": {
  133. "type": "list",
  134. "default": [],
  135. "items": [
  136. {
  137. "variable": "env",
  138. "label": "Environment Variable",
  139. "schema": {
  140. "type": "dict",
  141. "attrs": [
  142. {
  143. "variable": "name",
  144. "label": "Name",
  145. "schema": {
  146. "type": "string",
  147. "required": true
  148. }
  149. },
  150. {
  151. "variable": "value",
  152. "label": "Value",
  153. "schema": {
  154. "type": "string"
  155. }
  156. }
  157. ]
  158. }
  159. }
  160. ]
  161. }
  162. }
  163. ]
  164. }
  165. },
  166. {
  167. "variable": "run_as",
  168. "label": "",
  169. "group": "User and Group Configuration",
  170. "schema": {
  171. "type": "dict",
  172. "attrs": [
  173. {
  174. "variable": "user",
  175. "label": "User ID",
  176. "description": "The user id that Omada Controller files will be owned by.",
  177. "schema": {
  178. "type": "int",
  179. "min": 568,
  180. "default": 568,
  181. "required": true
  182. }
  183. },
  184. {
  185. "variable": "group",
  186. "label": "Group ID",
  187. "description": "The group id that Omada Controller files will be owned by.",
  188. "schema": {
  189. "type": "int",
  190. "min": 568,
  191. "default": 568,
  192. "required": true
  193. }
  194. }
  195. ]
  196. }
  197. },
  198. {
  199. "variable": "network",
  200. "label": "",
  201. "group": "Network Configuration",
  202. "schema": {
  203. "type": "dict",
  204. "attrs": [
  205. {
  206. "variable": "manage_http_port",
  207. "label": "Manage HTTP Port",
  208. "description": "Management portal HTTP port",
  209. "schema": {
  210. "type": "dict",
  211. "attrs": [
  212. {
  213. "variable": "bind_mode",
  214. "label": "Port Bind Mode",
  215. "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",
  216. "schema": {
  217. "type": "string",
  218. "default": "published",
  219. "enum": [
  220. {
  221. "value": "published",
  222. "description": "Publish port on the host for external access"
  223. },
  224. {
  225. "value": "exposed",
  226. "description": "Expose port for inter-container communication"
  227. },
  228. {
  229. "value": "",
  230. "description": "None"
  231. }
  232. ]
  233. }
  234. },
  235. {
  236. "variable": "port_number",
  237. "label": "Port Number",
  238. "schema": {
  239. "type": "int",
  240. "default": 30076,
  241. "min": 1,
  242. "max": 65535,
  243. "required": true
  244. }
  245. },
  246. {
  247. "variable": "host_ips",
  248. "label": "Host IPs",
  249. "description": "IPs on the host to bind this port",
  250. "schema": {
  251. "type": "list",
  252. "show_if": [
  253. [
  254. "bind_mode",
  255. "=",
  256. "published"
  257. ]
  258. ],
  259. "default": [],
  260. "items": [
  261. {
  262. "variable": "host_ip",
  263. "label": "Host IP",
  264. "schema": {
  265. "type": "string",
  266. "required": true,
  267. "$ref": [
  268. "definitions/node_bind_ip"
  269. ]
  270. }
  271. }
  272. ]
  273. }
  274. }
  275. ]
  276. }
  277. },
  278. {
  279. "variable": "manage_https_port",
  280. "label": "Manage HTTPS Port",
  281. "description": "Management portal HTTPS port",
  282. "schema": {
  283. "type": "dict",
  284. "attrs": [
  285. {
  286. "variable": "bind_mode",
  287. "label": "Port Bind Mode",
  288. "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",
  289. "schema": {
  290. "type": "string",
  291. "default": "published",
  292. "enum": [
  293. {
  294. "value": "published",
  295. "description": "Publish port on the host for external access"
  296. },
  297. {
  298. "value": "exposed",
  299. "description": "Expose port for inter-container communication"
  300. },
  301. {
  302. "value": "",
  303. "description": "None"
  304. }
  305. ]
  306. }
  307. },
  308. {
  309. "variable": "port_number",
  310. "label": "Port Number",
  311. "schema": {
  312. "type": "int",
  313. "default": 30077,
  314. "min": 1,
  315. "max": 65535,
  316. "required": true
  317. }
  318. },
  319. {
  320. "variable": "host_ips",
  321. "label": "Host IPs",
  322. "description": "IPs on the host to bind this port",
  323. "schema": {
  324. "type": "list",
  325. "show_if": [
  326. [
  327. "bind_mode",
  328. "=",
  329. "published"
  330. ]
  331. ],
  332. "default": [],
  333. "items": [
  334. {
  335. "variable": "host_ip",
  336. "label": "Host IP",
  337. "schema": {
  338. "type": "string",
  339. "required": true,
  340. "$ref": [
  341. "definitions/node_bind_ip"
  342. ]
  343. }
  344. }
  345. ]
  346. }
  347. }
  348. ]
  349. }
  350. },
  351. {
  352. "variable": "portal_http_port",
  353. "label": "Portal HTTP Port",
  354. "description": "User portal HTTP port",
  355. "schema": {
  356. "type": "dict",
  357. "attrs": [
  358. {
  359. "variable": "bind_mode",
  360. "label": "Port Bind Mode",
  361. "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",
  362. "schema": {
  363. "type": "string",
  364. "default": "published",
  365. "enum": [
  366. {
  367. "value": "published",
  368. "description": "Publish port on the host for external access"
  369. },
  370. {
  371. "value": "exposed",
  372. "description": "Expose port for inter-container communication"
  373. },
  374. {
  375. "value": "",
  376. "description": "None"
  377. }
  378. ]
  379. }
  380. },
  381. {
  382. "variable": "port_number",
  383. "label": "Port Number",
  384. "schema": {
  385. "type": "int",
  386. "default": 30078,
  387. "min": 1,
  388. "max": 65535,
  389. "required": true
  390. }
  391. },
  392. {
  393. "variable": "host_ips",
  394. "label": "Host IPs",
  395. "description": "IPs on the host to bind this port",
  396. "schema": {
  397. "type": "list",
  398. "show_if": [
  399. [
  400. "bind_mode",
  401. "=",
  402. "published"
  403. ]
  404. ],
  405. "default": [],
  406. "items": [
  407. {
  408. "variable": "host_ip",
  409. "label": "Host IP",
  410. "schema": {
  411. "type": "string",
  412. "required": true,
  413. "$ref": [
  414. "definitions/node_bind_ip"
  415. ]
  416. }
  417. }
  418. ]
  419. }
  420. }
  421. ]
  422. }
  423. },
  424. {
  425. "variable": "portal_https_port",
  426. "label": "Portal HTTPS Port",
  427. "description": "User portal HTTPS port",
  428. "schema": {
  429. "type": "dict",
  430. "attrs": [
  431. {
  432. "variable": "bind_mode",
  433. "label": "Port Bind Mode",
  434. "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",
  435. "schema": {
  436. "type": "string",
  437. "default": "published",
  438. "enum": [
  439. {
  440. "value": "published",
  441. "description": "Publish port on the host for external access"
  442. },
  443. {
  444. "value": "exposed",
  445. "description": "Expose port for inter-container communication"
  446. },
  447. {
  448. "value": "",
  449. "description": "None"
  450. }
  451. ]
  452. }
  453. },
  454. {
  455. "variable": "port_number",
  456. "label": "Port Number",
  457. "schema": {
  458. "type": "int",
  459. "default": 30079,
  460. "min": 1,
  461. "max": 65535,
  462. "required": true
  463. }
  464. },
  465. {
  466. "variable": "host_ips",
  467. "label": "Host IPs",
  468. "description": "IPs on the host to bind this port",
  469. "schema": {
  470. "type": "list",
  471. "show_if": [
  472. [
  473. "bind_mode",
  474. "=",
  475. "published"
  476. ]
  477. ],
  478. "default": [],
  479. "items": [
  480. {
  481. "variable": "host_ip",
  482. "label": "Host IP",
  483. "schema": {
  484. "type": "string",
  485. "required": true,
  486. "$ref": [
  487. "definitions/node_bind_ip"
  488. ]
  489. }
  490. }
  491. ]
  492. }
  493. }
  494. ]
  495. }
  496. },
  497. {
  498. "variable": "app_discovery_port",
  499. "label": "App Discovery Port",
  500. "description": "Omada Controller can be discovered by the Omada APP within the same network through this port",
  501. "schema": {
  502. "type": "dict",
  503. "attrs": [
  504. {
  505. "variable": "bind_mode",
  506. "label": "Port Bind Mode",
  507. "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",
  508. "schema": {
  509. "type": "string",
  510. "default": "published",
  511. "enum": [
  512. {
  513. "value": "published",
  514. "description": "Publish port on the host for external access"
  515. },
  516. {
  517. "value": "exposed",
  518. "description": "Expose port for inter-container communication"
  519. },
  520. {
  521. "value": "",
  522. "description": "None"
  523. }
  524. ]
  525. }
  526. },
  527. {
  528. "variable": "port_number",
  529. "label": "Port Number",
  530. "schema": {
  531. "type": "int",
  532. "default": 27001,
  533. "min": 1,
  534. "max": 65535,
  535. "required": true
  536. }
  537. },
  538. {
  539. "variable": "host_ips",
  540. "label": "Host IPs",
  541. "description": "IPs on the host to bind this port",
  542. "schema": {
  543. "type": "list",
  544. "show_if": [
  545. [
  546. "bind_mode",
  547. "=",
  548. "published"
  549. ]
  550. ],
  551. "default": [],
  552. "items": [
  553. {
  554. "variable": "host_ip",
  555. "label": "Host IP",
  556. "schema": {
  557. "type": "string",
  558. "required": true,
  559. "$ref": [
  560. "definitions/node_bind_ip"
  561. ]
  562. }
  563. }
  564. ]
  565. }
  566. }
  567. ]
  568. }
  569. },
  570. {
  571. "variable": "discovery_port",
  572. "label": "Discovery Port",
  573. "description": "Omada Controller and Omada Discovery Utility discover Omada devices",
  574. "schema": {
  575. "type": "dict",
  576. "attrs": [
  577. {
  578. "variable": "bind_mode",
  579. "label": "Port Bind Mode",
  580. "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",
  581. "schema": {
  582. "type": "string",
  583. "default": "published",
  584. "enum": [
  585. {
  586. "value": "published",
  587. "description": "Publish port on the host for external access"
  588. },
  589. {
  590. "value": "exposed",
  591. "description": "Expose port for inter-container communication"
  592. },
  593. {
  594. "value": "",
  595. "description": "None"
  596. }
  597. ]
  598. }
  599. },
  600. {
  601. "variable": "port_number",
  602. "label": "Port Number",
  603. "schema": {
  604. "type": "int",
  605. "default": 29810,
  606. "min": 1,
  607. "max": 65535,
  608. "required": true
  609. }
  610. },
  611. {
  612. "variable": "host_ips",
  613. "label": "Host IPs",
  614. "description": "IPs on the host to bind this port",
  615. "schema": {
  616. "type": "list",
  617. "show_if": [
  618. [
  619. "bind_mode",
  620. "=",
  621. "published"
  622. ]
  623. ],
  624. "default": [],
  625. "items": [
  626. {
  627. "variable": "host_ip",
  628. "label": "Host IP",
  629. "schema": {
  630. "type": "string",
  631. "required": true,
  632. "$ref": [
  633. "definitions/node_bind_ip"
  634. ]
  635. }
  636. }
  637. ]
  638. }
  639. }
  640. ]
  641. }
  642. },
  643. {
  644. "variable": "manager_v1_port",
  645. "label": "Manager V1 Port",
  646. "description": "Omada Controller and Omada Discovery Utility manage the Omada devices running firmware fully adapted to Omada Controller v4*",
  647. "schema": {
  648. "type": "dict",
  649. "attrs": [
  650. {
  651. "variable": "bind_mode",
  652. "label": "Port Bind Mode",
  653. "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",
  654. "schema": {
  655. "type": "string",
  656. "default": "published",
  657. "enum": [
  658. {
  659. "value": "published",
  660. "description": "Publish port on the host for external access"
  661. },
  662. {
  663. "value": "exposed",
  664. "description": "Expose port for inter-container communication"
  665. },
  666. {
  667. "value": "",
  668. "description": "None"
  669. }
  670. ]
  671. }
  672. },
  673. {
  674. "variable": "port_number",
  675. "label": "Port Number",
  676. "schema": {
  677. "type": "int",
  678. "default": 29811,
  679. "min": 1,
  680. "max": 65535,
  681. "required": true
  682. }
  683. },
  684. {
  685. "variable": "host_ips",
  686. "label": "Host IPs",
  687. "description": "IPs on the host to bind this port",
  688. "schema": {
  689. "type": "list",
  690. "show_if": [
  691. [
  692. "bind_mode",
  693. "=",
  694. "published"
  695. ]
  696. ],
  697. "default": [],
  698. "items": [
  699. {
  700. "variable": "host_ip",
  701. "label": "Host IP",
  702. "schema": {
  703. "type": "string",
  704. "required": true,
  705. "$ref": [
  706. "definitions/node_bind_ip"
  707. ]
  708. }
  709. }
  710. ]
  711. }
  712. }
  713. ]
  714. }
  715. },
  716. {
  717. "variable": "manager_v2_port",
  718. "label": "Manager V2 Port",
  719. "description": "Omada Controller and Omada Discovery Utility manage the Omada devices running firmware fully adapted to Omada Controller v5*",
  720. "schema": {
  721. "type": "dict",
  722. "attrs": [
  723. {
  724. "variable": "bind_mode",
  725. "label": "Port Bind Mode",
  726. "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",
  727. "schema": {
  728. "type": "string",
  729. "default": "published",
  730. "enum": [
  731. {
  732. "value": "published",
  733. "description": "Publish port on the host for external access"
  734. },
  735. {
  736. "value": "exposed",
  737. "description": "Expose port for inter-container communication"
  738. },
  739. {
  740. "value": "",
  741. "description": "None"
  742. }
  743. ]
  744. }
  745. },
  746. {
  747. "variable": "port_number",
  748. "label": "Port Number",
  749. "schema": {
  750. "type": "int",
  751. "default": 29814,
  752. "min": 1,
  753. "max": 65535,
  754. "required": true
  755. }
  756. },
  757. {
  758. "variable": "host_ips",
  759. "label": "Host IPs",
  760. "description": "IPs on the host to bind this port",
  761. "schema": {
  762. "type": "list",
  763. "show_if": [
  764. [
  765. "bind_mode",
  766. "=",
  767. "published"
  768. ]
  769. ],
  770. "default": [],
  771. "items": [
  772. {
  773. "variable": "host_ip",
  774. "label": "Host IP",
  775. "schema": {
  776. "type": "string",
  777. "required": true,
  778. "$ref": [
  779. "definitions/node_bind_ip"
  780. ]
  781. }
  782. }
  783. ]
  784. }
  785. }
  786. ]
  787. }
  788. },
  789. {
  790. "variable": "adopt_v1_port",
  791. "label": "Adopt V1 Port",
  792. "description": "Omada Controller and Omada Discovery Utility manage the Omada devices running firmware fully adapted to Omada Controller v4*",
  793. "schema": {
  794. "type": "dict",
  795. "attrs": [
  796. {
  797. "variable": "bind_mode",
  798. "label": "Port Bind Mode",
  799. "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",
  800. "schema": {
  801. "type": "string",
  802. "default": "published",
  803. "enum": [
  804. {
  805. "value": "published",
  806. "description": "Publish port on the host for external access"
  807. },
  808. {
  809. "value": "exposed",
  810. "description": "Expose port for inter-container communication"
  811. },
  812. {
  813. "value": "",
  814. "description": "None"
  815. }
  816. ]
  817. }
  818. },
  819. {
  820. "variable": "port_number",
  821. "label": "Port Number",
  822. "schema": {
  823. "type": "int",
  824. "default": 29812,
  825. "min": 1,
  826. "max": 65535,
  827. "required": true
  828. }
  829. },
  830. {
  831. "variable": "host_ips",
  832. "label": "Host IPs",
  833. "description": "IPs on the host to bind this port",
  834. "schema": {
  835. "type": "list",
  836. "show_if": [
  837. [
  838. "bind_mode",
  839. "=",
  840. "published"
  841. ]
  842. ],
  843. "default": [],
  844. "items": [
  845. {
  846. "variable": "host_ip",
  847. "label": "Host IP",
  848. "schema": {
  849. "type": "string",
  850. "required": true,
  851. "$ref": [
  852. "definitions/node_bind_ip"
  853. ]
  854. }
  855. }
  856. ]
  857. }
  858. }
  859. ]
  860. }
  861. },
  862. {
  863. "variable": "upgrade_v1_port",
  864. "label": "Upgrade V1 Port",
  865. "description": "When upgrading the firmware for the Omada devices running firmware fully adapted to Omada Controller v4*.",
  866. "schema": {
  867. "type": "dict",
  868. "attrs": [
  869. {
  870. "variable": "bind_mode",
  871. "label": "Port Bind Mode",
  872. "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",
  873. "schema": {
  874. "type": "string",
  875. "default": "published",
  876. "enum": [
  877. {
  878. "value": "published",
  879. "description": "Publish port on the host for external access"
  880. },
  881. {
  882. "value": "exposed",
  883. "description": "Expose port for inter-container communication"
  884. },
  885. {
  886. "value": "",
  887. "description": "None"
  888. }
  889. ]
  890. }
  891. },
  892. {
  893. "variable": "port_number",
  894. "label": "Port Number",
  895. "schema": {
  896. "type": "int",
  897. "default": 29813,
  898. "min": 1,
  899. "max": 65535,
  900. "required": true
  901. }
  902. },
  903. {
  904. "variable": "host_ips",
  905. "label": "Host IPs",
  906. "description": "IPs on the host to bind this port",
  907. "schema": {
  908. "type": "list",
  909. "show_if": [
  910. [
  911. "bind_mode",
  912. "=",
  913. "published"
  914. ]
  915. ],
  916. "default": [],
  917. "items": [
  918. {
  919. "variable": "host_ip",
  920. "label": "Host IP",
  921. "schema": {
  922. "type": "string",
  923. "required": true,
  924. "$ref": [
  925. "definitions/node_bind_ip"
  926. ]
  927. }
  928. }
  929. ]
  930. }
  931. }
  932. ]
  933. }
  934. },
  935. {
  936. "variable": "transfer_v2_port",
  937. "label": "Transfer V2 Port",
  938. "description": "Omada Controller receives Device Info and Packet Capture files from the Omada devices",
  939. "schema": {
  940. "type": "dict",
  941. "attrs": [
  942. {
  943. "variable": "bind_mode",
  944. "label": "Port Bind Mode",
  945. "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",
  946. "schema": {
  947. "type": "string",
  948. "default": "published",
  949. "enum": [
  950. {
  951. "value": "published",
  952. "description": "Publish port on the host for external access"
  953. },
  954. {
  955. "value": "exposed",
  956. "description": "Expose port for inter-container communication"
  957. },
  958. {
  959. "value": "",
  960. "description": "None"
  961. }
  962. ]
  963. }
  964. },
  965. {
  966. "variable": "port_number",
  967. "label": "Port Number",
  968. "schema": {
  969. "type": "int",
  970. "default": 29815,
  971. "min": 1,
  972. "max": 65535,
  973. "required": true
  974. }
  975. },
  976. {
  977. "variable": "host_ips",
  978. "label": "Host IPs",
  979. "description": "IPs on the host to bind this port",
  980. "schema": {
  981. "type": "list",
  982. "show_if": [
  983. [
  984. "bind_mode",
  985. "=",
  986. "published"
  987. ]
  988. ],
  989. "default": [],
  990. "items": [
  991. {
  992. "variable": "host_ip",
  993. "label": "Host IP",
  994. "schema": {
  995. "type": "string",
  996. "required": true,
  997. "$ref": [
  998. "definitions/node_bind_ip"
  999. ]
  1000. }
  1001. }
  1002. ]
  1003. }
  1004. }
  1005. ]
  1006. }
  1007. },
  1008. {
  1009. "variable": "rtty_port",
  1010. "label": "RTTY Port",
  1011. "description": "Omada Controller establishes the remote control terminal session with the Omada devices",
  1012. "schema": {
  1013. "type": "dict",
  1014. "attrs": [
  1015. {
  1016. "variable": "bind_mode",
  1017. "label": "Port Bind Mode",
  1018. "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",
  1019. "schema": {
  1020. "type": "string",
  1021. "default": "published",
  1022. "enum": [
  1023. {
  1024. "value": "published",
  1025. "description": "Publish port on the host for external access"
  1026. },
  1027. {
  1028. "value": "exposed",
  1029. "description": "Expose port for inter-container communication"
  1030. },
  1031. {
  1032. "value": "",
  1033. "description": "None"
  1034. }
  1035. ]
  1036. }
  1037. },
  1038. {
  1039. "variable": "port_number",
  1040. "label": "Port Number",
  1041. "schema": {
  1042. "type": "int",
  1043. "default": 29816,
  1044. "min": 1,
  1045. "max": 65535,
  1046. "required": true
  1047. }
  1048. },
  1049. {
  1050. "variable": "host_ips",
  1051. "label": "Host IPs",
  1052. "description": "IPs on the host to bind this port",
  1053. "schema": {
  1054. "type": "list",
  1055. "show_if": [
  1056. [
  1057. "bind_mode",
  1058. "=",
  1059. "published"
  1060. ]
  1061. ],
  1062. "default": [],
  1063. "items": [
  1064. {
  1065. "variable": "host_ip",
  1066. "label": "Host IP",
  1067. "schema": {
  1068. "type": "string",
  1069. "required": true,
  1070. "$ref": [
  1071. "definitions/node_bind_ip"
  1072. ]
  1073. }
  1074. }
  1075. ]
  1076. }
  1077. }
  1078. ]
  1079. }
  1080. },
  1081. {
  1082. "variable": "host_network",
  1083. "label": "Host Network",
  1084. "description": "Bind to the host network. It's recommended to keep this disabled.\n",
  1085. "schema": {
  1086. "type": "boolean",
  1087. "default": false
  1088. }
  1089. },
  1090. {
  1091. "variable": "certificate_id",
  1092. "label": "Certificate ID",
  1093. "description": "The certificate id to use for the https endpoint.",
  1094. "schema": {
  1095. "type": "int",
  1096. "null": true,
  1097. "$ref": [
  1098. "definitions/certificate"
  1099. ]
  1100. }
  1101. }
  1102. ]
  1103. }
  1104. },
  1105. {
  1106. "variable": "storage",
  1107. "label": "",
  1108. "group": "Storage Configuration",
  1109. "schema": {
  1110. "type": "dict",
  1111. "attrs": [
  1112. {
  1113. "variable": "data",
  1114. "label": "Omada Controller Data Storage",
  1115. "description": "The path to store Omada Controller Data.",
  1116. "schema": {
  1117. "type": "dict",
  1118. "attrs": [
  1119. {
  1120. "variable": "type",
  1121. "label": "Type",
  1122. "description": "ixVolume: Is dataset created automatically by the system.</br>\nHost Path: Is a path that already exists on the system.\n",
  1123. "schema": {
  1124. "type": "string",
  1125. "required": true,
  1126. "default": "ix_volume",
  1127. "enum": [
  1128. {
  1129. "value": "host_path",
  1130. "description": "Host Path (Path that already exists on the system)"
  1131. },
  1132. {
  1133. "value": "ix_volume",
  1134. "description": "ixVolume (Dataset created automatically by the system)"
  1135. }
  1136. ]
  1137. }
  1138. },
  1139. {
  1140. "variable": "ix_volume_config",
  1141. "label": "ixVolume Configuration",
  1142. "description": "The configuration for the ixVolume dataset.",
  1143. "schema": {
  1144. "type": "dict",
  1145. "show_if": [
  1146. [
  1147. "type",
  1148. "=",
  1149. "ix_volume"
  1150. ]
  1151. ],
  1152. "$ref": [
  1153. "normalize/ix_volume"
  1154. ],
  1155. "attrs": [
  1156. {
  1157. "variable": "acl_enable",
  1158. "label": "Enable ACL",
  1159. "description": "Enable ACL for the storage.",
  1160. "schema": {
  1161. "type": "boolean",
  1162. "default": false
  1163. }
  1164. },
  1165. {
  1166. "variable": "dataset_name",
  1167. "label": "Dataset Name",
  1168. "description": "The name of the dataset to use for storage.",
  1169. "schema": {
  1170. "type": "string",
  1171. "required": true,
  1172. "hidden": true,
  1173. "default": "data"
  1174. }
  1175. },
  1176. {
  1177. "variable": "acl_entries",
  1178. "label": "ACL Configuration",
  1179. "schema": {
  1180. "type": "dict",
  1181. "show_if": [
  1182. [
  1183. "acl_enable",
  1184. "=",
  1185. true
  1186. ]
  1187. ],
  1188. "attrs": []
  1189. }
  1190. }
  1191. ]
  1192. }
  1193. },
  1194. {
  1195. "variable": "host_path_config",
  1196. "label": "Host Path Configuration",
  1197. "schema": {
  1198. "type": "dict",
  1199. "show_if": [
  1200. [
  1201. "type",
  1202. "=",
  1203. "host_path"
  1204. ]
  1205. ],
  1206. "attrs": [
  1207. {
  1208. "variable": "acl_enable",
  1209. "label": "Enable ACL",
  1210. "description": "Enable ACL for the storage.",
  1211. "schema": {
  1212. "type": "boolean",
  1213. "default": false
  1214. }
  1215. },
  1216. {
  1217. "variable": "acl",
  1218. "label": "ACL Configuration",
  1219. "schema": {
  1220. "type": "dict",
  1221. "show_if": [
  1222. [
  1223. "acl_enable",
  1224. "=",
  1225. true
  1226. ]
  1227. ],
  1228. "attrs": [],
  1229. "$ref": [
  1230. "normalize/acl"
  1231. ]
  1232. }
  1233. },
  1234. {
  1235. "variable": "path",
  1236. "label": "Host Path",
  1237. "description": "The host path to use for storage.",
  1238. "schema": {
  1239. "type": "hostpath",
  1240. "show_if": [
  1241. [
  1242. "acl_enable",
  1243. "=",
  1244. false
  1245. ]
  1246. ],
  1247. "required": true
  1248. }
  1249. }
  1250. ]
  1251. }
  1252. }
  1253. ]
  1254. }
  1255. },
  1256. {
  1257. "variable": "logs",
  1258. "label": "Omada Controller Logs Storage",
  1259. "description": "The path to store Omada Controller Logs.",
  1260. "schema": {
  1261. "type": "dict",
  1262. "attrs": [
  1263. {
  1264. "variable": "type",
  1265. "label": "Type",
  1266. "description": "ixVolume: Is dataset created automatically by the system.</br>\nHost Path: Is a path that already exists on the system.\n",
  1267. "schema": {
  1268. "type": "string",
  1269. "required": true,
  1270. "default": "ix_volume",
  1271. "enum": [
  1272. {
  1273. "value": "host_path",
  1274. "description": "Host Path (Path that already exists on the system)"
  1275. },
  1276. {
  1277. "value": "ix_volume",
  1278. "description": "ixVolume (Dataset created automatically by the system)"
  1279. }
  1280. ]
  1281. }
  1282. },
  1283. {
  1284. "variable": "ix_volume_config",
  1285. "label": "ixVolume Configuration",
  1286. "description": "The configuration for the ixVolume dataset.",
  1287. "schema": {
  1288. "type": "dict",
  1289. "show_if": [
  1290. [
  1291. "type",
  1292. "=",
  1293. "ix_volume"
  1294. ]
  1295. ],
  1296. "$ref": [
  1297. "normalize/ix_volume"
  1298. ],
  1299. "attrs": [
  1300. {
  1301. "variable": "acl_enable",
  1302. "label": "Enable ACL",
  1303. "description": "Enable ACL for the storage.",
  1304. "schema": {
  1305. "type": "boolean",
  1306. "default": false
  1307. }
  1308. },
  1309. {
  1310. "variable": "dataset_name",
  1311. "label": "Dataset Name",
  1312. "description": "The name of the dataset to use for storage.",
  1313. "schema": {
  1314. "type": "string",
  1315. "required": true,
  1316. "hidden": true,
  1317. "default": "logs"
  1318. }
  1319. },
  1320. {
  1321. "variable": "acl_entries",
  1322. "label": "ACL Configuration",
  1323. "schema": {
  1324. "type": "dict",
  1325. "show_if": [
  1326. [
  1327. "acl_enable",
  1328. "=",
  1329. true
  1330. ]
  1331. ],
  1332. "attrs": []
  1333. }
  1334. }
  1335. ]
  1336. }
  1337. },
  1338. {
  1339. "variable": "host_path_config",
  1340. "label": "Host Path Configuration",
  1341. "schema": {
  1342. "type": "dict",
  1343. "show_if": [
  1344. [
  1345. "type",
  1346. "=",
  1347. "host_path"
  1348. ]
  1349. ],
  1350. "attrs": [
  1351. {
  1352. "variable": "acl_enable",
  1353. "label": "Enable ACL",
  1354. "description": "Enable ACL for the storage.",
  1355. "schema": {
  1356. "type": "boolean",
  1357. "default": false
  1358. }
  1359. },
  1360. {
  1361. "variable": "acl",
  1362. "label": "ACL Configuration",
  1363. "schema": {
  1364. "type": "dict",
  1365. "show_if": [
  1366. [
  1367. "acl_enable",
  1368. "=",
  1369. true
  1370. ]
  1371. ],
  1372. "attrs": [],
  1373. "$ref": [
  1374. "normalize/acl"
  1375. ]
  1376. }
  1377. },
  1378. {
  1379. "variable": "path",
  1380. "label": "Host Path",
  1381. "description": "The host path to use for storage.",
  1382. "schema": {
  1383. "type": "hostpath",
  1384. "show_if": [
  1385. [
  1386. "acl_enable",
  1387. "=",
  1388. false
  1389. ]
  1390. ],
  1391. "required": true
  1392. }
  1393. }
  1394. ]
  1395. }
  1396. }
  1397. ]
  1398. }
  1399. },
  1400. {
  1401. "variable": "additional_storage",
  1402. "label": "Additional Storage",
  1403. "schema": {
  1404. "type": "list",
  1405. "default": [],
  1406. "items": [
  1407. {
  1408. "variable": "storageEntry",
  1409. "label": "Storage Entry",
  1410. "schema": {
  1411. "type": "dict",
  1412. "attrs": [
  1413. {
  1414. "variable": "type",
  1415. "label": "Type",
  1416. "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",
  1417. "schema": {
  1418. "type": "string",
  1419. "required": true,
  1420. "default": "ix_volume",
  1421. "enum": [
  1422. {
  1423. "value": "host_path",
  1424. "description": "Host Path (Path that already exists on the system)"
  1425. },
  1426. {
  1427. "value": "ix_volume",
  1428. "description": "ixVolume (Dataset created automatically by the system)"
  1429. },
  1430. {
  1431. "value": "cifs",
  1432. "description": "SMB/CIFS Share (Mounts a volume to a SMB share)"
  1433. }
  1434. ]
  1435. }
  1436. },
  1437. {
  1438. "variable": "read_only",
  1439. "label": "Read Only",
  1440. "description": "Mount the volume as read only.",
  1441. "schema": {
  1442. "type": "boolean",
  1443. "default": false
  1444. }
  1445. },
  1446. {
  1447. "variable": "mount_path",
  1448. "label": "Mount Path",
  1449. "description": "The path inside the container to mount the storage.",
  1450. "schema": {
  1451. "type": "path",
  1452. "required": true
  1453. }
  1454. },
  1455. {
  1456. "variable": "host_path_config",
  1457. "label": "Host Path Configuration",
  1458. "schema": {
  1459. "type": "dict",
  1460. "show_if": [
  1461. [
  1462. "type",
  1463. "=",
  1464. "host_path"
  1465. ]
  1466. ],
  1467. "attrs": [
  1468. {
  1469. "variable": "acl_enable",
  1470. "label": "Enable ACL",
  1471. "description": "Enable ACL for the storage.",
  1472. "schema": {
  1473. "type": "boolean",
  1474. "default": false
  1475. }
  1476. },
  1477. {
  1478. "variable": "acl",
  1479. "label": "ACL Configuration",
  1480. "schema": {
  1481. "type": "dict",
  1482. "show_if": [
  1483. [
  1484. "acl_enable",
  1485. "=",
  1486. true
  1487. ]
  1488. ],
  1489. "attrs": [],
  1490. "$ref": [
  1491. "normalize/acl"
  1492. ]
  1493. }
  1494. },
  1495. {
  1496. "variable": "path",
  1497. "label": "Host Path",
  1498. "description": "The host path to use for storage.",
  1499. "schema": {
  1500. "type": "hostpath",
  1501. "show_if": [
  1502. [
  1503. "acl_enable",
  1504. "=",
  1505. false
  1506. ]
  1507. ],
  1508. "required": true
  1509. }
  1510. }
  1511. ]
  1512. }
  1513. },
  1514. {
  1515. "variable": "ix_volume_config",
  1516. "label": "ixVolume Configuration",
  1517. "description": "The configuration for the ixVolume dataset.",
  1518. "schema": {
  1519. "type": "dict",
  1520. "show_if": [
  1521. [
  1522. "type",
  1523. "=",
  1524. "ix_volume"
  1525. ]
  1526. ],
  1527. "$ref": [
  1528. "normalize/ix_volume"
  1529. ],
  1530. "attrs": [
  1531. {
  1532. "variable": "acl_enable",
  1533. "label": "Enable ACL",
  1534. "description": "Enable ACL for the storage.",
  1535. "schema": {
  1536. "type": "boolean",
  1537. "default": false
  1538. }
  1539. },
  1540. {
  1541. "variable": "dataset_name",
  1542. "label": "Dataset Name",
  1543. "description": "The name of the dataset to use for storage.",
  1544. "schema": {
  1545. "type": "string",
  1546. "required": true,
  1547. "default": "storage_entry"
  1548. }
  1549. },
  1550. {
  1551. "variable": "acl_entries",
  1552. "label": "ACL Configuration",
  1553. "schema": {
  1554. "type": "dict",
  1555. "show_if": [
  1556. [
  1557. "acl_enable",
  1558. "=",
  1559. true
  1560. ]
  1561. ],
  1562. "attrs": []
  1563. }
  1564. }
  1565. ]
  1566. }
  1567. },
  1568. {
  1569. "variable": "cifs_config",
  1570. "label": "SMB Configuration",
  1571. "description": "The configuration for the SMB dataset.",
  1572. "schema": {
  1573. "type": "dict",
  1574. "show_if": [
  1575. [
  1576. "type",
  1577. "=",
  1578. "cifs"
  1579. ]
  1580. ],
  1581. "attrs": [
  1582. {
  1583. "variable": "server",
  1584. "label": "Server",
  1585. "description": "The server to mount the SMB share.",
  1586. "schema": {
  1587. "type": "string",
  1588. "required": true
  1589. }
  1590. },
  1591. {
  1592. "variable": "path",
  1593. "label": "Path",
  1594. "description": "The path to mount the SMB share.",
  1595. "schema": {
  1596. "type": "string",
  1597. "required": true
  1598. }
  1599. },
  1600. {
  1601. "variable": "username",
  1602. "label": "Username",
  1603. "description": "The username to use for the SMB share.",
  1604. "schema": {
  1605. "type": "string",
  1606. "required": true
  1607. }
  1608. },
  1609. {
  1610. "variable": "password",
  1611. "label": "Password",
  1612. "description": "The password to use for the SMB share.",
  1613. "schema": {
  1614. "type": "string",
  1615. "required": true,
  1616. "private": true
  1617. }
  1618. },
  1619. {
  1620. "variable": "domain",
  1621. "label": "Domain",
  1622. "description": "The domain to use for the SMB share.",
  1623. "schema": {
  1624. "type": "string"
  1625. }
  1626. }
  1627. ]
  1628. }
  1629. }
  1630. ]
  1631. }
  1632. }
  1633. ]
  1634. }
  1635. }
  1636. ]
  1637. }
  1638. },
  1639. {
  1640. "variable": "labels",
  1641. "label": "",
  1642. "group": "Labels Configuration",
  1643. "schema": {
  1644. "type": "list",
  1645. "default": [],
  1646. "items": [
  1647. {
  1648. "variable": "label",
  1649. "label": "Label",
  1650. "schema": {
  1651. "type": "dict",
  1652. "attrs": [
  1653. {
  1654. "variable": "key",
  1655. "label": "Key",
  1656. "schema": {
  1657. "type": "string",
  1658. "required": true
  1659. }
  1660. },
  1661. {
  1662. "variable": "value",
  1663. "label": "Value",
  1664. "schema": {
  1665. "type": "string",
  1666. "required": true
  1667. }
  1668. },
  1669. {
  1670. "variable": "containers",
  1671. "label": "Containers",
  1672. "description": "Containers where the label should be applied",
  1673. "schema": {
  1674. "type": "list",
  1675. "items": [
  1676. {
  1677. "variable": "container",
  1678. "label": "Container",
  1679. "schema": {
  1680. "type": "string",
  1681. "required": true,
  1682. "enum": [
  1683. {
  1684. "value": "omada",
  1685. "description": "omada"
  1686. }
  1687. ]
  1688. }
  1689. }
  1690. ]
  1691. }
  1692. }
  1693. ]
  1694. }
  1695. }
  1696. ]
  1697. }
  1698. },
  1699. {
  1700. "variable": "resources",
  1701. "label": "",
  1702. "group": "Resources Configuration",
  1703. "schema": {
  1704. "type": "dict",
  1705. "attrs": [
  1706. {
  1707. "variable": "limits",
  1708. "label": "Limits",
  1709. "schema": {
  1710. "type": "dict",
  1711. "attrs": [
  1712. {
  1713. "variable": "cpus",
  1714. "label": "CPUs",
  1715. "description": "CPUs limit for Omada Controller.",
  1716. "schema": {
  1717. "type": "int",
  1718. "default": 2,
  1719. "required": true
  1720. }
  1721. },
  1722. {
  1723. "variable": "memory",
  1724. "label": "Memory (in MB)",
  1725. "description": "Memory limit for Omada Controller.",
  1726. "schema": {
  1727. "type": "int",
  1728. "default": 4096,
  1729. "required": true
  1730. }
  1731. }
  1732. ]
  1733. }
  1734. }
  1735. ]
  1736. }
  1737. }
  1738. ]
  1739. },
  1740. "readme": "<h1>Omada Controller</h1> <p><a href=\"https://github.com/mbentley/docker-omada-controller\">Omada Controller</a> is a network management controller for Omada (TP-Link) Equipment.</p>",
  1741. "changelog": null,
  1742. "chart_metadata": {
  1743. "annotations": {
  1744. "min_scale_version": "24.10.2.2"
  1745. },
  1746. "app_version": "5.15.24.19",
  1747. "capabilities": [
  1748. {
  1749. "description": "Omada Controller is able to change file ownership arbitrarily",
  1750. "name": "CHOWN"
  1751. },
  1752. {
  1753. "description": "Omada Controller is able to bypass file permission checks",
  1754. "name": "DAC_OVERRIDE"
  1755. },
  1756. {
  1757. "description": "Omada Controller is able to bypass permission checks for file operations",
  1758. "name": "FOWNER"
  1759. },
  1760. {
  1761. "description": "Omada Controller is able to change group ID of processes",
  1762. "name": "SETGID"
  1763. },
  1764. {
  1765. "description": "Omada Controller is able to change user ID of processes",
  1766. "name": "SETUID"
  1767. }
  1768. ],
  1769. "categories": [
  1770. "networking"
  1771. ],
  1772. "changelog_url": "https://github.com/mbentley/docker-omada-controller/releases",
  1773. "date_added": "2024-08-02",
  1774. "description": "Omada Controller (TP-Link) is a network management controller for TP-Link Omada Equipment",
  1775. "home": "https://github.com/mbentley/docker-omada-controller",
  1776. "host_mounts": [],
  1777. "icon": "https://media.sys.truenas.net/apps/omada-controller/icons/icon.svg",
  1778. "keywords": [
  1779. "network",
  1780. "controller",
  1781. "omada",
  1782. "tp-link"
  1783. ],
  1784. "lib_version": "2.1.49",
  1785. "lib_version_hash": "e71e6b0122c9446fa5ea6fb07e7eb01b11fb42d549a19845426bbd7e21a42634",
  1786. "maintainers": [
  1787. {
  1788. "email": "dev@ixsystems.com",
  1789. "name": "truenas",
  1790. "url": "https://www.truenas.com/"
  1791. }
  1792. ],
  1793. "name": "omada-controller",
  1794. "run_as_context": [
  1795. {
  1796. "description": "Omada Controller runs as root user.",
  1797. "gid": 0,
  1798. "group_name": "root",
  1799. "uid": 0,
  1800. "user_name": "root"
  1801. }
  1802. ],
  1803. "screenshots": [],
  1804. "sources": [
  1805. "https://github.com/mbentley/docker-omada-controller",
  1806. "https://hub.docker.com/r/mbentley/omada-controller"
  1807. ],
  1808. "title": "Omada Controller",
  1809. "train": "community",
  1810. "version": "1.3.8"
  1811. }
  1812. }
  1813. }