mirror of
https://github.com/yusing/godoxy.git
synced 2025-07-05 14:24:02 +02:00
fix(agent): remove agent properly on verify error
This commit is contained in:
parent
08b262d94b
commit
4d88d59100
2 changed files with 10 additions and 3 deletions
|
@ -63,20 +63,23 @@ func (cfg *Config) VerifyNewAgent(host string, ca agent.PEMPair, client agent.PE
|
||||||
return 0, gperr.New("agent already exists")
|
return 0, gperr.New("agent already exists")
|
||||||
}
|
}
|
||||||
|
|
||||||
var agentCfg agent.AgentConfig
|
agentCfg := new(agent.AgentConfig)
|
||||||
agentCfg.Addr = host
|
agentCfg.Addr = host
|
||||||
err := agentCfg.InitWithCerts(cfg.task.Context(), ca.Cert, client.Cert, client.Key)
|
err := agentCfg.InitWithCerts(cfg.task.Context(), ca.Cert, client.Cert, client.Key)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return 0, gperr.Wrap(err, "failed to start agent")
|
return 0, gperr.Wrap(err, "failed to start agent")
|
||||||
}
|
}
|
||||||
agent.Agents.Add(&agentCfg)
|
// must add it first to let LoadRoutes() reference from it
|
||||||
|
agent.Agents.Add(agentCfg)
|
||||||
|
|
||||||
provider := provider.NewAgentProvider(&agentCfg)
|
provider := provider.NewAgentProvider(agentCfg)
|
||||||
if err := cfg.errIfExists(provider); err != nil {
|
if err := cfg.errIfExists(provider); err != nil {
|
||||||
|
agent.Agents.Del(agentCfg)
|
||||||
return 0, err
|
return 0, err
|
||||||
}
|
}
|
||||||
err = provider.LoadRoutes()
|
err = provider.LoadRoutes()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
|
agent.Agents.Del(agentCfg)
|
||||||
return 0, gperr.Wrap(err, "failed to load routes")
|
return 0, gperr.Wrap(err, "failed to load routes")
|
||||||
}
|
}
|
||||||
return provider.NumRoutes(), nil
|
return provider.NumRoutes(), nil
|
||||||
|
|
|
@ -26,6 +26,10 @@ func (p Pool[T]) Add(obj T) {
|
||||||
p.m.Store(obj.Key(), obj)
|
p.m.Store(obj.Key(), obj)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func (p Pool[T]) Del(obj T) {
|
||||||
|
p.m.Delete(obj.Key())
|
||||||
|
}
|
||||||
|
|
||||||
func (p Pool[T]) Get(key string) (T, bool) {
|
func (p Pool[T]) Get(key string) (T, bool) {
|
||||||
return p.m.Load(key)
|
return p.m.Load(key)
|
||||||
}
|
}
|
||||||
|
|
Loading…
Add table
Reference in a new issue