Replace quickmail with a direct (and asynchronous) libcurl email sender.
authorCarl Hetherington <cth@carlh.net>
Wed, 7 Oct 2015 22:03:56 +0000 (23:03 +0100)
committerCarl Hetherington <cth@carlh.net>
Fri, 9 Oct 2015 12:44:59 +0000 (13:44 +0100)
src/lib/cinema_kdms.cc
src/lib/cinema_kdms.h
src/lib/quickmail.cc [deleted file]
src/lib/quickmail.h [deleted file]
src/lib/send_kdm_email_job.cc
src/lib/send_problem_report_job.cc
src/lib/wscript

index 966955ab4631cb92c972a3bc2da79a8fbb7c0979..9b839a3545f4f8597f6bb2c1b65bf0ecf8133ef7 100644 (file)
 
 */
 
-#include "quickmail.h"
 #include "exceptions.h"
 #include "cinema_kdms.h"
 #include "cinema.h"
 #include "screen.h"
 #include "config.h"
 #include "util.h"
+#include "emailer.h"
 #include "compose.hpp"
 #include <zip.h>
 #include <boost/foreach.hpp>
@@ -31,6 +31,7 @@
 #include "i18n.h"
 
 using std::list;
+using std::cout;
 using std::string;
 using boost::shared_ptr;
 
