[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[libmicrohttpd] 01/02: Allowed responses in special cases for backward-c
From: |
gnunet |
Subject: |
[libmicrohttpd] 01/02: Allowed responses in special cases for backward-compatibility. |
Date: |
Thu, 07 Sep 2023 16:53:45 +0200 |
This is an automated email from the git hooks/post-receive script.
karlson2k pushed a commit to branch master
in repository libmicrohttpd.
commit c19c0438ab62acc7eac02b80a1cd1a535c382bc7
Author: Evgeny Grin (Karlson2k) <k2k@narod.ru>
AuthorDate: Thu Sep 7 17:41:23 2023 +0300
Allowed responses in special cases for backward-compatibility.
Allowed responses for suspended connection any time
Allowed responses for "external polling" mode any time.
Marked this behaviour as deprecated.
---
src/include/microhttpd.h | 10 ++++++++--
src/microhttpd/connection.c | 35 ++++++++++++++++++++++++-----------
src/microhttpd/daemon.c | 4 ----
3 files changed, 32 insertions(+), 17 deletions(-)
diff --git a/src/include/microhttpd.h b/src/include/microhttpd.h
index 8745367c..933f146a 100644
--- a/src/include/microhttpd.h
+++ b/src/include/microhttpd.h
@@ -3528,8 +3528,14 @@ MHD_lookup_connection_value_n (struct MHD_Connection
*connection,
*
* For any active connection this function must be called
* only by #MHD_AccessHandlerCallback callback.
- * For suspended connection this function can be called at any moment. Response
- * will be sent as soon as connection is resumed.
+ *
+ * For suspended connection this function can be called at any moment (this
+ * behaviour is deprecated and will be removed!). Response will be sent
+ * as soon as connection is resumed.
+ *
+ * For single thread environment, when MHD is used in "external polling" mode
+ * (without MHD_USE_SELECT_INTERNALLY) this function can be called any
+ * time (this behaviour is deprecated and will be removed!).
*
* If HTTP specifications require use no body in reply, like @a status_code
with
* value 1xx, the response body is automatically not sent even if it is present
diff --git a/src/microhttpd/connection.c b/src/microhttpd/connection.c
index d6b24297..9440d112 100644
--- a/src/microhttpd/connection.c
+++ b/src/microhttpd/connection.c
@@ -7078,8 +7078,14 @@ MHD_set_connection_option (struct MHD_Connection
*connection,
*
* For any active connection this function must be called
* only by #MHD_AccessHandlerCallback callback.
- * For suspended connection this function can be called at any moment. Response
- * will be sent as soon as connection is resumed.
+ *
+ * For suspended connection this function can be called at any moment (this
+ * behaviour is deprecated and will be removed!). Response will be sent
+ * as soon as connection is resumed.
+ *
+ * For single thread environment, when MHD is used in "external polling" mode
+ * (without MHD_USE_SELECT_INTERNALLY) this function can be called any
+ * time (this behaviour is deprecated and will be removed!).
*
* If HTTP specifications require use no body in reply, like @a status_code
with
* value 1xx, the response body is automatically not sent even if it is present
@@ -7091,7 +7097,10 @@ MHD_set_connection_option (struct MHD_Connection
*connection,
* header is added automatically based the size of the body in the response.
* If body size it set to #MHD_SIZE_UNKNOWN or chunked encoding is enforced
* then "Transfer-Encoding: chunked" header (for HTTP/1.1 only) is added
instead
- * of "Content-Length" header.
+ * of "Content-Length" header. For example, if response with zero-size body is
+ * used for HEAD request, then "Content-Length: 0" is added automatically to
+ * reply headers.
+ * @sa #MHD_RF_HEAD_ONLY_RESPONSE
*
* In situations, where reply body is required, like answer for the GET request
* with @a status_code #MHD_HTTP_OK, headers "Content-Length" (for known body
@@ -7118,13 +7127,15 @@ MHD_queue_response (struct MHD_Connection *connection,
if ((NULL == connection) || (NULL == response))
return MHD_NO;
- if (! connection->in_access_handler)
+
+ daemon = connection->daemon;
+ if ((! connection->in_access_handler) && (! connection->suspended) &&
+ (0 != (daemon->options & MHD_USE_INTERNAL_POLLING_THREAD)))
return MHD_NO;
+
reply_icy = (0 != (status_code & MHD_ICY_FLAG));
status_code &= ~MHD_ICY_FLAG;
- daemon = connection->daemon;
-
#if defined(MHD_USE_POSIX_THREADS) || defined(MHD_USE_W32_THREADS)
if ( (! connection->suspended) &&
(0 != (daemon->options & MHD_USE_INTERNAL_POLLING_THREAD)) &&
@@ -7138,15 +7149,17 @@ MHD_queue_response (struct MHD_Connection *connection,
}
#endif
+ if (NULL != connection->rp.response)
+ return MHD_NO; /* The response was already set */
+
+ if ( (MHD_CONNECTION_HEADERS_PROCESSED != connection->state) &&
+ (MHD_CONNECTION_FULL_REQ_RECEIVED != connection->state) )
+ return MHD_NO; /* Wrong connection state */
+
if (daemon->shutdown)
return MHD_YES; /* If daemon was shut down in parallel,
* response will be aborted now or on later stage. */
- if ( (NULL != connection->rp.response) ||
- ( (MHD_CONNECTION_HEADERS_PROCESSED != connection->state) &&
- (MHD_CONNECTION_FULL_REQ_RECEIVED != connection->state) ) )
- return MHD_NO;
-
#ifdef UPGRADE_SUPPORT
if (NULL != response->upgrade_handler)
{
diff --git a/src/microhttpd/daemon.c b/src/microhttpd/daemon.c
index 9b088803..7db67cd0 100644
--- a/src/microhttpd/daemon.c
+++ b/src/microhttpd/daemon.c
@@ -3195,10 +3195,6 @@ internal_suspend_connection_ (struct MHD_Connection
*connection)
* socket leaks or lead to undefined behavior). You must explicitly
* resume all connections before stopping the daemon.
*
- * @remark In thread-per-connection mode: can be called from any thread,
- * in any other mode: to be called only from thread that process
- * daemon's select()/poll()/etc.
- *
* @param connection the connection to suspend
*
* @sa #MHD_AccessHandlerCallback
--
To stop receiving notification emails like this one, please contact
gnunet@gnunet.org.