-
Notifications
You must be signed in to change notification settings - Fork 638
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
expose parseRequest() methods for ftp and http requests #133
base: master
Are you sure you want to change the base?
Conversation
This allows redirects over different protocols (http -> https) becasue the `create` function can now reflect on the contents of the request at hand and create the correct socket.
Additional modifications; I updated the see also @brunoos remark here; lunarmodules/luasec#34 (comment) on importing more code. Exposing the parse commands would allow LuaSec to reduce the amount of imported code. Needs testing, so for discussion only at the moment. Additionally; I thought about adding the fields |
This PR is the basis for a LuaSec fix (lunarmodules/luasec#38) to allow redirects from http to https and vice versa. That PR uses the The code is good to go as far as I'm concerned, except for the ftp code, which I could not test. I've tested the http and smtp code with some of my own code using that functionality. But had none for ftp. Unfortunately by now I mixed two functionalities in this PR;
I can disentangle them and provide two separate requests, but that would only make sense if they stand a chance of being pulled. So @diegonehab can you give me a hint of whether you're inclined to pull either of those functionalities? Then I will prepare the required changes. |
Here's yet another request caused by the failure to detect redirects; lunarmodules/luasec#57 (comment) |
Hi @diegonehab Is there a reason these changes haven't been merged? |
@Babbleshack for now you could use copas, it has utility functions for http and https, including cross scheme redirects. see http://keplerproject.github.io/copas/manual.html#highlevel |
It's my bad. I'll take a look and see if I can tweak the interface a bit. |
I'm going to split this into two separate issues. Will look first into the exporting of parse request. I recently fixed an issue in which HTTP was redirecting to HTTPS without checking the scheme. So we should probably revisit that part of the pull request. |
@Tieske, can you check the latest push? I exposed the URL parsing functions as "_M.genericform" in http.lua and ftp.lua since that is the name I use for the type of function that accepts tables instead of urls. Maybe generalform is a better name. Either way... If you are happy with the code, we can discuss the cross-scheme redirects. Sounds good? |
Looks good to me 👍 On the naming; |
Agree. I didn't like parseurl because there is a module url that actually does the parsing. It's more like building a generic form of the request from an url. With regard to the cross scheme redirection, I'm thinking about including a "schemes" field in the request table that includes all schemes that should be supported. The default would be { ["http"] = true }. This would let the code abort redirects from http to https but would also allow the user to override this behavior. |
What would "supported" mean in that case? Another thing; considering the same http & https example; redirects of http to https (increasing security) should be allowed, whilst https to http (reducing security) should be disallowed by default. I don't see how to handle that with such a scheme table. If we already support the |
Right now, the code does the right thing. I.e., if there is a redirect to any scheme other than http, LuaSocket won't follow it. Previously, it would follow any scheme blindly. Naturally, this will break the redirect from http to https that LuaSec relies on. The question is how to best allow for this behavior so that LuaSec can keep using all the code in LuaSocket without LuaSocket ever knowing. |
It will involve the create trick, of course. But that trick is no longer enough. |
Not sure we're on the same page here. The changes I made pass the request table to the
I fail to see why that is no longer enough? What am I missing? The default |
I understand that it is possible for the create method to look at the request table and make modifications so it works with https. (We'd need to fix adjust request to not mess with the port, as it currently does. Or at least the messing around should be dependent on the scheme.) This is a good solution for the case in which the original scheme was already https. I am not sure I agree with the redirects, though. What you seem to be suggesting is that we use a default create method in LuaSocket that checks for the scheme and aborts on anything other than http. I think there should exist a separate mechanism for that. Perhaps a schemes field with the create methods for each scheme. There was an issue request some time ago that reported LuaSocket would blindly follow a redirect to https ignoring the fact it was https (it assumed it was http). So added a check for the scheme. It is this mechanism that I am not happy with at the moment. |
imho LuaSocket should not mess with the port. Use what is specified and if it is absent, assume 80, that's it, no more, no less.
Using the The core responsibility of the http module is to execute a request. The module has 2 uses; 1) provide a simple http request method, with proper sanity checks, 2) provide a way to implement the raw protocol, with no guarantees; garbage in == garbage out. If I want to perform a POST request to So I would expect the module to;
In case of redirects rerun the cycle with the new info, passing some old info along, to track number of redirects, etc. preferably a list with the entire redirect history. A table with schemes could be implemented to do this.Holding the callbacks by 'scheme'. It would also imply one 'catch_all' scheme in the table. That will be used if there is no match (and by default throws an error that the scheme is unsupported). |
My idea for the scheme table was as a field in the request. Obviously, there will be a default value in http.lua which we will use when it has not been overridden. The only thing missing is how to specify the "default" scheme in the table. The word "default" is not very safe because someone might create a scheme called "default". :) Maybe we can use the array part. Any good ideas come to mind? |
Can't we use an illegal character; eg |
Just throwing my two-cents in here. But you could use [0] on the table for the default scheme. That way, you do not interfere with typical string keys someone might pick, and you do not need to worry about the possibility of people using numeric keys because very few lua programmers seem to deviate from the 1-indexed style. I know it's not perfect, but perhaps it is GoodEnough™? |
lunarmodules/luasocket#133 expose parseRequest() methods for http requests (ftp.lua and smtp.lua ommitted)
Obviated by #268. |
Alternative for #131
The tests seem to be local to @diegonehab system, so I could not run them. So please check carfully.