@@ -117,8 +118,10 @@ CinemaKDMs::write_zip_files (string filename_first_part, list<CinemaKDMs> cinema
 
 /* XXX: should probably get from/to from the KDMs themselves */
 void
-CinemaKDMs::email (string filename_first_part, string cpl_name, list<CinemaKDMs> cinema_kdms, dcp::LocalTime from, dcp::LocalTime to)
+CinemaKDMs::email (string filename_first_part, string cpl_name, list<CinemaKDMs> cinema_kdms, dcp::LocalTime from, dcp::LocalTime to, shared_ptr<Job> job)
 {
+       Config* config = Config::instance ();
+
        BOOST_FOREACH (CinemaKDMs const & i, cinema_kdms) {
 
                boost::filesystem::path zip_file = boost::filesystem::temp_directory_path ();
@@ -127,29 +130,17 @@ CinemaKDMs::email (string filename_first_part, string cpl_name, list<CinemaKDMs>
 
                /* Send email */
 
-               quickmail_initialize ();
-
+               string subject = config->kdm_subject();
                SafeStringStream start;
                start << from.date() << " " << from.time_of_day();
                SafeStringStream end;
                end << to.date() << " " << to.time_of_day();
-
-               string subject = Config::instance()->kdm_subject();
                boost::algorithm::replace_all (subject, "$CPL_NAME", cpl_name);
                boost::algorithm::replace_all (subject, "$START_TIME", start.str ());
                boost::algorithm::replace_all (subject, "$END_TIME", end.str ());
                boost::algorithm::replace_all (subject, "$CINEMA_NAME", i.cinema->name);
-               quickmail mail = quickmail_create (Config::instance()->kdm_from().c_str(), subject.c_str ());
 
-               quickmail_add_to (mail, i.cinema->email.c_str ());
-               if (!Config::instance()->kdm_cc().empty ()) {
-                       quickmail_add_cc (mail, Config::instance()->kdm_cc().c_str ());
-               }
-               if (!Config::instance()->kdm_bcc().empty ()) {
-                       quickmail_add_bcc (mail, Config::instance()->kdm_bcc().c_str ());
-               }
-
-               string body = Config::instance()->kdm_email().c_str();
+               string body = config->kdm_email().c_str();
                boost::algorithm::replace_all (body, "$CPL_NAME", cpl_name);
                boost::algorithm::replace_all (body, "$START_TIME", start.str ());
                boost::algorithm::replace_all (body, "$END_TIME", end.str ());
@@ -161,34 +152,16 @@ CinemaKDMs::email (string filename_first_part, string cpl_name, list<CinemaKDMs>
                }
                boost::algorithm::replace_all (body, "$SCREENS", screens.str().substr (0, screens.str().length() - 2));
 
-               quickmail_set_body (mail, body.c_str());
-               quickmail_add_attachment_file (mail, zip_file.string().c_str(), "application/zip");
-
-               char const* e = quickmail_send (
-                       mail,
-                       Config::instance()->mail_server().c_str(),
-                       Config::instance()->mail_port(),
-                       Config::instance()->mail_user().c_str(),
-                       Config::instance()->mail_password().c_str()
-                       );
+               Emailer email (config->kdm_from(), i.cinema->email, subject, body);
 
-               if (e) {
-                       quickmail_destroy (mail);
-
-                       string error (e);
-
-                       if (Config::instance()->mail_server().empty ()) {
-                               error = _("no mail server set up in preferences");
-                       }
-
-                       throw KDMError (
-                               String::compose (
-                                       _("Failed to send KDM email to %1 (%2)"),
-                                       i.cinema->email,
-                                       error
-                                       )
-                               );
+               if (!config->kdm_cc().empty ()) {
+                       email.add_cc (config->kdm_cc ());
+               }
+               if (!config->kdm_bcc().empty ()) {
+                       email.add_bcc (config->kdm_bcc ());
                }
-               quickmail_destroy (mail);
+
+               email.add_attachment (zip_file, "application/zip");
+               email.send (job);
        }
 }
index d0f70328078c2c2dd22b4d8e1e1ed168855edf54..ecff32ff42c521c24817ea5fcb1d1501c1896d3e 100644 (file)
@@ -20,6 +20,7 @@
 #include "screen_kdm.h"
 
 class Cinema;
+class Job;
 
 class CinemaKDMs
 {
@@ -28,7 +29,14 @@ public:
 
        static std::list<CinemaKDMs> collect (std::list<ScreenKDM> kdms);
        static void write_zip_files (std::string filename_first_part, std::list<CinemaKDMs> cinema_kdms, boost::filesystem::path directory);
-       static void email (std::string filename_first_part, std::string cpl_name, std::list<CinemaKDMs> cinema_kdms, dcp::LocalTime from, dcp::LocalTime to);
+       static void email (
+               std::string filename_first_part,
+               std::string cpl_name,
+               std::list<CinemaKDMs> cinema_kdms,
+               dcp::LocalTime from,
+               dcp::LocalTime to,
+               boost::shared_ptr<Job> job
+               );
 
        boost::shared_ptr<Cinema> cinema;
        std::list<ScreenKDM> screen_kdms;
diff --git a/src/lib/quickmail.cc b/src/lib/quickmail.cc
deleted file mode 100644 (file)
index 39e724c..0000000
+++ /dev/null
@@ -1,949 +0,0 @@
-/*
-    This file is part of libquickmail.
-
-    libquickmail is free software: you can redistribute it and/or modify
-    it under the terms of the GNU General Public License as published by
-    the Free Software Foundation, either version 3 of the License, or
-    (at your option) any later version.
-
-    libquickmail is distributed in the hope that it will be useful,
-    but WITHOUT ANY WARRANTY; without even the implied warranty of
-    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
-    GNU General Public License for more details.
-
-    You should have received a copy of the GNU General Public License
-    along with libquickmail.  If not, see <http://www.gnu.org/licenses/>.
-*/
-
-#include "quickmail.h"
-#include <stdlib.h>
-#include <stdio.h>
-#include <string.h>
-#include <time.h>
-#ifndef _WIN32
-#include <unistd.h>
-#endif
-#include <curl/curl.h>
-
-#define NEWLINE "\r\n"
-#define NEWLINELENGTH 2
-
-#define MIME_LINE_WIDTH 72
-#define BODY_BUFFER_SIZE 256
-
-//definitions of the differen stages of generating the message data
-#define MAILPART_INITIALIZE 0
-#define MAILPART_HEADER     1
-#define MAILPART_BODY       2
-#define MAILPART_BODY_DONE  3
-#define MAILPART_ATTACHMENT 4
-#define MAILPART_END        5
-#define MAILPART_DONE       6
-
-static const char* default_mime_type = "text/plain; charset=UTF-8";
-
-////////////////////////////////////////////////////////////////////////
-
-#define DEBUG_ERROR(errmsg)
-static const char* ERRMSG_MEMORY_ALLOCATION_ERROR = "Memory allocation error";
-
-////////////////////////////////////////////////////////////////////////
-
-char* randomize_zeros (char* data)
-{
-  //replace all 0s with random digits
-  char* p = data;
-  while (*p) {
-    if (*p == '0')
-      *p = '0' + rand() % 10;
-    p++;
-  }
-  return data;
-}
-
-char* str_append (char** data, const char* newdata)
-{
-  //append a string to the end of an existing string
-  char* p;
-  int len = (*data ? strlen(*data) : 0);
-  if ((p = (char*)realloc(*data, len + strlen(newdata) + 1)) == NULL) {
-    free(p);
-    DEBUG_ERROR(ERRMSG_MEMORY_ALLOCATION_ERROR)
-    return NULL;
-  }
-  *data = p;
-  strcpy(*data + len, newdata);
-  return *data;
-}
-
-////////////////////////////////////////////////////////////////////////
-
-struct email_info_struct {
-  int current;  //must be zet to 0
-  time_t timestamp;
-  char* from;
-  struct email_info_email_list_struct* to;
-  struct email_info_email_list_struct* cc;
-  struct email_info_email_list_struct* bcc;
-  char* subject;
-  char* header;
-  struct email_info_attachment_list_struct* bodylist;
-  struct email_info_attachment_list_struct* attachmentlist;
-  char* buf;
-  int buflen;
-  char* mime_boundary_body;
-  char* mime_boundary_part;
-  struct email_info_attachment_list_struct* current_attachment;
-  FILE* debuglog;
-  char dtable[64];
-};
-
-////////////////////////////////////////////////////////////////////////
-
-struct email_info_email_list_struct {
-  char* data;
-  struct email_info_email_list_struct* next;
-};
-
-void email_info_string_list_add (struct email_info_email_list_struct** list, const char* data)
-{
-  struct email_info_email_list_struct** p = list;
-  while (*p)
-    p = &(*p)->next;
-  if ((*p = (struct email_info_email_list_struct*)malloc(sizeof(struct email_info_email_list_struct))) == NULL) {
-    DEBUG_ERROR(ERRMSG_MEMORY_ALLOCATION_ERROR)
-    return;
-  }
-  (*p)->data = (data ? strdup(data) : NULL);
-  (*p)->next = NULL;
-}
-
-void email_info_string_list_free (struct email_info_email_list_struct** list)
-{
-  struct email_info_email_list_struct* p = *list;
-  struct email_info_email_list_struct* current;
-  while (p) {
-    current = p;
-    p = current->next;
-    free(current->data);
-    free(current);
-  }
-  *list = NULL;
-}
-
-char* email_info_string_list_concatenate (struct email_info_email_list_struct* list)
-{
-  char* result = NULL;
-  struct email_info_email_list_struct* listentry = list;
-  while (listentry) {
-    if (listentry->data && *listentry->data) {
-      if (result)
-        str_append(&result, "," NEWLINE "\t");
-      str_append(&result, "<");
-      str_append(&result, listentry->data);
-      str_append(&result, ">");
-    }
-    listentry = listentry->next;
-  }
-  return result;
-}
-
-////////////////////////////////////////////////////////////////////////
-
-struct email_info_attachment_list_struct {
-  char* filename;
-  char* mimetype;
-  void* filedata;
-  void* handle;
-  quickmail_attachment_open_fn email_info_attachment_open;
-  quickmail_attachment_read_fn email_info_attachment_read;
-  quickmail_attachment_close_fn email_info_attachment_close;
-  quickmail_attachment_free_filedata_fn email_info_attachment_filedata_free;
-  struct email_info_attachment_list_struct* next;
-};
-
-struct email_info_attachment_list_struct* email_info_attachment_list_add (struct email_info_attachment_list_struct** list, const char* filename, const char* mimetype, void* filedata, quickmail_attachment_open_fn email_info_attachment_open, quickmail_attachment_read_fn email_info_attachment_read, quickmail_attachment_close_fn email_info_attachment_close, quickmail_attachment_free_filedata_fn email_info_attachment_filedata_free)
-{
-  struct email_info_attachment_list_struct** p = list;
-  while (*p)
-    p = &(*p)->next;
-  if ((*p = (struct email_info_attachment_list_struct*)malloc(sizeof(struct email_info_attachment_list_struct))) == NULL) {
-    DEBUG_ERROR(ERRMSG_MEMORY_ALLOCATION_ERROR)
-    return NULL;
-  }
-  (*p)->filename = strdup(filename ? filename : "UNNAMED");
-  (*p)->mimetype = (mimetype ? strdup(mimetype) : NULL);
-  (*p)->filedata = filedata;
-  (*p)->handle = NULL;
-  (*p)->email_info_attachment_open = email_info_attachment_open;
-  (*p)->email_info_attachment_read = email_info_attachment_read;
-  (*p)->email_info_attachment_close = email_info_attachment_close;
-  (*p)->email_info_attachment_filedata_free = email_info_attachment_filedata_free;
-  (*p)->next = NULL;
-  return *p;
-}
-
-void email_info_attachment_list_free_entry (struct email_info_attachment_list_struct* current)
-{
-  if (current->handle) {
-    if (current->email_info_attachment_close)
-      current->email_info_attachment_close(current->handle);
-    //else
-    //  free(current->handle);
-    current->handle = NULL;
-  }
-  if (current->filedata) {
-    if (current->email_info_attachment_filedata_free)
-      current->email_info_attachment_filedata_free(current->filedata);
-    else
-      free(current->filedata);
-  }
-  if (current->mimetype)
-    free(current->mimetype);
-  free(current->filename);
-  free(current);
-}
-
-void email_info_attachment_list_free (struct email_info_attachment_list_struct** list)
-{
-  struct email_info_attachment_list_struct* p = *list;
-  struct email_info_attachment_list_struct* current;
-  while (p) {
-    current = p;
-    p = current->next;
-    email_info_attachment_list_free_entry(current);
-  }
-  *list = NULL;
-}
-
-int email_info_attachment_list_delete (struct email_info_attachment_list_struct** list, const char* filename)
-{
-  struct email_info_attachment_list_struct** p = list;
-  while (*p) {
-    if (strcmp((*p)->filename, filename) == 0) {
-      struct email_info_attachment_list_struct* current = *p;
-      *p = current->next;
-      email_info_attachment_list_free_entry(current);
-      return 0;
-    }
-    p = &(*p)->next;
-  }
-  return -1;
-}
-
-void email_info_attachment_list_close_handles (struct email_info_attachment_list_struct* list)
-{
-  struct email_info_attachment_list_struct* p = list;
-  while (p) {
-    if (p->handle) {
-      if (p->email_info_attachment_close)
-        p->email_info_attachment_close(p->handle);
-      //else
-      //  free(p->handle);
-      p->handle = NULL;
-    }
-    p = p->next;
-  }
-}
-
-//dummy attachment functions
-
-void* email_info_attachment_open_dummy (void *)
-{
-       return (void *) &email_info_attachment_open_dummy;
-}
-
-size_t email_info_attachment_read_dummy (void *, void *, size_t)
-{
-  return 0;
-}
-
-struct email_info_attachment_list_struct* email_info_attachment_list_add_dummy (struct email_info_attachment_list_struct** list, const char* filename, const char* mimetype)
-{
-  return email_info_attachment_list_add(list, filename, mimetype, NULL, email_info_attachment_open_dummy, email_info_attachment_read_dummy, NULL, NULL);
-}
-
-//file attachment functions
-
-void* email_info_attachment_open_file (void* filedata)
-{
-  return (void*)fopen((char*)filedata, "rb");
-}
-
-size_t email_info_attachment_read_file (void* handle, void* buf, size_t len)
-{
-  return fread(buf, 1, len, (FILE*)handle);
-}
-
-void email_info_attachment_close_file (void* handle)
-{
-  if (handle)
-    fclose((FILE*)handle);
-}
-
-struct email_info_attachment_list_struct* email_info_attachment_list_add_file (struct email_info_attachment_list_struct** list, const char* path, const char* mimetype)
-{
-  //determine base filename
-  const char* basename = path + strlen(path);
-  while (basename != path) {
-    basename--;
-    if (*basename == '/'
-#ifdef _WIN32
-        || *basename == '\\' || *basename == ':'
-#endif
-    ) {
-      basename++;
-      break;
-    }
-  }
-  return email_info_attachment_list_add(list, basename, mimetype, (void*)strdup(path), email_info_attachment_open_file, email_info_attachment_read_file, email_info_attachment_close_file, NULL);
-}
-
-//memory attachment functions
-
-struct email_info_attachment_memory_filedata_struct {
-  char* data;
-  size_t datalen;
-  int mustfree;
-};
-
-struct email_info_attachment_memory_handle_struct {
-  const char* data;
-  size_t datalen;
-  size_t pos;
-};
-
-void* email_info_attachment_open_memory (void* filedata)
-{
-  struct email_info_attachment_memory_filedata_struct* data;
-  struct email_info_attachment_memory_handle_struct* result;
-  data = ((struct email_info_attachment_memory_filedata_struct*)filedata);
-  if (!data->data)
-    return NULL;
-  if ((result = (struct email_info_attachment_memory_handle_struct*)malloc(sizeof(struct email_info_attachment_memory_handle_struct))) == NULL) {
-    DEBUG_ERROR(ERRMSG_MEMORY_ALLOCATION_ERROR)
-    return NULL;
-  }
-  result->data = data->data;
-  result->datalen = data->datalen;
-  result->pos = 0;
-  return result;
-}
-
-size_t email_info_attachment_read_memory (void* handle, void* buf, size_t len)
-{
-  struct email_info_attachment_memory_handle_struct* h = (struct email_info_attachment_memory_handle_struct*)handle;
-  size_t n = (h->pos + len <= h->datalen ? len : h->datalen - h->pos);
-  memcpy(buf, h->data + h->pos, n);
-  h->pos += n;
-  return n;
-}
-
-void email_info_attachment_close_memory (void* handle)
-{
-  if (handle)
-    free(handle);
-}
-
-void email_info_attachment_filedata_free_memory (void* filedata)
-{
-  struct email_info_attachment_memory_filedata_struct* data = ((struct email_info_attachment_memory_filedata_struct*)filedata);
-  if (data) {
-    if (data->mustfree)
-      free(data->data);
-    free(data);
-  }
-}
-
-struct email_info_attachment_list_struct* email_info_attachment_list_add_memory (struct email_info_attachment_list_struct** list, const char* filename, const char* mimetype, char* data, size_t datalen, int mustfree)
-{
-  struct email_info_attachment_memory_filedata_struct* filedata;
-  if ((filedata = (struct email_info_attachment_memory_filedata_struct*)malloc(sizeof(struct email_info_attachment_memory_filedata_struct))) == NULL) {
-    DEBUG_ERROR(ERRMSG_MEMORY_ALLOCATION_ERROR)
-    return NULL;
-  }
-  filedata->data = data;
-  filedata->datalen = datalen;
-  filedata->mustfree = mustfree;
-  return email_info_attachment_list_add(list, filename, mimetype, filedata, email_info_attachment_open_memory, email_info_attachment_read_memory, email_info_attachment_close_memory, email_info_attachment_filedata_free_memory);
-}
-
-////////////////////////////////////////////////////////////////////////
-
-int quickmail_initialize ()
-{
-  return 0;
-}
-
-quickmail quickmail_create (const char* from, const char* subject)
-{
-  int i;
-  struct email_info_struct* mailobj;
-  if ((mailobj = (struct email_info_struct*)malloc(sizeof(struct email_info_struct))) == NULL) {
-    DEBUG_ERROR(ERRMSG_MEMORY_ALLOCATION_ERROR)
-    return NULL;
-  }
-  mailobj->current = 0;
-  mailobj->timestamp = time(NULL);
-  mailobj->from = (from ? strdup(from) : NULL);
-  mailobj->to = NULL;
-  mailobj->cc = NULL;
-  mailobj->bcc = NULL;
-  mailobj->subject = (subject ? strdup(subject) : NULL);
-  mailobj->header = NULL;
-  mailobj->bodylist = NULL;
-  mailobj->attachmentlist = NULL;
-  mailobj->buf = NULL;
-  mailobj->buflen = 0;
-  mailobj->mime_boundary_body = NULL;
-  mailobj->mime_boundary_part = NULL;
-  mailobj->current_attachment = NULL;
-  mailobj->debuglog = NULL;
-  for (i = 0; i < 26; i++) {
-    mailobj->dtable[i] = (char)('A' + i);
-    mailobj->dtable[26 + i] = (char)('a' + i);
-  }
-  for (i = 0; i < 10; i++) {
-    mailobj->dtable[52 + i] = (char)('0' + i);
-  }
-  mailobj->dtable[62] = '+';
-  mailobj->dtable[63] = '/';
-  srand(time(NULL));
-  return mailobj;
-}
-
-void quickmail_destroy (quickmail mailobj)
-{
-  free(mailobj->from);
-  email_info_string_list_free(&mailobj->to);
-  email_info_string_list_free(&mailobj->cc);
-  email_info_string_list_free(&mailobj->bcc);
-  free(mailobj->subject);
-  free(mailobj->header);
-  email_info_attachment_list_free(&mailobj->bodylist);
-  email_info_attachment_list_free(&mailobj->attachmentlist);
-  free(mailobj->buf);
-  free(mailobj->mime_boundary_body);
-  free(mailobj->mime_boundary_part);
-  free(mailobj);
-}
-
-void quickmail_set_from (quickmail mailobj, const char* from)
-{
-  free(mailobj->from);
-  mailobj->from = strdup(from);
-}
-
-const char* quickmail_get_from (quickmail mailobj)
-{
-  return mailobj->from;
-}
-
-void quickmail_add_to (quickmail mailobj, const char* email)
-{
-  email_info_string_list_add(&mailobj->to, email);
-}
-
-void quickmail_add_cc (quickmail mailobj, const char* email)
-{
-  email_info_string_list_add(&mailobj->cc, email);
-}
-
-void quickmail_add_bcc (quickmail mailobj, const char* email)
-{
-  email_info_string_list_add(&mailobj->bcc, email);
-}
-
-void quickmail_set_subject (quickmail mailobj, const char* subject)
-{
-  free(mailobj->subject);
-  mailobj->subject = (subject ? strdup(subject) : NULL);
-}
-
-const char* quickmail_get_subject (quickmail mailobj)
-{
-  return mailobj->subject;
-}
-
-void quickmail_add_header (quickmail mailobj, const char* headerline)
-{
-  str_append(&mailobj->header, headerline);
-  str_append(&mailobj->header, NEWLINE);
-}
-
-void quickmail_set_body (quickmail mailobj, const char* body)
-{
-  email_info_attachment_list_free(&mailobj->bodylist);
-  if (body)
-    email_info_attachment_list_add_memory(&mailobj->bodylist, default_mime_type, default_mime_type, strdup(body), strlen(body), 1);
-}
-
-char* quickmail_get_body (quickmail mailobj)
-{
-  size_t n;
-  char* p;
-  char* result = NULL;
-  size_t resultlen = 0;
-  if (mailobj->bodylist && (mailobj->bodylist->handle = mailobj->bodylist->email_info_attachment_open(mailobj->bodylist->filedata)) != NULL) {
-    do {
-      if ((p = (char*)realloc(result, resultlen + BODY_BUFFER_SIZE)) == NULL) {
-        free(result);
-       result = NULL;
-        DEBUG_ERROR(ERRMSG_MEMORY_ALLOCATION_ERROR)
-        break;
-      }
-      result = p;
-      if ((n = mailobj->bodylist->email_info_attachment_read(mailobj->bodylist->handle, result + resultlen, BODY_BUFFER_SIZE)) > 0)
-        resultlen += n;
-    } while (n > 0);
-    if (mailobj->bodylist->email_info_attachment_close)
-      mailobj->bodylist->email_info_attachment_close(mailobj->bodylist->handle);
-    //else
-    //  free(mailobj->bodylist->handle);
-    mailobj->bodylist->handle = NULL;
-  }
-  return result;
-}
-
-void quickmail_add_body_file (quickmail mailobj, const char* mimetype, const char* path)
-{
-  email_info_attachment_list_add(&mailobj->bodylist, (mimetype ? mimetype : default_mime_type), (mimetype ? mimetype : default_mime_type), (void*)strdup(path), email_info_attachment_open_file, email_info_attachment_read_file, email_info_attachment_close_file, NULL);
-}
-
-void quickmail_add_body_memory (quickmail mailobj, const char* mimetype, char* data, size_t datalen, int mustfree)
-{
-  email_info_attachment_list_add_memory(&mailobj->bodylist, (mimetype ? mimetype : default_mime_type), (mimetype ? mimetype : default_mime_type), data, datalen, mustfree);
-}
-
-void quickmail_add_body_custom (quickmail mailobj, const char* mimetype, char* data, quickmail_attachment_open_fn attachment_data_open, quickmail_attachment_read_fn attachment_data_read, quickmail_attachment_close_fn attachment_data_close, quickmail_attachment_free_filedata_fn attachment_data_filedata_free)
-{
-  email_info_attachment_list_add(&mailobj->bodylist, (mimetype ? mimetype : default_mime_type), (mimetype ? mimetype : default_mime_type), data, (attachment_data_open ? attachment_data_open : email_info_attachment_open_dummy), (attachment_data_read ? attachment_data_read : email_info_attachment_read_dummy), attachment_data_close, attachment_data_filedata_free);
-}
-
-int quickmail_remove_body (quickmail mailobj, const char* mimetype)
-{
-  return email_info_attachment_list_delete(&mailobj->bodylist, mimetype);
-}
-
-void quickmail_list_bodies (quickmail mailobj, quickmail_list_attachment_callback_fn callback, void* callbackdata)
-{
-  struct email_info_attachment_list_struct* p = mailobj->bodylist;
-  while (p) {
-    callback(mailobj, p->filename, p->mimetype, p->email_info_attachment_open, p->email_info_attachment_read, p->email_info_attachment_close, callbackdata);
-    p = p->next;
-  }
-}
-
-void quickmail_add_attachment_file (quickmail mailobj, const char* path, const char* mimetype)
-{
-  email_info_attachment_list_add_file(&mailobj->attachmentlist, path, mimetype);
-}
-
-void quickmail_add_attachment_memory (quickmail mailobj, const char* filename, const char* mimetype, char* data, size_t datalen, int mustfree)
-{
-  email_info_attachment_list_add_memory(&mailobj->attachmentlist, filename, mimetype, data, datalen, mustfree);
-}
-
-void quickmail_add_attachment_custom (quickmail mailobj, const char* filename, const char* mimetype, char* data, quickmail_attachment_open_fn attachment_data_open, quickmail_attachment_read_fn attachment_data_read, quickmail_attachment_close_fn attachment_data_close, quickmail_attachment_free_filedata_fn attachment_data_filedata_free)
-{
-  email_info_attachment_list_add(&mailobj->attachmentlist, filename, mimetype, data, (attachment_data_open ? attachment_data_open : email_info_attachment_open_dummy), (attachment_data_read ? attachment_data_read : email_info_attachment_read_dummy), attachment_data_close, attachment_data_filedata_free);
-}
-
-int quickmail_remove_attachment (quickmail mailobj, const char* filename)
-{
-  return email_info_attachment_list_delete(&mailobj->attachmentlist, filename);
-}
-
-void quickmail_list_attachments (quickmail mailobj, quickmail_list_attachment_callback_fn callback, void* callbackdata)
-{
-  struct email_info_attachment_list_struct* p = mailobj->attachmentlist;
-  while (p) {
-    callback(mailobj, p->filename, p->mimetype, p->email_info_attachment_open, p->email_info_attachment_read, p->email_info_attachment_close, callbackdata);
-    p = p->next;
-  }
-}
-
-void quickmail_set_debug_log (quickmail mailobj, FILE* filehandle)
-{
-  mailobj->debuglog = filehandle;
-}
-
-void quickmail_fsave (quickmail mailobj, FILE* filehandle)
-{
-  size_t n;
-  char buf[80];
-  while ((n = quickmail_get_data(buf, sizeof(buf), 1, mailobj)) > 0) {
-    for (size_t i = 0; i < n; i++)
-      fprintf(filehandle, "%c", buf[i]);
-  }
-}
-
-size_t quickmail_get_data (void* ptr, size_t size, size_t nmemb, void* userp)
-{
-  struct email_info_struct* mailobj = (struct email_info_struct*)userp;
-
-  //abort if no data is requested
-  if (size * nmemb == 0)
-    return 0;
-
-  //initialize on first run
-  if (mailobj->current == MAILPART_INITIALIZE) {
-    free(mailobj->buf);
-    mailobj->buf = NULL;
-    mailobj->buflen = 0;
-    free(mailobj->mime_boundary_body);
-    mailobj->mime_boundary_body = NULL;
-    free(mailobj->mime_boundary_part);
-    mailobj->mime_boundary_part = NULL;
-    mailobj->current_attachment = mailobj->bodylist;
-    mailobj->current++;
-  }
-
-  //process current part of mail if no partial data is pending
-  while (mailobj->buflen == 0) {
-    if (mailobj->buflen == 0 && mailobj->current == MAILPART_HEADER) {
-      char* s;
-      //generate header part
-      char** p = &mailobj->buf;
-      mailobj->buf = NULL;
-      str_append(p, "User-Agent: libquickmail\n");
-      if (mailobj->timestamp != 0) {
-        char timestamptext[32];
-        if (strftime(timestamptext, sizeof(timestamptext), "%a, %d %b %Y %H:%M:%S %z", localtime(&mailobj->timestamp))) {\r
-          str_append(p, "Date: ");
-          str_append(p, timestamptext);
-          str_append(p, NEWLINE);
-        }
-#ifdef _WIN32\r
-        //fallback method for Windows when %z (time zone offset) fails
-        else if (strftime(timestamptext, sizeof(timestamptext), "%a, %d %b %Y %H:%M:%S", localtime(&mailobj->timestamp))) {\r
-          TIME_ZONE_INFORMATION tzinfo;\r
-          if (GetTimeZoneInformation(&tzinfo) != TIME_ZONE_ID_INVALID)\r
-            sprintf(timestamptext + strlen(timestamptext), " %c%02i%02i", (tzinfo.Bias > 0 ? '-' : '+'), (int)-tzinfo.Bias / 60, (int)-tzinfo.Bias % 60);\r
-          str_append(p, "Date: ");
-          str_append(p, timestamptext);
-          str_append(p, NEWLINE);
-        }
-#endif\r
-      }
-      if (mailobj->from && *mailobj->from) {
-        str_append(p, "From: <");
-        str_append(p, mailobj->from);
-        str_append(p, ">" NEWLINE);
-      }
-      if ((s = email_info_string_list_concatenate(mailobj->to)) != NULL) {
-        str_append(p, "To: ");
-        str_append(p, s);
-        str_append(p, NEWLINE);
-        free(s);
-      }
-      if ((s = email_info_string_list_concatenate(mailobj->cc)) != NULL) {
-        str_append(p, "Cc: ");
-        str_append(p, s);
-        str_append(p, NEWLINE);
-        free(s);
-      }
-      if (mailobj->subject) {
-        str_append(p, "Subject: ");
-        str_append(p, mailobj->subject);
-        str_append(p, NEWLINE);
-      }
-      if (mailobj->header) {
-        str_append(p, mailobj->header);
-      }
-      if (mailobj->attachmentlist) {
-        str_append(p, "MIME-Version: 1.0" NEWLINE);
-      }
-      if (mailobj->attachmentlist) {
-        mailobj->mime_boundary_part = randomize_zeros(strdup("=PART=SEPARATOR=_0000_0000_0000_0000_0000_0000_="));
-        str_append(p, "Content-Type: multipart/mixed; boundary=\"");
-        str_append(p, mailobj->mime_boundary_part);
-        str_append(p, "\"" NEWLINE NEWLINE "This is a multipart message in MIME format." NEWLINE NEWLINE "--");
-        str_append(p, mailobj->mime_boundary_part);
-        str_append(p, NEWLINE);
-      }
-      if (mailobj->bodylist && mailobj->bodylist->next) {
-        mailobj->mime_boundary_body = randomize_zeros(strdup("=BODY=SEPARATOR=_0000_0000_0000_0000_0000_0000_="));
-        str_append(p, "Content-Type: multipart/alternative; boundary=\"");
-        str_append(p, mailobj->mime_boundary_body);
-        str_append(p, NEWLINE);
-      }
-      mailobj->buflen = strlen(mailobj->buf);
-      mailobj->current++;
-    }
-    if (mailobj->buflen == 0 && mailobj->current == MAILPART_BODY) {
-      if (mailobj->current_attachment) {
-        if (!mailobj->current_attachment->handle) {
-          //open file with body data
-          while (mailobj->current_attachment) {
-            if ((mailobj->current_attachment->handle = mailobj->current_attachment->email_info_attachment_open(mailobj->current_attachment->filedata)) != NULL) {
-              break;
-            }
-            mailobj->current_attachment = mailobj->current_attachment->next;
-          }
-          if (!mailobj->current_attachment) {
-            mailobj->current_attachment = mailobj->attachmentlist;
-            mailobj->current++;
-          }
-          //generate attachment header
-          if (mailobj->current_attachment && mailobj->current_attachment->handle) {
-            mailobj->buf = NULL;
-            if (mailobj->mime_boundary_body) {
-              mailobj->buf = str_append(&mailobj->buf, NEWLINE "--");
-              mailobj->buf = str_append(&mailobj->buf, mailobj->mime_boundary_body);
-              mailobj->buf = str_append(&mailobj->buf, NEWLINE);
-            }
-            mailobj->buf = str_append(&mailobj->buf, "Content-Type: ");
-            mailobj->buf = str_append(&mailobj->buf, (mailobj->bodylist && mailobj->current_attachment->filename ? mailobj->current_attachment->filename : default_mime_type));
-            mailobj->buf = str_append(&mailobj->buf, NEWLINE "Content-Transfer-Encoding: 8bit" NEWLINE "Content-Disposition: inline" NEWLINE NEWLINE);
-            mailobj->buflen = strlen(mailobj->buf);
-          }
-        }
-        if (mailobj->buflen == 0 && mailobj->current_attachment && mailobj->current_attachment->handle) {
-          //read body data
-       if ((mailobj->buf = (char *) malloc(BODY_BUFFER_SIZE)) == NULL) {
-            DEBUG_ERROR(ERRMSG_MEMORY_ALLOCATION_ERROR)
-          }
-          if (mailobj->buf == NULL || (mailobj->buflen = mailobj->current_attachment->email_info_attachment_read(mailobj->current_attachment->handle, mailobj->buf, BODY_BUFFER_SIZE)) <= 0) {
-            //end of file
-            free(mailobj->buf);
-            mailobj->buflen = 0;
-            if (mailobj->current_attachment->email_info_attachment_close)
-              mailobj->current_attachment->email_info_attachment_close(mailobj->current_attachment->handle);
-            //else
-            //  free(mailobj->current_attachment->handle);
-            mailobj->current_attachment->handle = NULL;
-            mailobj->current_attachment = mailobj->current_attachment->next;
-          }
-        }
-      } else {
-        mailobj->current_attachment = mailobj->attachmentlist;
-        mailobj->current++;
-      }
-    }
-    if (mailobj->buflen == 0 && mailobj->current == MAILPART_BODY_DONE) {
-      mailobj->buf = NULL;
-      if (mailobj->mime_boundary_body) {
-        mailobj->buf = str_append(&mailobj->buf, NEWLINE "--");
-        mailobj->buf = str_append(&mailobj->buf, mailobj->mime_boundary_body);
-        mailobj->buf = str_append(&mailobj->buf, "--" NEWLINE);
-        mailobj->buflen = strlen(mailobj->buf);
-        free(mailobj->mime_boundary_body);
-        mailobj->mime_boundary_body = NULL;
-      }
-      mailobj->current++;
-    }
-    if (mailobj->buflen == 0 && mailobj->current == MAILPART_ATTACHMENT) {
-      if (mailobj->current_attachment) {
-        if (!mailobj->current_attachment->handle) {
-          //open file to attach
-          while (mailobj->current_attachment) {
-            if ((mailobj->current_attachment->handle = mailobj->current_attachment->email_info_attachment_open(mailobj->current_attachment->filedata)) != NULL) {
-              break;
-            }
-            mailobj->current_attachment = mailobj->current_attachment->next;
-          }
-          //generate attachment header
-          if (mailobj->current_attachment && mailobj->current_attachment->handle) {
-            mailobj->buf = NULL;
-            if (mailobj->mime_boundary_part) {
-              mailobj->buf = str_append(&mailobj->buf, NEWLINE "--");
-              mailobj->buf = str_append(&mailobj->buf, mailobj->mime_boundary_part);
-              mailobj->buf = str_append(&mailobj->buf, NEWLINE);
-            }
-            mailobj->buf = str_append(&mailobj->buf, "Content-Type: ");
-            mailobj->buf = str_append(&mailobj->buf, (mailobj->current_attachment->mimetype ? mailobj->current_attachment->mimetype : "application/octet-stream"));
-            mailobj->buf = str_append(&mailobj->buf, "; Name=\"");
-            mailobj->buf = str_append(&mailobj->buf, mailobj->current_attachment->filename);
-            mailobj->buf = str_append(&mailobj->buf, "\"" NEWLINE "Content-Transfer-Encoding: base64" NEWLINE NEWLINE);
-            mailobj->buflen = strlen(mailobj->buf);
-          }
-        } else {
-          //generate next line of attachment data
-          size_t n = 0;
-          int mimelinepos = 0;
-          unsigned char igroup[3] = {0, 0, 0};
-          unsigned char ogroup[4];
-          mailobj->buflen = 0;
-          if ((mailobj->buf = (char*)malloc(MIME_LINE_WIDTH + NEWLINELENGTH + 1)) == NULL) {
-            DEBUG_ERROR(ERRMSG_MEMORY_ALLOCATION_ERROR)
-            n = 0;
-          } else {
-            while (mimelinepos < MIME_LINE_WIDTH && (n = mailobj->current_attachment->email_info_attachment_read(mailobj->current_attachment->handle, igroup, 3)) > 0) {
-              //code data
-              ogroup[0] = mailobj->dtable[igroup[0] >> 2];
-              ogroup[1] = mailobj->dtable[((igroup[0] & 3) << 4) | (igroup[1] >> 4)];
-              ogroup[2] = mailobj->dtable[((igroup[1] & 0xF) << 2) | (igroup[2] >> 6)];
-              ogroup[3] = mailobj->dtable[igroup[2] & 0x3F];
-              //padd with "=" characters if less than 3 characters were read
-              if (n < 3) {
-                ogroup[3] = '=';
-                if (n < 2)
-                  ogroup[2] = '=';
-              }
-              memcpy(mailobj->buf + mimelinepos, ogroup, 4);
-              mailobj->buflen += 4;
-              mimelinepos += 4;
-            }
-            if (mimelinepos > 0) {
-              memcpy(mailobj->buf + mimelinepos, NEWLINE, NEWLINELENGTH);
-              mailobj->buflen += NEWLINELENGTH;
-            }
-          }
-          if (n <= 0) {
-            //end of file
-            if (mailobj->current_attachment->email_info_attachment_close)
-              mailobj->current_attachment->email_info_attachment_close(mailobj->current_attachment->handle);
-            else
-              free(mailobj->current_attachment->handle);
-            mailobj->current_attachment->handle = NULL;
-            mailobj->current_attachment = mailobj->current_attachment->next;
-          }
-        }
-      } else {
-        mailobj->current++;
-      }
-    }
-    if (mailobj->buflen == 0 && mailobj->current == MAILPART_END) {
-      mailobj->buf = NULL;
-      mailobj->buflen = 0;
-      if (mailobj->mime_boundary_part) {
-        mailobj->buf = str_append(&mailobj->buf, NEWLINE "--");
-        mailobj->buf = str_append(&mailobj->buf, mailobj->mime_boundary_part);
-        mailobj->buf = str_append(&mailobj->buf, "--" NEWLINE);
-        mailobj->buflen = strlen(mailobj->buf);
-        free(mailobj->mime_boundary_part);
-        mailobj->mime_boundary_part = NULL;
-      }
-      //mailobj->buf = str_append(&mailobj->buf, NEWLINE "." NEWLINE);
-      //mailobj->buflen = strlen(mailobj->buf);
-      mailobj->current++;
-    }
-    if (mailobj->buflen == 0 && mailobj->current == MAILPART_DONE) {
-      break;
-    }
-  }
-
-  //flush pending data if any
-  if (mailobj->buflen > 0) {
-         int len = ((size_t) mailobj->buflen > size * nmemb ? size * nmemb : mailobj->buflen);
-    memcpy(ptr, mailobj->buf, len);
-    if (len < mailobj->buflen) {
-      mailobj->buf = (char *) memmove(mailobj->buf, mailobj->buf + len, mailobj->buflen - len);
-      mailobj->buflen -= len;
-    } else {
-      free(mailobj->buf);
-      mailobj->buf = NULL;
-      mailobj->buflen = 0;
-    }
-    return len;
-  }
-
-  //if (mailobj->current != MAILPART_DONE)
-  //  ;//this should never be reached
-  mailobj->current = 0;
-  return 0;
-}
-
-char* add_angle_brackets (const char* data)
-{
-  size_t datalen = strlen(data);
-  char* result;
-  if ((result = (char*)malloc(datalen + 3)) == NULL) {
-    DEBUG_ERROR(ERRMSG_MEMORY_ALLOCATION_ERROR)
-    return NULL;
-  }
-  result[0] = '<';
-  memcpy(result + 1, data, datalen);
-  result[datalen + 1] = '>';
-  result[datalen + 2] = 0;
-  return result;
-}
-
-const char* quickmail_send (quickmail mailobj, const char* smtpserver, unsigned int smtpport, const char* username, const char* password)
-{
-  //libcurl based sending
-  CURL *curl;
-  CURLcode result = CURLE_FAILED_INIT;
-  //curl_global_init(CURL_GLOBAL_ALL);
-  if ((curl = curl_easy_init()) != NULL) {
-    struct curl_slist *recipients = NULL;
-    struct email_info_email_list_struct* listentry;
-    //set destination URL
-    char* addr;
-    size_t len = strlen(smtpserver) + 14;
-    if ((addr = (char*)malloc(len)) == NULL) {
-      DEBUG_ERROR(ERRMSG_MEMORY_ALLOCATION_ERROR)
-      return ERRMSG_MEMORY_ALLOCATION_ERROR;
-    }
-    snprintf(addr, len, "smtp://%s:%u", smtpserver, smtpport);
-    curl_easy_setopt(curl, CURLOPT_URL, addr);
-    free(addr);
-    //try Transport Layer Security (TLS), but continue anyway if it fails
-    curl_easy_setopt(curl, CURLOPT_USE_SSL, (long)CURLUSESSL_TRY);
-    //don't fail if the TLS/SSL a certificate could not be verified
-    //alternative: add the issuer certificate (or the host certificate if
-    //the certificate is self-signed) to the set of certificates that are
-    //known to libcurl using CURLOPT_CAINFO and/or CURLOPT_CAPATH
-    curl_easy_setopt(curl, CURLOPT_SSL_VERIFYPEER, 0L);
-    curl_easy_setopt(curl, CURLOPT_SSL_VERIFYHOST, 0L);
-    //set authentication credentials if provided
-    if (username && *username)
-      curl_easy_setopt(curl, CURLOPT_USERNAME, username);
-    if (password)
-      curl_easy_setopt(curl, CURLOPT_PASSWORD, password);
-    //set from value for envelope reverse-path
-    if (mailobj->from && *mailobj->from) {
-      addr = add_angle_brackets(mailobj->from);
-      curl_easy_setopt(curl, CURLOPT_MAIL_FROM, addr);
-      free(addr);
-    }
-    //set recipients
-    listentry = mailobj->to;
-    while (listentry) {
-      if (listentry->data && *listentry->data) {
-        addr = add_angle_brackets(listentry->data);
-        recipients = curl_slist_append(recipients, addr);
-        free(addr);
-      }
-      listentry = listentry->next;
-    }
-    listentry = mailobj->cc;
-    while (listentry) {
-      if (listentry->data && *listentry->data) {
-        addr = add_angle_brackets(listentry->data);
-        recipients = curl_slist_append(recipients, addr);
-        free(addr);
-      }
-      listentry = listentry->next;
-    }
-    listentry = mailobj->bcc;
-    while (listentry) {
-      if (listentry->data && *listentry->data) {
-        addr = add_angle_brackets(listentry->data);
-        recipients = curl_slist_append(recipients, addr);
-        free(addr);
-      }
-      listentry = listentry->next;
-    }
-    curl_easy_setopt(curl, CURLOPT_MAIL_RCPT, recipients);
-    //set callback function for getting message body
-    curl_easy_setopt(curl, CURLOPT_READFUNCTION, quickmail_get_data);
-    curl_easy_setopt(curl, CURLOPT_READDATA, mailobj);
-    /* Without this curl sends VRFY, which exim errors on
-       (at least on main.carlh.net)
-    */
-    curl_easy_setopt(curl, CURLOPT_UPLOAD, 1L);
-    //enable debugging if requested
-    if (mailobj->debuglog) {
-      curl_easy_setopt(curl, CURLOPT_VERBOSE, 1L);
-      curl_easy_setopt(curl, CURLOPT_STDERR, mailobj->debuglog);
-    }
-    //send the message
-    result = curl_easy_perform(curl);
-    //free the list of recipients and clean up
-    curl_slist_free_all(recipients);
-    curl_easy_cleanup(curl);
-  }
-  return (result == CURLE_OK ? NULL : curl_easy_strerror(result));
-}
diff --git a/src/lib/quickmail.h b/src/lib/quickmail.h
deleted file mode 100644 (file)
index 9f1cc44..0000000
+++ /dev/null
@@ -1,289 +0,0 @@
-/*! \file      quickmail.h
- *  \brief     header file for libquickmail
- *  \author    Brecht Sanders
- *  \date      2012-2013
- *  \copyright GPL
- */
-/*
-    This file is part of libquickmail.
-
-    libquickmail is free software: you can redistribute it and/or modify
-    it under the terms of the GNU General Public License as published by
-    the Free Software Foundation, either version 3 of the License, or
-    (at your option) any later version.
-
-    libquickmail is distributed in the hope that it will be useful,
-    but WITHOUT ANY WARRANTY; without even the implied warranty of
-    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
-    GNU General Public License for more details.
-
-    You should have received a copy of the GNU General Public License
-    along with libquickmail.  If not, see <http://www.gnu.org/licenses/>.
-*/
-
-#ifndef __INCLUDED_QUICKMAIL_H
-#define __INCLUDED_QUICKMAIL_H
-
-#include <stdio.h>
-
-#ifdef __cplusplus
-extern "C" {
-#endif
-
-/*! \brief quickmail object type */
-typedef struct email_info_struct* quickmail;
-
-
-
-/*! \brief type of pointer to function for opening attachment data
- * \param  filedata    custom data as passed to quickmail_add_body_custom/quickmail_add_attachment_custom
- * \return data structure to be used in calls to quickmail_attachment_read_fn and quickmail_attachment_close_fn functions
- * \sa     quickmail_add_body_custom()
- * \sa     quickmail_add_attachment_custom()
- */
-typedef void* (*quickmail_attachment_open_fn)(void* filedata);
-
-/*! \brief type of pointer to function for reading attachment data
- * \param  handle      data structure obtained via the corresponding quickmail_attachment_open_fn function
- * \param  buf         buffer for receiving data
- * \param  len         size in bytes of buffer for receiving data
- * \return number of bytes read (zero on end of file)
- * \sa     quickmail_add_body_custom()
- * \sa     quickmail_add_attachment_custom()
- */
-typedef size_t (*quickmail_attachment_read_fn)(void* handle, void* buf, size_t len);
-
-/*! \brief type of pointer to function for closing attachment data
- * \param  handle      data structure obtained via the corresponding quickmail_attachment_open_fn function
- * \sa     quickmail_add_body_custom()
- * \sa     quickmail_add_attachment_custom()
- */
-typedef void (*quickmail_attachment_close_fn)(void* handle);
-
-/*! \brief type of pointer to function for cleaning up custom data in quickmail_destroy
- * \param  filedata    custom data as passed to quickmail_add_body_custom/quickmail_add_attachment_custom
- * \sa     quickmail_add_body_custom()
- * \sa     quickmail_add_attachment_custom()
- */
-typedef void (*quickmail_attachment_free_filedata_fn)(void* filedata);
-
-/*! \brief type of pointer to function for cleaning up custom data in quickmail_destroy
- * \param  mailobj                        quickmail object
- * \param  filename                       attachment filename (same value as mimetype for mail body)
- * \param  mimetype                       MIME type
- * \param  attachment_data_open           function for opening attachment data
- * \param  attachment_data_read           function for reading attachment data
- * \param  attachment_data_close          function for closing attachment data (optional, free() will be used if NULL)
- * \param  callbackdata                   custom data passed to quickmail_list_attachments
- * \sa     quickmail_list_bodies()
- * \sa     quickmail_list_attachments()
- */
-typedef void (*quickmail_list_attachment_callback_fn)(quickmail mailobj, const char* filename, const char* mimetype, quickmail_attachment_open_fn email_info_attachment_open, quickmail_attachment_read_fn email_info_attachment_read, quickmail_attachment_close_fn email_info_attachment_close, void* callbackdata);
-
-
-
-/*! \brief get version quickmail library
- * \return library version
- */
-const char* quickmail_get_version ();
-
-/*! \brief initialize quickmail library
- * \return zero on success
- */
-int quickmail_initialize ();
-
-/*! \brief create a new quickmail object
- * \param  from        sender e-mail address
- * \param  subject     e-mail subject
- * \return quickmail object or NULL on error
- */
-quickmail quickmail_create (const char* from, const char* subject);
-
-/*! \brief clean up a quickmail object
- * \param  mailobj     quickmail object
- */
-void quickmail_destroy (quickmail mailobj);
-
-/*! \brief set the sender (from) e-mail address of a quickmail object
- * \param  mailobj     quickmail object
- * \param  from        sender e-mail address
- */
-void quickmail_set_from (quickmail mailobj, const char* from);
-
-/*! \brief get the sender (from) e-mail address of a quickmail object
- * \param  mailobj     quickmail object
- * \return sender e-mail address
- */
-const char* quickmail_get_from (quickmail mailobj);
-
-/*! \brief add a recipient (to) e-mail address to a quickmail object
- * \param  mailobj     quickmail object
- * \param  e-mail      recipient e-mail address
- */
-void quickmail_add_to (quickmail mailobj, const char* email);
-
-/*! \brief add a carbon copy recipient (cc) e-mail address to a quickmail object
- * \param  mailobj     quickmail object
- * \param  e-mail      recipient e-mail address
- */
-void quickmail_add_cc (quickmail mailobj, const char* email);
-
-/*! \brief add a blind carbon copy recipient (bcc) e-mail address to a quickmail object
- * \param  mailobj     quickmail object
- * \param  e-mail      recipient e-mail address
- */
-void quickmail_add_bcc (quickmail mailobj, const char* email);
-
-/*! \brief set the subject of a quickmail object
- * \param  mailobj     quickmail object
- * \param  subject     e-mail subject
- */
-void quickmail_set_subject (quickmail mailobj, const char* subject);
-
-/*! \brief set the subject of a quickmail object
- * \param  mailobj     quickmail object
- * \return e-mail subject
- */
-const char* quickmail_get_subject (quickmail mailobj);
-
-/*! \brief add an e-mail header to a quickmail object
- * \param  mailobj     quickmail object
- * \param  headerline  header line to add
- */
-void quickmail_add_header (quickmail mailobj, const char* headerline);
-
-/*! \brief set the body of a quickmail object
- * \param  mailobj     quickmail object
- * \param  body        e-mail body
- */
-void quickmail_set_body (quickmail mailobj, const char* body);
-
-/*! \brief set the body of a quickmail object
- * any existing bodies will be removed and a single plain text body will be added
- * \param  mailobj     quickmail object
- * \return e-mail body or NULL on error (caller must free result)
- */
-char* quickmail_get_body (quickmail mailobj);
-
-/*! \brief add a body file to a quickmail object (deprecated)
- * \param  mailobj     quickmail object
- * \param  mimetype    MIME type (text/plain will be used if set to NULL)
- * \param  path        path of file with body data
- */
-void quickmail_add_body_file (quickmail mailobj, const char* mimetype, const char* path);
-
-/*! \brief add a body from memory to a quickmail object
- * \param  mailobj     quickmail object
- * \param  mimetype    MIME type (text/plain will be used if set to NULL)
- * \param  data        body content
- * \param  datalen     size of data in bytes
- * \param  mustfree    non-zero if data must be freed by quickmail_destroy
- */
-void quickmail_add_body_memory (quickmail mailobj, const char* mimetype, char* data, size_t datalen, int mustfree);
-
-/*! \brief add a body with custom read functions to a quickmail object
- * \param  mailobj                        quickmail object
- * \param  mimetype                       MIME type (text/plain will be used if set to NULL)
- * \param  data                           custom data passed to attachment_data_open and attachment_data_filedata_free functions
- * \param  attachment_data_open           function for opening attachment data
- * \param  attachment_data_read           function for reading attachment data
- * \param  attachment_data_close          function for closing attachment data (optional, free() will be used if NULL)
- * \param  attachment_data_filedata_free  function for cleaning up custom data in quickmail_destroy (optional, free() will be used if NULL)
- */
-void quickmail_add_body_custom (quickmail mailobj, const char* mimetype, char* data, quickmail_attachment_open_fn attachment_data_open, quickmail_attachment_read_fn attachment_data_read, quickmail_attachment_close_fn attachment_data_close, quickmail_attachment_free_filedata_fn attachment_data_filedata_free);
-
-/*! \brief remove body from quickmail object
- * \param  mailobj     quickmail object
- * \param  mimetype    MIME type (text/plain will be used if set to NULL)
- * \return zero on success
- */
-int quickmail_remove_body (quickmail mailobj, const char* mimetype);
-
-/*! \brief list bodies by calling a callback function for each body
- * \param  mailobj                        quickmail object
- * \param  callback                       function to call for each attachment
- * \param  callbackdata                   custom data to pass to the callback function
- * \sa     quickmail_list_attachment_callback_fn
- */
-void quickmail_list_bodies (quickmail mailobj, quickmail_list_attachment_callback_fn callback, void* callbackdata);
-
-/*! \brief add a file attachment to a quickmail object
- * \param  mailobj     quickmail object
- * \param  path        path of file to attach
- * \param  mimetype    MIME type of file to attach (application/octet-stream will be used if set to NULL)
- */
-void quickmail_add_attachment_file (quickmail mailobj, const char* path, const char* mimetype);
-
-/*! \brief add an attachment from memory to a quickmail object
- * \param  mailobj     quickmail object
- * \param  filename    name of file to attach (must not include full path)
- * \param  mimetype    MIME type of file to attach (set to NULL for default binary file)
- * \param  data        data content
- * \param  datalen     size of data in bytes
- * \param  mustfree    non-zero if data must be freed by quickmail_destroy
- */
-void quickmail_add_attachment_memory (quickmail mailobj, const char* filename, const char* mimetype, char* data, size_t datalen, int mustfree);
-
-/*! \brief add an attachment with custom read functions to a quickmail object
- * \param  mailobj                        quickmail object
- * \param  filename                       name of file to attach (must not include full path)
- * \param  mimetype                       MIME type of file to attach (set to NULL for default binary file)
- * \param  data                           custom data passed to attachment_data_open and attachment_data_filedata_free functions
- * \param  attachment_data_open           function for opening attachment data
- * \param  attachment_data_read           function for reading attachment data
- * \param  attachment_data_close          function for closing attachment data (optional, free() will be used if NULL)
- * \param  attachment_data_filedata_free  function for cleaning up custom data in quickmail_destroy (optional, free() will be used if NULL)
- */
-void quickmail_add_attachment_custom (quickmail mailobj, const char* filename, const char* mimetype, char* data, quickmail_attachment_open_fn attachment_data_open, quickmail_attachment_read_fn attachment_data_read, quickmail_attachment_close_fn attachment_data_close, quickmail_attachment_free_filedata_fn attachment_data_filedata_free);
-
-/*! \brief remove attachment from quickmail object
- * \param  mailobj     quickmail object
- * \param  filename    name of file to attach (must not include full path)
- * \return zero on success
- */
-int quickmail_remove_attachment (quickmail mailobj, const char* filename);
-
-/*! \brief list attachments by calling a callback function for each attachment
- * \param  mailobj                        quickmail object
- * \param  callback                       function to call for each attachment
- * \param  callbackdata                   custom data to pass to the callback function
- * \sa     quickmail_list_attachment_callback_fn
- */
-void quickmail_list_attachments (quickmail mailobj, quickmail_list_attachment_callback_fn callback, void* callbackdata);
-
-/*! \brief set the debug logging destination of a quickmail object
- * \param  mailobj     quickmail object
- * \param  filehandle  file handle of logging destination (or NULL for no logging)
- */
-void quickmail_set_debug_log (quickmail mailobj, FILE* filehandle);
-
-/*! \brief save the generated e-mail to a file
- * \param  mailobj     quickmail object
- * \param  filehandle  file handle to write the e-mail contents to
- */
-void quickmail_fsave (quickmail mailobj, FILE* filehandle);
-
-/*! \brief read data the next data from the e-mail contents (can be used as CURLOPT_READFUNCTION callback function)
- * \param  buffer      buffer to copy data to (bust be able to hold size * nmemb bytes)
- * \param  size        record size
- * \param  nmemb       number of records to copy to \p buffer
- * \param  mailobj     quickmail object
- * \return number of bytes copied to \p buffer or 0 if at end
- */
-size_t quickmail_get_data (void* buffer, size_t size, size_t nmemb, void* mailobj);
-
-/*! \brief send the e-mail via SMTP
- * \param  mailobj     quickmail object
- * \param  smtpserver  IP address or hostname of SMTP server
- * \param  smtpport    SMTP port number (normally this is 25)
- * \param  username    username to use for authentication (or NULL if not needed)
- * \param  password    password to use for authentication (or NULL if not needed)
- * \return NULL on success or error message on error
- */
-const char* quickmail_send (quickmail mailobj, const char* smtpserver, unsigned int smtpport, const char* username, const char* password);
-
-#ifdef __cplusplus
-}
-#endif
-
-#endif //__INCLUDED_QUICKMAIL_H
index 5b37d8c87e2626d5969b4ea7f81b42022b6494b5..0d77f0862b3f0876951e03314396cf6f73ef555b 100644 (file)
@@ -66,7 +66,7 @@ void
 SendKDMEmailJob::run ()
 {
        set_progress_unknown ();
-       CinemaKDMs::email (_film_name, _cpl_name, _cinema_kdms, _from, _to);
+       CinemaKDMs::email (_film_name, _cpl_name, _cinema_kdms, _from, _to, shared_from_this ());
        set_progress (1);
        set_state (FINISHED_OK);
 }
index d0532a0479cf51d551c9dc48696d2307a7e1e3bb..f0c34f590bca5f823dadabbfdc70863d9d5a84a1 100644 (file)
@@ -23,8 +23,8 @@
 #include "cross.h"
 #include "film.h"
 #include "log.h"
-#include "quickmail.h"
 #include "version.h"
+#include "emailer.h"
 
 #include "i18n.h"
 
@@ -67,10 +67,6 @@ SendProblemReportJob::run ()
        sub (_("Sending email"));
        set_progress_unknown ();
 
-       quickmail mail = quickmail_create (_from.c_str(), "DCP-o-matic problem report");
-
-       quickmail_add_to (mail, "carl@dcpomatic.com");
-
        string body = _summary + "\n\n";
 
        body += "Version: " + string (dcpomatic_version) + " " + string (dcpomatic_git_commit) + "\n\n";
@@ -85,18 +81,8 @@ SendProblemReportJob::run ()
                add_file (body, "metadata.xml");
        }
 
-       quickmail_set_body (mail, body.c_str());
-
-       char const* error = quickmail_send (mail, "main.carlh.net", 2525, 0, 0);
-
-       if (error) {
-               set_state (FINISHED_ERROR);
-               set_error (error, "");
-       } else {
-               set_state (FINISHED_OK);
-       }
-
-       quickmail_destroy (mail);
+       Emailer emailer (_from, "carl@dcpomatic.com", "DCP-o-matic problem report", body);
+       emailer.send (shared_from_this ());
 
        set_progress (1);
 }
index d897e997dfc35c491c5530d6fde75bc06ff66bff..bc61c87bfd4686fb71a785d6fd1323d8471852c0 100644 (file)
@@ -53,6 +53,7 @@ sources = """
           dcpomatic_socket.cc
           dcpomatic_time.cc
           dolby_cp750.cc
+          emailer.cc
           encoder.cc
           environment_info.cc
           examine_content_job.cc
@@ -91,7 +92,6 @@ sources = """
           player_video.cc
           playlist.cc
           position_image.cc
-          quickmail.cc
           ratio.cc
           raw_image_proxy.cc
           render_subtitles.cc