Annotation of embedaddon/curl/lib/pop3.h, revision 1.1.1.1

1.1       misho       1: #ifndef HEADER_CURL_POP3_H
                      2: #define HEADER_CURL_POP3_H
                      3: /***************************************************************************
                      4:  *                                  _   _ ____  _
                      5:  *  Project                     ___| | | |  _ \| |
                      6:  *                             / __| | | | |_) | |
                      7:  *                            | (__| |_| |  _ <| |___
                      8:  *                             \___|\___/|_| \_\_____|
                      9:  *
                     10:  * Copyright (C) 2009 - 2019, 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.haxx.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:  ***************************************************************************/
                     24: 
                     25: #include "pingpong.h"
                     26: #include "curl_sasl.h"
                     27: 
                     28: /****************************************************************************
                     29:  * POP3 unique setup
                     30:  ***************************************************************************/
                     31: typedef enum {
                     32:   POP3_STOP,         /* do nothing state, stops the state machine */
                     33:   POP3_SERVERGREET,  /* waiting for the initial greeting immediately after
                     34:                         a connect */
                     35:   POP3_CAPA,
                     36:   POP3_STARTTLS,
                     37:   POP3_UPGRADETLS,   /* asynchronously upgrade the connection to SSL/TLS
                     38:                        (multi mode only) */
                     39:   POP3_AUTH,
                     40:   POP3_APOP,
                     41:   POP3_USER,
                     42:   POP3_PASS,
                     43:   POP3_COMMAND,
                     44:   POP3_QUIT,
                     45:   POP3_LAST          /* never used */
                     46: } pop3state;
                     47: 
                     48: /* This POP3 struct is used in the Curl_easy. All POP3 data that is
                     49:    connection-oriented must be in pop3_conn to properly deal with the fact that
                     50:    perhaps the Curl_easy is changed between the times the connection is
                     51:    used. */
                     52: struct POP3 {
                     53:   curl_pp_transfer transfer;
                     54:   char *id;               /* Message ID */
                     55:   char *custom;           /* Custom Request */
                     56: };
                     57: 
                     58: /* pop3_conn is used for struct connection-oriented data in the connectdata
                     59:    struct */
                     60: struct pop3_conn {
                     61:   struct pingpong pp;
                     62:   pop3state state;        /* Always use pop3.c:state() to change state! */
                     63:   bool ssldone;           /* Is connect() over SSL done? */
                     64:   size_t eob;             /* Number of bytes of the EOB (End Of Body) that
                     65:                              have been received so far */
                     66:   size_t strip;           /* Number of bytes from the start to ignore as
                     67:                              non-body */
                     68:   struct SASL sasl;       /* SASL-related storage */
                     69:   unsigned int authtypes; /* Accepted authentication types */
                     70:   unsigned int preftype;  /* Preferred authentication type */
                     71:   char *apoptimestamp;    /* APOP timestamp from the server greeting */
                     72:   bool tls_supported;     /* StartTLS capability supported by server */
                     73: };
                     74: 
                     75: extern const struct Curl_handler Curl_handler_pop3;
                     76: extern const struct Curl_handler Curl_handler_pop3s;
                     77: 
                     78: /* Authentication type flags */
                     79: #define POP3_TYPE_CLEARTEXT (1 << 0)
                     80: #define POP3_TYPE_APOP      (1 << 1)
                     81: #define POP3_TYPE_SASL      (1 << 2)
                     82: 
                     83: /* Authentication type values */
                     84: #define POP3_TYPE_NONE      0
                     85: #define POP3_TYPE_ANY       ~0U
                     86: 
                     87: /* This is the 5-bytes End-Of-Body marker for POP3 */
                     88: #define POP3_EOB "\x0d\x0a\x2e\x0d\x0a"
                     89: #define POP3_EOB_LEN 5
                     90: 
                     91: /* This function scans the body after the end-of-body and writes everything
                     92:  * until the end is found */
                     93: CURLcode Curl_pop3_write(struct connectdata *conn, char *str, size_t nread);
                     94: 
                     95: #endif /* HEADER_CURL_POP3_H */

FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>