-
Notifications
You must be signed in to change notification settings - Fork 1
/
delete_bot.go
64 lines (54 loc) · 1.56 KB
/
delete_bot.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
package backend
import (
"fmt"
"log"
"net/http"
"time"
"github.com/stellar/kelp/gui/model2"
"github.com/stellar/kelp/support/kelpos"
)
func (s *APIServer) deleteBot(w http.ResponseWriter, r *http.Request) {
botName, e := s.parseBotName(r)
if e != nil {
s.writeError(w, fmt.Sprintf("error in deleteBot: %s\n", e))
return
}
// only stop bot if current state is running
botState, e := s.doGetBotState(botName)
if e != nil {
s.writeError(w, fmt.Sprintf("error in deleteBot unable to get botState: %s\n", e))
return
}
log.Printf("current botState: %s\n", botState)
if botState == kelpos.BotStateRunning {
e = s.doStopBot(botName)
if e != nil {
s.writeError(w, fmt.Sprintf("error stopping bot when trying to delete: %s\n", e))
return
}
}
for {
botState, e := s.doGetBotState(botName)
if e != nil {
s.writeError(w, fmt.Sprintf("error in deleteBot for loop, unable to get botState: %s\n", e))
return
}
log.Printf("deleteBot for loop, current botState: %s\n", botState)
if botState == kelpos.BotStateStopped || botState == kelpos.BotStateInitializing {
break
}
time.Sleep(time.Second)
}
// unregister bot
s.kos.SafeUnregisterBot(botName)
// delete configs
botPrefix := model2.GetPrefix(botName)
botConfigPath := s.botConfigsPath.Join(botPrefix)
_, e = s.kos.Blocking("rm", fmt.Sprintf("rm %s*", botConfigPath.Unix()))
if e != nil {
s.writeError(w, fmt.Sprintf("error running rm command for bot configs: %s\n", e))
return
}
log.Printf("removed bot configs for prefix '%s'\n", botPrefix)
w.WriteHeader(http.StatusOK)
}