Fetch messages and save them in $spool_file.
518{
520 if (!c_pop_host)
521 {
523 return;
524 }
525
526 char buf[1024] = { 0 };
527 char msgbuf[128] = { 0 };
528 int last = 0, msgs = 0, bytes = 0, rset = 0, rc;
530
532 char *url = p;
534 {
535 strcpy(url, "pop://");
536 p = strchr(url, '\0');
537 }
538 strcpy(p, c_pop_host);
539
542 if (rc)
543 {
544 mutt_error(
_(
"%s is an invalid POP path"), c_pop_host);
545 return;
546 }
547
549 if (!conn)
550 return;
551
554
556 {
558 return;
559 }
560
562
563
566 if (rc == -1)
567 goto fail;
568 if (rc == -2)
569 {
571 goto finish;
572 }
573
574 sscanf(buf, "+OK %d %d", &msgs, &bytes);
575
576
578 if ((msgs > 0) && c_pop_last)
579 {
582 if (rc == -1)
583 goto fail;
584 if (rc == 0)
585 sscanf(buf, "+OK %d", &last);
586 }
587
588 if (msgs <= last)
589 {
591 goto finish;
592 }
593
596
598 {
600 goto finish;
601 }
602 bool old_append = m_spool->
append;
604
607
608 snprintf(msgbuf, sizeof(msgbuf),
609 ngettext("Reading new messages (%d byte)...",
610 "Reading new messages (%d bytes)...", bytes),
611 bytes);
613
614 for (int i = last + 1; i <= msgs; i++)
615 {
617 if (msg)
618 {
619 snprintf(buf, sizeof(buf), "RETR %d\r\n", i);
621 if (rc == -3)
622 rset = 1;
623
625 {
626 rset = 1;
627 rc = -3;
628 }
629
631 }
632 else
633 {
634 rc = -3;
635 }
636
637 if ((rc == 0) && (delanswer ==
MUTT_YES))
638 {
639
640 snprintf(buf, sizeof(buf), "DELE %d\r\n", i);
642 }
643
644 if (rc == -1)
645 {
646 m_spool->
append = old_append;
648 goto fail;
649 }
650 if (rc == -2)
651 {
653 break;
654 }
655 if (rc == -3)
656 {
658 break;
659 }
660
661
662
664 "%s [%d of %d messages read]", msgs - last),
665 msgbuf, i - last, msgs - last);
666 }
667
668 m_spool->
append = old_append;
670
671 if (rset)
672 {
673
675 if (
pop_query(adata, buf,
sizeof(buf)) == -1)
676 goto fail;
677 }
678
679finish:
680
682 if (
pop_query(adata, buf,
sizeof(buf)) == -1)
683 goto fail;
686 return;
687
688fail:
692}
const char * cs_subset_string(const struct ConfigSubset *sub, const char *name)
Get a string config item by name.
bool cs_subset_bool(const struct ConfigSubset *sub, const char *name)
Get a boolean config item by name.
void mailbox_free(struct Mailbox **ptr)
Free a Mailbox.
void pop_adata_free(void **ptr)
Free the private Account data - Implements Account::adata_free() -.
#define mutt_message(...)
static int fetch_message(const char *line, void *data)
Parse a Message response - Implements pop_fetch_t -.
#define FREE(x)
Free memory and set the pointer to NULL.
#define MUTT_MEM_CALLOC(n, type)
size_t mutt_str_copy(char *dest, const char *src, size_t dsize)
Copy a string into a buffer (guaranteeing NUL-termination)
struct Connection * mutt_conn_find(const struct ConnAccount *cac)
Find a connection from a list.
int mx_msg_close(struct Mailbox *m, struct Message **ptr)
Close a message.
bool mx_mbox_open(struct Mailbox *m, OpenMailboxFlags flags)
Open a mailbox and parse it.
struct Message * mx_msg_open_new(struct Mailbox *m, const struct Email *e, MsgOpenFlags flags)
Open a new message.
int mx_msg_commit(struct Mailbox *m, struct Message *msg)
Commit a message to a folder - Wrapper for MxOps::msg_commit()
struct Mailbox * mx_path_resolve(const char *path)
Get a Mailbox for a path.
enum MxStatus mx_mbox_close(struct Mailbox *m)
Save changes and close mailbox.
#define MUTT_ADD_FROM
add a From_ line
#define MUTT_OPEN_NO_FLAGS
No flags are set.
struct PopAccountData * pop_adata_new(void)
Create a new PopAccountData object.
int pop_open_connection(struct PopAccountData *adata)
Open connection and authenticate.
int pop_parse_path(const char *path, struct ConnAccount *cac)
Parse a POP mailbox name.
int pop_fetch_data(struct PopAccountData *adata, const char *query, struct Progress *progress, pop_fetch_t callback, void *data)
Read Headers with callback function.
#define pop_query(adata, buf, buflen)
QuadOption
Possible values for a quad-option.
@ MUTT_YES
User answered 'Yes', or assume 'Yes'.
enum QuadOption query_quadoption(const char *prompt, struct ConfigSubset *sub, const char *name)
Ask the user a quad-question.
int mutt_socket_close(struct Connection *conn)
Close a socket.
void * adata
Private data (for Mailbox backends)
Login details for a remote server.
bool append
Mailbox is opened in append mode.
A local copy of an email.
FILE * fp
pointer to the message data
Container for Accounts, Notifications.
struct ConfigSubset * sub
Inherited config items.
POP-specific Account data -.
char err_msg[POP_CMD_RESPONSE]
Last error message.
struct Connection * conn
Connection to POP server.
enum UrlScheme url_check_scheme(const char *str)
Check the protocol of a URL.
@ U_UNKNOWN
Url wasn't recognised.