| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768 |
- // package mod_serv_http -- модуль HTTP-сервера.
- package mod_serv_http
- import (
- "fmt"
- "sync"
- . "gitp78su.ipnodns.ru/svi/kern/v4/lev0/ktypes"
- . "gitp78su.ipnodns.ru/svi/kern/v4/lev1/result"
- "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"
- )
- // ModuleServHttp -- модуль HTTP-сервера.
- type ModuleServHttp struct {
- IKernelModule
- kServHttp IKernelServerHttp
- log ILogBuf
- }
- var (
- mod *ModuleServHttp
- block sync.RWMutex
- )
- // GetModuleServHttp -- возвращает новый модуль HTTP-сервера.
- func GetModuleServHttp() IResult[*ModuleServHttp] {
- block.Lock()
- defer block.Unlock()
- if mod != nil {
- return NewRes(mod)
- }
- resMod := kmodule.NewKernelModule("kServHttp")
- if resMod.IsErr() {
- err := fmt.Errorf("GetModuleServHttp(): in NewKernelModule, err=\n\t%w", resMod.Err())
- return NewErr[*ModuleServHttp](err)
- }
- resHttp := kserv_http.GetKernelServHttp()
- if resHttp.IsErr() {
- err := fmt.Errorf("GetModuleServHttp(): in GetKernelServHttp, err=\n\t%w", resHttp.Err())
- return NewErr[*ModuleServHttp](err)
- }
- sf := &ModuleServHttp{
- IKernelModule: resMod.Val(),
- kServHttp: resHttp.Val(),
- }
- sf.log = sf.Ctx().Log()
- _ = page_monolit.GetPageMonolit()
- _ = page_module.GetPageModule()
- _ = http_api.NewHttpApi()
- mod = sf
- return NewRes(sf)
- }
- // Run -- запускает модуль в работу.
- func (sf *ModuleServHttp) Run() {
- sf.log.Info("ModuleServHttp.Run(): module=%v, is run", sf.Name())
- go sf.kServHttp.Run()
- }
- // IsWork -- признак работы модуля.
- func (sf *ModuleServHttp) IsWork() bool {
- return sf.kServHttp.IsWork()
- }
|