mirror of
https://bitbucket.org/jsuto/piler.git
synced 2025-01-12 22:20:12 +01:00
added a filename attribute to the sdata struct
This commit is contained in:
parent
1b57459f89
commit
0353b27f68
@ -38,6 +38,10 @@ backlog=20
|
|||||||
|
|
||||||
workdir=/var/spool/piler/tmp
|
workdir=/var/spool/piler/tmp
|
||||||
|
|
||||||
|
; comma separated list of your domains. piler uses this information to determine
|
||||||
|
; the direction of the given email
|
||||||
|
mydomains=
|
||||||
|
|
||||||
;
|
;
|
||||||
; memcached stuff
|
; memcached stuff
|
||||||
;
|
;
|
||||||
|
@ -11,12 +11,13 @@ source main
|
|||||||
sql_pass = sphinx
|
sql_pass = sphinx
|
||||||
|
|
||||||
sql_query_pre = SET NAMES utf8
|
sql_query_pre = SET NAMES utf8
|
||||||
sql_query = SELECT id, `from`, `to`, `subject`, `arrived`, `sent`, `body`, `size`, `attachments`, `deleted` FROM sph_index \
|
sql_query = SELECT id, `from`, `to`, `subject`, `arrived`, `sent`, `body`, `size`, `direction`, `attachments`, `deleted` FROM sph_index \
|
||||||
WHERE id<=( SELECT max_doc_id FROM sph_counter WHERE counter_id=1 )
|
WHERE id<=( SELECT max_doc_id FROM sph_counter WHERE counter_id=1 )
|
||||||
|
|
||||||
sql_attr_uint = size
|
sql_attr_uint = size
|
||||||
sql_attr_uint = arrived
|
sql_attr_uint = arrived
|
||||||
sql_attr_uint = sent
|
sql_attr_uint = sent
|
||||||
|
sql_attr_uint = direction
|
||||||
sql_attr_uint = attachments
|
sql_attr_uint = attachments
|
||||||
sql_attr_bool = deleted
|
sql_attr_bool = deleted
|
||||||
|
|
||||||
@ -33,12 +34,13 @@ source delta
|
|||||||
sql_query_pre = SET NAMES utf8
|
sql_query_pre = SET NAMES utf8
|
||||||
sql_query_pre = REPLACE INTO sph_counter SELECT 1, MAX(id) FROM sph_index
|
sql_query_pre = REPLACE INTO sph_counter SELECT 1, MAX(id) FROM sph_index
|
||||||
sql_query_post_index = DELETE FROM sph_index WHERE id<=(SELECT max_doc_id FROM sph_counter WHERE counter_id=1)
|
sql_query_post_index = DELETE FROM sph_index WHERE id<=(SELECT max_doc_id FROM sph_counter WHERE counter_id=1)
|
||||||
sql_query = SELECT id, `from`, `to`, `subject`, `arrived`, `sent`, `body`, `size`, `attachments`, `deleted` FROM sph_index \
|
sql_query = SELECT id, `from`, `to`, `subject`, `arrived`, `sent`, `body`, `size`, `direction`, `attachments`, `deleted` FROM sph_index \
|
||||||
WHERE id <= (SELECT max_doc_id FROM sph_counter WHERE counter_id=1)
|
WHERE id <= (SELECT max_doc_id FROM sph_counter WHERE counter_id=1)
|
||||||
|
|
||||||
sql_attr_uint = size
|
sql_attr_uint = size
|
||||||
sql_attr_uint = arrived
|
sql_attr_uint = arrived
|
||||||
sql_attr_uint = sent
|
sql_attr_uint = sent
|
||||||
|
sql_attr_uint = direction
|
||||||
sql_attr_uint = attachments
|
sql_attr_uint = attachments
|
||||||
sql_attr_bool = deleted
|
sql_attr_bool = deleted
|
||||||
|
|
||||||
|
@ -72,6 +72,7 @@ struct _parse_rule config_parse_rules[] =
|
|||||||
{ "max_requests_per_child", "integer", (void*) int_parser, offsetof(struct __config, max_requests_per_child), "200", sizeof(int)},
|
{ "max_requests_per_child", "integer", (void*) int_parser, offsetof(struct __config, max_requests_per_child), "200", sizeof(int)},
|
||||||
{ "memcached_servers", "string", (void*) string_parser, offsetof(struct __config, memcached_servers), "127.0.0.1", MAXVAL-1},
|
{ "memcached_servers", "string", (void*) string_parser, offsetof(struct __config, memcached_servers), "127.0.0.1", MAXVAL-1},
|
||||||
{ "memcached_ttl", "integer", (void*) int_parser, offsetof(struct __config, memcached_ttl), "86400", sizeof(int)},
|
{ "memcached_ttl", "integer", (void*) int_parser, offsetof(struct __config, memcached_ttl), "86400", sizeof(int)},
|
||||||
|
{ "mydomains", "string", (void*) string_parser, offsetof(struct __config, mydomains), "", MAXVAL-1},
|
||||||
{ "mysqlhost", "string", (void*) string_parser, offsetof(struct __config, mysqlhost), "", MAXVAL-1},
|
{ "mysqlhost", "string", (void*) string_parser, offsetof(struct __config, mysqlhost), "", MAXVAL-1},
|
||||||
{ "mysqlport", "integer", (void*) int_parser, offsetof(struct __config, mysqlport), "", sizeof(int)},
|
{ "mysqlport", "integer", (void*) int_parser, offsetof(struct __config, mysqlport), "", sizeof(int)},
|
||||||
{ "mysqlsocket", "string", (void*) string_parser, offsetof(struct __config, mysqlsocket), "/tmp/mysql.sock", MAXVAL-1},
|
{ "mysqlsocket", "string", (void*) string_parser, offsetof(struct __config, mysqlsocket), "/tmp/mysql.sock", MAXVAL-1},
|
||||||
|
@ -44,6 +44,8 @@ struct __config {
|
|||||||
unsigned char key[KEYLEN];
|
unsigned char key[KEYLEN];
|
||||||
unsigned char iv[MAXVAL];
|
unsigned char iv[MAXVAL];
|
||||||
|
|
||||||
|
char mydomains[MAXVAL];
|
||||||
|
|
||||||
// mysql stuff
|
// mysql stuff
|
||||||
|
|
||||||
char mysqlhost[MAXVAL];
|
char mysqlhost[MAXVAL];
|
||||||
|
@ -94,6 +94,10 @@
|
|||||||
#define AVIR_VIRUS 1
|
#define AVIR_VIRUS 1
|
||||||
|
|
||||||
|
|
||||||
|
#define DIRECTION_INCOMING 0
|
||||||
|
#define DIRECTION_INTERNAL 1
|
||||||
|
#define DIRECTION_OUTGOING 2
|
||||||
|
#define DIRECTION_INTERNAL_AND_OUTGOING 3
|
||||||
|
|
||||||
#endif /* _CONFIG_H */
|
#endif /* _CONFIG_H */
|
||||||
|
|
||||||
|
@ -148,10 +148,13 @@ struct _state {
|
|||||||
|
|
||||||
|
|
||||||
struct session_data {
|
struct session_data {
|
||||||
|
char filename[SMALLBUFSIZE];
|
||||||
char ttmpfile[SMALLBUFSIZE], tmpframe[SMALLBUFSIZE], tre, restored_copy;
|
char ttmpfile[SMALLBUFSIZE], tmpframe[SMALLBUFSIZE], tre, restored_copy;
|
||||||
char mailfrom[SMALLBUFSIZE], rcptto[MAX_RCPT_TO][SMALLBUFSIZE], client_addr[SMALLBUFSIZE];
|
char mailfrom[SMALLBUFSIZE], rcptto[MAX_RCPT_TO][SMALLBUFSIZE], client_addr[SMALLBUFSIZE];
|
||||||
char acceptbuf[SMALLBUFSIZE];
|
char acceptbuf[SMALLBUFSIZE];
|
||||||
char attachments[SMALLBUFSIZE];
|
char attachments[SMALLBUFSIZE];
|
||||||
|
char internal_sender, internal_recipient, external_recipient;
|
||||||
|
int direction;
|
||||||
int fd, hdr_len, tot_len, num_of_rcpt_to, rav;
|
int fd, hdr_len, tot_len, num_of_rcpt_to, rav;
|
||||||
int need_scan;
|
int need_scan;
|
||||||
float __acquire, __parsed, __av, __store, __compress, __encrypt;
|
float __acquire, __parsed, __av, __store, __compress, __encrypt;
|
||||||
|
@ -44,7 +44,7 @@ int make_digests(struct session_data *sdata, struct __config *cfg){
|
|||||||
SHA256_Init(&context2);
|
SHA256_Init(&context2);
|
||||||
|
|
||||||
|
|
||||||
fd = open(sdata->ttmpfile, O_RDONLY);
|
fd = open(sdata->filename, O_RDONLY);
|
||||||
if(fd == -1) return -1;
|
if(fd == -1) return -1;
|
||||||
|
|
||||||
while((n = read(fd, buf, sizeof(buf))) > 0){
|
while((n = read(fd, buf, sizeof(buf))) > 0){
|
||||||
|
@ -131,7 +131,7 @@ int store_index_data(struct session_data *sdata, struct _state *state, uint64 id
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
snprintf(s, sizeof(s)-1, "INSERT INTO %s (`id`, `from`, `to`, `subject`, `body`, `arrived`, `sent`, `size`, `attachments`, `attachment_types`) values(%llu,?,?,?,?,%ld,%ld,%d,%d,?)", SQL_SPHINX_TABLE, id, sdata->now, sdata->sent, sdata->tot_len, state->n_attachments);
|
snprintf(s, sizeof(s)-1, "INSERT INTO %s (`id`, `from`, `to`, `subject`, `body`, `arrived`, `sent`, `size`, `direction`, `attachments`, `attachment_types`) values(%llu,?,?,?,?,%ld,%ld,%d,%d,%d,?)", SQL_SPHINX_TABLE, id, sdata->now, sdata->sent, sdata->tot_len, sdata->direction, state->n_attachments);
|
||||||
|
|
||||||
|
|
||||||
if(mysql_stmt_prepare(stmt, s, strlen(s))){
|
if(mysql_stmt_prepare(stmt, s, strlen(s))){
|
||||||
@ -169,7 +169,7 @@ int store_index_data(struct session_data *sdata, struct _state *state, uint64 id
|
|||||||
bind[4].buffer_type = MYSQL_TYPE_STRING;
|
bind[4].buffer_type = MYSQL_TYPE_STRING;
|
||||||
bind[4].buffer = sdata->attachments;
|
bind[4].buffer = sdata->attachments;
|
||||||
bind[4].is_null = 0;
|
bind[4].is_null = 0;
|
||||||
len[4] = strlen(sdata->attachments); bind[4].length = &len[3];
|
len[4] = strlen(sdata->attachments); bind[4].length = &len[4];
|
||||||
|
|
||||||
|
|
||||||
if(mysql_stmt_bind_param(stmt, bind)){
|
if(mysql_stmt_bind_param(stmt, bind)){
|
||||||
@ -265,7 +265,7 @@ int store_meta_data(struct session_data *sdata, struct _state *state, struct __c
|
|||||||
subj = state->b_subject;
|
subj = state->b_subject;
|
||||||
if(*subj == ' ') subj++;
|
if(*subj == ' ') subj++;
|
||||||
|
|
||||||
snprintf(s, MAXBUFSIZE-1, "INSERT INTO %s (`from`,`subject`,`arrived`,`sent`,`size`,`hlen`,`attachments`,`piler_id`,`message_id`,`digest`,`bodydigest`) VALUES(?,?,%ld,%ld,%d,%d,%d,'%s',?,'%s','%s')", SQL_METADATA_TABLE, sdata->now, sdata->sent, sdata->tot_len, sdata->hdr_len, state->n_attachments, sdata->ttmpfile, sdata->digest, sdata->bodydigest);
|
snprintf(s, MAXBUFSIZE-1, "INSERT INTO %s (`from`,`subject`,`arrived`,`sent`,`size`,`hlen`,`direction`,`attachments`,`piler_id`,`message_id`,`digest`,`bodydigest`) VALUES(?,?,%ld,%ld,%d,%d,%d,%d,'%s',?,'%s','%s')", SQL_METADATA_TABLE, sdata->now, sdata->sent, sdata->tot_len, sdata->hdr_len, sdata->direction, state->n_attachments, sdata->ttmpfile, sdata->digest, sdata->bodydigest);
|
||||||
|
|
||||||
if(cfg->verbosity >= _LOG_DEBUG) syslog(LOG_PRIORITY, "%s: meta sql: *%s*", sdata->ttmpfile, s);
|
if(cfg->verbosity >= _LOG_DEBUG) syslog(LOG_PRIORITY, "%s: meta sql: *%s*", sdata->ttmpfile, s);
|
||||||
|
|
||||||
|
66
src/misc.c
66
src/misc.c
@ -341,6 +341,72 @@ int drop_privileges(struct passwd *pwd){
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
int is_email_address_on_my_domains(char *email, struct __config *cfg){
|
||||||
|
int rc=0;
|
||||||
|
char *p, *q=NULL;
|
||||||
|
|
||||||
|
if(email == NULL || cfg->mydomains == NULL) return rc;
|
||||||
|
|
||||||
|
p = strchr(email, '@');
|
||||||
|
|
||||||
|
if(!p) return rc;
|
||||||
|
|
||||||
|
if(strlen(p) < 3) return rc;
|
||||||
|
|
||||||
|
q = strrchr(p+1, ' ');
|
||||||
|
|
||||||
|
if(q) *q = '\0';
|
||||||
|
|
||||||
|
if(strcasestr(cfg->mydomains, p+1)) rc = 1;
|
||||||
|
|
||||||
|
if(q) *q = ' ';
|
||||||
|
|
||||||
|
return rc;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void init_session_data(struct session_data *sdata){
|
||||||
|
int i;
|
||||||
|
|
||||||
|
|
||||||
|
sdata->fd = -1;
|
||||||
|
|
||||||
|
create_id(&(sdata->ttmpfile[0]));
|
||||||
|
unlink(sdata->ttmpfile);
|
||||||
|
|
||||||
|
snprintf(sdata->filename, SMALLBUFSIZE-1, "%s", sdata->ttmpfile);
|
||||||
|
|
||||||
|
snprintf(sdata->tmpframe, SMALLBUFSIZE-1, "%s.m", sdata->ttmpfile);
|
||||||
|
unlink(sdata->tmpframe);
|
||||||
|
|
||||||
|
memset(sdata->mailfrom, 0, SMALLBUFSIZE);
|
||||||
|
snprintf(sdata->client_addr, SMALLBUFSIZE-1, "null");
|
||||||
|
|
||||||
|
memset(sdata->attachments, 0, SMALLBUFSIZE);
|
||||||
|
|
||||||
|
sdata->restored_copy = 0;
|
||||||
|
|
||||||
|
sdata->internal_sender = sdata->internal_recipient = sdata->external_recipient = 0;
|
||||||
|
sdata->direction = 0;
|
||||||
|
|
||||||
|
sdata->hdr_len = 0;
|
||||||
|
sdata->tot_len = 0;
|
||||||
|
sdata->num_of_rcpt_to = 0;
|
||||||
|
|
||||||
|
sdata->tre = '-';
|
||||||
|
|
||||||
|
sdata->rav = AVIR_OK;
|
||||||
|
|
||||||
|
sdata->__acquire = sdata->__parsed = sdata->__av = sdata->__store = sdata->__compress = sdata->__encrypt = 0;
|
||||||
|
|
||||||
|
|
||||||
|
for(i=0; i<MAX_RCPT_TO; i++) memset(sdata->rcptto[i], 0, SMALLBUFSIZE);
|
||||||
|
|
||||||
|
time(&(sdata->now));
|
||||||
|
sdata->sent = sdata->now;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
#ifndef _GNU_SOURCE
|
#ifndef _GNU_SOURCE
|
||||||
char *strcasestr(const char *s, const char *find){
|
char *strcasestr(const char *s, const char *find){
|
||||||
char c, sc;
|
char c, sc;
|
||||||
|
@ -23,14 +23,12 @@ 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 isValidClapfID(char *p);
|
|
||||||
|
|
||||||
int isDottedIPv4Address(char *s);
|
|
||||||
int isEmailAddressOnList(char *list, char *tmpfile, char *email, struct __config *cfg);
|
|
||||||
|
|
||||||
void write_pid_file(char *pidfile);
|
void write_pid_file(char *pidfile);
|
||||||
int drop_privileges(struct passwd *pwd);
|
int drop_privileges(struct passwd *pwd);
|
||||||
|
|
||||||
|
int is_email_address_on_my_domains(char *email, struct __config *cfg);
|
||||||
|
void init_session_data(struct session_data *sdata);
|
||||||
|
|
||||||
#ifndef _GNU_SOURCE
|
#ifndef _GNU_SOURCE
|
||||||
char *strcasestr(const char *s, const char *find);
|
char *strcasestr(const char *s, const char *find);
|
||||||
|
68
src/parser.c
68
src/parser.c
@ -18,13 +18,12 @@
|
|||||||
|
|
||||||
struct _state parse_message(struct session_data *sdata, struct __config *cfg){
|
struct _state parse_message(struct session_data *sdata, struct __config *cfg){
|
||||||
FILE *f;
|
FILE *f;
|
||||||
char *p, buf[MAXBUFSIZE];
|
char buf[MAXBUFSIZE];
|
||||||
struct _state state;
|
struct _state state;
|
||||||
int i, len;
|
|
||||||
|
|
||||||
init_state(&state);
|
init_state(&state);
|
||||||
|
|
||||||
f = fopen(sdata->ttmpfile, "r");
|
f = fopen(sdata->filename, "r");
|
||||||
if(!f){
|
if(!f){
|
||||||
syslog(LOG_PRIORITY, "%s: cannot open", sdata->ttmpfile);
|
syslog(LOG_PRIORITY, "%s: cannot open", sdata->ttmpfile);
|
||||||
return state;
|
return state;
|
||||||
@ -34,6 +33,7 @@ struct _state parse_message(struct session_data *sdata, struct __config *cfg){
|
|||||||
state.mfd = open(sdata->tmpframe, O_CREAT|O_RDWR, S_IRUSR|S_IWUSR);
|
state.mfd = open(sdata->tmpframe, O_CREAT|O_RDWR, S_IRUSR|S_IWUSR);
|
||||||
if(state.mfd == -1){
|
if(state.mfd == -1){
|
||||||
syslog(LOG_PRIORITY, "%s: cannot open frame file: %s", sdata->ttmpfile, sdata->tmpframe);
|
syslog(LOG_PRIORITY, "%s: cannot open frame file: %s", sdata->ttmpfile, sdata->tmpframe);
|
||||||
|
fclose(f);
|
||||||
return state;
|
return state;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -45,38 +45,52 @@ struct _state parse_message(struct session_data *sdata, struct __config *cfg){
|
|||||||
close(state.mfd); state.mfd = 0;
|
close(state.mfd); state.mfd = 0;
|
||||||
fclose(f);
|
fclose(f);
|
||||||
|
|
||||||
|
return state;
|
||||||
free_list(state.boundaries);
|
}
|
||||||
free_list(state.rcpt);
|
|
||||||
|
|
||||||
trimBuffer(state.b_subject);
|
|
||||||
fixupEncodedHeaderLine(state.b_subject);
|
|
||||||
|
|
||||||
|
|
||||||
for(i=1; i<=state.n_attachments; i++){
|
void post_parse(struct session_data *sdata, struct _state *state, struct __config *cfg){
|
||||||
digest_file(state.attachments[i].internalname, &(state.attachments[i].digest[0]));
|
int i, len;
|
||||||
fixupEncodedHeaderLine(state.attachments[i].filename);
|
char *p;
|
||||||
|
|
||||||
if(cfg->verbosity >= _LOG_DEBUG) syslog(LOG_PRIORITY, "%s: attachment list: i:%d, name=*%s*, type: *%s*, size: %d, int.name: %s, digest: %s", sdata->ttmpfile, i, state.attachments[i].filename, state.attachments[i].type, state.attachments[i].size, state.attachments[i].internalname, state.attachments[i].digest);
|
free_list(state->boundaries);
|
||||||
|
free_list(state->rcpt);
|
||||||
|
|
||||||
p = determine_attachment_type(state.attachments[i].filename, state.attachments[i].type);
|
trimBuffer(state->b_subject);
|
||||||
len = strlen(p);
|
fixupEncodedHeaderLine(state->b_subject);
|
||||||
|
|
||||||
if(strlen(sdata->attachments) < SMALLBUFSIZE-len-1) memcpy(&(sdata->attachments[strlen(sdata->attachments)]), p, len);
|
|
||||||
|
if(sdata->internal_sender == 0) sdata->direction = DIRECTION_INCOMING;
|
||||||
|
else {
|
||||||
|
if(sdata->internal_recipient == 1) sdata->direction = DIRECTION_INTERNAL;
|
||||||
|
if(sdata->external_recipient == 1) sdata->direction = DIRECTION_OUTGOING;
|
||||||
|
if(sdata->internal_recipient == 1 && sdata->external_recipient == 1) sdata->direction = DIRECTION_INTERNAL_AND_OUTGOING;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
if(state.message_id[0] == 0) snprintf(state.message_id, SMALLBUFSIZE-1, "null");
|
for(i=1; i<=state->n_attachments; i++){
|
||||||
|
digest_file(state->attachments[i].internalname, &(state->attachments[i].digest[0]));
|
||||||
|
fixupEncodedHeaderLine(state->attachments[i].filename);
|
||||||
|
|
||||||
len = strlen(state.b_from);
|
if(cfg->verbosity >= _LOG_DEBUG) syslog(LOG_PRIORITY, "%s: attachment list: i:%d, name=*%s*, type: *%s*, size: %d, int.name: %s, digest: %s", sdata->ttmpfile, i, state->attachments[i].filename, state->attachments[i].type, state->attachments[i].size, state->attachments[i].internalname, state->attachments[i].digest);
|
||||||
if(state.b_from[len-1] == ' ') state.b_from[len-1] = '\0';
|
|
||||||
|
|
||||||
len = strlen(state.b_to);
|
p = determine_attachment_type(state->attachments[i].filename, state->attachments[i].type);
|
||||||
if(state.b_to[len-1] == ' ') state.b_to[len-1] = '\0';
|
len = strlen(p);
|
||||||
|
|
||||||
syslog(LOG_PRIORITY, "%s: from=%s, to=%s, subj=%s, message-id=%s", sdata->ttmpfile, state.b_from, state.b_to, state.b_subject, state.message_id);
|
if(strlen(sdata->attachments) < SMALLBUFSIZE-len-1 && !strstr(sdata->attachments, p)) memcpy(&(sdata->attachments[strlen(sdata->attachments)]), p, len);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
if(state->message_id[0] == 0) snprintf(state->message_id, SMALLBUFSIZE-1, "null");
|
||||||
|
|
||||||
|
len = strlen(state->b_from);
|
||||||
|
if(state->b_from[len-1] == ' ') state->b_from[len-1] = '\0';
|
||||||
|
|
||||||
|
len = strlen(state->b_to);
|
||||||
|
if(state->b_to[len-1] == ' ') state->b_to[len-1] = '\0';
|
||||||
|
|
||||||
|
syslog(LOG_PRIORITY, "%s: from=%s, to=%s, subj=%s, message-id=%s", sdata->ttmpfile, state->b_from, state->b_to, state->b_subject, state->message_id);
|
||||||
|
|
||||||
return state;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -384,14 +398,20 @@ int parse_line(char *buf, struct _state *state, struct session_data *sdata, stru
|
|||||||
|
|
||||||
len = strlen(puf);
|
len = strlen(puf);
|
||||||
|
|
||||||
if(state->message_state == MSG_FROM && strchr(puf, '@') && strlen(puf) > 5 && state->is_1st_header == 1 && state->b_from[0] == '\0' && strlen(state->b_from) < SMALLBUFSIZE-len-1)
|
if(state->message_state == MSG_FROM && strchr(puf, '@') && strlen(puf) > 5 && state->is_1st_header == 1 && state->b_from[0] == '\0' && strlen(state->b_from) < SMALLBUFSIZE-len-1){
|
||||||
memcpy(&(state->b_from[strlen(state->b_from)]), puf, len);
|
memcpy(&(state->b_from[strlen(state->b_from)]), puf, len);
|
||||||
|
|
||||||
|
if(is_email_address_on_my_domains(puf, cfg) == 1) sdata->internal_sender = 1;
|
||||||
|
}
|
||||||
else if((state->message_state == MSG_TO || state->message_state == MSG_CC) && state->is_1st_header == 1 && strchr(puf, '@') && strlen(puf) > 5 && strlen(state->b_to) < SMALLBUFSIZE-len-1){
|
else if((state->message_state == MSG_TO || state->message_state == MSG_CC) && state->is_1st_header == 1 && strchr(puf, '@') && strlen(puf) > 5 && strlen(state->b_to) < SMALLBUFSIZE-len-1){
|
||||||
|
|
||||||
if(is_string_on_list(state->rcpt, puf) == 0){
|
if(is_string_on_list(state->rcpt, puf) == 0){
|
||||||
append_list(&(state->rcpt), puf);
|
append_list(&(state->rcpt), puf);
|
||||||
memcpy(&(state->b_to[strlen(state->b_to)]), puf, len);
|
memcpy(&(state->b_to[strlen(state->b_to)]), puf, len);
|
||||||
|
|
||||||
|
if(is_email_address_on_my_domains(puf, cfg) == 1) sdata->internal_recipient = 1;
|
||||||
|
else sdata->external_recipient = 1;
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else if(state->message_state == MSG_BODY && strlen(state->b_body) < BIGBUFSIZE-len-1)
|
else if(state->message_state == MSG_BODY && strlen(state->b_body) < BIGBUFSIZE-len-1)
|
||||||
|
@ -10,6 +10,7 @@
|
|||||||
#include "defs.h"
|
#include "defs.h"
|
||||||
|
|
||||||
struct _state parse_message(struct session_data *sdata, struct __config *cfg);
|
struct _state parse_message(struct session_data *sdata, struct __config *cfg);
|
||||||
|
void post_parse(struct session_data *sdata, struct _state *state, struct __config *cfg);
|
||||||
int parse_line(char *buf, struct _state *state, struct session_data *sdata, struct __config *cfg);
|
int parse_line(char *buf, struct _state *state, struct session_data *sdata, struct __config *cfg);
|
||||||
|
|
||||||
void init_state(struct _state *state);
|
void init_state(struct _state *state);
|
||||||
|
@ -389,6 +389,8 @@ int main(int argc, char **argv){
|
|||||||
memset(sdata.ttmpfile, 0, sizeof(sdata.ttmpfile));
|
memset(sdata.ttmpfile, 0, sizeof(sdata.ttmpfile));
|
||||||
|
|
||||||
while((rc = read(0, sdata.ttmpfile, RND_STR_LEN+1)) > 0){
|
while((rc = read(0, sdata.ttmpfile, RND_STR_LEN+1)) > 0){
|
||||||
|
snprintf(sdata.filename, SMALLBUFSIZE-1, "%s", sdata.ttmpfile);
|
||||||
|
|
||||||
trimBuffer(sdata.ttmpfile);
|
trimBuffer(sdata.ttmpfile);
|
||||||
|
|
||||||
id = get_id_by_piler_id(&sdata, &digest[0], &bodydigest[0], &cfg);
|
id = get_id_by_piler_id(&sdata, &digest[0], &bodydigest[0], &cfg);
|
||||||
@ -420,6 +422,7 @@ int main(int argc, char **argv){
|
|||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
snprintf(sdata.ttmpfile, SMALLBUFSIZE-1, "%s", argv[1]);
|
snprintf(sdata.ttmpfile, SMALLBUFSIZE-1, "%s", argv[1]);
|
||||||
|
snprintf(sdata.filename, SMALLBUFSIZE-1, "%s", sdata.ttmpfile);
|
||||||
rc = retrieve_email_from_archive(&sdata, stdout, &cfg);
|
rc = retrieve_email_from_archive(&sdata, stdout, &cfg);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -8,7 +8,7 @@
|
|||||||
#include <sys/time.h>
|
#include <sys/time.h>
|
||||||
#include <sys/types.h>
|
#include <sys/types.h>
|
||||||
#include <sys/stat.h>
|
#include <sys/stat.h>
|
||||||
#include <sys/stat.h>
|
#include <dirent.h>
|
||||||
#include <unistd.h>
|
#include <unistd.h>
|
||||||
#include <time.h>
|
#include <time.h>
|
||||||
#include <locale.h>
|
#include <locale.h>
|
||||||
@ -16,8 +16,12 @@
|
|||||||
#include <piler.h>
|
#include <piler.h>
|
||||||
|
|
||||||
|
|
||||||
|
extern char *optarg;
|
||||||
|
extern int optind;
|
||||||
|
|
||||||
|
|
||||||
int import_message(char *filename, struct session_data *sdata, struct __data *data, struct __config *cfg){
|
int import_message(char *filename, struct session_data *sdata, struct __data *data, struct __config *cfg){
|
||||||
int i, rc=ERR;
|
int rc=ERR;
|
||||||
char *rule;
|
char *rule;
|
||||||
struct stat st;
|
struct stat st;
|
||||||
struct _state state;
|
struct _state state;
|
||||||
@ -27,25 +31,32 @@ int import_message(char *filename, struct session_data *sdata, struct __data *da
|
|||||||
return rc;
|
return rc;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if(S_ISREG(st.st_mode) == 0){
|
||||||
|
printf("%s is not a file\n", filename);
|
||||||
|
return rc;
|
||||||
|
}
|
||||||
|
|
||||||
create_id(&(sdata->ttmpfile[0]));
|
|
||||||
|
|
||||||
printf("a: %s\n", sdata->ttmpfile);
|
init_session_data(sdata);
|
||||||
|
snprintf(sdata->filename, SMALLBUFSIZE-1, "%s", filename);
|
||||||
|
|
||||||
link(filename, sdata->ttmpfile);
|
|
||||||
|
|
||||||
sdata->num_of_rcpt_to = -1;
|
|
||||||
memset(sdata->rcptto[0], 0, SMALLBUFSIZE);
|
|
||||||
|
|
||||||
time(&(sdata->now));
|
|
||||||
sdata->sent = 0;
|
sdata->sent = 0;
|
||||||
sdata->hdr_len = 0;
|
|
||||||
sdata->tot_len = st.st_size;
|
sdata->tot_len = st.st_size;
|
||||||
memset(sdata->attachments, 0, SMALLBUFSIZE);
|
|
||||||
|
|
||||||
snprintf(sdata->tmpframe, SMALLBUFSIZE-1, "%s.m", sdata->ttmpfile);
|
|
||||||
|
|
||||||
state = parse_message(sdata, cfg);
|
state = parse_message(sdata, cfg);
|
||||||
|
post_parse(sdata, &state, cfg);
|
||||||
|
|
||||||
|
if(sdata->sent > sdata->now) sdata->sent = sdata->now;
|
||||||
|
|
||||||
|
/*printf("message-id: %s\n", state.message_id);
|
||||||
|
printf("from: *%s*\n", state.b_from);
|
||||||
|
printf("to: *%s*\n", state.b_to);
|
||||||
|
printf("subject: *%s*\n", state.b_subject);
|
||||||
|
printf("attachments:%s\n", sdata->attachments);
|
||||||
|
printf("direction: %d\n", sdata->direction);*/
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
rule = check_againt_ruleset(data->rules, &state, st.st_size);
|
rule = check_againt_ruleset(data->rules, &state, st.st_size);
|
||||||
|
|
||||||
@ -55,54 +66,157 @@ int import_message(char *filename, struct session_data *sdata, struct __data *da
|
|||||||
goto ENDE;
|
goto ENDE;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
printf("message-id: %s\n", state.message_id);
|
|
||||||
printf("from: *%s*\n", state.b_from);
|
|
||||||
printf("to: *%s*\n", state.b_to);
|
|
||||||
printf("subject: *%s*\n", state.b_subject);
|
|
||||||
|
|
||||||
make_digests(sdata, cfg);
|
make_digests(sdata, cfg);
|
||||||
|
|
||||||
printf("hdr len: %d\n", sdata->hdr_len);
|
|
||||||
|
|
||||||
printf("body digest: %s\n", sdata->bodydigest);
|
|
||||||
|
|
||||||
for(i=1; i<=state.n_attachments; i++){
|
|
||||||
printf("i:%d, name=*%s*, type: *%s*, size: %d, int.name: %s, digest: %s\n", i, state.attachments[i].filename, state.attachments[i].type, state.attachments[i].size, state.attachments[i].internalname, state.attachments[i].digest);
|
|
||||||
}
|
|
||||||
|
|
||||||
printf("attachments:%s\n", sdata->attachments);
|
|
||||||
|
|
||||||
printf("\n\n");
|
|
||||||
|
|
||||||
rc = processMessage(sdata, &state, cfg);
|
rc = processMessage(sdata, &state, cfg);
|
||||||
|
|
||||||
ENDE:
|
ENDE:
|
||||||
unlink(sdata->ttmpfile);
|
|
||||||
unlink(sdata->tmpframe);
|
unlink(sdata->tmpframe);
|
||||||
|
|
||||||
if(rc == ERR) return rc;
|
switch(rc) {
|
||||||
|
case OK:
|
||||||
|
printf("imported: %s\n", filename);
|
||||||
|
break;
|
||||||
|
|
||||||
if(rc == ERR_EXISTS) printf("discarding duplicate message: %s\n", sdata->ttmpfile);
|
case ERR_EXISTS:
|
||||||
|
printf("discarding duplicate message: %s\n", filename);
|
||||||
|
break;
|
||||||
|
|
||||||
|
default:
|
||||||
|
printf("failed to import: %s\n", filename);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
printf("\n\n");
|
||||||
|
|
||||||
|
return rc;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
return OK;
|
int import_from_mailbox(char *mailbox, struct session_data *sdata, struct __data *data, struct __config *cfg){
|
||||||
|
FILE *F, *f=NULL;
|
||||||
|
int rc=ERR, tot_msgs=0;
|
||||||
|
char buf[MAXBUFSIZE], fname[SMALLBUFSIZE];
|
||||||
|
time_t t;
|
||||||
|
|
||||||
|
|
||||||
|
F = fopen(mailbox, "r");
|
||||||
|
if(!F){
|
||||||
|
printf("cannot open mailbox: %s\n", mailbox);
|
||||||
|
return rc;
|
||||||
|
}
|
||||||
|
|
||||||
|
t = time(NULL);
|
||||||
|
|
||||||
|
while(fgets(buf, sizeof(buf)-1, F)){
|
||||||
|
|
||||||
|
if(buf[0] == 'F' && buf[1] == 'r' && buf[2] == 'o' && buf[3] == 'm' && buf[4] == ' '){
|
||||||
|
tot_msgs++;
|
||||||
|
if(f){
|
||||||
|
fclose(f);
|
||||||
|
rc = import_message(fname, sdata, data, cfg);
|
||||||
|
unlink(fname);
|
||||||
|
}
|
||||||
|
|
||||||
|
snprintf(fname, sizeof(fname)-1, "%ld-%d", t, tot_msgs);
|
||||||
|
f = fopen(fname, "w+");
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
if(f) fprintf(f, "%s", buf);
|
||||||
|
}
|
||||||
|
|
||||||
|
if(f){
|
||||||
|
fclose(f);
|
||||||
|
rc = import_message(fname, sdata, data, cfg);
|
||||||
|
unlink(fname);
|
||||||
|
}
|
||||||
|
|
||||||
|
fclose(F);
|
||||||
|
|
||||||
|
|
||||||
|
return rc;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
int import_from_maildir(char *directory, struct session_data *sdata, struct __data *data, struct __config *cfg){
|
||||||
|
DIR *dir;
|
||||||
|
struct dirent *de;
|
||||||
|
int rc=ERR, tot_msgs=0;
|
||||||
|
char fname[SMALLBUFSIZE];
|
||||||
|
|
||||||
|
dir = opendir(directory);
|
||||||
|
if(!dir){
|
||||||
|
printf("cannot open directory: %s\n", directory);
|
||||||
|
return rc;
|
||||||
|
}
|
||||||
|
|
||||||
|
while((de = readdir(dir))){
|
||||||
|
if(strcmp(de->d_name, ".") == 0 || strcmp(de->d_name, "..") == 0) continue;
|
||||||
|
|
||||||
|
snprintf(fname, sizeof(fname)-1, "%s/%s", directory, de->d_name);
|
||||||
|
|
||||||
|
rc = import_message(fname, sdata, data, cfg);
|
||||||
|
|
||||||
|
if(rc != ERR) tot_msgs++;
|
||||||
|
|
||||||
|
}
|
||||||
|
closedir(dir);
|
||||||
|
|
||||||
|
return rc;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void usage(){
|
||||||
|
printf("usage: pilerimport -e <eml file> -m <mailbox file> -d <directory>\n");
|
||||||
|
exit(0);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
int main(int argc, char **argv){
|
int main(int argc, char **argv){
|
||||||
int rc;
|
int i, rc;
|
||||||
|
char *configfile=CONFIG_FILE, *mailbox=NULL, *emlfile=NULL, *directory=NULL;
|
||||||
struct session_data sdata;
|
struct session_data sdata;
|
||||||
struct __config cfg;
|
struct __config cfg;
|
||||||
struct __data data;
|
struct __data data;
|
||||||
|
|
||||||
|
|
||||||
if(argc < 2){
|
while((i = getopt(argc, argv, "c:m:e:d:h?")) > 0){
|
||||||
printf("usage: %s <message>\n", argv[0]);
|
switch(i){
|
||||||
exit(1);
|
|
||||||
|
case 'c' :
|
||||||
|
configfile = optarg;
|
||||||
|
break;
|
||||||
|
|
||||||
|
case 'e' :
|
||||||
|
emlfile = optarg;
|
||||||
|
break;
|
||||||
|
|
||||||
|
case 'd' :
|
||||||
|
directory = optarg;
|
||||||
|
break;
|
||||||
|
|
||||||
|
case 'm' :
|
||||||
|
mailbox = optarg;
|
||||||
|
break;
|
||||||
|
|
||||||
|
case 'h' :
|
||||||
|
case '?' :
|
||||||
|
usage();
|
||||||
|
break;
|
||||||
|
|
||||||
|
|
||||||
|
default :
|
||||||
|
break;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
cfg = read_config(CONFIG_FILE);
|
|
||||||
|
|
||||||
|
if(!mailbox && !emlfile && !directory) usage();
|
||||||
|
|
||||||
|
|
||||||
|
cfg = read_config(configfile);
|
||||||
|
|
||||||
if(read_key(&cfg)){
|
if(read_key(&cfg)){
|
||||||
printf("%s\n", ERR_READING_KEY);
|
printf("%s\n", ERR_READING_KEY);
|
||||||
@ -119,7 +233,6 @@ int main(int argc, char **argv){
|
|||||||
mysql_real_query(&(sdata.mysql), "SET NAMES utf8", strlen("SET NAMES utf8"));
|
mysql_real_query(&(sdata.mysql), "SET NAMES utf8", strlen("SET NAMES utf8"));
|
||||||
mysql_real_query(&(sdata.mysql), "SET CHARACTER SET utf8", strlen("SET CHARACTER SET utf8"));
|
mysql_real_query(&(sdata.mysql), "SET CHARACTER SET utf8", strlen("SET CHARACTER SET utf8"));
|
||||||
|
|
||||||
printf("locale: %s\n", setlocale(LC_MESSAGES, cfg.locale));
|
|
||||||
setlocale(LC_CTYPE, cfg.locale);
|
setlocale(LC_CTYPE, cfg.locale);
|
||||||
|
|
||||||
data.rules = NULL;
|
data.rules = NULL;
|
||||||
@ -128,7 +241,9 @@ int main(int argc, char **argv){
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
rc = import_message(argv[1], &sdata, &data, &cfg);
|
if(emlfile) rc = import_message(emlfile, &sdata, &data, &cfg);
|
||||||
|
if(mailbox) rc = import_from_mailbox(mailbox, &sdata, &data, &cfg);
|
||||||
|
if(directory) rc = import_from_maildir(directory, &sdata, &data, &cfg);
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
@ -36,7 +36,7 @@ void handle_smtp_session(int new_sd, struct __data *data, struct __config *cfg){
|
|||||||
|
|
||||||
state = SMTP_STATE_INIT;
|
state = SMTP_STATE_INIT;
|
||||||
|
|
||||||
initSessionData(&sdata);
|
init_session_data(&sdata);
|
||||||
|
|
||||||
bzero(&counters, sizeof(counters));
|
bzero(&counters, sizeof(counters));
|
||||||
|
|
||||||
@ -141,7 +141,10 @@ void handle_smtp_session(int new_sd, struct __data *data, struct __config *cfg){
|
|||||||
|
|
||||||
|
|
||||||
gettimeofday(&tv1, &tz);
|
gettimeofday(&tv1, &tz);
|
||||||
|
|
||||||
sstate = parse_message(&sdata, cfg);
|
sstate = parse_message(&sdata, cfg);
|
||||||
|
post_parse(&sdata, &sstate, cfg);
|
||||||
|
|
||||||
gettimeofday(&tv2, &tz);
|
gettimeofday(&tv2, &tz);
|
||||||
sdata.__parsed = tvdiff(tv2, tv1);
|
sdata.__parsed = tvdiff(tv2, tv1);
|
||||||
|
|
||||||
@ -378,7 +381,7 @@ AFTER_PERIOD:
|
|||||||
strncat(resp, SMTP_RESP_503_ERR, MAXBUFSIZE-1);
|
strncat(resp, SMTP_RESP_503_ERR, MAXBUFSIZE-1);
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
sdata.fd = open(sdata.ttmpfile, O_CREAT|O_RDWR, S_IRUSR|S_IWUSR|S_IRGRP);
|
sdata.fd = open(sdata.filename, O_CREAT|O_RDWR, S_IRUSR|S_IWUSR|S_IRGRP);
|
||||||
if(sdata.fd == -1){
|
if(sdata.fd == -1){
|
||||||
syslog(LOG_PRIORITY, "%s: %s", ERR_OPEN_TMP_FILE, sdata.ttmpfile);
|
syslog(LOG_PRIORITY, "%s: %s", ERR_OPEN_TMP_FILE, sdata.ttmpfile);
|
||||||
strncat(resp, SMTP_RESP_451_ERR, MAXBUFSIZE-1);
|
strncat(resp, SMTP_RESP_451_ERR, MAXBUFSIZE-1);
|
||||||
@ -424,7 +427,7 @@ AFTER_PERIOD:
|
|||||||
unlink(sdata.ttmpfile);
|
unlink(sdata.ttmpfile);
|
||||||
unlink(sdata.tmpframe);
|
unlink(sdata.tmpframe);
|
||||||
|
|
||||||
initSessionData(&sdata);
|
init_session_data(&sdata);
|
||||||
|
|
||||||
state = SMTP_STATE_HELO;
|
state = SMTP_STATE_HELO;
|
||||||
|
|
||||||
@ -487,39 +490,3 @@ void killChild(){
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
void initSessionData(struct session_data *sdata){
|
|
||||||
int i;
|
|
||||||
|
|
||||||
|
|
||||||
sdata->fd = -1;
|
|
||||||
|
|
||||||
create_id(&(sdata->ttmpfile[0]));
|
|
||||||
unlink(sdata->ttmpfile);
|
|
||||||
|
|
||||||
snprintf(sdata->tmpframe, SMALLBUFSIZE-1, "%s.m", sdata->ttmpfile);
|
|
||||||
unlink(sdata->tmpframe);
|
|
||||||
|
|
||||||
memset(sdata->mailfrom, 0, SMALLBUFSIZE);
|
|
||||||
snprintf(sdata->client_addr, SMALLBUFSIZE-1, "null");
|
|
||||||
|
|
||||||
memset(sdata->attachments, 0, SMALLBUFSIZE);
|
|
||||||
|
|
||||||
sdata->restored_copy = 0;
|
|
||||||
|
|
||||||
sdata->hdr_len = 0;
|
|
||||||
sdata->tot_len = 0;
|
|
||||||
sdata->num_of_rcpt_to = 0;
|
|
||||||
|
|
||||||
sdata->tre = '-';
|
|
||||||
|
|
||||||
sdata->rav = AVIR_OK;
|
|
||||||
|
|
||||||
sdata->__acquire = sdata->__parsed = sdata->__av = sdata->__store = sdata->__compress = sdata->__encrypt = 0;
|
|
||||||
|
|
||||||
|
|
||||||
for(i=0; i<MAX_RCPT_TO; i++) memset(sdata->rcptto[i], 0, SMALLBUFSIZE);
|
|
||||||
|
|
||||||
time(&(sdata->now));
|
|
||||||
sdata->sent = sdata->now;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
12
src/test.c
12
src/test.c
@ -57,17 +57,17 @@ int main(int argc, char **argv){
|
|||||||
|
|
||||||
rc = 0;
|
rc = 0;
|
||||||
|
|
||||||
sdata.num_of_rcpt_to = -1;
|
init_session_data(&sdata);
|
||||||
time(&(sdata.now));
|
|
||||||
sdata.sent = 0;
|
sdata.sent = 0;
|
||||||
sdata.tot_len = st.st_size;
|
sdata.tot_len = st.st_size;
|
||||||
memset(sdata.rcptto[0], 0, SMALLBUFSIZE);
|
|
||||||
memset(sdata.attachments, 0, SMALLBUFSIZE);
|
|
||||||
snprintf(sdata.ttmpfile, SMALLBUFSIZE-1, "%s", argv[1]);
|
snprintf(sdata.ttmpfile, SMALLBUFSIZE-1, "%s", argv[1]);
|
||||||
|
snprintf(sdata.filename, SMALLBUFSIZE-1, "%s", argv[1]);
|
||||||
snprintf(sdata.tmpframe, SMALLBUFSIZE-1, "%s.m", argv[1]);
|
snprintf(sdata.tmpframe, SMALLBUFSIZE-1, "%s.m", argv[1]);
|
||||||
|
|
||||||
|
|
||||||
state = parse_message(&sdata, &cfg);
|
state = parse_message(&sdata, &cfg);
|
||||||
|
post_parse(&sdata, &state, &cfg);
|
||||||
|
|
||||||
printf("message-id: %s\n", state.message_id);
|
printf("message-id: %s\n", state.message_id);
|
||||||
printf("from: *%s*\n", state.b_from);
|
printf("from: *%s*\n", state.b_from);
|
||||||
@ -93,6 +93,8 @@ int main(int argc, char **argv){
|
|||||||
|
|
||||||
printf("attachments:%s\n", sdata.attachments);
|
printf("attachments:%s\n", sdata.attachments);
|
||||||
|
|
||||||
|
printf("direction: %d\n", sdata.direction);
|
||||||
|
|
||||||
printf("\n\n");
|
printf("\n\n");
|
||||||
|
|
||||||
mysql_close(&(sdata.mysql));
|
mysql_close(&(sdata.mysql));
|
||||||
|
@ -20,6 +20,7 @@ create table if not exists `sph_index` (
|
|||||||
`sent` int not null,
|
`sent` int not null,
|
||||||
`body` text,
|
`body` text,
|
||||||
`size` int default '0',
|
`size` int default '0',
|
||||||
|
`direction` int default 0,
|
||||||
`attachments` int default 0,
|
`attachments` int default 0,
|
||||||
`attachment_types` text(512) default null,
|
`attachment_types` text(512) default null,
|
||||||
primary key (`id`)
|
primary key (`id`)
|
||||||
@ -36,6 +37,7 @@ create table if not exists `metadata` (
|
|||||||
`deleted` tinyint(1) default 0,
|
`deleted` tinyint(1) default 0,
|
||||||
`size` int default 0,
|
`size` int default 0,
|
||||||
`hlen` int default 0,
|
`hlen` int default 0,
|
||||||
|
`direction` int default 0,
|
||||||
`attachments` int default 0,
|
`attachments` int default 0,
|
||||||
`piler_id` char(36) not null,
|
`piler_id` char(36) not null,
|
||||||
`message_id` char(128) character set 'latin1' not null,
|
`message_id` char(128) character set 'latin1' not null,
|
||||||
@ -62,7 +64,7 @@ create index `rcpt_idx2` on `rcpt`(`to`);
|
|||||||
|
|
||||||
|
|
||||||
drop view if exists `messages`;
|
drop view if exists `messages`;
|
||||||
create view `messages` AS select `metadata`.`id` AS `id`,`metadata`.`piler_id` AS `piler_id`,`metadata`.`from` AS `from`,`rcpt`.`to` AS `to`,`metadata`.`subject` AS `subject`, `metadata`.`size` AS `size`, `metadata`.`arrived` AS `arrived` from (`metadata` join `rcpt`) where (`metadata`.`id` = `rcpt`.`id`);
|
create view `messages` AS select `metadata`.`id` AS `id`,`metadata`.`piler_id` AS `piler_id`,`metadata`.`from` AS `from`,`rcpt`.`to` AS `to`,`metadata`.`subject` AS `subject`, `metadata`.`size` AS `size`, `metadata`.`direction` AS `direction`, `metadata`.`arrived` AS `arrived` from (`metadata` join `rcpt`) where (`metadata`.`id` = `rcpt`.`id`);
|
||||||
|
|
||||||
drop table if exists `attachment`;
|
drop table if exists `attachment`;
|
||||||
create table if not exists `attachment` (
|
create table if not exists `attachment` (
|
||||||
@ -150,7 +152,7 @@ create table if not exists `user_settings` (
|
|||||||
create index `user_settings_idx` on `user_settings`(`username`);
|
create index `user_settings_idx` on `user_settings`(`username`);
|
||||||
|
|
||||||
|
|
||||||
|
drop table if exists `user`;
|
||||||
create table if not exists `user` (
|
create table if not exists `user` (
|
||||||
`uid` int unsigned not null primary key,
|
`uid` int unsigned not null primary key,
|
||||||
`gid` int unsigned not null,
|
`gid` int unsigned not null,
|
||||||
@ -165,6 +167,7 @@ create table if not exists `user` (
|
|||||||
|
|
||||||
insert into `user` (`uid`, `gid`, `username`, `realname`, `password`, `policy_group`, `isadmin`, `domain`) values (0, 0, 'admin', 'built-in piler admin', '$1$PItc7d$zsUgON3JRrbdGS11t9JQW1', 0, 1, 'local');
|
insert into `user` (`uid`, `gid`, `username`, `realname`, `password`, `policy_group`, `isadmin`, `domain`) values (0, 0, 'admin', 'built-in piler admin', '$1$PItc7d$zsUgON3JRrbdGS11t9JQW1', 0, 1, 'local');
|
||||||
|
|
||||||
|
drop table if exists `email`;
|
||||||
create table if not exists `email` (
|
create table if not exists `email` (
|
||||||
`uid` int unsigned not null,
|
`uid` int unsigned not null,
|
||||||
`email` char(128) not null primary key
|
`email` char(128) not null primary key
|
||||||
@ -190,6 +193,7 @@ create table if not exists `remote` (
|
|||||||
) ENGINE=InnoDB;
|
) ENGINE=InnoDB;
|
||||||
|
|
||||||
|
|
||||||
|
drop table if exists `domain`;
|
||||||
create table if not exists `domain` (
|
create table if not exists `domain` (
|
||||||
`domain` char(64) not null primary key,
|
`domain` char(64) not null primary key,
|
||||||
`mapped` char(64) not null
|
`mapped` char(64) not null
|
||||||
|
Loading…
Reference in New Issue
Block a user