mod_wui.go 3.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119
  1. // package mod_wui -- модуль WUI
  2. package mod_wui
  3. import (
  4. "fmt"
  5. "net/http"
  6. "strings"
  7. "sync"
  8. "github.com/gofiber/fiber/v2"
  9. "github.com/gofiber/fiber/v2/middleware/adaptor"
  10. . "gitp78su.ipnodns.ru/svi/kern/v3/kc/helpers"
  11. "gitp78su.ipnodns.ru/svi/kern/v3/krn/kctx"
  12. "gitp78su.ipnodns.ru/svi/kern/v3/krn/kmodule"
  13. "gitp78su.ipnodns.ru/svi/kern/v3/krn/kserv_http"
  14. . "gitp78su.ipnodns.ru/svi/kern/v3/krn/ktypes"
  15. "gitp78su.ipnodns.ru/svi/kern/v3/mds/mod_serv_http/http_api"
  16. "gitp78su.ipnodns.ru/svi/kern/v3/mds/mod_serv_http/page_module"
  17. "gitp78su.ipnodns.ru/svi/kern/v3/mds/mod_serv_http/page_monolit"
  18. "gitp78su.ipnodns.ru/svi/kern/v3/wui"
  19. . "gitp78su.ipnodns.ru/svi/kern/v3/wui/wtypes"
  20. )
  21. // ModuleWui -- модуль WUI
  22. type ModuleWui struct {
  23. IKernelModule
  24. kCtx IKernelCtx
  25. wCtx IWuiCtx
  26. kServHttp IKernelServerHttp
  27. log ILogBuf
  28. }
  29. var (
  30. mod *ModuleWui
  31. block sync.Mutex
  32. )
  33. // GetModuleWui -- возвращает новый модуль WUI
  34. func GetModuleWui() *ModuleWui {
  35. block.Lock()
  36. defer block.Unlock()
  37. if mod != nil {
  38. return mod
  39. }
  40. sf := &ModuleWui{
  41. kCtx: kctx.GetKernelCtx(),
  42. wCtx: wui.GetWuiCtx(),
  43. IKernelModule: kmodule.NewKernelModule("wui"),
  44. kServHttp: kserv_http.GetKernelServHttp(),
  45. }
  46. sf.log = sf.wCtx.Log()
  47. _ = page_monolit.GetPageMonolit()
  48. _ = page_module.GetPageModule()
  49. _ = http_api.NewHttpApi()
  50. fibApp := sf.kCtx.Get("fiberApp").Val().(*fiber.App)
  51. fibApp.Post("/wui/click/:id", adaptor.HTTPHandlerFunc(sf.wuiClick)) // adaptor.HTTPHandlerFunc(greet)
  52. mod = sf
  53. return sf
  54. }
  55. // Run -- запускает модуль в работу
  56. func (sf *ModuleWui) Run() {
  57. sf.log.Info("ModuleWui.Run(): module=%v, is run", sf.Name())
  58. go sf.kServHttp.Run()
  59. }
  60. // Log -- возвращает буферный лог
  61. func (sf *ModuleWui) Log() ILogBuf {
  62. return sf.log
  63. }
  64. // IsWork -- признак работы модуля
  65. func (sf *ModuleWui) IsWork() bool {
  66. return sf.kCtx.Wg().IsWork()
  67. }
  68. // Получает событие из сети
  69. func (sf *ModuleWui) wuiClick(resp http.ResponseWriter, req *http.Request) {
  70. url := req.RequestURI
  71. id := strings.TrimPrefix(url, "/wui/click/")
  72. widget0 := sf.wCtx.Get(id)
  73. if widget0 == nil {
  74. strOut := fmt.Sprintf("ModuleWui.wuiClick(): id(%v), widget not exists", id)
  75. sf.log.Err(strOut)
  76. fmt.Fprint(resp, strOut)
  77. return
  78. }
  79. widget1, isOk := widget0.Val().(IWuiButton)
  80. if !isOk {
  81. strOut := fmt.Sprintf("ModuleWui.wuiClick(): widget(%T) not button", widget0.Val())
  82. sf.log.Err(strOut)
  83. fmt.Fprint(resp, strOut)
  84. return
  85. }
  86. dict := map[string]string{}
  87. // headers := ctx.GetReqHeaders()
  88. for key, lstVal := range req.Header {
  89. if len(lstVal) >= 1 {
  90. dict[key] = lstVal[0]
  91. continue
  92. }
  93. }
  94. err := req.ParseForm()
  95. Hassert(err == nil, "ModuleWui.wuiClick(): in parse form, err=\n\t%v", err)
  96. // Получаем все form-значения
  97. //values := req.ParseForm()
  98. for key, lstVal := range req.Form {
  99. if len(lstVal) >= 1 {
  100. dict[key] = lstVal[0]
  101. continue
  102. }
  103. }
  104. strOut := widget1.Click(dict)
  105. fmt.Fprint(resp, strOut)
  106. }