Fetch messages and save them in $spool_file.
530{
532 if (!c_pop_host)
533 {
535 return;
536 }
537
538 char buf[1024] = { 0 };
539 char msgbuf[128] = { 0 };
540 int last = 0, msgs = 0, bytes = 0, rset = 0, rc;
542
543 char *url = NULL;
546 else
548
551 if (rc)
552 {
553 mutt_error(
_(
"%s is an invalid POP path"), c_pop_host);
554 return;
555 }
556
558 if (!conn)
559 return;
560
563
565 {
567 return;
568 }
569
571
572
575 if (rc == -1)
576 goto fail;
577 if (rc == -2)
578 {
580 goto finish;
581 }
582
583 sscanf(buf, "+OK %d %d", &msgs, &bytes);
584
585
587 if ((msgs > 0) && c_pop_last)
588 {
591 if (rc == -1)
592 goto fail;
593 if (rc == 0)
594 sscanf(buf, "+OK %d", &last);
595 }
596
597 if (msgs <= last)
598 {
600 goto finish;
601 }
602
605
607 {
609 goto finish;
610 }
611 bool old_append = m_spool->
append;
613
616
617 snprintf(msgbuf, sizeof(msgbuf),
618 ngettext("Reading new messages (%d byte)...",
619 "Reading new messages (%d bytes)...", bytes),
620 bytes);
622
623 for (int i = last + 1; i <= msgs; i++)
624 {
626 if (msg)
627 {
628 snprintf(buf, sizeof(buf), "RETR %d\r\n", i);
630 if (rc == -3)
631 rset = 1;
632
634 {
635 rset = 1;
636 rc = -3;
637 }
638
640 }
641 else
642 {
643 rc = -3;
644 }
645
646 if ((rc == 0) && (delanswer ==
MUTT_YES))
647 {
648
649 snprintf(buf, sizeof(buf), "DELE %d\r\n", i);
651 }
652
653 if (rc == -1)
654 {
655 m_spool->
append = old_append;
657 goto fail;
658 }
659 if (rc == -2)
660 {
662 break;
663 }
664 if (rc == -3)
665 {
667 break;
668 }
669
670
671
673 "%s [%d of %d messages read]", msgs - last),
674 msgbuf, i - last, msgs - last);
675 }
676
677 m_spool->
append = old_append;
679
680 if (rset)
681 {
682
684 if (
pop_query(adata, buf,
sizeof(buf)) == -1)
685 goto fail;
686 }
687
688finish:
689
691 if (
pop_query(adata, buf,
sizeof(buf)) == -1)
692 goto fail;
695 return;
696
697fail:
701}
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.
char * mutt_str_dup(const char *str)
Copy a string, safely.
int mutt_str_asprintf(char **strp, const char *fmt,...)
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.
@ MUTT_ADD_FROM
add a From_ line
@ MUTT_OPEN_NONE
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.