mirror of
				https://bitbucket.org/jsuto/piler.git
				synced 2025-10-26 02:52:26 +02:00 
			
		
		
		
	Introduced -Z option for pilerimport to add delay between importing emails
Signed-off-by: Janos SUTO <sj@acts.hu>
This commit is contained in:
		| @@ -315,6 +315,7 @@ struct import { | |||||||
|    int port; |    int port; | ||||||
|    int seq; |    int seq; | ||||||
|    int table_id; |    int table_id; | ||||||
|  |    int delay; | ||||||
|    char *server; |    char *server; | ||||||
|    char *username; |    char *username; | ||||||
|    char *password; |    char *password; | ||||||
|   | |||||||
| @@ -25,6 +25,14 @@ int import_message(struct session_data *sdata, struct data *data, struct config | |||||||
|    struct parser_state state; |    struct parser_state state; | ||||||
|    struct counters counters; |    struct counters counters; | ||||||
|  |  | ||||||
|  |    if(data->import->delay > 0){ | ||||||
|  |       struct timespec req; | ||||||
|  |  | ||||||
|  |       req.tv_sec = 0; | ||||||
|  |       req.tv_nsec = 1000000 * data->import->delay; | ||||||
|  |  | ||||||
|  |       nanosleep(&req, NULL); | ||||||
|  |    } | ||||||
|  |  | ||||||
|    init_session_data(sdata, cfg); |    init_session_data(sdata, cfg); | ||||||
|  |  | ||||||
|   | |||||||
| @@ -53,6 +53,7 @@ void usage(){ | |||||||
|    printf("    -j <failed folder>                Move failed to import emails to this folder\n"); |    printf("    -j <failed folder>                Move failed to import emails to this folder\n"); | ||||||
|    printf("    -a <recipient>                    Add recipient to the To:/Cc: list\n"); |    printf("    -a <recipient>                    Add recipient to the To:/Cc: list\n"); | ||||||
|    printf("    -T <id>                           Update import table at id=<id>\n"); |    printf("    -T <id>                           Update import table at id=<id>\n"); | ||||||
|  |    printf("    -Z <ms>                           Delay Z milliseconds in between emails being imported\n"); | ||||||
|    printf("    -D                                Dry-run, do not import anything\n"); |    printf("    -D                                Dry-run, do not import anything\n"); | ||||||
|    printf("    -y                                Read pilerexport data from stdin\n"); |    printf("    -y                                Read pilerexport data from stdin\n"); | ||||||
|    printf("    -o                                Only download emails for POP3/IMAP import\n"); |    printf("    -o                                Only download emails for POP3/IMAP import\n"); | ||||||
| @@ -100,6 +101,7 @@ int main(int argc, char **argv){ | |||||||
|    import.tot_msgs = 0; |    import.tot_msgs = 0; | ||||||
|    import.table_id = 0; |    import.table_id = 0; | ||||||
|    import.folder = NULL; |    import.folder = NULL; | ||||||
|  |    import.delay = 0; | ||||||
|  |  | ||||||
|    data.import = &import; |    data.import = &import; | ||||||
|  |  | ||||||
| @@ -136,6 +138,7 @@ int main(int argc, char **argv){ | |||||||
|             {"timeout",      required_argument,  0,  't' }, |             {"timeout",      required_argument,  0,  't' }, | ||||||
|             {"start-position",required_argument,  0,  's' }, |             {"start-position",required_argument,  0,  's' }, | ||||||
|             {"table-id",     required_argument,  0,  'T' }, |             {"table-id",     required_argument,  0,  'T' }, | ||||||
|  |             {"delay",        required_argument,  0,  'Z' }, | ||||||
|             {"quiet",        no_argument,        0,  'q' }, |             {"quiet",        no_argument,        0,  'q' }, | ||||||
|             {"recursive",    no_argument,        0,  'R' }, |             {"recursive",    no_argument,        0,  'R' }, | ||||||
|             {"remove-after-import",no_argument,  0,  'r' }, |             {"remove-after-import",no_argument,  0,  'r' }, | ||||||
| @@ -150,9 +153,9 @@ int main(int argc, char **argv){ | |||||||
|  |  | ||||||
|       int option_index = 0; |       int option_index = 0; | ||||||
|  |  | ||||||
|       int c = getopt_long(argc, argv, "c:m:M:e:d:i:K:u:p:P:x:F:f:a:b:t:s:g:j:T:yDRroqh?", long_options, &option_index); |       int c = getopt_long(argc, argv, "c:m:M:e:d:i:K:u:p:P:x:F:f:a:b:t:s:g:j:T:Z:yDRroqh?", long_options, &option_index); | ||||||
| #else | #else | ||||||
|       int c = getopt(argc, argv, "c:m:M:e:d:i:K:u:p:P:x:F:f:a:b:t:s:g:j:T:yDRroqh?"); |       int c = getopt(argc, argv, "c:m:M:e:d:i:K:u:p:P:x:F:f:a:b:t:s:g:j:T:Z:yDRroqh?"); | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|       if(c == -1) break; |       if(c == -1) break; | ||||||
| @@ -271,6 +274,15 @@ int main(int argc, char **argv){ | |||||||
|                     data.import->table_id = atoi(optarg); |                     data.import->table_id = atoi(optarg); | ||||||
|                     break; |                     break; | ||||||
|  |  | ||||||
|  |          case 'Z' : | ||||||
|  |                     if(atoi(optarg) < 1){ | ||||||
|  |                        printf("invalid delay value: %s\n", optarg); | ||||||
|  |                        return -1; | ||||||
|  |                     } | ||||||
|  |  | ||||||
|  |                     data.import->delay = atoi(optarg); | ||||||
|  |                     break; | ||||||
|  |  | ||||||
|          case 'y' : |          case 'y' : | ||||||
|                     read_from_pilerexport = 1; |                     read_from_pilerexport = 1; | ||||||
|                     break; |                     break; | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user