Skip to content

Commit

Permalink
add reverse DNS resolution
Browse files Browse the repository at this point in the history
  • Loading branch information
noboruma committed Jun 12, 2024
1 parent 6240fd5 commit ac486ad
Showing 1 changed file with 26 additions and 5 deletions.
31 changes: 26 additions & 5 deletions deepfence_server/ingesters/agent.go
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,7 @@ import (
"encoding/json"
"fmt"
"io"
"net"
"net/http"
"os"
"strconv"
Expand Down Expand Up @@ -414,6 +415,7 @@ type Connection struct {
localPort int
leftIP *string
rightIP *string
resolved bool
}

func connections2maps(connections []Connection, buf *bytes.Buffer) []map[string]interface{} {
Expand Down Expand Up @@ -625,7 +627,8 @@ func prepareNeo4jIngestion(rpt *report.Report, resolvers *EndpointResolversCache
}
}
}
connections = resolveCloudService(connections, token)
connections = resolveCloudServices(connections, token)
connections = resolveReverseDNS(connections)
res.EndpointEdgesBatch = connections2maps(connections, buf)

processEdgesBatch := map[string][]string{}
Expand Down Expand Up @@ -768,7 +771,8 @@ func (nc *neo4jIngester) PushToDBSeq(ctx context.Context, batches ReportIngestio
if _, err := tx.Run(ctx, `
UNWIND $batch as row
MATCH (n:Node{node_id: row.source})
MATCH (m:Node{node_id: row.destination})
MERGE (m:Node{node_id: row.destination})
ON CREATE SET m.pseudo = true, m.active = true, m.updated_at = TIMESTAMP()
MERGE (n)-[r:CONNECTS]->(m)
WITH n, r, m, row.pids as rpids
UNWIND rpids as pids
Expand Down Expand Up @@ -1422,9 +1426,9 @@ func requestCloudInfo(ctx context.Context, strIps []string, token string) ([]Clo
return res.Infos, nil
}

func resolveCloudService(connections []Connection, token string) []Connection {
func resolveCloudServices(connections []Connection, token string) []Connection {
ips := []string{}
ids := []int{}
ids := []int{}
for i := range connections {
if connections[i].rightIP != nil {
ips = append(ips, *connections[i].rightIP)
Expand All @@ -1440,7 +1444,24 @@ func resolveCloudService(connections []Connection, token string) []Connection {
return connections
}
for i := range infos {
connections[ids[i]].destination = infos[i].NodeID()
if !strings.Contains(infos[i].NodeID(), "unknown") {
connections[ids[i]].destination = infos[i].NodeID()
connections[ids[i]].resolved = true
}
}
return connections
}

func resolveReverseDNS(connections []Connection) []Connection {
for i := range connections {
if connections[i].rightIP != nil && !connections[i].resolved {
names, err := net.LookupAddr(*connections[i].rightIP)
if err != nil || len(names) == 0 {
log.Error().Err(err).Msgf("Reverse DNS failed for %s", *connections[i].rightIP)
continue
}
connections[i].destination = fmt.Sprintf("out-", names[0])

Check failure on line 1463 in deepfence_server/ingesters/agent.go

View workflow job for this annotation

GitHub Actions / lint-server

printf: fmt.Sprintf call has arguments but no formatting directives (govet)
}
}
return connections
}

0 comments on commit ac486ad

Please sign in to comment.