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

Why the DSL language doesn't match the documentation ? #245

Closed
theoberthier opened this issue Aug 7, 2024 · 3 comments
Closed

Why the DSL language doesn't match the documentation ? #245

theoberthier opened this issue Aug 7, 2024 · 3 comments
Assignees
Labels
bug Something isn't working

Comments

@theoberthier
Copy link

Describe the bug
The DSL(Gremlin) request differ between documentation and reality.

To Reproduce
Steps to reproduce the behavior:

  1. Go to jupyter Notebook
  2. Go to one playbook
  3. found container name with kh.containers().elementMap()
  4. take one name of container and launchd " kh.containers("name_of_container").attacks().
  5. i have this error : {'error': TypeError("unhashable type: 'dict'")}

same for

  • 'kh.services().criticalPath()'
  • 'kh.group("name_of_group").criticalPaths(5)' : => group doesn't exist, it's groups() and with groups().criticalPaths(5) doesn't works too
  • and maybe another

Expected behavior
All attacks possible from a specific in the graph (like documentation)

Kubehound version
Release v1.3.2

Another question
Why the release 2.* are gone ?

@edznux-dd
Copy link
Contributor

edznux-dd commented Aug 19, 2024

Hey, thanks for the report and sorry for the delay, we've been busy with the preparation for defcon/BH workshops!

We have updated the documentation a bit for 1.4.0 but I can reproduce kh.containers("name_of_container").attacks()., i'm going to take a look ASAP.

'kh.group("name_of_group").criticalPaths(5)' : => group doesn't exist, it's groups() and with groups().criticalPaths(5) doesn't works too

group => groups in the documentation was fixed with the 1.4 release (see documentation here)

The {'error': TypeError("unhashable type: 'dict'")} is still there however.

Another question
Why the release 2.* are gone ?

We realized it didn't make sense to have a 2.0 that is pretty much identical to 1.x (there wasn't any breaking change).
And moving to 2.0 would have made some release process more annoying (for example, the ability to go install) both from a user and a maintainer perspective.

Since the user base was still low and was going to grow after our workshops/presentation we decided to move back to 1.x.
We know it's not great, and we shouldn't have released the 2.0 in the first place but it was simply better to do it now instead of later. We deemed the number of downloads for the 2.x release to be low enough that we wouldn't break any major workflows :)
We could have kept the images, available but that would have caused confusion for the users for "which version is the latest".

The project now more closely match the SemVer model.

(I've created ASENG-1437 for internal tracking)

@theoberthier
Copy link
Author

Thank you for your answer.
I understand that my base is 1.4.0 now.
Do you want me to specify here which commands don’t work when i found them ?

@jt-dd jt-dd added the bug Something isn't working label Sep 19, 2024
@jt-dd jt-dd self-assigned this Sep 19, 2024
@Zenithar
Copy link
Contributor

Zenithar commented Jan 7, 2025

The documentation has been updated to be re-aligned with the implementation. Please feel free to re-open this issue if you find any more inconsistencies.

Thank you for your contributions.

@Zenithar Zenithar closed this as completed Jan 7, 2025
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
bug Something isn't working
Projects
None yet
Development

No branches or pull requests

4 participants