Commit 1ec157da authored by Wandenberg Peixoto's avatar Wandenberg Peixoto

refactoring the function...

refactoring the function ngx_http_push_stream_send_response_all_channels_info_detailed to not response as a chuncked response
parent e2d5d8d3
...@@ -223,44 +223,54 @@ ngx_http_push_stream_rbtree_walker_channel_info_locked(ngx_rbtree_t *tree, ngx_p ...@@ -223,44 +223,54 @@ ngx_http_push_stream_rbtree_walker_channel_info_locked(ngx_rbtree_t *tree, ngx_p
static ngx_int_t static ngx_int_t
ngx_http_push_stream_send_response_all_channels_info_detailed(ngx_http_request_t *r) { ngx_http_push_stream_send_response_all_channels_info_detailed(ngx_http_request_t *r) {
ngx_int_t rc; ngx_int_t rc, content_len = 0;
ngx_chain_t *chain; ngx_chain_t *chain, *first = NULL, *last = NULL;
ngx_str_t *currenttime, *hostname; ngx_str_t *currenttime, *hostname;
ngx_str_t header_response; ngx_str_t header_response;
ngx_queue_t queue_channel_info; ngx_queue_t queue_channel_info;
ngx_queue_t *cur, *next; ngx_queue_t *cur, *next;
ngx_http_push_stream_shm_data_t *shm_data; ngx_http_push_stream_shm_data_t *data = (ngx_http_push_stream_shm_data_t *) ngx_http_push_stream_shm_zone->data;
ngx_slab_pool_t *shpool; ngx_slab_pool_t *shpool = (ngx_slab_pool_t *) ngx_http_push_stream_shm_zone->shm.addr;
ngx_http_push_stream_content_subtype_t *subtype = ngx_http_push_stream_match_channel_info_format_and_content_type(r, 1);
ngx_http_push_stream_content_subtype_t *subtype;
subtype = ngx_http_push_stream_match_channel_info_format_and_content_type(r, 1);
const ngx_str_t *format; const ngx_str_t *format;
const ngx_str_t *head = subtype->format_group_head; const ngx_str_t *head = subtype->format_group_head;
const ngx_str_t *tail = subtype->format_group_tail; const ngx_str_t *tail = subtype->format_group_tail;
shpool = (ngx_slab_pool_t *) ngx_http_push_stream_shm_zone->shm.addr; ngx_queue_init(&queue_channel_info);
shm_data = (ngx_http_push_stream_shm_data_t *) ngx_http_push_stream_shm_zone->data;
r->headers_out.content_type.len = subtype->content_type->len; ngx_shmtx_lock(&shpool->mutex);
r->headers_out.content_type.data = subtype->content_type->data; ngx_http_push_stream_rbtree_walker_channel_info_locked(&data->tree, r->pool, data->tree.root, &queue_channel_info);
r->headers_out.content_length_n = -1; ngx_shmtx_unlock(&shpool->mutex);
r->headers_out.status = NGX_HTTP_OK;
rc = ngx_http_send_header(r); // send content body
if (rc == NGX_ERROR || rc > NGX_OK || r->header_only) { cur = ngx_queue_head(&queue_channel_info);
return rc; while (cur != &queue_channel_info) {
} next = ngx_queue_next(cur);
ngx_http_push_stream_channel_info_t *channel_info = (ngx_http_push_stream_channel_info_t *) cur;
if ((chain = ngx_pcalloc(r->pool, sizeof(ngx_chain_t))) == NULL) {
ngx_log_error(NGX_LOG_ERR, r->connection->log, 0, "push stream module: unable to allocate memory for response channels info");
return NGX_HTTP_INTERNAL_SERVER_ERROR;
}
// this method send the response as a streaming cause the content could be very big format = (next != &queue_channel_info) ? subtype->format_group_item : subtype->format_group_last_item;
r->keepalive = 1;
ngx_queue_init(&queue_channel_info); chain->buf = ngx_http_push_stream_channel_info_formatted(r->pool, format, &channel_info->id, channel_info->published_messages, channel_info->stored_messages, channel_info->subscribers);
chain->buf->last_buf = 0;
ngx_shmtx_lock(&shpool->mutex); content_len += ngx_buf_size(chain->buf);
ngx_http_push_stream_rbtree_walker_channel_info_locked(&shm_data->tree, r->pool, shm_data->tree.root, &queue_channel_info);
ngx_shmtx_unlock(&shpool->mutex); if (first == NULL) {
first = chain;
}
if (last != NULL) {
last->next = chain;
}
last = chain;
cur = next;
}
// get formatted current time // get formatted current time
currenttime = ngx_http_push_stream_get_formatted_current_time(r->pool); currenttime = ngx_http_push_stream_get_formatted_current_time(r->pool);
...@@ -275,33 +285,23 @@ ngx_http_push_stream_send_response_all_channels_info_detailed(ngx_http_request_t ...@@ -275,33 +285,23 @@ ngx_http_push_stream_send_response_all_channels_info_detailed(ngx_http_request_t
} }
ngx_memset(header_response.data, '\0', head->len + hostname->len + currenttime->len + 1); ngx_memset(header_response.data, '\0', head->len + hostname->len + currenttime->len + 1);
ngx_sprintf(header_response.data, (char *) head->data, hostname->data, currenttime->data, shm_data->channels, shm_data->broadcast_channels); ngx_sprintf(header_response.data, (char *) head->data, hostname->data, currenttime->data, data->channels, data->broadcast_channels);
header_response.len = ngx_strlen(header_response.data); header_response.len = ngx_strlen(header_response.data);
ngx_http_push_stream_send_response_chunk(r, header_response.data, header_response.len,0);
// send content body content_len += header_response.len + tail->len;
cur = ngx_queue_head(&queue_channel_info);
while (cur != &queue_channel_info) {
next = ngx_queue_next(cur);
ngx_http_push_stream_channel_info_t *channel_info = (ngx_http_push_stream_channel_info_t *) cur;
if ((chain = ngx_pcalloc(r->pool, sizeof(ngx_chain_t))) == NULL) {
ngx_log_error(NGX_LOG_ERR, r->connection->log, 0, "push stream module: unable to allocate memory for response channels info");
return NGX_HTTP_INTERNAL_SERVER_ERROR;
}
format = (next != &queue_channel_info) ? subtype->format_group_item : subtype->format_group_last_item; r->headers_out.content_type.len = subtype->content_type->len;
r->headers_out.content_type.data = subtype->content_type->data;
chain->buf = ngx_http_push_stream_channel_info_formatted(r->pool, format, &channel_info->id, channel_info->published_messages, channel_info->stored_messages, channel_info->subscribers); r->headers_out.content_length_n = content_len;
chain->buf->last_buf = 0; r->headers_out.status = NGX_HTTP_OK;
chain->buf->flush = 1;
ngx_http_output_filter(r, chain);
cur = next; rc = ngx_http_send_header(r);
if (rc == NGX_ERROR || rc > NGX_OK || r->header_only) {
return rc;
} }
r->keepalive = 0; ngx_http_push_stream_send_response_chunk(r, header_response.data, header_response.len,0);
ngx_http_output_filter(r, first);
// send content tail
return ngx_http_push_stream_send_response_chunk(r, tail->data, tail->len, 1); return ngx_http_push_stream_send_response_chunk(r, tail->data, tail->len, 1);
} }
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment