Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[1.6.4] Alert Context map[] if using AppSec collection #3340

Open
LaurenceJJones opened this issue Nov 21, 2024 · 4 comments
Open

[1.6.4] Alert Context map[] if using AppSec collection #3340

LaurenceJJones opened this issue Nov 21, 2024 · 4 comments
Assignees
Milestone

Comments

@LaurenceJJones
Copy link
Contributor

We have found that if you are currently using the AppSec collection and a scenario triggers, the context will get flooded with map[] for properties that should be empty.

We are investigating from CrowdSec side what is happening here, however, from the console side we are working to flush any contexts that are map[] as this is not real data and should be removed.

Copy link

@LaurenceJJones: Thanks for opening an issue, it is currently awaiting triage.

In the meantime, you can:

  1. Check Crowdsec Documentation to see if your issue can be self resolved.
  2. You can also join our Discord.
  3. Check Releases to make sure your agent is on the latest version.
Details

I am a bot created to help the crowdsecurity developers manage community feedback and contributions. You can check out my manifest file to understand my behavior and what I can do. If you want to use this for your project, you can check out the BirthdayResearch/oss-governance-bot repository.

Copy link

@LaurenceJJones: There are no 'kind' label on this issue. You need a 'kind' label to start the triage process.

  • /kind feature
  • /kind enhancement
  • /kind refactoring
  • /kind bug
  • /kind packaging
Details

I am a bot created to help the crowdsecurity developers manage community feedback and contributions. You can check out my manifest file to understand my behavior and what I can do. If you want to use this for your project, you can check out the BirthdayResearch/oss-governance-bot repository.

@LaurenceJJones
Copy link
Contributor Author

Update: we have merged a fix to the context file itself, please run:

cscli hub update && cscli hub upgrade

To download the latest context file, and then run systemctl restart crowdsec to ensure the context is reloaded before adding a comment to this discussion.

@blotus blotus added this to the 1.6.5 milestone Nov 25, 2024
@buixor buixor self-assigned this Dec 18, 2024
@LaurenceJJones
Copy link
Contributor Author

LaurenceJJones commented Jan 27, 2025

link to problematic code:

for _, value := range values {
var val string
output, err := expr.Run(value, map[string]interface{}{"match": match, "evt": evt, "req": request})
if err != nil {
errors = append(errors, fmt.Errorf("failed to get value for %s: %w", key, err))
continue
}
switch out := output.(type) {
case string:
val = out
if val != "" && !slices.Contains(tmpContext[key], val) {
tmpContext[key] = append(tmpContext[key], val)
}
case []string:
for _, v := range out {
if v != "" && !slices.Contains(tmpContext[key], v) {
tmpContext[key] = append(tmpContext[key], v)
}
}
case int:
val = strconv.Itoa(out)
if val != "" && !slices.Contains(tmpContext[key], val) {
tmpContext[key] = append(tmpContext[key], val)
}
case []int:
for _, v := range out {
val = strconv.Itoa(v)
if val != "" && !slices.Contains(tmpContext[key], val) {
tmpContext[key] = append(tmpContext[key], val)
}
}
default:
val := fmt.Sprintf("%v", output)
if val != "" && !slices.Contains(tmpContext[key], val) {
tmpContext[key] = append(tmpContext[key], val)
}
}
}

The default case is hit and "%v" returns a string of any value in this case an empty map meaning map[] is returned and non empty string is valid.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

No branches or pull requests

3 participants