static int echo_post_chunk_handler()

in c-modules/echo_post_chunk/mod_echo_post_chunk.c [13:91]


static int echo_post_chunk_handler(request_rec *r)
{
    int rc;
    long nrd, total = 0;
    char buff[BUFSIZ];
    const char *trailer_header;

    if (strcmp(r->handler, "echo_post_chunk")) {
        return DECLINED;
    }
    if (r->method_number != M_POST) {
        return DECLINED;
    }

    if ((rc = ap_setup_client_block(r, REQUEST_CHUNKED_DECHUNK)) != OK) {
#ifdef APACHE1
        ap_log_error(APLOG_MARK, APLOG_ERR|APLOG_NOERRNO, r->server,
                     "[mod_echo_post_chunk] ap_setup_client_block failed: %d", rc);
#else
        ap_log_error(APLOG_MARK, APLOG_ERR|APLOG_NOERRNO, 0, r->server,
                     "[mod_echo_post_chunk] ap_setup_client_block failed: %d", rc);
#endif /* APACHE1 */
        return 0;
    }

    if (!ap_should_client_block(r)) {
        return OK;
    }

    if (r->args) {
        ap_rprintf(r, "%" APR_OFF_T_FMT ":", r->remaining);
    }

    fprintf(stderr, "[mod_echo_post_chunk] going to echo "
            "%" APR_OFF_T_FMT " bytes\n",
            r->remaining);

    while ((nrd = ap_get_client_block(r, buff, sizeof(buff))) > 0) {
        fprintf(stderr,
                "[mod_echo_post_chunk] read %ld bytes "
                "(wanted %" APR_SIZE_T_FMT ", remaining=%" APR_OFF_T_FMT ")\n",
                nrd, sizeof(buff), r->remaining);
        total += nrd;
    }

    /* nrd < 0 is an error condition. Either the chunk size overflowed or the buffer
     * size was insufficient. We can only deduce that the request is in error.
     */
    if (nrd < 0) {
        return HTTP_BAD_REQUEST;
    }
#ifdef APACHE1
    ap_send_http_header(r);
#endif

#ifdef APACHE1
    trailer_header = ap_table_get(r->headers_in, "X-Chunk-Trailer");
#elif (MODULE_MAGIC_COOKIE >= 0x41503235UL) && AP_MODULE_MAGIC_AT_LEAST(20140627,5)
    trailer_header = apr_table_get(r->trailers_in, "X-Chunk-Trailer");
#elif (MODULE_MAGIC_COOKIE == 0x41503234UL) && AP_MODULE_MAGIC_AT_LEAST(20120211,37)
    trailer_header = apr_table_get(r->trailers_in, "X-Chunk-Trailer");
#elif (MODULE_MAGIC_COOKIE == 0x41503232UL) && AP_MODULE_MAGIC_AT_LEAST(20051115,36)
    trailer_header = apr_table_get(r->trailers_in, "X-Chunk-Trailer");
#else
    trailer_header = apr_table_get(r->headers_in, "X-Chunk-Trailer");
#endif
    if (!trailer_header) {
        trailer_header = "No chunked trailer available!";
    }

    ap_rputs(trailer_header, r);

    fprintf(stderr,
            "[mod_echo_post_chunk] done reading %ld bytes, "
            "%" APR_OFF_T_FMT " bytes remain\n",
            total, r->remaining);
    
    return OK;
}