| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263 |
- // package mod_keeper -- модуль сторожа ядра.
- package mod_keeper
- import (
- "sync"
- "gitp78su.ipnodns.ru/svi/kern/v4/lev0/defs"
- mKs "gitp78su.ipnodns.ru/svi/kern/v4/lev0/kspec"
- "gitp78su.ipnodns.ru/svi/kern/v4/lev2/kctx"
- "gitp78su.ipnodns.ru/svi/kern/v4/lev2/kmodule"
- "gitp78su.ipnodns.ru/svi/kern/v4/lev2/kserv_http"
- "gitp78su.ipnodns.ru/svi/kern/v4/lev3/mod_serv_http/http_api"
- "gitp78su.ipnodns.ru/svi/kern/v4/lev3/mod_serv_http/page_module"
- "gitp78su.ipnodns.ru/svi/kern/v4/lev3/mod_serv_http/page_monolit"
- )
- // ModuleKeeper -- модуль сторожа.
- type ModuleKeeper struct {
- mKs.IKernelModule
- kCtx mKs.IKernelCtx
- kServHttp mKs.IKernelServerHttp
- log mKs.ILogBuf
- }
- var (
- mod *ModuleKeeper
- block sync.Mutex
- )
- // GetModuleKeeper -- возвращает новый модуль сторожа ядра.
- func GetModuleKeeper() *ModuleKeeper {
- block.Lock()
- defer block.Unlock()
- if mod != nil {
- return mod
- }
- kServHttp := kserv_http.GetKernelServHttp()
- modName := defs.NewModuleName("kKeeper")
- kModKeep := kmodule.NewKernelModule(modName)
- sf := &ModuleKeeper{
- kCtx: kctx.GetKernelCtx(),
- IKernelModule: kModKeep,
- kServHttp: kServHttp,
- }
- sf.log = sf.kCtx.Keeper().Log()
- _ = page_monolit.GetPageMonolit()
- _ = page_module.GetPageModule()
- _ = http_api.NewHttpApi()
- mod = sf
- return sf
- }
- // Run -- запускает модуль в работу.
- func (sf *ModuleKeeper) Run() {
- sf.log.Info("ModuleKernelCtx.Run(): module=%v, is run", sf.Name())
- go sf.kServHttp.Run()
- }
- // IsWork -- признак работы модуля.
- func (sf *ModuleKeeper) IsWork() bool {
- return sf.kCtx.Wg().IsWork()
- }
|