mirror of
https://bitbucket.org/jsuto/piler.git
synced 2025-01-12 12:10:12 +01:00
Added support for pilerexport to spread files among several directories
Signed-off-by: Janos SUTO <sj@acts.hu>
This commit is contained in:
parent
83172387a7
commit
c860ca6799
@ -4,7 +4,8 @@
|
|||||||
- Replaced sphinx with manticore 5.0.2, see https://www.mailpiler.org/wiki/current:manticore
|
- Replaced sphinx with manticore 5.0.2, see https://www.mailpiler.org/wiki/current:manticore
|
||||||
- Replaced obsoleted libchart library with chart.js
|
- Replaced obsoleted libchart library with chart.js
|
||||||
- Added real-time index support
|
- Added real-time index support
|
||||||
|
- Added oauth2 support to imapfetch.py
|
||||||
|
- Added support for pilerexport to spread files among several directories. See the -D option
|
||||||
|
|
||||||
|
|
||||||
1.3.12:
|
1.3.12:
|
||||||
|
@ -51,6 +51,7 @@ int query_attachments(struct session_data *sdata, struct ptr_array *ptr_arr);
|
|||||||
|
|
||||||
struct config read_config(char *configfile);
|
struct config read_config(char *configfile);
|
||||||
|
|
||||||
|
void createdir(char *path, uid_t uid, gid_t gid, mode_t mode);
|
||||||
void check_and_create_directories(struct config *cfg, uid_t uid, gid_t gid);
|
void check_and_create_directories(struct config *cfg, uid_t uid, gid_t gid);
|
||||||
|
|
||||||
void update_counters(struct session_data *sdata, struct data *data, struct counters *counters, struct config *cfg);
|
void update_counters(struct session_data *sdata, struct data *data, struct counters *counters, struct config *cfg);
|
||||||
|
@ -30,12 +30,14 @@ char *query=NULL;
|
|||||||
int verbosity = 0;
|
int verbosity = 0;
|
||||||
int max_matches = 1000;
|
int max_matches = 1000;
|
||||||
char *index_list = "main1,dailydelta1,delta1";
|
char *index_list = "main1,dailydelta1,delta1";
|
||||||
|
struct passwd *pwd;
|
||||||
regex_t regexp;
|
regex_t regexp;
|
||||||
char *zipfile = NULL;
|
char *zipfile = NULL;
|
||||||
struct zip *zip = NULL;
|
struct zip *zip = NULL;
|
||||||
uint64 *zip_ids = NULL;
|
uint64 *zip_ids = NULL;
|
||||||
int zip_counter = 0;
|
int zip_counter = 0;
|
||||||
int zip_batch = 2000;
|
int zip_batch = 2000;
|
||||||
|
int max_files_in_export_dir = 0;
|
||||||
|
|
||||||
int export_emails_matching_to_query(struct session_data *sdata, char *s, struct config *cfg);
|
int export_emails_matching_to_query(struct session_data *sdata, char *s, struct config *cfg);
|
||||||
|
|
||||||
@ -60,6 +62,7 @@ void usage(){
|
|||||||
printf(" -Z <batch size> Zip batch size. Valid range: 10-10000, default: 2000\n");
|
printf(" -Z <batch size> Zip batch size. Valid range: 10-10000, default: 2000\n");
|
||||||
#endif
|
#endif
|
||||||
printf(" -A Export all emails from archive\n");
|
printf(" -A Export all emails from archive\n");
|
||||||
|
printf(" -D <max files> Max. number of files to put in a single directory, default: 2000\n");
|
||||||
printf(" -o Export emails to stdout\n");
|
printf(" -o Export emails to stdout\n");
|
||||||
printf(" -d Dry run\n");
|
printf(" -d Dry run\n");
|
||||||
|
|
||||||
@ -356,9 +359,10 @@ void zip_flush(){
|
|||||||
|
|
||||||
int export_emails_matching_to_query(struct session_data *sdata, char *s, struct config *cfg){
|
int export_emails_matching_to_query(struct session_data *sdata, char *s, struct config *cfg){
|
||||||
FILE *f;
|
FILE *f;
|
||||||
uint64 id, n=0;
|
uint64 id, n=0, dir_counter=0;
|
||||||
char digest[SMALLBUFSIZE], bodydigest[SMALLBUFSIZE];
|
char digest[SMALLBUFSIZE], bodydigest[SMALLBUFSIZE];
|
||||||
char filename[SMALLBUFSIZE];
|
char filename[SMALLBUFSIZE];
|
||||||
|
char export_subdir[SMALLBUFSIZE];
|
||||||
struct sql sql;
|
struct sql sql;
|
||||||
int errorp, rc=0, attachments;
|
int errorp, rc=0, attachments;
|
||||||
unsigned long total_attachments=0;
|
unsigned long total_attachments=0;
|
||||||
@ -394,6 +398,19 @@ int export_emails_matching_to_query(struct session_data *sdata, char *s, struct
|
|||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if(max_files_in_export_dir > 0 && n % max_files_in_export_dir == 0){
|
||||||
|
dir_counter++;
|
||||||
|
snprintf(export_subdir, sizeof(export_subdir)-1, "export-%llu", dir_counter);
|
||||||
|
if(n > 0 && chdir("..")){
|
||||||
|
p_clean_exit("error chdir(\"..\")", 1);
|
||||||
|
}
|
||||||
|
|
||||||
|
createdir(export_subdir, pwd->pw_uid, pwd->pw_gid, 0700);
|
||||||
|
if(chdir(export_subdir)){
|
||||||
|
p_clean_exit("error chdir to export-* dir", 1);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
snprintf(filename, sizeof(filename)-1, "%llu.eml", id);
|
snprintf(filename, sizeof(filename)-1, "%llu.eml", id);
|
||||||
|
|
||||||
f = fopen(filename, "w");
|
f = fopen(filename, "w");
|
||||||
@ -512,6 +529,7 @@ int main(int argc, char **argv){
|
|||||||
{"zip", required_argument, 0, 'z' },
|
{"zip", required_argument, 0, 'z' },
|
||||||
{"zip-batch", required_argument, 0, 'Z' },
|
{"zip-batch", required_argument, 0, 'Z' },
|
||||||
{"where-condition", required_argument, 0, 'w' },
|
{"where-condition", required_argument, 0, 'w' },
|
||||||
|
{"max-files", required_argument, 0, 'D' },
|
||||||
{"max-matches", required_argument, 0, 'm' },
|
{"max-matches", required_argument, 0, 'm' },
|
||||||
{"index-list", required_argument, 0, 'i' },
|
{"index-list", required_argument, 0, 'i' },
|
||||||
{0,0,0,0}
|
{0,0,0,0}
|
||||||
@ -519,9 +537,9 @@ int main(int argc, char **argv){
|
|||||||
|
|
||||||
int option_index = 0;
|
int option_index = 0;
|
||||||
|
|
||||||
int c = getopt_long(argc, argv, "c:s:S:f:r:F:R:a:b:w:m:i:z:Z:oAdhv?", long_options, &option_index);
|
int c = getopt_long(argc, argv, "c:s:S:f:r:F:R:a:b:w:m:i:z:Z:D:oAdhv?", long_options, &option_index);
|
||||||
#else
|
#else
|
||||||
int c = getopt(argc, argv, "c:s:S:f:r:F:R:a:b:w:m:i:z:Z:oAdhv?");
|
int c = getopt(argc, argv, "c:s:S:f:r:F:R:a:b:w:m:i:z:Z:D:oAdhv?");
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
if(c == -1) break;
|
if(c == -1) break;
|
||||||
@ -630,6 +648,11 @@ int main(int argc, char **argv){
|
|||||||
zip_batch = 2000;
|
zip_batch = 2000;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
case 'D': max_files_in_export_dir = atoi(optarg);
|
||||||
|
if(max_files_in_export_dir < 10 || max_files_in_export_dir > 100000)
|
||||||
|
max_files_in_export_dir = 2000;
|
||||||
|
break;
|
||||||
|
|
||||||
case 'o':
|
case 'o':
|
||||||
export_to_stdout = 1;
|
export_to_stdout = 1;
|
||||||
break;
|
break;
|
||||||
@ -661,6 +684,11 @@ int main(int argc, char **argv){
|
|||||||
|
|
||||||
if(read_key(&cfg)) p_clean_exit(ERR_READING_KEY, 1);
|
if(read_key(&cfg)) p_clean_exit(ERR_READING_KEY, 1);
|
||||||
|
|
||||||
|
if(strlen(cfg.username) > 1){
|
||||||
|
pwd = getpwnam(cfg.username);
|
||||||
|
if(!pwd) __fatal(ERR_NON_EXISTENT_USER);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
init_session_data(&sdata, &cfg);
|
init_session_data(&sdata, &cfg);
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user