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

S3 External Modules Cannot Be Downloaded, breaking suppressions w/ plan files #5895

Open
tarfeef101 opened this issue Dec 21, 2023 · 13 comments · May be fixed by #7066
Open

S3 External Modules Cannot Be Downloaded, breaking suppressions w/ plan files #5895

tarfeef101 opened this issue Dec 21, 2023 · 13 comments · May be fixed by #7066
Labels

Comments

@tarfeef101
Copy link
Contributor

Describe the issue
I use s3-sourced modules for private modules at my company. We sometimes need to mute checks for various reasons inside these modules. However, since we run checkov on plans w/ enrichment, these need downloading for skips to work. They do not, however, as checkov throws this error when it tries to get modules:

No connection adapters were found for 's3::https:/versions'

It seems that s3-stored modules are just "not handled" currently, and are treated as just http, which requests cannot handle

Examples

module "geotab-example" {
  source       = "s3::https://s3.amazonaws.com/path-to-module.tgz"
  argument = "foo"
}

^ the above module should contain a skip inside its code, and it should work, but it does not

Version (please complete the following information):

  • Checkov Version 2.5.18

Additional context
Add any other context about the problem here.

@gruebel
Copy link
Contributor

gruebel commented Dec 21, 2023

hey @tarfeef101 thanks for reaching out.

checkov currently doesn't support modules stored in S3.

@tarfeef101
Copy link
Contributor Author

hey @tarfeef101 thanks for reaching out.

checkov currently doesn't support modules stored in S3.

is that roadmapped at all? in theory, it should be pretty simple to add, since boto3 takes care of auth implicitly, it's basically just an exercise of "if the url starts with the s3 prefix, use boto3 to get the module". I could try my hand at it myself, but i'm not sure when i'd get the time from work to do that (or where the code should live)

@gruebel
Copy link
Contributor

gruebel commented Dec 22, 2023

At some point it was on the roadmap, but adoption was not so huge compared to other things, so it was pushed. Can't say when this will be tackled.

In theory it is quiet straight forward, but the code area is kind of icky 😅

@JamesWoolfenden
Copy link
Contributor

If you fancy taking a go at it @tarfeef101 ?

@tarfeef101
Copy link
Contributor Author

If you fancy taking a go at it @tarfeef101 ?

i can try, but no promises, it's gotta be deigned to be a big enough priority for my team, which doesn't seem all too likely. or be actually really fast/easy.

if you can point me at the requisite area(s) of the code that need massaging, I can try and see how much work it'd be and see if I can make the time for it

@gruebel
Copy link
Contributor

gruebel commented Dec 22, 2023

Sure, here is the entry point for all module source variants https://github.com/bridgecrewio/checkov/blob/main/checkov/terraform/module_loading/registry.py

Copy link

stale bot commented Jun 24, 2024

Thanks for contributing to Checkov! We've automatically marked this issue as stale to keep our issues list tidy, because it has not had any activity for 6 months. It will be closed in 14 days if no further activity occurs. Commenting on this issue will remove the stale tag. If you want to talk through the issue or help us understand the priority and context, feel free to add a comment or join us in the Checkov slack channel at codifiedsecurity.slack.com
Thanks!

@stale stale bot added the stale label Jun 24, 2024
@Saarett Saarett closed this as completed Jul 11, 2024
@UgniusV
Copy link

UgniusV commented Jul 25, 2024

Hey, was this fixed? The latest version still seems to have this problem

@tarfeef101
Copy link
Contributor Author

Hey, was this fixed? The latest version still seems to have this problem

Not to my knowledge, no (sadly personally I've not had the time to unravel the indeed somewhat icky code that goes through this stuff 😅)

@tarfeef101
Copy link
Contributor Author

@Saarett looks like this was closed as completed but I don't see a commit reference or anything, can you provide a release tag where this was patched in pls?

@Saarett Saarett reopened this Jan 15, 2025
@stale stale bot removed the stale label Jan 15, 2025
@Saarett
Copy link
Contributor

Saarett commented Jan 15, 2025

Hi @tarfeef101 , we plan to address it in a future update. Currently, it’s a lower priority, but it remains on our roadmap.
We appreciate your patience and understanding.

@tarfeef101 tarfeef101 linked a pull request Mar 20, 2025 that will close this issue
5 tasks
@tarfeef101
Copy link
Contributor Author

@Saarett is this still true? if so, #7066 is a bad first draft. I blame AI for the bad parts

(and also I don't appcode 🙃, I'm surprised it even technically works at all)

@tarfeef101
Copy link
Contributor Author

@UgniusV @kunickiaj @SantiRaposo

y'all seemed to want this feature, please feel free to continue my effort :D (offer is, of course, open to maintainers. encouraged, even. trying to decode the somewhat obscure code to make this work is not particularly fun 😅)

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

Successfully merging a pull request may close this issue.

5 participants