Comments (6)
@thexa4 , thank you very much for exposing this issue. 🎉👏🏻🙏🏻👍🏻
You're right, iodine should have returned an empty string (""
) rather than nil
. The issue occurred when an optimized "no content" path was taken instead of reaching EOF on the rack.input
stream.
I posted an initial patch and I hope to release it soon, after running a few tests.
I'm not sure what you meant by suggesting to test the content_length
?
I'm assuming you were suggesting a way to patch Rack... and although I think your instincts are great, 99.9% of all POST requests probably contain some data. I think it's fair that Rack would upstream the edge-case handling to the server.
from iodine.
@SleeplessByte - yes, I agree... the Rack documentation could be improved.
On the other hand, Rack was a huge undertaking and it's so relied upon that it became practically impossible to replace. It's battle tested and dependable. No matter how many of us complain about Rack's CGI core, it's probably here to stay and it's making many developers happy.
from iodine.
It makes me happy 😉 so it gets my upvote regardless of the 🆗 documentation.
from iodine.
This should probably also check the content_length before performing any mutation.
from iodine.
Patch released. closing issue.
Thanks again! 🙏🏻👍🏻🎉
from iodine.
@boazsegev you're absolutely right on my intention with that comment, and I agree that this edge case can be handled here, in iodine :). Thank you for the blazingly fast update ❤️
The biggest issue I have with the rack implementation is that the comment for the rack functionality says it's supposed to check if there is data, whereas it's actually checking if there could be data -- and then it's further assumed that there is data.
from iodine.
Related Issues (20)
- Async task on subscribe HOT 3
- Question about crashes HOT 2
- Assertion failure HOT 9
- Iodine failing to compile with Ruby 3.2.0preview_2 HOT 5
- The future of iodine (vs. plezi)...? HOT 9
- [Rack 3] Response headers with Array value should produce multiple header fields HOT 3
- CPU usage when idle HOT 3
- Iodine.unsubscribe crashes when called with symbol. HOT 4
- Subscribing from the enter_master block subscribes even the children. HOT 3
- unix socket not writeable due umask HOT 8
- Writes to STDOUT even when Iodine.verbosity = 0 HOT 1
- Does not honor HUP signal. HOT 1
- Iodine stops on TERM signal with error when it run with -pid key and more than one worker HOT 1
- The Fixnum is gone as of Ruby-2.4 HOT 3
- response code 418 results in 500 Internal Server Error HOT 1
- [FEAT] return reason for closed connection/client HOT 7
- Static file serving: allow mounting of multiple local dirs HOT 14
- binary C extension not built? HOT 26
- How to get client instance id HOT 3
- ondisconnect example HOT 1
Recommend Projects
-
React
A declarative, efficient, and flexible JavaScript library for building user interfaces.
-
Vue.js
🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.
-
Typescript
TypeScript is a superset of JavaScript that compiles to clean JavaScript output.
-
TensorFlow
An Open Source Machine Learning Framework for Everyone
-
Django
The Web framework for perfectionists with deadlines.
-
Laravel
A PHP framework for web artisans
-
D3
Bring data to life with SVG, Canvas and HTML. 📊📈🎉
-
Recommend Topics
-
javascript
JavaScript (JS) is a lightweight interpreted programming language with first-class functions.
-
web
Some thing interesting about web. New door for the world.
-
server
A server is a program made to process requests and deliver data to clients.
-
Machine learning
Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.
-
Visualization
Some thing interesting about visualization, use data art
-
Game
Some thing interesting about game, make everyone happy.
Recommend Org
-
Facebook
We are working to build community through open source technology. NB: members must have two-factor auth.
-
Microsoft
Open source projects and samples from Microsoft.
-
Google
Google ❤️ Open Source for everyone.
-
Alibaba
Alibaba Open Source for everyone
-
D3
Data-Driven Documents codes.
-
Tencent
China tencent open source team.
from iodine.