feature/query-results #12
@ -51,27 +51,27 @@ func (a *Action) Execute(ctx context.Context, area *storage.Area) error {
|
|||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func (a *Action) Query(ctx context.Context, area *storage.Area) ([]string, error) {
|
func (a *Action) Query(ctx context.Context, area *storage.Area) ([]string, bool, error) {
|
||||||
for _, query := range a.Schema.Queries {
|
for _, query := range a.Schema.Queries {
|
||||||
switch query.Type {
|
switch query.Type {
|
||||||
case "grep":
|
case "grep":
|
||||||
exe, err := querier.NewRipGrep(zap.L()).Build(ctx, a.SchemaPath, query.Query)
|
exe, err := querier.NewRipGrep(zap.L()).Build(ctx, a.SchemaPath, query.Query)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, false, err
|
||||||
}
|
}
|
||||||
output, err := exe(ctx, area.Path)
|
output, found, err := exe(ctx, area.Path)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, false, err
|
||||||
}
|
}
|
||||||
|
|
||||||
zap.L().Debug("Execution done")
|
zap.L().Debug("Execution done")
|
||||||
|
|
||||||
return output, nil
|
return output, found, nil
|
||||||
|
|
||||||
default:
|
default:
|
||||||
return nil, errors.New("could not determine query type")
|
return nil, false, errors.New("could not determine query type")
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return nil, nil
|
return nil, false, nil
|
||||||
}
|
}
|
||||||
|
@ -19,7 +19,7 @@ func NewRipGrep(logger *zap.Logger) *RipGrep {
|
|||||||
return &RipGrep{logger: logger}
|
return &RipGrep{logger: logger}
|
||||||
}
|
}
|
||||||
|
|
||||||
type RipGrepCommand func(ctx context.Context, victimPath string) ([]string, error)
|
type RipGrepCommand func(ctx context.Context, victimPath string) ([]string, bool, error)
|
||||||
|
|
||||||
func (g *RipGrep) Build(ctx context.Context, modulePath, query string) (RipGrepCommand, error) {
|
func (g *RipGrep) Build(ctx context.Context, modulePath, query string) (RipGrepCommand, error) {
|
||||||
g.logger.Debug("Pulling docker image", zap.String("actiondir", modulePath), zap.String("query", query))
|
g.logger.Debug("Pulling docker image", zap.String("actiondir", modulePath), zap.String("query", query))
|
||||||
@ -54,14 +54,18 @@ func (g *RipGrep) Build(ctx context.Context, modulePath, query string) (RipGrepC
|
|||||||
|
|
||||||
g.logger.Debug("Docker image pulled")
|
g.logger.Debug("Docker image pulled")
|
||||||
|
|
||||||
return func(ctx context.Context, victimPath string) ([]string, error) {
|
return func(ctx context.Context, victimPath string) ([]string, bool, error) {
|
||||||
g.logger.Debug("Executing script", zap.String("victim", victimPath))
|
g.logger.Debug("Executing script", zap.String("victim", victimPath))
|
||||||
|
|
||||||
|
runRipGrepCmd := fmt.Sprintf("docker run --rm -v %s/:/data:ro mbologna/docker-ripgrep rg -i '%s' || true", victimPath, query)
|
||||||
|
|
||||||
|
g.logger.Debug("Execute ripgrep query", zap.String("command", runRipGrepCmd))
|
||||||
|
|
||||||
cmd := exec.CommandContext(
|
cmd := exec.CommandContext(
|
||||||
ctx,
|
ctx,
|
||||||
"/bin/bash",
|
"/bin/bash",
|
||||||
"-c",
|
"-c",
|
||||||
fmt.Sprintf("docker run --rm -v %s/:/data mbologna/docker-ripgrep rg -i %s", victimPath, query),
|
runRipGrepCmd,
|
||||||
)
|
)
|
||||||
|
|
||||||
runDockerWriter := &zapio.Writer{
|
runDockerWriter := &zapio.Writer{
|
||||||
@ -71,25 +75,32 @@ func (g *RipGrep) Build(ctx context.Context, modulePath, query string) (RipGrepC
|
|||||||
defer runDockerWriter.Close()
|
defer runDockerWriter.Close()
|
||||||
|
|
||||||
builder := &strings.Builder{}
|
builder := &strings.Builder{}
|
||||||
|
|
||||||
combinedWriter := io.MultiWriter(runDockerWriter, builder)
|
combinedWriter := io.MultiWriter(runDockerWriter, builder)
|
||||||
|
|
||||||
cmd.Stdout = combinedWriter
|
cmd.Stdout = combinedWriter
|
||||||
cmd.Stderr = runDockerWriter
|
cmd.Stderr = combinedWriter
|
||||||
|
|
||||||
err = cmd.Start()
|
err = cmd.Start()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, false, err
|
||||||
}
|
}
|
||||||
|
|
||||||
err = cmd.Wait()
|
err = cmd.Wait()
|
||||||
|
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, false, err
|
||||||
}
|
}
|
||||||
|
|
||||||
contents := strings.Split(builder.String(), "\n")
|
contents := strings.Split(builder.String(), "\n")
|
||||||
|
validatedOutput := make([]string, 0)
|
||||||
|
|
||||||
return contents, nil
|
for _, c := range contents {
|
||||||
|
if !strings.Contains(c, "WARNING:") {
|
||||||
|
validatedOutput = append(validatedOutput, c)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
found := len(validatedOutput) > 0
|
||||||
|
|
||||||
|
return validatedOutput, found, nil
|
||||||
}, nil
|
}, nil
|
||||||
}
|
}
|
||||||
|
@ -113,12 +113,15 @@ func (pr *ProcessRepos) processRepo(ctx context.Context, repoUrl string, action
|
|||||||
}
|
}
|
||||||
|
|
||||||
if len(action.Schema.Queries) > 0 {
|
if len(action.Schema.Queries) > 0 {
|
||||||
result, err := action.Query(ctx, area)
|
result, found, err := action.Query(ctx, area)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
pr.logger.Info("Query result", zap.Strings("result", result))
|
if found {
|
||||||
|
pr.logger.Info("Query result", zap.Strings("result", result))
|
||||||
|
// TODO: Append to real result, and return together
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if len(action.Schema.Actions) > 0 {
|
if len(action.Schema.Actions) > 0 {
|
||||||
|
Loading…
Reference in New Issue
Block a user