mod_wui.go 4.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147
  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/lev0/helpers"
  11. . "gitp78su.ipnodns.ru/svi/kern/v4/lev0/ktypes"
  12. . "gitp78su.ipnodns.ru/svi/kern/v4/lev1/result"
  13. "gitp78su.ipnodns.ru/svi/kern/v4/lev2/kctx"
  14. "gitp78su.ipnodns.ru/svi/kern/v4/lev2/kmodule"
  15. "gitp78su.ipnodns.ru/svi/kern/v4/lev2/kserv_http"
  16. "gitp78su.ipnodns.ru/svi/kern/v4/lev2/wui"
  17. . "gitp78su.ipnodns.ru/svi/kern/v4/lev2/wui/wtypes"
  18. "gitp78su.ipnodns.ru/svi/kern/v4/lev3/mod_serv_http/http_api"
  19. "gitp78su.ipnodns.ru/svi/kern/v4/lev3/mod_serv_http/page_module"
  20. "gitp78su.ipnodns.ru/svi/kern/v4/lev3/mod_serv_http/page_monolit"
  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. resKernCtx := kctx.GetKernelCtx()
  52. if resKernCtx.IsErr() {
  53. err := fmt.Errorf("GetModuleWui(): mod='wui', in get KernelCtx, err=\n\t%w", resKernCtx.Err())
  54. return NewErr[*ModuleWui](err)
  55. }
  56. kCtx := resKernCtx.Val()
  57. resWuiCtx := wui.GetWuiCtx()
  58. if resWuiCtx.IsErr() {
  59. err := fmt.Errorf("GetModuleWui(): mod='wui', in get WuiCtx, err=\n\t%w", resWuiCtx.Err())
  60. return NewErr[*ModuleWui](err)
  61. }
  62. wuiCtx := resWuiCtx.Val()
  63. sf := &ModuleWui{
  64. kCtx: kCtx,
  65. wCtx: wuiCtx,
  66. IKernelModule: resMod.Val(),
  67. kServHttp: resHttp.Val(),
  68. }
  69. sf.log = sf.wCtx.Log()
  70. _ = page_monolit.GetPageMonolit()
  71. _ = page_module.GetPageModule()
  72. _ = http_api.NewHttpApi()
  73. optFiber := sf.kCtx.Get("fiberApp")
  74. if optFiber.IsNone() {
  75. err := fmt.Errorf("GetModuleWui(): mod='wui', not found fiberApp in kernel ctx")
  76. return NewErr[*ModuleWui](err)
  77. }
  78. fibApp := optFiber.Val().Val().(*fiber.App)
  79. fibApp.Post("/wui/click/:id", adaptor.HTTPHandlerFunc(sf.wuiClick)) // adaptor.HTTPHandlerFunc(greet)
  80. mod = sf
  81. return NewRes(sf)
  82. }
  83. // Run -- запускает модуль в работу
  84. func (sf *ModuleWui) Run() {
  85. sf.log.Info("ModuleWui.Run(): module=%v, is run", sf.Name())
  86. sf.kServHttp.Run()
  87. }
  88. // Log -- возвращает буферный лог
  89. func (sf *ModuleWui) Log() ILogBuf {
  90. return sf.log
  91. }
  92. // IsWork -- признак работы модуля
  93. func (sf *ModuleWui) IsWork() bool {
  94. return sf.kCtx.Wg().IsWork()
  95. }
  96. // Получает событие из сети
  97. func (sf *ModuleWui) wuiClick(resp http.ResponseWriter, req *http.Request) {
  98. url := req.RequestURI
  99. id := strings.TrimPrefix(url, "/wui/click/")
  100. widget0 := sf.wCtx.Get(id)
  101. if widget0 == nil {
  102. strOut := fmt.Sprintf("ModuleWui.wuiClick(): id(%v), widget not exists", id)
  103. sf.log.Err(strOut)
  104. fmt.Fprint(resp, strOut)
  105. return
  106. }
  107. widget1, isOk := widget0.Val().(IWuiButton)
  108. if !isOk {
  109. strOut := fmt.Sprintf("ModuleWui.wuiClick(): widget(%T) not button", widget0.Val())
  110. sf.log.Err(strOut)
  111. fmt.Fprint(resp, strOut)
  112. return
  113. }
  114. dict := map[string]string{}
  115. // headers := ctx.GetReqHeaders()
  116. for key, lstVal := range req.Header {
  117. if len(lstVal) >= 1 {
  118. dict[key] = lstVal[0]
  119. continue
  120. }
  121. }
  122. err := req.ParseForm()
  123. Hassert(err == nil, "ModuleWui.wuiClick(): in parse form, err=\n\t%v", err)
  124. // Получаем все form-значения
  125. // values := req.ParseForm()
  126. for key, lstVal := range req.Form {
  127. if len(lstVal) >= 1 {
  128. dict[key] = lstVal[0]
  129. continue
  130. }
  131. }
  132. strOut := widget1.Click(dict)
  133. fmt.Fprint(resp, strOut)
  134. }