overflow_probes/auth/auth.go
crusader e6f66ad7f0 ing
2018-03-26 12:50:29 +09:00

131 lines
2.7 KiB
Go

package auth
import (
"context"
"fmt"
"path"
"sync"
cc "git.loafle.net/commons_go/config"
"git.loafle.net/commons_go/logging"
crr "git.loafle.net/commons_go/rpc/registry"
ooccn "git.loafle.net/overflow/overflow_commons_go/config/noauthprobe"
oocmci "git.loafle.net/overflow/overflow_commons_go/modules/commons/interfaces"
oogwc "git.loafle.net/overflow/overflow_gateway_websocket/client"
"git.loafle.net/overflow/overflow_probes/auth/client"
oopas "git.loafle.net/overflow/overflow_probes/auth/service"
"git.loafle.net/overflow/overflow_probes/config"
)
func New() AuthManager {
am := &authManagers{}
return am
}
type AuthManager interface {
oocmci.EndableStarter
oocmci.Stopper
}
type authManagers struct {
doneChan chan<- error
cClient oogwc.Client
configPath string
config ooccn.NoAuthProbeConfig
serviceDoneChan chan error
stopChan chan struct{}
stopWg sync.WaitGroup
}
func (am *authManagers) EndableStart(doneChan chan<- error) error {
if nil != am.stopChan {
logging.Logger().Panicf("Auth: auth is already running. Stop it before starting it again")
}
am.configPath = path.Join(*config.ConfigDir, ooccn.ConfigFileName)
conf := cc.New()
if cc.Exists(am.configPath) {
if err := conf.Load(&am.config, am.configPath); nil != err {
return fmt.Errorf("Auth: Loading of NoAuth config file[%s] failed error[%v]", am.configPath, err)
}
}
if nil != am.config.DenyDate {
return fmt.Errorf("Cannot start because this probe have been denied from overFlow at %s", am.config.DenyDate.String())
}
am.serviceDoneChan = make(chan error, 1)
rpcRegistry := crr.NewRPCRegistry()
napService := &oopas.NoAuthProbeService{
DoneChan: am.serviceDoneChan,
ConfigPath: am.configPath,
Config: am.config,
}
rpcRegistry.RegisterService(napService, "")
ch := client.NewClientHandler(rpcRegistry)
sb := client.NewSocketBuilder(napService)
if nil == sb {
return fmt.Errorf("Auth: Cannot create SocketBuilder")
}
am.cClient = client.NewClient(ch, sb)
am.doneChan = doneChan
am.stopChan = make(chan struct{})
am.stopWg.Add(1)
go am.handleAuth()
return nil
}
func (am *authManagers) Stop(ctx context.Context) error {
am.destroy(nil)
return nil
}
func (am *authManagers) destroy(err error) {
if am.stopChan == nil {
logging.Logger().Warnf("Auth: auth must be started before stopping it")
}
close(am.stopChan)
am.stopWg.Wait()
am.stopChan = nil
am.cClient.Close()
close(am.serviceDoneChan)
logging.Logger().Infof("Auth: stopped")
am.doneChan <- err
}
func (am *authManagers) handleAuth() {
var err error
defer func() {
am.stopWg.Done()
am.destroy(err)
}()
if err = am.cClient.Connect(); nil != err {
return
}
for {
select {
case err = <-am.serviceDoneChan:
return
case <-am.stopChan:
return
}
}
}