aboutsummaryrefslogblamecommitdiffstats
path: root/mail/evolution-mbox-importer.c
blob: 0e18fb673218027071e371fb87ad191b7e41c035 (plain) (tree)


























                                                                           
                                    






                                              
                       
 
                        


                                           
        
                       

                            












                                                      
                              
                           






                                                                   
                





                                                                                                   
                











                                                                              
                        

                                                               
                 





                                                                

         

                                                                
                                                                                           
                                                                  







                                               












                                                           
         



                   






                                       
        
                                        






                                                                
                                                     

         

                                                                     
        
                               


                                                            









                                           

               

                                        
        
                                            


                                       


                                               





                                                                 

         
                                 
                                                            

                                       
                                         
                          
         
        
                                               
                                


                                                                                 
                    





                                                    
















                                                                           
/* -*- Mode: C; tab-width: 8; indent-tabs-mode: t; c-basic-offset: 8 -*- */
/* evolution-mbox-importer.c
 *
 * Authors: Iain Holmes <iain@ximian.com>
 *
 * Copyright (C) 2001  Ximian, Inc.
 *
 * This program 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 2 of the
 * License, or (at your option) any later version.
 *
 * This program 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 this program; if not, write to the
 * Free Software Foundation, Inc., 59 Temple Place - Suite 330,
 * Boston, MA 02111-1307, USA.
 */

#ifdef HAVE_CONFIG_H
#include <config.h>
#endif

#include "evolution-mbox-importer.h"

#include <stdio.h>

#include <importer/evolution-importer.h>
#include <importer/GNOME_Evolution_Importer.h>

#include "mail-importer.h"
#include "mail-tools.h"

#include <camel/camel.h>

typedef struct {
    MailImporter importer; /* Parent */
    
    char *filename;
    int num;
    CamelMimeParser *mp;
} MboxImporter;


/* EvolutionImporter methods */

static void
process_item_fn (EvolutionImporter *eimporter,
         CORBA_Object listener,
         void *closure,
         CORBA_Environment *ev)
{
    MboxImporter *mbi = (MboxImporter *) closure;
    MailImporter *importer = (MailImporter *) mbi;
    gboolean done = FALSE;
    CamelException *ex;
    
    ex = camel_exception_new ();
    
    if (camel_mime_parser_step (mbi->mp, 0, 0) == HSCAN_FROM) {
        /* Import the next message */
        CamelMimeMessage *msg;
        CamelMessageInfo *info;
        
        msg = camel_mime_message_new ();
        if (camel_mime_part_construct_from_parser (CAMEL_MIME_PART (msg), mbi->mp) == -1) {
            g_warning ("Failed message %d", mbi->num);
            camel_object_unref (CAMEL_OBJECT (msg));
            done = TRUE;
        }
        
        /* write the mesg */
        info = g_new0 (CamelMessageInfo, 1);
        camel_folder_append_message (importer->folder, msg, info, ex);
        g_free (info);
        camel_object_unref (CAMEL_OBJECT (msg));
        if (camel_exception_is_set (ex)) {
            g_warning ("Failed message %d", mbi->num);
            done = TRUE;
        }
        
        if (!done) {
            mbi->num++;
            
            /* skip over the FROM_END state */
            camel_mime_parser_step (mbi->mp, 0, 0);
        }
    } else {
        /* all messages have now been imported */
        camel_folder_sync (importer->folder, FALSE, ex);
        camel_folder_thaw (importer->folder);
        importer->frozen = FALSE;
        done = TRUE;
    }
    
    camel_exception_free (ex);
    GNOME_Evolution_ImporterListener_notifyResult (listener,
                               GNOME_Evolution_ImporterListener_OK,
                               !done, ev);
    return;
}

static gboolean
support_format_fn (EvolutionImporter *importer,
           const char *filename,
           void *closure)
{
    char signature[6];
    gboolean ret = FALSE;
    int fd, n;
    
    fd = open (filename, O_RDONLY);
    if (fd == -1)
        return FALSE;
    
    n = read (fd, signature, 5);
    if (n > 0) {
        signature[n] = '\0';
        if (!g_strncasecmp (signature, "From ", 5))
            ret = TRUE;
    }
    
    close (fd);
    
    return ret;
}

static void
importer_destroy_cb (GtkObject *object,
             MboxImporter *mbi)
{
    MailImporter *importer;
    
    importer = (MailImporter *) mbi;
    if (importer->frozen) {
        CamelException *ex;
        
        ex = camel_exception_new ();
        camel_folder_sync (importer->folder, FALSE, ex);
        camel_exception_free (ex);
        
        camel_folder_thaw (importer->folder);
    }
    
    if (importer->folder)
        camel_object_unref (CAMEL_OBJECT (importer->folder));
    
    g_free (mbi->filename);
    if (mbi->mp)
        camel_object_unref (CAMEL_OBJECT (mbi->mp));
    
    g_free (mbi);
}

static gboolean
load_file_fn (EvolutionImporter *eimporter,
          const char *filename,
          void *closure)
{
    MboxImporter *mbi;
    MailImporter *importer;
    int fd;
    
    mbi = (MboxImporter *) closure;
    importer = (MailImporter *) mbi;
    
    mbi->filename = g_strdup (filename);
    
    fd = open (filename, O_RDONLY);
    if (fd == -1) {
        g_warning ("Cannot open file");
        return FALSE;
    }
    
    mbi->mp = camel_mime_parser_new ();
    camel_mime_parser_scan_from (mbi->mp, TRUE);
    if (camel_mime_parser_init_with_fd (mbi->mp, fd) == -1) {
        g_warning ("Unable to process spool folder");
        goto fail;
    }
    
    importer->mstream = NULL;
    importer->folder = mail_tool_get_local_inbox (NULL);
    
    if (importer->folder == NULL) {
        g_print ("Bad folder\n");
        goto fail;
    }
    
    camel_folder_freeze (importer->folder);
    importer->frozen = TRUE;
    
    g_warning ("Okay, so everything is now ready to import that mbox file!");
    
    return TRUE;
    
 fail:
    camel_object_unref (CAMEL_OBJECT (mbi->mp));
    mbi->mp = NULL;
    
    return FALSE;
}

BonoboObject *
mbox_factory_fn (BonoboGenericFactory *_factory,
         void *closure)
{
    EvolutionImporter *importer;
    MboxImporter *mbox;
    
    mbox = g_new0 (MboxImporter, 1);
    importer = evolution_importer_new (support_format_fn, load_file_fn,
                       process_item_fn, NULL, mbox);
    gtk_signal_connect (GTK_OBJECT (importer), "destroy",
                GTK_SIGNAL_FUNC (importer_destroy_cb), mbox);
    
    return BONOBO_OBJECT (importer);
}