kmodule.go 3.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123
  1. // package kmodule -- модуль на основе ядра
  2. package kmodule
  3. import (
  4. "time"
  5. . "gitp78su.ipnodns.ru/svi/kern/v3/kc/helpers"
  6. "gitp78su.ipnodns.ru/svi/kern/v3/kc/local_ctx"
  7. "gitp78su.ipnodns.ru/svi/kern/v3/kc/safe_int"
  8. "gitp78su.ipnodns.ru/svi/kern/v3/kc/safe_string"
  9. . "gitp78su.ipnodns.ru/svi/kern/v3/krn/kalias"
  10. "gitp78su.ipnodns.ru/svi/kern/v3/krn/kbus/kbus_local"
  11. "gitp78su.ipnodns.ru/svi/kern/v3/krn/kctx"
  12. "gitp78su.ipnodns.ru/svi/kern/v3/krn/kmodule/mod_stat"
  13. . "gitp78su.ipnodns.ru/svi/kern/v3/krn/ktypes"
  14. )
  15. // kModule -- модуль на основе ядра
  16. type kModule struct {
  17. kCtx IKernelCtx
  18. ctx ILocalCtx
  19. name AModuleName
  20. bus IKernelBus
  21. timePhase ISafeInt
  22. strLive ISafeString
  23. stat IModuleStat
  24. }
  25. // NewKernelModule -- возвращает новый модуль на основе ядра
  26. func NewKernelModule(name AModuleName) IKernelModule {
  27. Hassert(name != "", "NewKernelModule(): name is empty")
  28. kCtx := kctx.GetKernelCtx()
  29. sf := &kModule{
  30. kCtx: kCtx,
  31. ctx: local_ctx.NewLocalCtx(kCtx.Ctx()),
  32. name: name,
  33. bus: kbus_local.GetKernelBusLocal(),
  34. timePhase: safe_int.NewSafeInt(1000), // 1000 msec
  35. strLive: safe_string.NewSafeString(),
  36. stat: mod_stat.NewModStat(name),
  37. }
  38. go sf.sigLive()
  39. return sf
  40. }
  41. // Stat -- возвращает статистику модуля
  42. func (sf *kModule) Stat() IModuleStat {
  43. return sf.stat
  44. }
  45. // Log -- возвращает буферный лог
  46. func (sf *kModule) Log() ILogBuf {
  47. return sf.ctx.Log()
  48. }
  49. // Ctx -- возвращает контекст модуля
  50. func (sf *kModule) Ctx() ILocalCtx {
  51. return sf.ctx
  52. }
  53. // Run -- запускает модуль в работу
  54. func (sf *kModule) Run() {
  55. Hassert(false, "kModule.Run(): module='%v', parent not realised this method", sf.name)
  56. }
  57. // Name -- возвращает уникальное имя модуля
  58. func (sf *kModule) Name() AModuleName {
  59. return sf.name
  60. }
  61. // IsWork -- возвращает признак состояния работы
  62. func (sf *kModule) IsWork() bool {
  63. Hassert(false, "kModule.IsWork(): module='%v', parent not realised this method", sf.name)
  64. return false
  65. }
  66. // Live -- возвращает индикатор жизни модуля
  67. func (sf *kModule) Live() string {
  68. return sf.strLive.Get()
  69. }
  70. // Сигнал жизни, каждые 5 сек публикует в шину метку
  71. func (sf *kModule) sigLive() {
  72. var (
  73. topic = sf.name + "_live"
  74. iPhase = 0
  75. res Result[bool]
  76. )
  77. fnPhase := func() {
  78. time.Sleep(time.Millisecond * time.Duration(sf.timePhase.Get()))
  79. select {
  80. case <-sf.kCtx.Ctx().Done():
  81. return
  82. default:
  83. switch iPhase {
  84. case 0:
  85. sf.strLive.Set("|")
  86. res = sf.bus.Publish(ATopic(topic), sf.strLive.Byte())
  87. case 1:
  88. sf.strLive.Set("/")
  89. res = sf.bus.Publish(ATopic(topic), sf.strLive.Byte())
  90. case 2:
  91. sf.strLive.Set("-")
  92. res = sf.bus.Publish(ATopic(topic), sf.strLive.Byte())
  93. case 3:
  94. sf.strLive.Set("\\")
  95. res = sf.bus.Publish(ATopic(topic), sf.strLive.Byte())
  96. iPhase = -1
  97. }
  98. res.Hassert("kModule.sigLive(): name=%v, in publish live", sf.Name())
  99. iPhase++
  100. sf.stat.Add(1)
  101. }
  102. }
  103. for {
  104. select {
  105. case <-sf.kCtx.Ctx().Done():
  106. return
  107. default:
  108. fnPhase()
  109. }
  110. }
  111. }