-
Notifications
You must be signed in to change notification settings - Fork 842
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
URL in config files can specify request method #2431
Comments
Certainly seems like something worth addressing. I don't see how to exploit it either, since this isn't a browser POST, there are no cookies. |
There are a lot of ways that building Haskell code is insecure. For example, TemplateHaskell code can basically issue any HTTP request it wants to (or do anything else on your system), so security issues in stack.yaml, while unfortunate, probably don't make much difference to overall security. |
Indeed, so we could possibly leave this in as just a somewhat odd feature. |
Somewhat related: my thoughts on using a custom URL type. |
While reviewing #2412, I double-checked that the URL-parser
parseRequest
inFromJSON PackageLocation
did the right thing. But it seems it doesn't quite do that. It allows specifying a method:parseRequest "POST http://httpbin.org/post"
[1].Potentially worse, I can ship somebody a stack.yaml that will trigger POST requests upon install. I don't see how to actually exploit this, but someone might. Switching to another URI parser should prevent this, and should be easy since the parsed URI is thrown away. One should probably also review the parsing that is used to actually access the URI though.
[1] https://hackage.haskell.org/package/http-client-0.5.0/docs/Network-HTTP-Client.html#v:parseRequest
[2] http://hackage.haskell.org/package/network-uri-2.6.1.0/docs/Network-URI.html#v:parseURI
The text was updated successfully, but these errors were encountered: