mod_wui.go 3.6 KB

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