2016-03-03 11:04:32 +01:00
|
|
|
/*
|
|
|
|
* import_imap.c
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include <stdio.h>
|
|
|
|
#include <stdlib.h>
|
|
|
|
#include <string.h>
|
|
|
|
#include <sys/time.h>
|
|
|
|
#include <sys/types.h>
|
|
|
|
#include <sys/stat.h>
|
|
|
|
#include <sys/socket.h>
|
|
|
|
#include <netdb.h>
|
|
|
|
#include <arpa/inet.h>
|
|
|
|
#include <netinet/in.h>
|
|
|
|
#include <fcntl.h>
|
|
|
|
#include <dirent.h>
|
|
|
|
#include <unistd.h>
|
|
|
|
#include <time.h>
|
|
|
|
#include <locale.h>
|
|
|
|
#include <getopt.h>
|
|
|
|
#include <syslog.h>
|
|
|
|
#include <piler.h>
|
|
|
|
|
|
|
|
|
2017-08-08 15:34:45 +02:00
|
|
|
int import_from_imap_server(struct session_data *sdata, struct data *data, struct config *cfg){
|
|
|
|
int i, rc=ERR, ret=OK, skipmatch;
|
2016-03-03 11:04:32 +01:00
|
|
|
char port_string[8], puf[SMALLBUFSIZE];
|
|
|
|
struct addrinfo hints, *res;
|
|
|
|
struct node *q;
|
|
|
|
|
2017-08-08 15:34:45 +02:00
|
|
|
data->net->use_ssl = 0;
|
|
|
|
data->import->seq = 1;
|
2016-03-03 11:04:32 +01:00
|
|
|
|
|
|
|
inithash(data->imapfolders);
|
|
|
|
|
2017-08-08 15:34:45 +02:00
|
|
|
snprintf(port_string, sizeof(port_string)-1, "%d", data->import->port);
|
2016-03-03 11:04:32 +01:00
|
|
|
|
|
|
|
memset(&hints, 0, sizeof(hints));
|
|
|
|
hints.ai_family = AF_UNSPEC;
|
|
|
|
hints.ai_socktype = SOCK_STREAM;
|
|
|
|
|
2017-08-08 15:34:45 +02:00
|
|
|
if((rc = getaddrinfo(data->import->server, port_string, &hints, &res)) != 0){
|
|
|
|
printf("getaddrinfo for '%s': %s\n", data->import->server, gai_strerror(rc));
|
2016-03-03 11:04:32 +01:00
|
|
|
return ERR;
|
|
|
|
}
|
|
|
|
|
2017-08-08 15:34:45 +02:00
|
|
|
if(data->import->port == 993) data->net->use_ssl = 1;
|
2016-03-03 11:04:32 +01:00
|
|
|
|
|
|
|
|
2017-08-08 15:34:45 +02:00
|
|
|
if((data->net->socket = socket(res->ai_family, res->ai_socktype, res->ai_protocol)) == -1){
|
2016-03-03 11:04:32 +01:00
|
|
|
printf("cannot create socket\n");
|
|
|
|
ret = ERR;
|
|
|
|
goto ENDE_IMAP;
|
|
|
|
}
|
|
|
|
|
2017-08-08 15:34:45 +02:00
|
|
|
if(connect(data->net->socket, res->ai_addr, res->ai_addrlen) == -1){
|
2016-03-03 11:04:32 +01:00
|
|
|
printf("connect()\n");
|
|
|
|
ret = ERR;
|
|
|
|
goto ENDE_IMAP;
|
|
|
|
}
|
|
|
|
|
2017-08-08 15:34:45 +02:00
|
|
|
if(connect_to_imap_server(data) == ERR){
|
|
|
|
close(data->net->socket);
|
2016-03-03 11:04:32 +01:00
|
|
|
ret = ERR;
|
|
|
|
goto ENDE_IMAP;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2017-08-08 15:34:45 +02:00
|
|
|
if(list_folders(data) == ERR) goto ENDE_IMAP;
|
|
|
|
|
2016-03-03 11:04:32 +01:00
|
|
|
|
|
|
|
for(i=0;i<MAXHASH;i++){
|
|
|
|
q = data->imapfolders[i];
|
|
|
|
while(q != NULL){
|
|
|
|
|
|
|
|
if(q && q->str && strlen(q->str) > 1){
|
|
|
|
|
|
|
|
skipmatch = 0;
|
|
|
|
|
2017-08-08 15:34:45 +02:00
|
|
|
if(data->import->skiplist && strlen(data->import->skiplist) > 0){
|
2016-03-03 11:04:32 +01:00
|
|
|
snprintf(puf, sizeof(puf)-1, "%s,", (char *)q->str);
|
2017-08-08 15:34:45 +02:00
|
|
|
if(strstr(data->import->skiplist, puf)) skipmatch = 1;
|
2016-03-03 11:04:32 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
if(skipmatch == 1){
|
|
|
|
if(data->quiet == 0) printf("SKIPPING FOLDER: %s\n", (char *)q->str);
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
if(data->quiet == 0) printf("processing folder: %s... ", (char *)q->str);
|
|
|
|
|
2017-08-08 15:34:45 +02:00
|
|
|
if(process_imap_folder(q->str, sdata, data, cfg) == ERR) ret = ERR;
|
2016-03-03 11:04:32 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
q = q->r;
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2017-08-08 15:34:45 +02:00
|
|
|
send_imap_close(data);
|
2016-03-03 11:04:32 +01:00
|
|
|
|
2017-08-08 15:34:45 +02:00
|
|
|
close_connection(data->net);
|
2016-03-03 11:04:32 +01:00
|
|
|
|
|
|
|
ENDE_IMAP:
|
|
|
|
freeaddrinfo(res);
|
|
|
|
|
|
|
|
clearhash(data->imapfolders);
|
|
|
|
|
|
|
|
data->import->status = 2;
|
|
|
|
|
|
|
|
return ret;
|
|
|
|
}
|