tacticalrmm/natsapi/tasks.go

77 lines
2.1 KiB
Go
Raw Normal View History

2021-01-29 20:10:52 +00:00
package api
import (
2021-02-16 08:33:54 +00:00
"sync"
2021-01-29 20:10:52 +00:00
"time"
"github.com/go-resty/resty/v2"
nats "github.com/nats-io/nats.go"
"github.com/ugorji/go/codec"
)
2021-01-30 04:39:15 +00:00
func monitorAgents(c *resty.Client, nc *nats.Conn) {
var payload, recPayload []byte
var mh codec.MsgpackHandle
mh.RawToString = true
ret := codec.NewEncoderBytes(&payload, new(codec.MsgpackHandle))
ret.Encode(map[string]string{"func": "ping"})
rec := codec.NewEncoderBytes(&recPayload, new(codec.MsgpackHandle))
rec.Encode(Recovery{
Func: "recover",
Data: map[string]string{"mode": "tacagent"},
})
tick := time.NewTicker(10 * time.Minute)
for range tick.C {
2021-02-16 08:33:54 +00:00
var wg sync.WaitGroup
2021-01-30 04:39:15 +00:00
agentids, _ := c.R().SetResult(&AgentIDS{}).Get("/offline/")
ids := agentids.Result().(*AgentIDS).IDs
2021-02-16 08:33:54 +00:00
wg.Add(len(ids))
2021-01-30 04:39:15 +00:00
var resp string
2021-02-16 08:33:54 +00:00
2021-01-30 04:39:15 +00:00
for _, id := range ids {
2021-02-16 08:33:54 +00:00
go func(id string, nc *nats.Conn, wg *sync.WaitGroup, c *resty.Client) {
defer wg.Done()
out, err := nc.Request(id, payload, 1*time.Second)
if err != nil {
return
2021-01-30 04:39:15 +00:00
}
2021-02-16 08:33:54 +00:00
dec := codec.NewDecoderBytes(out.Data, &mh)
if err := dec.Decode(&resp); err == nil {
// if the agent is respoding to pong from the rpc service but is not showing as online (handled by tacticalagent service)
// then tacticalagent service is hung. forcefully restart it
if resp == "pong" {
nc.Publish(id, recPayload)
p := map[string]string{"agentid": id}
c.R().SetBody(p).Post("/logcrash/")
}
}
}(id, nc, &wg, c)
2021-01-30 04:39:15 +00:00
}
}
}
2021-01-29 20:10:52 +00:00
func getWMI(c *resty.Client, nc *nats.Conn) {
var payload []byte
var mh codec.MsgpackHandle
mh.RawToString = true
ret := codec.NewEncoderBytes(&payload, new(codec.MsgpackHandle))
ret.Encode(map[string]string{"func": "wmi"})
tick := time.NewTicker(18 * time.Minute)
for range tick.C {
agentids, _ := c.R().SetResult(&AgentIDS{}).Get("/wmi/")
ids := agentids.Result().(*AgentIDS).IDs
chunks := makeChunks(ids, 40)
for _, id := range chunks {
for _, chunk := range id {
nc.Publish(chunk, payload)
time.Sleep(time.Duration(randRange(50, 400)) * time.Millisecond)
}
time.Sleep(15 * time.Second)
}
}
}