mirror of
				https://bitbucket.org/jsuto/piler.git
				synced 2025-10-31 07:32:27 +01:00 
			
		
		
		
	improved import test
This commit is contained in:
		| @@ -21,10 +21,11 @@ LIBDIR = -L. @LIBDIR@ @LDFLAGS@ -L../../src | |||||||
| LIBS = @LIBS@ @mysql_libs@ | LIBS = @LIBS@ @mysql_libs@ | ||||||
| RUNNING_USER = @RUNNING_USER@ | RUNNING_USER = @RUNNING_USER@ | ||||||
| RUNNING_GROUP = `@id_bin@ -gn $(RUNNING_USER)` | RUNNING_GROUP = `@id_bin@ -gn $(RUNNING_USER)` | ||||||
|  | OBJS = import_helper.o | ||||||
|  |  | ||||||
| INSTALL = @INSTALL@ | INSTALL = @INSTALL@ | ||||||
|  |  | ||||||
| all: parser debug | all: $(OBJS) parser debug import | ||||||
|  |  | ||||||
| parser: parser.c ../src/libpiler.a | parser: parser.c ../src/libpiler.a | ||||||
| 	$(CC) $(CFLAGS) $(INCDIR) $(DEFS) -o $@ $^ -lpiler $(LIBS) $(LIBDIR) | 	$(CC) $(CFLAGS) $(INCDIR) $(DEFS) -o $@ $^ -lpiler $(LIBS) $(LIBDIR) | ||||||
| @@ -32,13 +33,18 @@ parser: parser.c ../src/libpiler.a | |||||||
| debug: debug.c ../src/libpiler.a | debug: debug.c ../src/libpiler.a | ||||||
| 	$(CC) $(CFLAGS) $(INCDIR) $(DEFS) -o $@ $^ -lpiler $(LIBS) $(LIBDIR) | 	$(CC) $(CFLAGS) $(INCDIR) $(DEFS) -o $@ $^ -lpiler $(LIBS) $(LIBDIR) | ||||||
|  |  | ||||||
|  | import: import.c ../src/libpiler.a | ||||||
|  | 	$(CC) $(CFLAGS) $(INCDIR) $(DEFS) -o $@ $^ -lpiler import_helper.o $(LIBS) $(LIBDIR) | ||||||
|  |  | ||||||
|  |  | ||||||
|  | %.o: $(srcdir)/%.c | ||||||
|  | 	$(CC) $(CFLAGS) -fPIC $(INCDIR) $(DEFS) -c $< -o $@ | ||||||
|  |  | ||||||
|  |  | ||||||
| install: | install: | ||||||
|  |  | ||||||
| test: |  | ||||||
| 	./parser |  | ||||||
|  |  | ||||||
| clean: | clean: | ||||||
| 	rm -f parser debug | 	rm -f parser debug import | ||||||
|  |  | ||||||
| distclean: clean | distclean: clean | ||||||
| 	rm -f Makefile | 	rm -f Makefile | ||||||
|   | |||||||
							
								
								
									
										248
									
								
								test/import.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										248
									
								
								test/import.c
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,248 @@ | |||||||
|  | /* | ||||||
|  |  * pilerimport.c, SJ | ||||||
|  |  */ | ||||||
|  |  | ||||||
|  | #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 <fcntl.h> | ||||||
|  | #include <dirent.h> | ||||||
|  | #include <unistd.h> | ||||||
|  | #include <time.h> | ||||||
|  | #include <locale.h> | ||||||
|  | #include <syslog.h> | ||||||
|  | #include <piler.h> | ||||||
|  |  | ||||||
|  |  | ||||||
|  | extern char *optarg; | ||||||
|  | extern int optind; | ||||||
|  |  | ||||||
|  |  | ||||||
|  | int connect_to_imap_server(int sd, int *seq, char *imapserver, char *username, char *password); | ||||||
|  | int list_folders(int sd, int *seq, char *folders, int foldersize); | ||||||
|  | int process_imap_folder(int sd, int *seq, char *folder, struct session_data *sdata, struct __data *data, struct __config *cfg); | ||||||
|  | int import_message2(char *filename, 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){ | ||||||
|  |    FILE *F, *f=NULL; | ||||||
|  |    int rc=ERR, tot_msgs=0, ret=OK; | ||||||
|  |    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_message2(fname, sdata, data, cfg); | ||||||
|  |             printf("processed: %7d\r", tot_msgs); fflush(stdout); | ||||||
|  |  | ||||||
|  |             if(rc == ERR) ret = ERR; | ||||||
|  |             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_message2(fname, sdata, data, cfg); | ||||||
|  |       printf("processed: %7d\r", tot_msgs); fflush(stdout); | ||||||
|  |  | ||||||
|  |       if(rc == ERR) ret = ERR; | ||||||
|  |       unlink(fname); | ||||||
|  |    } | ||||||
|  |  | ||||||
|  |    fclose(F); | ||||||
|  |  | ||||||
|  |    printf("\n"); | ||||||
|  |  | ||||||
|  |    return ret; | ||||||
|  | } | ||||||
|  |  | ||||||
|  |  | ||||||
|  | int import_from_maildir(char *directory, struct session_data *sdata, struct __data *data, struct __config *cfg){ | ||||||
|  |    DIR *dir; | ||||||
|  |    struct dirent *de; | ||||||
|  |    int rc=ERR, ret=OK, tot_msgs=0; | ||||||
|  |    char fname[SMALLBUFSIZE]; | ||||||
|  |    struct stat st; | ||||||
|  |  | ||||||
|  |    dir = opendir(directory); | ||||||
|  |    if(!dir){ | ||||||
|  |       printf("cannot open directory: %s\n", directory); | ||||||
|  |       return ERR; | ||||||
|  |    } | ||||||
|  |  | ||||||
|  |  | ||||||
|  |    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); | ||||||
|  |  | ||||||
|  |       if(stat(fname, &st) == 0){ | ||||||
|  |          if(S_ISDIR(st.st_mode)){ | ||||||
|  |             rc = import_from_maildir(fname, sdata, data, cfg); | ||||||
|  |             if(rc == ERR) ret = ERR; | ||||||
|  |          } | ||||||
|  |          else { | ||||||
|  |  | ||||||
|  |             if(S_ISREG(st.st_mode)){ | ||||||
|  |                rc = import_message2(fname, sdata, data, cfg); | ||||||
|  |                if(rc == OK) tot_msgs++; | ||||||
|  |                else ret = ERR; | ||||||
|  |             } | ||||||
|  |             else { | ||||||
|  |                printf("%s is not a file\n", fname); | ||||||
|  |             } | ||||||
|  |  | ||||||
|  |          } | ||||||
|  |       } | ||||||
|  |       else { | ||||||
|  |          printf("cannot stat() %s\n", fname); | ||||||
|  |       } | ||||||
|  |  | ||||||
|  |    } | ||||||
|  |    closedir(dir); | ||||||
|  |  | ||||||
|  |    return ret; | ||||||
|  | } | ||||||
|  |  | ||||||
|  |  | ||||||
|  | int import_from_imap_server(char *imapserver, char *username, char *password, struct session_data *sdata, struct __data *data, struct __config *cfg){ | ||||||
|  |    int rc=ERR, ret=OK, sd, seq=1; | ||||||
|  |    char *p, puf[MAXBUFSIZE]; | ||||||
|  |    char folders[MAXBUFSIZE]; | ||||||
|  |     | ||||||
|  |    if((sd = socket(AF_INET, SOCK_STREAM, 0)) == -1){ | ||||||
|  |       printf("cannot create socket\n"); | ||||||
|  |       return ERR; | ||||||
|  |    } | ||||||
|  |  | ||||||
|  |    if(connect_to_imap_server(sd, &seq, imapserver, username, password) == ERR){ | ||||||
|  |       close(sd); | ||||||
|  |       return ERR; | ||||||
|  |    } | ||||||
|  |  | ||||||
|  |  | ||||||
|  |    list_folders(sd, &seq, &folders[0], sizeof(folders)); | ||||||
|  |  | ||||||
|  |  | ||||||
|  |    p = &folders[0]; | ||||||
|  |    do { | ||||||
|  |       memset(puf, 0, sizeof(puf)); | ||||||
|  |       p = split(p, '\n', puf, sizeof(puf)-1); | ||||||
|  |  | ||||||
|  |       printf("processing folder: %s... ", puf); | ||||||
|  |  | ||||||
|  |       rc = process_imap_folder(sd, &seq, puf, sdata, data, cfg); | ||||||
|  |       if(rc == ERR) ret = ERR; | ||||||
|  |  | ||||||
|  |    } while(p); | ||||||
|  |  | ||||||
|  |  | ||||||
|  |    close(sd); | ||||||
|  |  | ||||||
|  |    return ret; | ||||||
|  | } | ||||||
|  |  | ||||||
|  |  | ||||||
|  | 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>\n"); | ||||||
|  |    exit(0); | ||||||
|  | } | ||||||
|  |  | ||||||
|  |  | ||||||
|  | int main(int argc, char **argv){ | ||||||
|  |    int i, rc=0; | ||||||
|  |    char *configfile=CONFIG_FILE, *mailbox=NULL, *emlfile=NULL, *directory=NULL; | ||||||
|  |    char *imapserver=NULL, *username=NULL, *password=NULL; | ||||||
|  |    struct session_data sdata; | ||||||
|  |    struct __config cfg; | ||||||
|  |    struct __data data; | ||||||
|  |  | ||||||
|  |  | ||||||
|  |    while((i = getopt(argc, argv, "c:m:e:d:i:u:p:h?")) > 0){ | ||||||
|  |        switch(i){ | ||||||
|  |  | ||||||
|  |          case 'c' : | ||||||
|  |                     configfile = optarg; | ||||||
|  |                     break; | ||||||
|  |  | ||||||
|  |          case 'e' : | ||||||
|  |                     emlfile = optarg; | ||||||
|  |                     break; | ||||||
|  |  | ||||||
|  |          case 'd' : | ||||||
|  |                     directory = optarg; | ||||||
|  |                     break; | ||||||
|  |  | ||||||
|  |          case 'm' : | ||||||
|  |                     mailbox = optarg; | ||||||
|  |                     break; | ||||||
|  |  | ||||||
|  |          case 'i' : | ||||||
|  |                     imapserver = optarg; | ||||||
|  |                     break; | ||||||
|  |  | ||||||
|  |          case 'u' : | ||||||
|  |                     username = optarg; | ||||||
|  |                     break; | ||||||
|  |  | ||||||
|  |          case 'p' : | ||||||
|  |                     password = optarg; | ||||||
|  |                     break; | ||||||
|  |  | ||||||
|  |          case 'h' : | ||||||
|  |          case '?' : | ||||||
|  |                     usage(); | ||||||
|  |                     break; | ||||||
|  |  | ||||||
|  |  | ||||||
|  |          default  :  | ||||||
|  |                     break; | ||||||
|  |        } | ||||||
|  |    } | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |    if(!mailbox && !emlfile && !directory && !imapserver) usage(); | ||||||
|  |  | ||||||
|  |  | ||||||
|  |    cfg = read_config(configfile); | ||||||
|  |  | ||||||
|  |    setlocale(LC_CTYPE, cfg.locale); | ||||||
|  |  | ||||||
|  |    data.archiving_rules = NULL; | ||||||
|  |    data.retention_rules = NULL; | ||||||
|  |  | ||||||
|  |    if(emlfile) rc = import_message2(emlfile, &sdata, &data, &cfg); | ||||||
|  |    if(mailbox) rc = import_from_mailbox(mailbox, &sdata, &data, &cfg); | ||||||
|  |    if(directory) rc = import_from_maildir(directory, &sdata, &data, &cfg); | ||||||
|  |    if(imapserver && username && password) rc = import_from_imap_server(imapserver, username, password, &sdata, &data, &cfg); | ||||||
|  |  | ||||||
|  |  | ||||||
|  |    return rc; | ||||||
|  | } | ||||||
|  |  | ||||||
|  |  | ||||||
							
								
								
									
										97
									
								
								test/import_helper.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										97
									
								
								test/import_helper.c
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,97 @@ | |||||||
|  | /* | ||||||
|  |  * import.c, SJ | ||||||
|  |  */ | ||||||
|  |  | ||||||
|  | #include <stdio.h> | ||||||
|  | #include <stdlib.h> | ||||||
|  | #include <string.h> | ||||||
|  | #include <sys/time.h> | ||||||
|  | #include <sys/types.h> | ||||||
|  | #include <sys/stat.h> | ||||||
|  | #include <fcntl.h> | ||||||
|  | #include <dirent.h> | ||||||
|  | #include <unistd.h> | ||||||
|  | #include <time.h> | ||||||
|  | #include <locale.h> | ||||||
|  | #include <syslog.h> | ||||||
|  | #include <piler.h> | ||||||
|  |  | ||||||
|  |  | ||||||
|  | int import_message2(char *filename, struct session_data *sdata, struct __data *data, struct __config *cfg){ | ||||||
|  |    int rc=ERR, i, fd; | ||||||
|  |    char *rule; | ||||||
|  |    struct stat st; | ||||||
|  |    struct _state state; | ||||||
|  |  | ||||||
|  |  | ||||||
|  |    init_session_data(sdata); | ||||||
|  |  | ||||||
|  |  | ||||||
|  |    if(strcmp(filename, "-") == 0){ | ||||||
|  |  | ||||||
|  |       if(read_from_stdin(sdata) == ERR){ | ||||||
|  |          printf("error reading from stdin\n"); | ||||||
|  |          return rc; | ||||||
|  |       } | ||||||
|  |  | ||||||
|  |       snprintf(sdata->filename, SMALLBUFSIZE-1, "%s", sdata->ttmpfile); | ||||||
|  |  | ||||||
|  |    } | ||||||
|  |    else { | ||||||
|  |  | ||||||
|  |       if(stat(filename, &st) != 0){ | ||||||
|  |          printf("cannot stat() %s\n", filename); | ||||||
|  |          return rc; | ||||||
|  |       } | ||||||
|  |  | ||||||
|  |       if(S_ISREG(st.st_mode) == 0){ | ||||||
|  |          printf("%s is not a file\n", filename); | ||||||
|  |          return rc; | ||||||
|  |       } | ||||||
|  |  | ||||||
|  |       fd = open(filename, O_RDONLY); | ||||||
|  |       if(fd == -1){ | ||||||
|  |          printf("cannot open %s\n", filename); | ||||||
|  |          return rc; | ||||||
|  |       } | ||||||
|  |       close(fd); | ||||||
|  |  | ||||||
|  |       snprintf(sdata->filename, SMALLBUFSIZE-1, "%s", filename); | ||||||
|  |  | ||||||
|  |       sdata->tot_len = st.st_size; | ||||||
|  |    } | ||||||
|  |  | ||||||
|  |  | ||||||
|  |     | ||||||
|  |    sdata->sent = 0; | ||||||
|  |  | ||||||
|  |    state = parse_message(sdata, 1, cfg); | ||||||
|  |    post_parse(sdata, &state, cfg); | ||||||
|  |  | ||||||
|  |    if(sdata->sent > sdata->now) sdata->sent = sdata->now; | ||||||
|  |    if(sdata->sent == -1) sdata->sent = 0; | ||||||
|  |  | ||||||
|  |    /* fat chances that you won't import emails before 1990.01.01 */ | ||||||
|  |  | ||||||
|  |    if(sdata->sent > 631148400) sdata->retained = sdata->sent; | ||||||
|  |  | ||||||
|  |    rule = check_againt_ruleset(data->archiving_rules, &state, sdata->tot_len, sdata->spam_message); | ||||||
|  |  | ||||||
|  |    if(rule){ | ||||||
|  |       printf("discarding %s by archiving policy: %s\n", filename, rule); | ||||||
|  |       rc = OK; | ||||||
|  |       goto ENDE; | ||||||
|  |    } | ||||||
|  |  | ||||||
|  |    make_digests(sdata, cfg); | ||||||
|  |  | ||||||
|  | ENDE: | ||||||
|  |    unlink(sdata->tmpframe); | ||||||
|  |  | ||||||
|  |    if(strcmp(filename, "-") == 0) unlink(sdata->ttmpfile); | ||||||
|  |  | ||||||
|  |    for(i=1; i<=state.n_attachments; i++) unlink(state.attachments[i].internalname); | ||||||
|  |  | ||||||
|  |    return OK; | ||||||
|  | } | ||||||
|  |  | ||||||
		Reference in New Issue
	
	Block a user