mod_wui.go 4.1 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. mKh "gitp78su.ipnodns.ru/svi/kern/v4/lev0/helpers"
  11. mKt "gitp78su.ipnodns.ru/svi/kern/v4/lev0/ktypes"
  12. mKr "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. mWt "gitp78su.ipnodns.ru/svi/kern/v4/lev2/wui/wui_types"
  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. mKt.IKernelModule
  25. kCtx mKt.IKernelCtx
  26. wCtx mWt.IWuiCtx
  27. kServHttp mKt.IKernelServerHttp
  28. log mKt.ILogBuf
  29. }
  30. var (
  31. mod *ModuleWui
  32. block sync.Mutex
  33. )
  34. // GetModuleWui -- возвращает новый модуль WUI.
  35. func GetModuleWui() mKt.IResult[*ModuleWui] {
  36. block.Lock()
  37. defer block.Unlock()
  38. if mod != nil {
  39. return mKr.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 mKr.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 mKr.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 mKr.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 mKr.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 mKr.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 mKr.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() mKt.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().(mWt.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. mKh.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. }