#include </builddir/build/BUILD/libmicrohttpd-0.9.33/src/microhttpd/internal.h>
State kept for each HTTP request.
Definition at line 506 of file internal.h.
struct sockaddr* MHD_Connection::addr [read] |
Foreign address (of length addr_len). MALLOCED (not in pool!).
Definition at line 632 of file internal.h.
Referenced by internal_add_connection(), MHD_cleanup_connections(), and MHD_get_connection_info().
socklen_t MHD_Connection::addr_len |
Length of the foreign address.
Definition at line 692 of file internal.h.
Referenced by internal_add_connection(), and MHD_cleanup_connections().
Did we ever call the "default_handler" on this connection? (this flag will determine if we call the 'notify_completed' handler when the connection closes down).
Definition at line 711 of file internal.h.
Referenced by call_connection_handler(), MHD_connection_close(), MHD_connection_handle_idle(), and process_request_body().
We allow the main application to associate some pointer with the connection. Here is where we store it. (MHD does not know or care what it is).
Definition at line 579 of file internal.h.
Referenced by call_connection_handler(), MHD_connection_close(), MHD_connection_handle_idle(), parse_initial_message_line(), and process_request_body().
char* MHD_Connection::colon |
Position after the colon on the last incomplete header line during parsing of headers. Allocated in pool. Only valid if state is either HEADER_PART_RECEIVED or FOOTER_PART_RECEIVED.
Definition at line 626 of file internal.h.
Referenced by process_broken_line(), and process_header_line().
unsigned int MHD_Connection::connection_timeout |
After how many seconds of inactivity should this connection time out? Zero for no timeout.
Definition at line 704 of file internal.h.
Referenced by cleanup_connection(), close_connection(), internal_add_connection(), MHD_connection_handle_idle(), MHD_get_timeout(), MHD_set_connection_option(), MHD_suspend_connection(), MHD_tls_connection_handle_idle(), resume_suspended_connections(), and update_last_activity().
Position in the 100 CONTINUE message that we need to send when receiving http 1.1 requests.
Definition at line 687 of file internal.h.
Referenced by MHD_connection_handle_idle(), MHD_connection_handle_write(), and need_100_continue().
unsigned int MHD_Connection::current_chunk_offset |
If we are receiving with chunked encoding, where are we currently with respect to the current chunk (at what offset / position)?
Definition at line 791 of file internal.h.
Referenced by process_request_body().
unsigned int MHD_Connection::current_chunk_size |
If we are receiving with chunked encoding, where are we right now? Set to 0 if we are waiting to receive the chunk size; otherwise, this is the size of the current chunk. A value of zero is also used when we're at the end of the chunks.
Definition at line 785 of file internal.h.
Referenced by process_request_body().
struct MHD_Daemon* MHD_Connection::daemon [read] |
Reference to the MHD_Daemon struct.
Definition at line 544 of file internal.h.
Referenced by build_header_response(), call_connection_handler(), check_argument_match(), check_nonce_nc(), cleanup_connection(), close_connection(), connection_add_header(), connection_close_error(), do_read(), do_write(), internal_add_connection(), MHD_basic_auth_get_username_password(), MHD_connection_close(), MHD_connection_handle_idle(), MHD_connection_handle_read(), MHD_connection_handle_write(), MHD_connection_update_event_loop_info(), MHD_digest_auth_check(), MHD_get_connection_info(), MHD_handle_connection(), MHD_queue_auth_fail_response(), MHD_resume_connection(), MHD_set_connection_option(), MHD_suspend_connection(), MHD_tls_connection_handle_idle(), parse_arguments(), parse_connection_headers(), parse_cookie_header(), parse_initial_message_line(), process_request_body(), run_tls_handshake(), send_param_adapter(), transmit_error_response(), try_grow_read_buffer(), try_ready_chunked_body(), try_ready_normal_body(), and update_last_activity().
What is this connection waiting for?
Definition at line 753 of file internal.h.
Referenced by close_connection(), MHD_connection_close(), MHD_connection_handle_idle(), MHD_connection_update_event_loop_info(), MHD_get_fdset(), MHD_handle_connection(), and MHD_run_from_select().
Are we receiving with chunked encoding? This will be set to MHD_YES after we parse the headers and are processing the body with chunks. After we are done with the body and we are processing the footers; once the footers are also done, this will be set to MHD_NO again (before the final call to the handler).
Definition at line 777 of file internal.h.
Referenced by add_extra_headers(), MHD_connection_handle_idle(), parse_connection_headers(), and process_request_body().
struct MHD_HTTP_Header* MHD_Connection::headers_received [read] |
Linked list of parsed headers.
Definition at line 549 of file internal.h.
Referenced by check_argument_match(), MHD_connection_handle_idle(), MHD_get_connection_values(), MHD_lookup_connection_value(), MHD_set_connection_value(), and test_header().
struct MHD_HTTP_Header* MHD_Connection::headers_received_tail [read] |
Tail of linked list of parsed headers.
Definition at line 554 of file internal.h.
Referenced by MHD_connection_handle_idle(), and MHD_set_connection_value().
int(* MHD_Connection::idle_handler)(struct MHD_Connection *connection) |
Handler used for processing idle connection operations
Referenced by MHD_handle_connection(), MHD_run_from_select(), MHD_set_http_callbacks_(), and MHD_set_https_callbacks().
Are we currently inside the "idle" handler (to avoid recursively invoking it).
Definition at line 736 of file internal.h.
Referenced by cleanup_connection(), MHD_connection_handle_idle(), and MHD_queue_response().
char* MHD_Connection::last |
Last incomplete header line during parsing of headers. Allocated in pool. Only valid if state is either HEADER_PART_RECEIVED or FOOTER_PART_RECEIVED.
Definition at line 618 of file internal.h.
Referenced by process_broken_line(), and process_header_line().
Last time this connection had any activity (reading or writing).
Definition at line 698 of file internal.h.
Referenced by internal_add_connection(), MHD_connection_handle_idle(), MHD_get_timeout(), MHD_handle_connection(), MHD_tls_connection_handle_idle(), run_tls_handshake(), and update_last_activity().
char* MHD_Connection::method |
Request method. Should be GET/POST/etc. Allocated in pool.
Definition at line 585 of file internal.h.
Referenced by add_extra_headers(), call_connection_handler(), MHD_connection_handle_idle(), MHD_digest_auth_check(), MHD_queue_auth_fail_response(), MHD_queue_response(), parse_initial_message_line(), and process_request_body().
struct MHD_Connection* MHD_Connection::next [read] |
Next pointer for the DLL describing our IO state.
Definition at line 524 of file internal.h.
Referenced by MHD_get_fdset(), MHD_run_from_select(), and resume_suspended_connections().
struct MHD_Connection* MHD_Connection::nextX [read] |
Next pointer for the XDLL organizing connections by timeout.
Definition at line 534 of file internal.h.
Referenced by close_all_connections(), and MHD_get_timeout().
pthread_t MHD_Connection::pid |
Thread for this connection (if we are using one thread per connection).
Definition at line 638 of file internal.h.
Referenced by close_all_connections(), internal_add_connection(), and MHD_cleanup_connections().
struct MemoryPool* MHD_Connection::pool [read] |
The memory pool is created whenever we first read from the TCP stream and destroyed at the end of each request (and re-created for the next request). In the meantime, this pointer is NULL. The pool is used for all connection-related data except for the response (which maybe shared between connections) and the IP address (which persists across individual requests).
Definition at line 571 of file internal.h.
Referenced by build_header_response(), check_write_done(), internal_add_connection(), MHD_cleanup_connections(), MHD_connection_handle_idle(), MHD_connection_handle_read(), MHD_set_connection_value(), parse_cookie_header(), process_broken_line(), try_grow_read_buffer(), and try_ready_chunked_body().
struct MHD_Connection* MHD_Connection::prev [read] |
Previous pointer for the DLL describing our IO state.
Definition at line 529 of file internal.h.
struct MHD_Connection* MHD_Connection::prevX [read] |
Previous pointer for the XDLL organizing connections by timeout.
Definition at line 539 of file internal.h.
Buffer for reading requests. Allocated in pool. Actually one byte larger than read_buffer_size (if non-NULL) to allow for 0-termination.
Definition at line 605 of file internal.h.
Referenced by do_read(), get_next_header_line(), MHD_connection_handle_idle(), MHD_connection_handle_read(), process_request_body(), and try_grow_read_buffer().
Position where we currently append data in read_buffer (last valid position).
Definition at line 652 of file internal.h.
Referenced by do_read(), get_next_header_line(), MHD_connection_handle_idle(), MHD_connection_handle_read(), MHD_connection_update_event_loop_info(), MHD_get_fdset(), MHD_handle_connection(), MHD_run_from_select(), and process_request_body().
Size of read_buffer (in bytes). This value indicates how many bytes we're willing to read into the buffer; the real buffer is one byte longer to allow for adding zero-termination (when needed).
Definition at line 646 of file internal.h.
Referenced by do_read(), get_next_header_line(), MHD_connection_handle_idle(), MHD_connection_handle_read(), MHD_connection_update_event_loop_info(), MHD_get_fdset(), MHD_handle_connection(), MHD_run_from_select(), and try_grow_read_buffer().
Has this socket been closed for reading (i.e. other side closed the connection)? If so, we must completely close the connection once we are done sending our response (and stop trying to read from this socket).
Definition at line 726 of file internal.h.
Referenced by build_header_response(), close_all_connections(), do_read(), MHD_connection_close(), MHD_connection_handle_idle(), MHD_connection_handle_read(), MHD_connection_update_event_loop_info(), MHD_queue_response(), parse_connection_headers(), and transmit_error_response().
int(* MHD_Connection::read_handler)(struct MHD_Connection *connection) |
Handler used for processing read connection operations
Referenced by MHD_handle_connection(), MHD_run_from_select(), MHD_set_http_callbacks_(), and MHD_set_https_callbacks().
Function used for reading HTTP request stream.
Definition at line 811 of file internal.h.
Referenced by do_read(), and internal_add_connection().
How many more bytes of the body do we expect to read? MHD_SIZE_UNKNOWN for unknown.
Definition at line 674 of file internal.h.
Referenced by MHD_connection_handle_idle(), parse_connection_headers(), and process_request_body().
struct MHD_Response* MHD_Connection::response [read] |
Response to transmit (initially NULL).
Definition at line 559 of file internal.h.
Referenced by add_extra_headers(), build_header_response(), call_connection_handler(), cleanup_connection(), MHD_cleanup_connections(), MHD_connection_handle_idle(), MHD_connection_handle_write(), MHD_handle_connection(), MHD_queue_response(), need_100_continue(), parse_connection_headers(), process_request_body(), send_param_adapter(), transmit_error_response(), try_ready_chunked_body(), and try_ready_normal_body().
Set to MHD_YES if the response's content reader callback failed to provide data the last time we tried to read from it. In that case, the write socket should be marked as unready until the CRC call succeeds.
Definition at line 768 of file internal.h.
Current write position in the actual response (excluding headers, content only; should be 0 while sending headers).
Definition at line 681 of file internal.h.
Referenced by MHD_connection_handle_idle(), MHD_connection_handle_write(), MHD_queue_response(), send_param_adapter(), try_ready_chunked_body(), and try_ready_normal_body().
unsigned int MHD_Connection::responseCode |
HTTP response code. Only valid if response object is already set.
Definition at line 759 of file internal.h.
Referenced by build_header_response(), MHD_connection_handle_idle(), and MHD_queue_response().
Is the connection wanting to resume?
Definition at line 849 of file internal.h.
Referenced by cleanup_connection(), MHD_resume_connection(), and resume_suspended_connections().
Function used for writing HTTP response stream.
Definition at line 816 of file internal.h.
Referenced by do_write(), internal_add_connection(), and MHD_connection_handle_write().
Socket for this connection. Set to -1 if this connection has died (daemon should clean up in that case).
Definition at line 718 of file internal.h.
Referenced by close_all_connections(), internal_add_connection(), MHD_cleanup_connections(), MHD_connection_close(), MHD_connection_handle_idle(), MHD_get_connection_info(), MHD_get_fdset(), MHD_handle_connection(), MHD_run_from_select(), MHD_suspend_connection(), recv_param_adapter(), resume_suspended_connections(), and send_param_adapter().
State in the FSM for this connection.
Definition at line 748 of file internal.h.
Referenced by build_header_response(), check_write_done(), internal_add_connection(), MHD_connection_close(), MHD_connection_handle_idle(), MHD_connection_handle_read(), MHD_connection_handle_write(), MHD_connection_update_event_loop_info(), MHD_handle_connection(), MHD_queue_response(), MHD_tls_connection_handle_idle(), parse_connection_headers(), recv_param_adapter(), run_tls_handshake(), send_param_adapter(), transmit_error_response(), try_ready_chunked_body(), and try_ready_normal_body().
Is the connection suspended?
Definition at line 844 of file internal.h.
Referenced by cleanup_connection(), MHD_suspend_connection(), and resume_suspended_connections().
Set to MHD_YES if the thread has been joined.
Definition at line 731 of file internal.h.
Referenced by close_all_connections(), and MHD_cleanup_connections().
char* MHD_Connection::url |
Requested URL (everything after "GET" only). Allocated in pool.
Definition at line 591 of file internal.h.
Referenced by call_connection_handler(), get_next_header_line(), MHD_connection_handle_idle(), MHD_connection_update_event_loop_info(), MHD_digest_auth_check(), MHD_queue_auth_fail_response(), parse_initial_message_line(), and process_request_body().
char* MHD_Connection::version |
HTTP version string (i.e. http/1.1). Allocated in pool.
Definition at line 597 of file internal.h.
Referenced by add_extra_headers(), build_header_response(), call_connection_handler(), MHD_connection_handle_idle(), need_100_continue(), parse_connection_headers(), parse_initial_message_line(), process_request_body(), and transmit_error_response().
Buffer for writing response (headers only). Allocated in pool.
Definition at line 611 of file internal.h.
Referenced by build_header_response(), check_write_done(), do_write(), MHD_connection_handle_idle(), and try_ready_chunked_body().
Last valid location in write_buffer (where do we append and up to where is it safe to send?)
Definition at line 668 of file internal.h.
Referenced by build_header_response(), check_write_done(), do_write(), MHD_connection_handle_idle(), send_param_adapter(), and try_ready_chunked_body().
Offset where we are with sending from write_buffer.
Definition at line 662 of file internal.h.
Referenced by build_header_response(), check_write_done(), do_write(), MHD_connection_handle_idle(), send_param_adapter(), and try_ready_chunked_body().
Size of write_buffer (in bytes).
Definition at line 657 of file internal.h.
Referenced by build_header_response(), check_write_done(), MHD_connection_handle_idle(), and try_ready_chunked_body().
int(* MHD_Connection::write_handler)(struct MHD_Connection *connection) |
Handler used for processing write connection operations
Referenced by MHD_handle_connection(), MHD_run_from_select(), MHD_set_http_callbacks_(), and MHD_set_https_callbacks().