mirror of
https://bitbucket.org/jsuto/piler.git
synced 2025-01-12 05:10:12 +01:00
internal date fix
This commit is contained in:
parent
bb62920db8
commit
8bf89488bf
@ -14,7 +14,7 @@
|
|||||||
|
|
||||||
#define VERSION "1.2.0-master"
|
#define VERSION "1.2.0-master"
|
||||||
|
|
||||||
#define BUILD 923
|
#define BUILD 924
|
||||||
|
|
||||||
#define HOSTID "mailarchiver"
|
#define HOSTID "mailarchiver"
|
||||||
|
|
||||||
|
@ -226,8 +226,7 @@ struct session_data {
|
|||||||
float __acquire, __parsed, __av, __store, __compress, __encrypt;
|
float __acquire, __parsed, __av, __store, __compress, __encrypt;
|
||||||
char bodydigest[2*DIGEST_LENGTH+1];
|
char bodydigest[2*DIGEST_LENGTH+1];
|
||||||
char digest[2*DIGEST_LENGTH+1];
|
char digest[2*DIGEST_LENGTH+1];
|
||||||
time_t now, sent, delivered;
|
time_t now, sent, delivered, retained;
|
||||||
unsigned long retained;
|
|
||||||
char ms_journal;
|
char ms_journal;
|
||||||
char import;
|
char import;
|
||||||
int journal_envelope_length, journal_bottom_length;
|
int journal_envelope_length, journal_bottom_length;
|
||||||
|
@ -14,7 +14,7 @@ void post_parse(struct session_data *sdata, struct _state *state, struct __confi
|
|||||||
int parse_line(char *buf, struct _state *state, struct session_data *sdata, int take_into_pieces, char *writebuffer, int writebuffersize, char *abuffer, int abuffersize, struct __data *data, struct __config *cfg);
|
int parse_line(char *buf, struct _state *state, struct session_data *sdata, int take_into_pieces, char *writebuffer, int writebuffersize, char *abuffer, int abuffersize, struct __data *data, struct __config *cfg);
|
||||||
|
|
||||||
void init_state(struct _state *state);
|
void init_state(struct _state *state);
|
||||||
unsigned long parse_date_header(char *s, struct __config *cfg);
|
time_t parse_date_header(char *s, struct __config *cfg);
|
||||||
int isHexNumber(char *p);
|
int isHexNumber(char *p);
|
||||||
int extract_boundary(char *p, struct _state *state);
|
int extract_boundary(char *p, struct _state *state);
|
||||||
void fixupEncodedHeaderLine(char *buf, int buflen);
|
void fixupEncodedHeaderLine(char *buf, int buflen);
|
||||||
|
@ -112,10 +112,10 @@ long get_local_timezone_offset(){
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
unsigned long parse_date_header(char *datestr, struct __config *cfg){
|
time_t parse_date_header(char *datestr, struct __config *cfg){
|
||||||
int n=0, len;
|
int n=0, len;
|
||||||
long offset=0;
|
long offset=0;
|
||||||
unsigned long ts=0;
|
time_t ts=0;
|
||||||
char *p, *q, *r, *tz, s[SMALLBUFSIZE], tzh[4], tzm[3];
|
char *p, *q, *r, *tz, s[SMALLBUFSIZE], tzh[4], tzm[3];
|
||||||
struct tm tm;
|
struct tm tm;
|
||||||
|
|
||||||
|
@ -249,7 +249,7 @@ char *check_againt_ruleset(struct node *xhash[], struct _state *state, int size,
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
unsigned long query_retain_period(struct __data *data, struct _state *state, int size, int spam, struct __config *cfg){
|
time_t query_retain_period(struct __data *data, struct _state *state, int size, int spam, struct __config *cfg){
|
||||||
size_t nmatch=0;
|
size_t nmatch=0;
|
||||||
struct rule *p;
|
struct rule *p;
|
||||||
struct node *q;
|
struct node *q;
|
||||||
@ -267,7 +267,7 @@ unsigned long query_retain_period(struct __data *data, struct _state *state, int
|
|||||||
if(p->domainlen > 2){
|
if(p->domainlen > 2){
|
||||||
if(strcasestr(state->b_to_domain, p->domain) || strcasestr(state->b_from_domain, p->domain)){
|
if(strcasestr(state->b_to_domain, p->domain) || strcasestr(state->b_from_domain, p->domain)){
|
||||||
state->retention = p->days;
|
state->retention = p->days;
|
||||||
return p->days * 86400;
|
return (time_t)p->days * (time_t)86400;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
@ -301,7 +301,7 @@ unsigned long query_retain_period(struct __data *data, struct _state *state, int
|
|||||||
|
|
||||||
if(ismatch > 0){
|
if(ismatch > 0){
|
||||||
state->retention = p->days;
|
state->retention = p->days;
|
||||||
return p->days * 86400;
|
return (time_t)p->days * (time_t)86400;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -313,7 +313,7 @@ unsigned long query_retain_period(struct __data *data, struct _state *state, int
|
|||||||
|
|
||||||
state->retention = cfg->default_retention_days;
|
state->retention = cfg->default_retention_days;
|
||||||
|
|
||||||
return cfg->default_retention_days * 86400;
|
return (time_t)cfg->default_retention_days * (time_t)86400;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -11,7 +11,7 @@ void load_rules(struct session_data *sdata, struct __data *data, struct node *xh
|
|||||||
int append_rule(struct node *xhash[], struct rule_cond *rule_cond, struct __data *data);
|
int append_rule(struct node *xhash[], struct rule_cond *rule_cond, struct __data *data);
|
||||||
struct rule *create_rule_item(struct rule_cond *rule_cond, struct __data *data);
|
struct rule *create_rule_item(struct rule_cond *rule_cond, struct __data *data);
|
||||||
char *check_againt_ruleset(struct node *xhash[], struct _state *state, int size, int spam);
|
char *check_againt_ruleset(struct node *xhash[], struct _state *state, int size, int spam);
|
||||||
unsigned long query_retain_period(struct __data *data, struct _state *state, int size, int spam, struct __config *cfg);
|
time_t query_retain_period(struct __data *data, struct _state *state, int size, int spam, struct __config *cfg);
|
||||||
int get_folder_id_by_rule(struct __data *data, struct _state *state, int size, int spam, struct __config *cfg);
|
int get_folder_id_by_rule(struct __data *data, struct _state *state, int size, int spam, struct __config *cfg);
|
||||||
int check_size_rule(int message_size, int size, char *_size);
|
int check_size_rule(int message_size, int size, char *_size);
|
||||||
int check_spam_rule(int is_spam, int spam);
|
int check_spam_rule(int is_spam, int spam);
|
||||||
|
@ -96,7 +96,7 @@ int main(int argc, char **argv){
|
|||||||
printf("subject: *%s*\n", state.b_subject);
|
printf("subject: *%s*\n", state.b_subject);
|
||||||
printf("body: *%s*\n", state.b_body);
|
printf("body: *%s*\n", state.b_body);
|
||||||
|
|
||||||
printf("sent: %ld, delivered-date: %ld\n", sdata.sent, sdata.delivered);
|
printf("sent: %lu, delivered-date: %lu\n", sdata.sent, sdata.delivered);
|
||||||
|
|
||||||
make_digests(&sdata, &cfg);
|
make_digests(&sdata, &cfg);
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user