| 1 | #ifndef HEADER_CURL_SENDF_H |
| 2 | #define |
| 3 | /*************************************************************************** |
| 4 | * _ _ ____ _ |
| 5 | * Project ___| | | | _ \| | |
| 6 | * / __| | | | |_) | | |
| 7 | * | (__| |_| | _ <| |___ |
| 8 | * \___|\___/|_| \_\_____| |
| 9 | * |
| 10 | * Copyright (C) Daniel Stenberg, <daniel@haxx.se>, et al. |
| 11 | * |
| 12 | * This software is licensed as described in the file COPYING, which |
| 13 | * you should have received as part of this distribution. The terms |
| 14 | * are also available at https://curl.se/docs/copyright.html. |
| 15 | * |
| 16 | * You may opt to use, copy, modify, merge, publish, distribute and/or sell |
| 17 | * copies of the Software, and permit persons to whom the Software is |
| 18 | * furnished to do so, under the terms of the COPYING file. |
| 19 | * |
| 20 | * This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY |
| 21 | * KIND, either express or implied. |
| 22 | * |
| 23 | * SPDX-License-Identifier: curl |
| 24 | * |
| 25 | ***************************************************************************/ |
| 26 | |
| 27 | #include "curl_setup.h" |
| 28 | |
| 29 | #include "curl_trc.h" |
| 30 | |
| 31 | /** |
| 32 | * Type of data that is being written to the client (application) |
| 33 | * - data written can be either BODY or META data |
| 34 | * - META data is either INFO or HEADER |
| 35 | * - INFO is meta information, e.g. not BODY, that cannot be interpreted |
| 36 | * as headers of a response. Example FTP/IMAP pingpong answers. |
| 37 | * - HEADER can have additional bits set (more than one) |
| 38 | * - STATUS special "header", e.g. response status line in HTTP |
| 39 | * - CONNECT header was received during proxying the connection |
| 40 | * - 1XX header is part of an intermediate response, e.g. HTTP 1xx code |
| 41 | * - TRAILER header is trailing response data, e.g. HTTP trailers |
| 42 | * BODY, INFO and HEADER should not be mixed, as this would lead to |
| 43 | * confusion on how to interpret/format/convert the data. |
| 44 | */ |
| 45 | #define CLIENTWRITE_BODY (1<<0) /* non-meta information, BODY */ |
| 46 | #define CLIENTWRITE_INFO (1<<1) /* meta information, not a HEADER */ |
| 47 | #define (1<<2) /* meta information, HEADER */ |
| 48 | #define CLIENTWRITE_STATUS (1<<3) /* a special status HEADER */ |
| 49 | #define CLIENTWRITE_CONNECT (1<<4) /* a CONNECT related HEADER */ |
| 50 | #define CLIENTWRITE_1XX (1<<5) /* a 1xx response related HEADER */ |
| 51 | #define CLIENTWRITE_TRAILER (1<<6) /* a trailer HEADER */ |
| 52 | |
| 53 | CURLcode Curl_client_write(struct Curl_easy *data, int type, char *ptr, |
| 54 | size_t len) WARN_UNUSED_RESULT; |
| 55 | |
| 56 | CURLcode Curl_client_unpause(struct Curl_easy *data); |
| 57 | void Curl_client_cleanup(struct Curl_easy *data); |
| 58 | |
| 59 | struct contenc_writer { |
| 60 | const struct content_encoding *handler; /* Encoding handler. */ |
| 61 | struct contenc_writer *downstream; /* Downstream writer. */ |
| 62 | unsigned int order; /* Ordering within writer stack. */ |
| 63 | }; |
| 64 | |
| 65 | /* Content encoding writer. */ |
| 66 | struct content_encoding { |
| 67 | const char *name; /* Encoding name. */ |
| 68 | const char *alias; /* Encoding name alias. */ |
| 69 | CURLcode (*init_writer)(struct Curl_easy *data, |
| 70 | struct contenc_writer *writer); |
| 71 | CURLcode (*unencode_write)(struct Curl_easy *data, |
| 72 | struct contenc_writer *writer, |
| 73 | const char *buf, size_t nbytes); |
| 74 | void (*close_writer)(struct Curl_easy *data, |
| 75 | struct contenc_writer *writer); |
| 76 | size_t writersize; |
| 77 | }; |
| 78 | |
| 79 | |
| 80 | CURLcode Curl_client_create_writer(struct contenc_writer **pwriter, |
| 81 | struct Curl_easy *data, |
| 82 | const struct content_encoding *ce_handler, |
| 83 | int order); |
| 84 | |
| 85 | void Curl_client_free_writer(struct Curl_easy *data, |
| 86 | struct contenc_writer *writer); |
| 87 | |
| 88 | CURLcode Curl_client_add_writer(struct Curl_easy *data, |
| 89 | struct contenc_writer *writer); |
| 90 | |
| 91 | |
| 92 | /* internal read-function, does plain socket, SSL and krb4 */ |
| 93 | CURLcode Curl_read(struct Curl_easy *data, curl_socket_t sockfd, |
| 94 | char *buf, size_t buffersize, |
| 95 | ssize_t *n); |
| 96 | |
| 97 | /* internal write-function, does plain socket, SSL, SCP, SFTP and krb4 */ |
| 98 | CURLcode Curl_write(struct Curl_easy *data, |
| 99 | curl_socket_t sockfd, |
| 100 | const void *mem, size_t len, |
| 101 | ssize_t *written); |
| 102 | |
| 103 | /* internal write-function, using sockindex for connection destination */ |
| 104 | CURLcode Curl_nwrite(struct Curl_easy *data, |
| 105 | int sockindex, |
| 106 | const void *buf, |
| 107 | size_t blen, |
| 108 | ssize_t *pnwritten); |
| 109 | |
| 110 | #endif /* HEADER_CURL_SENDF_H */ |
| 111 | |