Fetch messages and save them in $spool_file.
519{
521 if (!c_pop_host)
522 {
524 return;
525 }
526
527 char buf[1024] = { 0 };
528 char msgbuf[128] = { 0 };
529 int last = 0, msgs = 0, bytes = 0, rset = 0, rc;
531
533 char *url = p;
535 {
536 strcpy(url, "pop://");
537 p = strchr(url, '\0');
538 }
539 strcpy(p, c_pop_host);
540
543 if (rc)
544 {
545 mutt_error(
_(
"%s is an invalid POP path"), c_pop_host);
546 return;
547 }
548
550 if (!conn)
551 return;
552
555
557 {
559 return;
560 }
561
563
564
567 if (rc == -1)
568 goto fail;
569 if (rc == -2)
570 {
572 goto finish;
573 }
574
575 sscanf(buf, "+OK %d %d", &msgs, &bytes);
576
577
579 if ((msgs > 0) && c_pop_last)
580 {
583 if (rc == -1)
584 goto fail;
585 if (rc == 0)
586 sscanf(buf, "+OK %d", &last);
587 }
588
589 if (msgs <= last)
590 {
592 goto finish;
593 }
594
597
599 {
601 goto finish;
602 }
603 bool old_append = m_spool->
append;
605
608
609 snprintf(msgbuf, sizeof(msgbuf),
610 ngettext("Reading new messages (%d byte)...",
611 "Reading new messages (%d bytes)...", bytes),
612 bytes);
614
615 for (int i = last + 1; i <= msgs; i++)
616 {
618 if (msg)
619 {
620 snprintf(buf, sizeof(buf), "RETR %d\r\n", i);
622 if (rc == -3)
623 rset = 1;
624
626 {
627 rset = 1;
628 rc = -3;
629 }
630
632 }
633 else
634 {
635 rc = -3;
636 }
637
638 if ((rc == 0) && (delanswer ==
MUTT_YES))
639 {
640
641 snprintf(buf, sizeof(buf), "DELE %d\r\n", i);
643 }
644
645 if (rc == -1)
646 {
647 m_spool->
append = old_append;
649 goto fail;
650 }
651 if (rc == -2)
652 {
654 break;
655 }
656 if (rc == -3)
657 {
659 break;
660 }
661
662
663
665 "%s [%d of %d messages read]", msgs - last),
666 msgbuf, i - last, msgs - last);
667 }
668
669 m_spool->
append = old_append;
671
672 if (rset)
673 {
674
676 if (
pop_query(adata, buf,
sizeof(buf)) == -1)
677 goto fail;
678 }
679
680finish:
681
683 if (
pop_query(adata, buf,
sizeof(buf)) == -1)
684 goto fail;
687 return;
688
689fail:
693}
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.