kern.go 7.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226
  1. // package kern -- библиотека гибкого универсального облегчённого ядра для любого микросервиса.
  2. package kern
  3. import (
  4. "context"
  5. mL0 "gitp78su.ipnodns.ru/svi/kern/v4/lev0"
  6. "gitp78su.ipnodns.ru/svi/kern/v4/lev0/defs/module_name"
  7. mKs "gitp78su.ipnodns.ru/svi/kern/v4/lev0/kspec"
  8. mL1 "gitp78su.ipnodns.ru/svi/kern/v4/lev1"
  9. "gitp78su.ipnodns.ru/svi/kern/v4/lev2/kbus_http"
  10. "gitp78su.ipnodns.ru/svi/kern/v4/lev2/kbus_http/client_bus_http"
  11. "gitp78su.ipnodns.ru/svi/kern/v4/lev2/kbus_local"
  12. "gitp78su.ipnodns.ru/svi/kern/v4/lev2/kbus_local/client_bus_local"
  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/kmonolit"
  16. "gitp78su.ipnodns.ru/svi/kern/v4/lev2/kserv_http"
  17. "gitp78su.ipnodns.ru/svi/kern/v4/lev2/kstore_kv"
  18. "gitp78su.ipnodns.ru/svi/kern/v4/lev3/mod_kctx"
  19. "gitp78su.ipnodns.ru/svi/kern/v4/lev3/mod_keeper"
  20. "gitp78su.ipnodns.ru/svi/kern/v4/lev3/mod_serv_http"
  21. "gitp78su.ipnodns.ru/svi/kern/v4/lev3/mod_wui"
  22. )
  23. // GetKernelCtx -- возвращает контекст ядра.
  24. func GetKernelCtx() mKs.IKernelCtx {
  25. ctx := kctx.GetKernelCtx()
  26. return ctx
  27. }
  28. // NewErr -- возвращает Result с ошибкой.
  29. func NewErr[T any](err error) mL0.IResult[T] {
  30. return mL0.NewErr[T](err)
  31. }
  32. // NewOk -- возвращает успешный Result с значением.
  33. func NewOk[T any](res T) mL0.IResult[T] {
  34. return mL0.NewOk(res)
  35. }
  36. // WrapErr -- оборачивает существующий Result с ошибкой с новой ошибкой.
  37. func WrapErr[T any](res mL0.IResult[T], err error) mL0.IResult[T] {
  38. return mL0.WrapErr(res, err)
  39. }
  40. // GetKernelStoreKv -- возвращает быстрое key-value хранилище ядра.
  41. func GetKernelStoreKv() mKs.IKernelStoreKv {
  42. store := kstore_kv.GetKernelStore()
  43. return store
  44. }
  45. // GetKernelServerHttp -- возвращает веб-сервер ядра.
  46. func GetKernelServerHttp() mKs.IKernelServerHttp {
  47. kernServHttp := kserv_http.GetKernelServHttp()
  48. return kernServHttp
  49. }
  50. type ISafeBool = mKs.ISafeBool
  51. // NewSafeBool -- возвращает новый потокобезопасный булевый признак.
  52. func NewSafeBool(val bool) ISafeBool {
  53. sb := mL1.NewSafeBool(val)
  54. return sb
  55. }
  56. // GetKernelBusLocal -- возвращает локальную шину данных.
  57. func GetKernelBusLocal() mKs.IKernelBus {
  58. kCtx := kctx.GetKernelCtx()
  59. kCtx.Set("monolitName", "unknown monolit", "GetKernelBusLocal()")
  60. lBus := kbus_local.GetKernelBusLocal()
  61. return lBus
  62. }
  63. // GetKernelBusHttp -- возвращает HTTP шину данных.
  64. func GetKernelBusHttp() mKs.IKernelBus {
  65. bus := kbus_http.GetKernelBusHttp()
  66. return bus
  67. }
  68. // SleepMs -- спит миллисекунду.
  69. func SleepMs() {
  70. mL1.SleepMs()
  71. }
  72. // GetMonolitLocal -- возвращает монолит с локальной шиной.
  73. func GetMonolitLocal(name string) mKs.IKernelMonolit {
  74. kCtx := kctx.GetKernelCtx()
  75. kCtx.Set("isLocal", true, "bus type")
  76. for {
  77. SleepMs()
  78. optIsLocal := kCtx.Get("isLocal")
  79. if optIsLocal.IsSome() {
  80. break
  81. }
  82. }
  83. kMonolit := kmonolit.GetMonolit(name)
  84. _ = kbus_local.GetKernelBusLocal()
  85. return kMonolit
  86. }
  87. // GetMonolitHttp -- возвращает монолит с локальной шиной поверх HTTP.
  88. func GetMonolitHttp(name string) mKs.IKernelMonolit {
  89. kCtx := kctx.GetKernelCtx()
  90. _ = kbus_http.GetKernelBusHttp()
  91. kCtx.Set("isLocal", false, "bus type")
  92. for {
  93. SleepMs()
  94. optIsLocal := kCtx.Get("isLocal")
  95. if optIsLocal.IsSome() {
  96. break
  97. }
  98. }
  99. kMon := kmonolit.GetMonolit(name)
  100. return kMon
  101. }
  102. // NewKernelModule -- возвращает новый модуль на ядре.
  103. func NewKernelModule(name *module_name.AModuleName) mKs.IKernelModule {
  104. resMod := kmodule.NewKernelModule(name)
  105. return resMod
  106. }
  107. // NewClientBusLocal -- возвращает клиент для работы с локальной шиной.
  108. func NewClientBusLocal() mKs.IBusClient {
  109. lClient := client_bus_local.NewClientBusLocal()
  110. return lClient
  111. }
  112. // NewClientBusHttp -- возвращает клиент для работы с шиной поверх HTTP.
  113. func NewClientBusHttp(url string) mKs.IBusClient {
  114. client := client_bus_http.NewClientBusHttp(url)
  115. return client
  116. }
  117. // GetModuleServHttp -- возвращает модуль для IKernelServHttp.
  118. func GetModuleServHttp() mKs.IKernelModule {
  119. modServHttp := mod_serv_http.GetModuleServHttp()
  120. return modServHttp
  121. }
  122. // GetModuleKernelCtx -- возвращает модуль для IKernelCtx.
  123. func GetModuleKernelCtx() mKs.IKernelModule {
  124. kModCtx := mod_kctx.GetModuleKernelCtx()
  125. return kModCtx
  126. }
  127. // GetModuleKernelKeeper -- возвращает модуль для IKernelKeeper.
  128. func GetModuleKernelKeeper() mKs.IKernelModule {
  129. modKernelKeeper := mod_keeper.GetModuleKeeper()
  130. return modKernelKeeper
  131. }
  132. // GetModuleWui -- возвращает модуль для WUI.
  133. func GetModuleWui() mKs.IKernelModule {
  134. modWui := mod_wui.GetModuleWui()
  135. return modWui
  136. }
  137. // ILogBuf -- буферизованный лог
  138. type ILogBuf = mKs.ILogBuf
  139. // LogBufParam -- параметры для создания нового буферизованного лога.
  140. type LogBufParam = mL1.LogBufParam
  141. // NewLogBuf -- возвращает новый буферизованный лог.
  142. func NewLogBuf(param *LogBufParam) ILogBuf {
  143. log := mL1.NewLogBuf(param)
  144. return log
  145. }
  146. // NewSafeBoolReact -- возвращает новую потокобезопасную реактивную булеву переменную.
  147. func NewSafeBoolReact() mKs.ISafeBoolReact {
  148. val := mL1.NewSafeBoolReact()
  149. return val
  150. }
  151. // NewSafeInt -- возвращает новую потокобезопасную целочисленную переменную.
  152. func NewSafeInt(val int) mKs.ISafeInt {
  153. val_ := mL1.NewSafeInt(val)
  154. return val_
  155. }
  156. // NewInt -- возвращает новую целочисленную переменную.
  157. func NewInt(val int) mKs.Int {
  158. val_ := mL1.NewInt(val)
  159. return val_
  160. }
  161. // NewLocalCtx -- возвращает новый локальный контекст.
  162. func NewLocalCtx(ctx context.Context) mKs.ILocalCtx {
  163. lCtx := mL1.NewLocalCtx(ctx)
  164. return lCtx
  165. }
  166. // NewSafeString -- возвращает новую потокобезопасную строку.
  167. func NewSafeString() mKs.ISafeString {
  168. str := mL1.NewSafeString()
  169. return str
  170. }
  171. // NewSome -- возвращает новый не пустой результат операции.
  172. func NewSome[T any](some T) mL0.IOption[T] {
  173. return mL0.NewSome(some)
  174. }
  175. // NewNone -- возвращает новый пустой результат операции.
  176. func NewNone[T any]() mL0.IOption[T] {
  177. return mL0.NewNone[T]()
  178. }
  179. // FnHassert -- проверяет с жёстким падением условие.
  180. type FnHassert = mL1.FnHassert
  181. // Hassert -- возвращает ссылку на функцию Hassert.
  182. func Hassert() FnHassert {
  183. return mL1.Hassert()
  184. }
  185. // FnAssert -- проверка на правильность утверждения с падением в панику на локальном стенде (soft assert).
  186. type FnAssert = mL1.FnAssert
  187. // Assert -- возвращает ссылку на функцию Hassert.
  188. func Assert() FnAssert {
  189. return mL1.Assert()
  190. }