mirror of
https://bitbucket.org/jsuto/piler.git
synced 2025-01-12 12:20:11 +01:00
added SSL support to pilerimport
This commit is contained in:
parent
0f61106386
commit
d7f860c15b
100
configure
vendored
100
configure
vendored
@ -3425,7 +3425,7 @@ unrtf="no"
|
|||||||
|
|
||||||
have_static_build="no"
|
have_static_build="no"
|
||||||
|
|
||||||
antispam_libs="-lz -lm -ldl -lcrypto"
|
antispam_libs="-lz -lm -ldl -lcrypto -lssl"
|
||||||
defs=""
|
defs=""
|
||||||
objs=""
|
objs=""
|
||||||
user_obj=""
|
user_obj=""
|
||||||
@ -3684,7 +3684,103 @@ fi
|
|||||||
fi
|
fi
|
||||||
ac_cv_lib_crypto=ac_cv_lib_crypto_main
|
ac_cv_lib_crypto=ac_cv_lib_crypto_main
|
||||||
|
|
||||||
if test "$have_crypto" = "no"; then
|
for ac_header in openssl/ssl.h
|
||||||
|
do :
|
||||||
|
ac_fn_c_check_header_mongrel "$LINENO" "openssl/ssl.h" "ac_cv_header_openssl_ssl_h" "$ac_includes_default"
|
||||||
|
if test "x$ac_cv_header_openssl_ssl_h" = xyes; then :
|
||||||
|
cat >>confdefs.h <<_ACEOF
|
||||||
|
#define HAVE_OPENSSL_SSL_H 1
|
||||||
|
_ACEOF
|
||||||
|
have_ssl=yes
|
||||||
|
else
|
||||||
|
have_ssl=no
|
||||||
|
fi
|
||||||
|
|
||||||
|
done
|
||||||
|
|
||||||
|
{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for SSL_write in -lssl" >&5
|
||||||
|
$as_echo_n "checking for SSL_write in -lssl... " >&6; }
|
||||||
|
if ${ac_cv_lib_ssl_SSL_write+:} false; then :
|
||||||
|
$as_echo_n "(cached) " >&6
|
||||||
|
else
|
||||||
|
ac_check_lib_save_LIBS=$LIBS
|
||||||
|
LIBS="-lssl $LIBS"
|
||||||
|
cat confdefs.h - <<_ACEOF >conftest.$ac_ext
|
||||||
|
/* end confdefs.h. */
|
||||||
|
|
||||||
|
/* Override any GCC internal prototype to avoid an error.
|
||||||
|
Use char because int might match the return type of a GCC
|
||||||
|
builtin and then its argument prototype would still apply. */
|
||||||
|
#ifdef __cplusplus
|
||||||
|
extern "C"
|
||||||
|
#endif
|
||||||
|
char SSL_write ();
|
||||||
|
int
|
||||||
|
main ()
|
||||||
|
{
|
||||||
|
return SSL_write ();
|
||||||
|
;
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
_ACEOF
|
||||||
|
if ac_fn_c_try_link "$LINENO"; then :
|
||||||
|
ac_cv_lib_ssl_SSL_write=yes
|
||||||
|
else
|
||||||
|
ac_cv_lib_ssl_SSL_write=no
|
||||||
|
fi
|
||||||
|
rm -f core conftest.err conftest.$ac_objext \
|
||||||
|
conftest$ac_exeext conftest.$ac_ext
|
||||||
|
LIBS=$ac_check_lib_save_LIBS
|
||||||
|
fi
|
||||||
|
{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_ssl_SSL_write" >&5
|
||||||
|
$as_echo "$ac_cv_lib_ssl_SSL_write" >&6; }
|
||||||
|
if test "x$ac_cv_lib_ssl_SSL_write" = xyes; then :
|
||||||
|
{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for SSL_write in -lssl" >&5
|
||||||
|
$as_echo_n "checking for SSL_write in -lssl... " >&6; }
|
||||||
|
if ${ac_cv_lib_ssl_SSL_write+:} false; then :
|
||||||
|
$as_echo_n "(cached) " >&6
|
||||||
|
else
|
||||||
|
ac_check_lib_save_LIBS=$LIBS
|
||||||
|
LIBS="-lssl $LIBS"
|
||||||
|
cat confdefs.h - <<_ACEOF >conftest.$ac_ext
|
||||||
|
/* end confdefs.h. */
|
||||||
|
|
||||||
|
/* Override any GCC internal prototype to avoid an error.
|
||||||
|
Use char because int might match the return type of a GCC
|
||||||
|
builtin and then its argument prototype would still apply. */
|
||||||
|
#ifdef __cplusplus
|
||||||
|
extern "C"
|
||||||
|
#endif
|
||||||
|
char SSL_write ();
|
||||||
|
int
|
||||||
|
main ()
|
||||||
|
{
|
||||||
|
return SSL_write ();
|
||||||
|
;
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
_ACEOF
|
||||||
|
if ac_fn_c_try_link "$LINENO"; then :
|
||||||
|
ac_cv_lib_ssl_SSL_write=yes
|
||||||
|
else
|
||||||
|
ac_cv_lib_ssl_SSL_write=no
|
||||||
|
fi
|
||||||
|
rm -f core conftest.err conftest.$ac_objext \
|
||||||
|
conftest$ac_exeext conftest.$ac_ext
|
||||||
|
LIBS=$ac_check_lib_save_LIBS
|
||||||
|
fi
|
||||||
|
{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_ssl_SSL_write" >&5
|
||||||
|
$as_echo "$ac_cv_lib_ssl_SSL_write" >&6; }
|
||||||
|
if test "x$ac_cv_lib_ssl_SSL_write" = xyes; then :
|
||||||
|
have_ssl=yes
|
||||||
|
else
|
||||||
|
echo "libssl is not found"; have_ssl=no
|
||||||
|
fi
|
||||||
|
|
||||||
|
fi
|
||||||
|
ac_cv_lib_ssl=ac_cv_lib_ssl_main
|
||||||
|
|
||||||
|
if test "$have_crypto" = "no" || test "$have_ssl" = "no"; then
|
||||||
echo "please install openssl developer package"
|
echo "please install openssl developer package"
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
|
@ -51,7 +51,7 @@ unrtf="no"
|
|||||||
|
|
||||||
have_static_build="no"
|
have_static_build="no"
|
||||||
|
|
||||||
antispam_libs="-lz -lm -ldl -lcrypto"
|
antispam_libs="-lz -lm -ldl -lcrypto -lssl"
|
||||||
defs=""
|
defs=""
|
||||||
objs=""
|
objs=""
|
||||||
user_obj=""
|
user_obj=""
|
||||||
@ -109,7 +109,10 @@ dnl openssl library
|
|||||||
AC_CHECK_HEADERS(openssl/sha.h, have_crypto=yes, have_crypto=no)
|
AC_CHECK_HEADERS(openssl/sha.h, have_crypto=yes, have_crypto=no)
|
||||||
AC_CHECK_LIB([crypto],[SHA256_Init],[AC_CHECK_LIB(crypto, SHA256_Init, have_crypto=yes, echo "libcrypto is not found"; have_crypto=no)],[],[])ac_cv_lib_crypto=ac_cv_lib_crypto_main
|
AC_CHECK_LIB([crypto],[SHA256_Init],[AC_CHECK_LIB(crypto, SHA256_Init, have_crypto=yes, echo "libcrypto is not found"; have_crypto=no)],[],[])ac_cv_lib_crypto=ac_cv_lib_crypto_main
|
||||||
|
|
||||||
if test "$have_crypto" = "no"; then
|
AC_CHECK_HEADERS(openssl/ssl.h, have_ssl=yes, have_ssl=no)
|
||||||
|
AC_CHECK_LIB([ssl],[SSL_write],[AC_CHECK_LIB(ssl, SSL_write, have_ssl=yes, echo "libssl is not found"; have_ssl=no)],[],[])ac_cv_lib_ssl=ac_cv_lib_ssl_main
|
||||||
|
|
||||||
|
if test "$have_crypto" = "no" || test "$have_ssl" = "no"; then
|
||||||
echo "please install openssl developer package"
|
echo "please install openssl developer package"
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
|
@ -13,7 +13,7 @@
|
|||||||
|
|
||||||
#define VERSION "0.1.21"
|
#define VERSION "0.1.21"
|
||||||
|
|
||||||
#define BUILD 717
|
#define BUILD 719
|
||||||
|
|
||||||
#define HOSTID "mailarchiver"
|
#define HOSTID "mailarchiver"
|
||||||
|
|
||||||
|
@ -24,6 +24,7 @@
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
#include <openssl/sha.h>
|
#include <openssl/sha.h>
|
||||||
|
#include <openssl/ssl.h>
|
||||||
#include "tai.h"
|
#include "tai.h"
|
||||||
#include "config.h"
|
#include "config.h"
|
||||||
|
|
||||||
@ -247,6 +248,8 @@ struct __data {
|
|||||||
struct memcached_server memc;
|
struct memcached_server memc;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
SSL_CTX *ctx;
|
||||||
|
SSL *ssl;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
|
133
src/imap.c
133
src/imap.c
@ -14,6 +14,7 @@
|
|||||||
#include <netdb.h>
|
#include <netdb.h>
|
||||||
#include <sys/time.h>
|
#include <sys/time.h>
|
||||||
#include <openssl/ssl.h>
|
#include <openssl/ssl.h>
|
||||||
|
#include <openssl/err.h>
|
||||||
#include <fcntl.h>
|
#include <fcntl.h>
|
||||||
#include <ctype.h>
|
#include <ctype.h>
|
||||||
#include <syslog.h>
|
#include <syslog.h>
|
||||||
@ -22,6 +23,9 @@
|
|||||||
#include <piler.h>
|
#include <piler.h>
|
||||||
|
|
||||||
|
|
||||||
|
#define CHK_NULL(x, errmsg) if ((x)==NULL) { printf("error: %s\n", errmsg); return ERR; }
|
||||||
|
#define CHK_SSL(err, msg) if ((err)==-1) { printf("ssl error: %s\n", msg); return ERR; }
|
||||||
|
|
||||||
|
|
||||||
unsigned long resolve_host(char *host){
|
unsigned long resolve_host(char *host){
|
||||||
struct hostent *h;
|
struct hostent *h;
|
||||||
@ -52,7 +56,8 @@ int get_message_length_from_imap_answer(char *s, int *_1st_line_bytes){
|
|||||||
|
|
||||||
*p = '\0';
|
*p = '\0';
|
||||||
|
|
||||||
*_1st_line_bytes = strlen(s)+2;
|
//*_1st_line_bytes = strlen(s)+2;
|
||||||
|
*_1st_line_bytes = p-s+2;
|
||||||
|
|
||||||
if(*(p-1) == '}') *(p-1) = '\0';
|
if(*(p-1) == '}') *(p-1) = '\0';
|
||||||
|
|
||||||
@ -88,16 +93,16 @@ int is_last_complete_packet(char *s, int len, char *tagok, char *tagbad, int *po
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
int process_imap_folder(int sd, int *seq, char *folder, struct session_data *sdata, struct __data *data, struct __config *cfg){
|
int process_imap_folder(int sd, int *seq, char *folder, struct session_data *sdata, struct __data *data, int use_ssl, struct __config *cfg){
|
||||||
int rc=ERR, i, n, pos, endpos, messages=0, len, readlen, fd, lastpos, nreads, nwrites, processed_messages=0;
|
int rc=ERR, i, n, pos, endpos, messages=0, len, readlen, fd, lastpos, nreads, processed_messages=0;
|
||||||
char *p, tag[SMALLBUFSIZE], tagok[SMALLBUFSIZE], tagbad[SMALLBUFSIZE], buf[MAXBUFSIZE], filename[SMALLBUFSIZE];
|
char *p, tag[SMALLBUFSIZE], tagok[SMALLBUFSIZE], tagbad[SMALLBUFSIZE], buf[MAXBUFSIZE], filename[SMALLBUFSIZE];
|
||||||
char aggrbuf[3*MAXBUFSIZE];
|
char aggrbuf[3*MAXBUFSIZE];
|
||||||
|
|
||||||
snprintf(tag, sizeof(tag)-1, "A%d", *seq); snprintf(tagok, sizeof(tagok)-1, "\r\nA%d OK", (*seq)++);
|
snprintf(tag, sizeof(tag)-1, "A%d", *seq); snprintf(tagok, sizeof(tagok)-1, "\r\nA%d OK", (*seq)++);
|
||||||
snprintf(buf, sizeof(buf)-1, "%s SELECT \"%s\"\r\n", tag, folder);
|
snprintf(buf, sizeof(buf)-1, "%s SELECT \"%s\"\r\n", tag, folder);
|
||||||
send(sd, buf, strlen(buf), 0);
|
|
||||||
|
|
||||||
n = recvtimeout(sd, buf, MAXBUFSIZE, 10);
|
n = write1(sd, buf, use_ssl, data->ssl);
|
||||||
|
n = recvtimeoutssl(sd, buf, sizeof(buf), 10, use_ssl, data->ssl);
|
||||||
|
|
||||||
if(!strstr(buf, tagok)){
|
if(!strstr(buf, tagok)){
|
||||||
trimBuffer(buf);
|
trimBuffer(buf);
|
||||||
@ -139,20 +144,19 @@ int process_imap_folder(int sd, int *seq, char *folder, struct session_data *sda
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
send(sd, buf, strlen(buf), 0);
|
n = write1(sd, buf, use_ssl, data->ssl);
|
||||||
|
|
||||||
readlen = 0;
|
readlen = 0;
|
||||||
pos = 0;
|
pos = 0;
|
||||||
len = 0;
|
len = 0;
|
||||||
nreads = 0;
|
nreads = 0;
|
||||||
nwrites = 0;
|
|
||||||
endpos = 0;
|
endpos = 0;
|
||||||
|
|
||||||
memset(aggrbuf, 0, sizeof(aggrbuf));
|
memset(aggrbuf, 0, sizeof(aggrbuf));
|
||||||
lastpos = 0;
|
lastpos = 0;
|
||||||
|
|
||||||
|
|
||||||
while((n = recvtimeout(sd, buf, sizeof(buf), 15)) > 0){
|
while((n = recvtimeoutssl(sd, buf, sizeof(buf), 15, use_ssl, data->ssl)) > 0){
|
||||||
nreads++;
|
nreads++;
|
||||||
readlen += n;
|
readlen += n;
|
||||||
|
|
||||||
@ -165,45 +169,33 @@ int process_imap_folder(int sd, int *seq, char *folder, struct session_data *sda
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if(lastpos + n + sizeof(buf) > sizeof(aggrbuf)){
|
if(lastpos + 1 + n < sizeof(aggrbuf)){
|
||||||
nwrites++;
|
|
||||||
|
|
||||||
if(nwrites == 1)
|
if(nreads == 1){
|
||||||
write(fd, aggrbuf+pos, lastpos-pos);
|
memcpy(aggrbuf+lastpos, buf+pos, n-pos);
|
||||||
else
|
lastpos += n-pos;
|
||||||
write(fd, aggrbuf, lastpos);
|
|
||||||
|
|
||||||
memset(aggrbuf, 0, sizeof(aggrbuf));
|
|
||||||
lastpos = 0;
|
|
||||||
}
|
}
|
||||||
|
else {
|
||||||
|
memcpy(aggrbuf+lastpos, buf, n);
|
||||||
|
lastpos += n;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
write(fd, aggrbuf, sizeof(buf));
|
||||||
|
|
||||||
|
memmove(aggrbuf, aggrbuf+sizeof(buf), lastpos-sizeof(buf));
|
||||||
|
lastpos -= sizeof(buf);
|
||||||
|
|
||||||
memcpy(aggrbuf+lastpos, buf, n);
|
memcpy(aggrbuf+lastpos, buf, n);
|
||||||
lastpos += n;
|
lastpos += n;
|
||||||
|
}
|
||||||
|
|
||||||
if(is_last_complete_packet(aggrbuf, lastpos, tagok, tagbad, &endpos) == 1){
|
if(is_last_complete_packet(aggrbuf, lastpos, tagok, tagbad, &endpos) == 1){
|
||||||
nwrites++;
|
|
||||||
if(nwrites == 1)
|
|
||||||
write(fd, aggrbuf+pos, lastpos-(lastpos-endpos)-pos);
|
|
||||||
else
|
|
||||||
write(fd, aggrbuf, lastpos-(lastpos-endpos));
|
write(fd, aggrbuf, lastpos-(lastpos-endpos));
|
||||||
|
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
else {
|
|
||||||
nwrites++;
|
|
||||||
if(nwrites == 1){
|
|
||||||
if(lastpos-n-pos > 0) write(fd, aggrbuf+pos, lastpos-n-pos); else nwrites--;
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
write(fd, aggrbuf, lastpos-n);
|
|
||||||
}
|
|
||||||
|
|
||||||
memmove(aggrbuf, aggrbuf+lastpos-n, n);
|
|
||||||
lastpos = n;
|
|
||||||
memset(aggrbuf+lastpos, 0, sizeof(aggrbuf)-lastpos);
|
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
close(fd);
|
close(fd);
|
||||||
|
|
||||||
@ -218,29 +210,69 @@ int process_imap_folder(int sd, int *seq, char *folder, struct session_data *sda
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
int connect_to_imap_server(int sd, int *seq, char *imapserver, char *username, char *password){
|
int connect_to_imap_server(int sd, int *seq, char *imapserver, char *username, char *password, int port, struct __data *data, int use_ssl){
|
||||||
int n, pos=0;
|
int n, pos=0;
|
||||||
char tag[SMALLBUFSIZE], tagok[SMALLBUFSIZE], buf[MAXBUFSIZE];
|
char tag[SMALLBUFSIZE], tagok[SMALLBUFSIZE], buf[MAXBUFSIZE];
|
||||||
char auth[2*SMALLBUFSIZE];
|
char auth[2*SMALLBUFSIZE];
|
||||||
unsigned char tmp[SMALLBUFSIZE];
|
unsigned char tmp[SMALLBUFSIZE];
|
||||||
unsigned long host=0;
|
unsigned long host=0;
|
||||||
struct sockaddr_in remote_addr;
|
struct sockaddr_in remote_addr;
|
||||||
|
X509* server_cert;
|
||||||
|
SSL_METHOD *meth;
|
||||||
|
char *str;
|
||||||
|
|
||||||
|
|
||||||
host = resolve_host(imapserver);
|
host = resolve_host(imapserver);
|
||||||
|
|
||||||
remote_addr.sin_family = AF_INET;
|
remote_addr.sin_family = AF_INET;
|
||||||
remote_addr.sin_port = htons(143);
|
remote_addr.sin_port = htons(port);
|
||||||
remote_addr.sin_addr.s_addr = host;
|
remote_addr.sin_addr.s_addr = host;
|
||||||
bzero(&(remote_addr.sin_zero),8);
|
bzero(&(remote_addr.sin_zero),8);
|
||||||
|
|
||||||
|
|
||||||
if(connect(sd, (struct sockaddr *)&remote_addr, sizeof(struct sockaddr)) == -1){
|
if(connect(sd, (struct sockaddr *)&remote_addr, sizeof(struct sockaddr)) == -1){
|
||||||
printf("connect()\n");
|
printf("connect()\n");
|
||||||
return ERR;
|
return ERR;
|
||||||
}
|
}
|
||||||
|
|
||||||
n = recvtimeout(sd, buf, MAXBUFSIZE, 10);
|
|
||||||
|
if(use_ssl == 1){
|
||||||
|
|
||||||
|
SSLeay_add_ssl_algorithms();
|
||||||
|
meth = SSLv3_client_method();
|
||||||
|
SSL_load_error_strings();
|
||||||
|
|
||||||
|
data->ctx = SSL_CTX_new(meth);
|
||||||
|
CHK_NULL(data->ctx, "internal SSL error");
|
||||||
|
|
||||||
|
data->ssl = SSL_new(data->ctx);
|
||||||
|
CHK_NULL(data->ssl, "internal ssl error");
|
||||||
|
|
||||||
|
SSL_set_fd(data->ssl, sd);
|
||||||
|
n = SSL_connect(data->ssl);
|
||||||
|
CHK_SSL(n, "internal ssl error");
|
||||||
|
|
||||||
|
//printf("Cipher: %s\n", SSL_get_cipher(data->ssl));
|
||||||
|
|
||||||
|
server_cert = SSL_get_peer_certificate(data->ssl);
|
||||||
|
CHK_NULL(server_cert, "server cert error");
|
||||||
|
|
||||||
|
//if(verbose){
|
||||||
|
str = X509_NAME_oneline(X509_get_subject_name(server_cert), 0, 0);
|
||||||
|
CHK_NULL(str, "error in server cert");
|
||||||
|
printf("server cert:\n\t subject: %s\n", str);
|
||||||
|
OPENSSL_free(str);
|
||||||
|
|
||||||
|
str = X509_NAME_oneline(X509_get_issuer_name(server_cert), 0, 0);
|
||||||
|
CHK_NULL(str, "error in server cert");
|
||||||
|
printf("\t issuer: %s\n\n", str);
|
||||||
|
OPENSSL_free(str);
|
||||||
|
//}
|
||||||
|
|
||||||
|
X509_free(server_cert);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
n = recvtimeoutssl(sd, buf, sizeof(buf), 10, use_ssl, data->ssl);
|
||||||
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@ -262,8 +294,10 @@ int connect_to_imap_server(int sd, int *seq, char *imapserver, char *username, c
|
|||||||
|
|
||||||
snprintf(tag, sizeof(tag)-1, "A%d", *seq); snprintf(tagok, sizeof(tagok)-1, "A%d OK", (*seq)++);
|
snprintf(tag, sizeof(tag)-1, "A%d", *seq); snprintf(tagok, sizeof(tagok)-1, "A%d OK", (*seq)++);
|
||||||
snprintf(buf, sizeof(buf)-1, "%s AUTHENTICATE PLAIN %s\r\n", tag, auth);
|
snprintf(buf, sizeof(buf)-1, "%s AUTHENTICATE PLAIN %s\r\n", tag, auth);
|
||||||
send(sd, buf, strlen(buf), 0);
|
|
||||||
n = recvtimeout(sd, buf, MAXBUFSIZE, 10);
|
write1(sd, buf, use_ssl, data->ssl);
|
||||||
|
n = recvtimeoutssl(sd, buf, sizeof(buf), 10, use_ssl, data->ssl);
|
||||||
|
|
||||||
if(strncmp(buf, tagok, strlen(tagok))){
|
if(strncmp(buf, tagok, strlen(tagok))){
|
||||||
printf("login failed, server reponse: %s\n", buf);
|
printf("login failed, server reponse: %s\n", buf);
|
||||||
return ERR;
|
return ERR;
|
||||||
@ -273,7 +307,18 @@ int connect_to_imap_server(int sd, int *seq, char *imapserver, char *username, c
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
int list_folders(int sd, int *seq, char *folders, int foldersize){
|
void close_connection(int sd, struct __data *data, int use_ssl){
|
||||||
|
close(sd);
|
||||||
|
|
||||||
|
if(use_ssl == 1){
|
||||||
|
SSL_shutdown(data->ssl);
|
||||||
|
SSL_free(data->ssl);
|
||||||
|
SSL_CTX_free(data->ctx);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
int list_folders(int sd, int *seq, char *folders, int foldersize, int use_ssl, struct __data *data){
|
||||||
int n;
|
int n;
|
||||||
char *p, *q, tag[SMALLBUFSIZE], tagok[SMALLBUFSIZE], buf[MAXBUFSIZE], puf[MAXBUFSIZE];
|
char *p, *q, tag[SMALLBUFSIZE], tagok[SMALLBUFSIZE], buf[MAXBUFSIZE], puf[MAXBUFSIZE];
|
||||||
|
|
||||||
@ -281,9 +326,9 @@ int list_folders(int sd, int *seq, char *folders, int foldersize){
|
|||||||
//snprintf(buf, sizeof(buf)-1, "%s LIST \"\" %%\r\n", tag);
|
//snprintf(buf, sizeof(buf)-1, "%s LIST \"\" %%\r\n", tag);
|
||||||
snprintf(buf, sizeof(buf)-1, "%s LIST \"\" \"*\"\r\n", tag);
|
snprintf(buf, sizeof(buf)-1, "%s LIST \"\" \"*\"\r\n", tag);
|
||||||
|
|
||||||
send(sd, buf, strlen(buf), 0);
|
write1(sd, buf, use_ssl, data->ssl);
|
||||||
|
|
||||||
n = recvtimeout(sd, buf, MAXBUFSIZE, 10);
|
n = recvtimeoutssl(sd, buf, sizeof(buf), 10, use_ssl, data->ssl);
|
||||||
|
|
||||||
p = &buf[0];
|
p = &buf[0];
|
||||||
do {
|
do {
|
||||||
|
28
src/misc.c
28
src/misc.c
@ -18,6 +18,7 @@
|
|||||||
#include <syslog.h>
|
#include <syslog.h>
|
||||||
#include <unistd.h>
|
#include <unistd.h>
|
||||||
#include <ctype.h>
|
#include <ctype.h>
|
||||||
|
#include <openssl/ssl.h>
|
||||||
#include "misc.h"
|
#include "misc.h"
|
||||||
#include "smtpcodes.h"
|
#include "smtpcodes.h"
|
||||||
#include "errmsg.h"
|
#include "errmsg.h"
|
||||||
@ -293,7 +294,7 @@ int recvtimeout(int s, char *buf, int len, int timeout){
|
|||||||
int n;
|
int n;
|
||||||
struct timeval tv;
|
struct timeval tv;
|
||||||
|
|
||||||
memset(buf, 0, MAXBUFSIZE);
|
memset(buf, 0, len);
|
||||||
|
|
||||||
FD_ZERO(&fds);
|
FD_ZERO(&fds);
|
||||||
FD_SET(s, &fds);
|
FD_SET(s, &fds);
|
||||||
@ -309,6 +310,31 @@ int recvtimeout(int s, char *buf, int len, int timeout){
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
int write1(int sd, char *buf, int use_ssl, SSL *ssl){
|
||||||
|
int n;
|
||||||
|
|
||||||
|
if(use_ssl == 1)
|
||||||
|
n = SSL_write(ssl, buf, strlen(buf));
|
||||||
|
else
|
||||||
|
n = send(sd, buf, strlen(buf), 0);
|
||||||
|
|
||||||
|
return n;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
int recvtimeoutssl(int s, char *buf, int len, int timeout, int use_ssl, SSL *ssl){
|
||||||
|
|
||||||
|
memset(buf, 0, len);
|
||||||
|
|
||||||
|
if(use_ssl == 1){
|
||||||
|
return SSL_read(ssl, buf, len-1);
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
return recvtimeout(s, buf, len-1, timeout);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* is it a valid dotted IPv4 address
|
* is it a valid dotted IPv4 address
|
||||||
*/
|
*/
|
||||||
|
@ -5,6 +5,7 @@
|
|||||||
#ifndef _MISC_H
|
#ifndef _MISC_H
|
||||||
#define _MISC_H
|
#define _MISC_H
|
||||||
|
|
||||||
|
#include <openssl/ssl.h>
|
||||||
#include <sys/time.h>
|
#include <sys/time.h>
|
||||||
#include <pwd.h>
|
#include <pwd.h>
|
||||||
#include <cfg.h>
|
#include <cfg.h>
|
||||||
@ -24,6 +25,8 @@ void create_id(char *id);
|
|||||||
int get_random_bytes(unsigned char *buf, int len);
|
int get_random_bytes(unsigned char *buf, int len);
|
||||||
int readFromEntropyPool(int fd, void *_s, size_t n);
|
int readFromEntropyPool(int fd, void *_s, size_t n);
|
||||||
int recvtimeout(int s, char *buf, int len, int timeout);
|
int recvtimeout(int s, char *buf, int len, int timeout);
|
||||||
|
int write1(int sd, char *buf, int use_ssl, SSL *ssl);
|
||||||
|
int recvtimeoutssl(int s, char *buf, int len, int timeout, int use_ssl, SSL *ssl);
|
||||||
|
|
||||||
void write_pid_file(char *pidfile);
|
void write_pid_file(char *pidfile);
|
||||||
int drop_privileges(struct passwd *pwd);
|
int drop_privileges(struct passwd *pwd);
|
||||||
|
@ -31,9 +31,10 @@ int quiet=0;
|
|||||||
int remove_after_successful_import = 0;
|
int remove_after_successful_import = 0;
|
||||||
|
|
||||||
|
|
||||||
int connect_to_imap_server(int sd, int *seq, char *imapserver, char *username, char *password);
|
int connect_to_imap_server(int sd, int *seq, char *imapserver, char *username, char *password, int port, struct __data *data, int use_ssl);
|
||||||
int list_folders(int sd, int *seq, char *folders, int foldersize);
|
void close_connection(int sd, struct __data *data, int use_ssl);
|
||||||
int process_imap_folder(int sd, int *seq, char *folder, struct session_data *sdata, struct __data *data, struct __config *cfg);
|
int list_folders(int sd, int *seq, char *folders, int foldersize, int use_ssl, struct __data *data);
|
||||||
|
int process_imap_folder(int sd, int *seq, char *folder, struct session_data *sdata, struct __data *data, int use_ssl, struct __config *cfg);
|
||||||
|
|
||||||
|
|
||||||
int import_from_mailbox(char *mailbox, struct session_data *sdata, struct __data *data, struct __config *cfg){
|
int import_from_mailbox(char *mailbox, struct session_data *sdata, struct __data *data, struct __config *cfg){
|
||||||
@ -236,24 +237,28 @@ int import_from_maildir(char *directory, struct session_data *sdata, struct __da
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
int import_from_imap_server(char *imapserver, char *username, char *password, struct session_data *sdata, struct __data *data, char *skiplist, struct __config *cfg){
|
int import_from_imap_server(char *imapserver, char *username, char *password, int port, struct session_data *sdata, struct __data *data, char *skiplist, struct __config *cfg){
|
||||||
int rc=ERR, ret=OK, sd, seq=1, skipmatch;
|
int rc=ERR, ret=OK, sd, seq=1, skipmatch, use_ssl=0;
|
||||||
char *p, puf[SMALLBUFSIZE];
|
char *p, puf[SMALLBUFSIZE];
|
||||||
char *q, muf[SMALLBUFSIZE];
|
char *q, muf[SMALLBUFSIZE];
|
||||||
char folders[MAXBUFSIZE];
|
char folders[MAXBUFSIZE];
|
||||||
|
|
||||||
|
|
||||||
|
if(port == 993) use_ssl = 1;
|
||||||
|
|
||||||
|
|
||||||
if((sd = socket(AF_INET, SOCK_STREAM, 0)) == -1){
|
if((sd = socket(AF_INET, SOCK_STREAM, 0)) == -1){
|
||||||
printf("cannot create socket\n");
|
printf("cannot create socket\n");
|
||||||
return ERR;
|
return ERR;
|
||||||
}
|
}
|
||||||
|
|
||||||
if(connect_to_imap_server(sd, &seq, imapserver, username, password) == ERR){
|
if(connect_to_imap_server(sd, &seq, imapserver, username, password, port, data, use_ssl) == ERR){
|
||||||
close(sd);
|
close(sd);
|
||||||
return ERR;
|
return ERR;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
list_folders(sd, &seq, &folders[0], sizeof(folders));
|
list_folders(sd, &seq, &folders[0], sizeof(folders), use_ssl, data);
|
||||||
|
|
||||||
|
|
||||||
p = &folders[0];
|
p = &folders[0];
|
||||||
@ -284,26 +289,26 @@ int import_from_imap_server(char *imapserver, char *username, char *password, st
|
|||||||
|
|
||||||
if(quiet == 0) printf("processing folder: %s... ", puf);
|
if(quiet == 0) printf("processing folder: %s... ", puf);
|
||||||
|
|
||||||
rc = process_imap_folder(sd, &seq, puf, sdata, data, cfg);
|
rc = process_imap_folder(sd, &seq, puf, sdata, data, use_ssl, cfg);
|
||||||
if(rc == ERR) ret = ERR;
|
if(rc == ERR) ret = ERR;
|
||||||
|
|
||||||
} while(p);
|
} while(p);
|
||||||
|
|
||||||
|
|
||||||
close(sd);
|
close_connection(sd, data, use_ssl);
|
||||||
|
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
void usage(){
|
void usage(){
|
||||||
printf("usage: pilerimport [-c <config file>] -e <eml file> | -m <mailbox file> | -d <directory> | -i <imap server> -u <imap username> -p <imap password> [-F <foldername>] [-R] [-r] [-q]\n");
|
printf("usage: pilerimport [-c <config file>] -e <eml file> | -m <mailbox file> | -d <directory> | -i <imap server> -u <imap username> -p <imap password> -P <imap port> [-F <foldername>] [-R] [-r] [-q]\n");
|
||||||
exit(0);
|
exit(0);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
int main(int argc, char **argv){
|
int main(int argc, char **argv){
|
||||||
int i, c, rc=0, n_mbox=0, tot_msgs=0;
|
int i, c, rc=0, n_mbox=0, tot_msgs=0, port=143;
|
||||||
char *configfile=CONFIG_FILE, *emlfile=NULL, *mboxdir=NULL, *mbox[MBOX_ARGS], *directory=NULL;
|
char *configfile=CONFIG_FILE, *emlfile=NULL, *mboxdir=NULL, *mbox[MBOX_ARGS], *directory=NULL;
|
||||||
char *imapserver=NULL, *username=NULL, *password=NULL, *skiplist=SKIPLIST, *folder=NULL;
|
char *imapserver=NULL, *username=NULL, *password=NULL, *skiplist=SKIPLIST, *folder=NULL;
|
||||||
struct session_data sdata;
|
struct session_data sdata;
|
||||||
@ -330,6 +335,7 @@ int main(int argc, char **argv){
|
|||||||
{"imapserver", required_argument, 0, 'i' },
|
{"imapserver", required_argument, 0, 'i' },
|
||||||
{"username", required_argument, 0, 'u' },
|
{"username", required_argument, 0, 'u' },
|
||||||
{"password", required_argument, 0, 'p' },
|
{"password", required_argument, 0, 'p' },
|
||||||
|
{"port", required_argument, 0, 'P' },
|
||||||
{"skiplist", required_argument, 0, 'x' },
|
{"skiplist", required_argument, 0, 'x' },
|
||||||
{"folder", required_argument, 0, 'F' },
|
{"folder", required_argument, 0, 'F' },
|
||||||
{"quiet", required_argument, 0, 'q' },
|
{"quiet", required_argument, 0, 'q' },
|
||||||
@ -341,9 +347,9 @@ int main(int argc, char **argv){
|
|||||||
|
|
||||||
int option_index = 0;
|
int option_index = 0;
|
||||||
|
|
||||||
c = getopt_long(argc, argv, "c:m:M:e:d:i:u:p:x:F:Rrqh?", long_options, &option_index);
|
c = getopt_long(argc, argv, "c:m:M:e:d:i:u:p:P:x:F:Rrqh?", long_options, &option_index);
|
||||||
#else
|
#else
|
||||||
c = getopt(argc, argv, "c:m:M:e:d:i:u:p:x:F:Rrqh?");
|
c = getopt(argc, argv, "c:m:M:e:d:i:u:p:P:x:F:Rrqh?");
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
if(c == -1) break;
|
if(c == -1) break;
|
||||||
@ -387,6 +393,10 @@ int main(int argc, char **argv){
|
|||||||
password = optarg;
|
password = optarg;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
case 'P' :
|
||||||
|
port = atoi(optarg);
|
||||||
|
break;
|
||||||
|
|
||||||
case 'x' :
|
case 'x' :
|
||||||
skiplist = optarg;
|
skiplist = optarg;
|
||||||
break;
|
break;
|
||||||
@ -470,7 +480,7 @@ int main(int argc, char **argv){
|
|||||||
}
|
}
|
||||||
if(mboxdir) rc = import_mbox_from_dir(mboxdir, &sdata, &data, &tot_msgs, &cfg);
|
if(mboxdir) rc = import_mbox_from_dir(mboxdir, &sdata, &data, &tot_msgs, &cfg);
|
||||||
if(directory) rc = import_from_maildir(directory, &sdata, &data, &tot_msgs, &cfg);
|
if(directory) rc = import_from_maildir(directory, &sdata, &data, &tot_msgs, &cfg);
|
||||||
if(imapserver && username && password) rc = import_from_imap_server(imapserver, username, password, &sdata, &data, skiplist, &cfg);
|
if(imapserver && username && password) rc = import_from_imap_server(imapserver, username, password, port, &sdata, &data, skiplist, &cfg);
|
||||||
|
|
||||||
|
|
||||||
free_rule(data.archiving_rules);
|
free_rule(data.archiving_rules);
|
||||||
|
Loading…
Reference in New Issue
Block a user