Skip to content

Commit

Permalink
Update the query for osctrl-admin
Browse files Browse the repository at this point in the history
  • Loading branch information
zhuoyuan-liu committed Dec 11, 2024
1 parent 370977b commit 234e42e
Show file tree
Hide file tree
Showing 3 changed files with 35 additions and 58 deletions.
72 changes: 31 additions & 41 deletions admin/handlers/post.go
Original file line number Diff line number Diff line change
Expand Up @@ -156,100 +156,90 @@ func (h *HandlersAdmin) QueryRunPOSTHandler(w http.ResponseWriter, r *http.Reque
adminErrorResponse(w, "error creating query", http.StatusInternalServerError, err)
return
}
// Temporary list of UUIDs to calculate Expected
var expected []string

// List all the nodes that match the query
var expected []uint

targetNodesID := []uint{}
// TODO: Refactor this to use osctrl-api instead of direct DB queries
// Create environment target
if len(q.Environments) > 0 {
expected = []uint{}
for _, e := range q.Environments {
if (e != "") && h.Envs.Exists(e) {
if err := h.Queries.CreateTarget(newQuery.Name, queries.QueryTargetEnvironment, e); err != nil {
adminErrorResponse(w, "error creating query environment target", http.StatusInternalServerError, err)
h.Inc(metricAdminErr)
return
}
nodes, err := h.Nodes.GetByEnv(e, "active", h.Settings.InactiveHours(settings.NoEnvironmentID))
if err != nil {
adminErrorResponse(w, "error getting nodes by environment", http.StatusInternalServerError, err)
h.Inc(metricAdminErr)
return
}
for _, n := range nodes {
expected = append(expected, n.UUID)
expected = append(expected, n.ID)
}
}
}
targetNodesID = utils.Intersect(targetNodesID, expected)
}
// Create platform target
if len(q.Platforms) > 0 {
expected = []uint{}
platforms, _ := h.Nodes.GetAllPlatforms()
for _, p := range q.Platforms {
if (p != "") && checkValidPlatform(platforms, p) {
if err := h.Queries.CreateTarget(newQuery.Name, queries.QueryTargetPlatform, p); err != nil {
adminErrorResponse(w, "error creating query platform target", http.StatusInternalServerError, err)
h.Inc(metricAdminErr)
return
}
nodes, err := h.Nodes.GetByPlatform(p, "active", h.Settings.InactiveHours(settings.NoEnvironmentID))
if err != nil {
adminErrorResponse(w, "error getting nodes by platform", http.StatusInternalServerError, err)
h.Inc(metricAdminErr)
return
}
for _, n := range nodes {
expected = append(expected, n.UUID)
expected = append(expected, n.ID)
}
}
}
targetNodesID = utils.Intersect(targetNodesID, expected)
}
// Create UUIDs target
if len(q.UUIDs) > 0 {
expected = []uint{}
for _, u := range q.UUIDs {
if (u != "") && h.Nodes.CheckByUUID(u) {
if err := h.Queries.CreateTarget(newQuery.Name, queries.QueryTargetUUID, u); err != nil {
adminErrorResponse(w, "error creating query UUID target", http.StatusInternalServerError, err)
h.Inc(metricAdminErr)
return
if u != "" {
node, err := h.Nodes.GetByUUID(u)
if err != nil {
log.Err(err).Msgf("error getting node %s and failed to create node query for it", u)
continue
}
expected = append(expected, u)
expected = append(expected, node.ID)
}
}
targetNodesID = utils.Intersect(targetNodesID, expected)
}
// Create hostnames target
if len(q.Hosts) > 0 {
expected = []uint{}
for _, _h := range q.Hosts {
if (_h != "") && h.Nodes.CheckByHost(_h) {
if err := h.Queries.CreateTarget(newQuery.Name, queries.QueryTargetLocalname, _h); err != nil {
adminErrorResponse(w, "error creating query hostname target", http.StatusInternalServerError, err)
h.Inc(metricAdminErr)
return
if _h != "" {
node, err := h.Nodes.GetByIdentifier(_h)
if err != nil {
log.Err(err).Msgf("error getting node %s and failed to create node query for it", _h)
continue
}
expected = append(expected, _h)
expected = append(expected, node.ID)
}
}
targetNodesID = utils.Intersect(targetNodesID, expected)
}
// Remove duplicates from expected
expectedClear := removeStringDuplicates(expected)

// Create new record for query list
nodesID := make([]uint, len(expectedClear))
for _, nodeUUID := range expectedClear {
node, err := h.Nodes.GetByUUID(nodeUUID)
if err != nil {
log.Err(err).Msgf("error getting node %s and failed to create node query for it", nodeUUID)
continue
}
nodesID = append(nodesID, node.ID)
}
// If the list is empty, we don't need to create node queries
if len(nodesID) != 0 {
if err := h.Queries.CreateNodeQueries(nodesID, newQuery.ID); err != nil {
if len(targetNodesID) != 0 {
if err := h.Queries.CreateNodeQueries(targetNodesID, newQuery.ID); err != nil {
log.Err(err).Msgf("error creating node queries for query %s", newQuery.Name)
adminErrorResponse(w, "error creating node queries", http.StatusInternalServerError, err)
return
}
}
// Update value for expected
if err := h.Queries.SetExpected(newQuery.Name, len(expectedClear), env.ID); err != nil {
if err := h.Queries.SetExpected(newQuery.Name, len(targetNodesID), env.ID); err != nil {
adminErrorResponse(w, "error setting expected", http.StatusInternalServerError, err)
h.Inc(metricAdminErr)
return
Expand Down
6 changes: 4 additions & 2 deletions api/handlers/queries.go
Original file line number Diff line number Diff line change
Expand Up @@ -200,7 +200,7 @@ func (h *HandlersApi) QueriesRunHandler(w http.ResponseWriter, r *http.Request)
if u != "" {
node, err := h.Nodes.GetByUUID(u)
if err != nil {
log.Err(err).Msgf("error getting node %s and failed to create node query for it", u)
log.Warn().Msgf("error getting node %s and failed to create node query for it", u)
continue
}
expected = append(expected, node.ID)
Expand All @@ -209,13 +209,15 @@ func (h *HandlersApi) QueriesRunHandler(w http.ResponseWriter, r *http.Request)
targetNodesID = utils.Intersect(targetNodesID, expected)
}
// Create hostnames target
// Currently we are using the GetByIdentifier function and it need be more clear
// about the definition of the identifier
if len(q.Hosts) > 0 {
expected = []uint{}
for _, hostName := range q.Hosts {
if hostName != "" {
node, err := h.Nodes.GetByIdentifier(hostName)
if err != nil {
log.Err(err).Msgf("error getting node %s and failed to create node query for it", hostName)
log.Warn().Msgf("error getting node %s and failed to create node query for it", hostName)
continue
}
expected = append(expected, node.ID)
Expand Down
15 changes: 0 additions & 15 deletions api/handlers/utils.go
Original file line number Diff line number Diff line change
Expand Up @@ -53,18 +53,3 @@ func checkValidPlatform(platforms []string, platform string) bool {
}
return false
}

// Helper to remove duplicates from []string
func removeStringDuplicates(s []string) []string {
seen := make(map[string]struct{}, len(s))
i := 0
for _, v := range s {
if _, ok := seen[v]; ok {
continue
}
seen[v] = struct{}{}
s[i] = v
i++
}
return s[:i]
}

0 comments on commit 234e42e

Please sign in to comment.