mirror of
				https://github.com/paperless-ngx/paperless-ngx.git
				synced 2025-10-26 00:02:35 -04:00 
			
		
		
		
	add prefix option to administration exporter
This commit is contained in:
		
							parent
							
								
									9ae186e6f9
								
							
						
					
					
						commit
						896304ccaa
					
				| @ -227,11 +227,12 @@ is not a TTY" errors. For example: | |||||||
| `docker-compose exec -T webserver document_exporter ../export` | `docker-compose exec -T webserver document_exporter ../export` | ||||||
| 
 | 
 | ||||||
| ``` | ``` | ||||||
| document_exporter target [-c] [-f] [-d] [-na] [-nt] | document_exporter target [-c] [-f] [-p] [-d] [-na] [-nt] | ||||||
| 
 | 
 | ||||||
| optional arguments: | optional arguments: | ||||||
| -c, --compare-checksums | -c, --compare-checksums | ||||||
| -f, --use-filename-format | -f, --use-filename-format | ||||||
|  | -p, --use-filename-prefix | ||||||
| -d, --delete | -d, --delete | ||||||
| -na, --no-archive | -na, --no-archive | ||||||
| -nt, --no-thumbnail | -nt, --no-thumbnail | ||||||
| @ -277,6 +278,10 @@ The filenames generated by this command follow the format | |||||||
| paperless to use `PAPERLESS_FILENAME_FORMAT` for exported filenames | paperless to use `PAPERLESS_FILENAME_FORMAT` for exported filenames | ||||||
| instead, specify `--use-filename-format`. | instead, specify `--use-filename-format`. | ||||||
| 
 | 
 | ||||||
|  | If `-p` or `--use-filename-format` is provided, Files will be exported | ||||||
|  | in dedicated folders according to their nature: `archive`, `originals` | ||||||
|  | or `thumbnails` | ||||||
|  | 
 | ||||||
| !!! warning | !!! warning | ||||||
| 
 | 
 | ||||||
|     If exporting with the file name format, there may be errors due to |     If exporting with the file name format, there may be errors due to | ||||||
|  | |||||||
| @ -72,6 +72,15 @@ class Command(BaseCommand): | |||||||
|             "export directory, if configured.", |             "export directory, if configured.", | ||||||
|         ) |         ) | ||||||
| 
 | 
 | ||||||
|  |         parser.add_argument( | ||||||
|  |             "-p", | ||||||
|  |             "--use-filename-prefix", | ||||||
|  |             default=False, | ||||||
|  |             action="store_true", | ||||||
|  |             help="Export files in dedicated folders according to their nature: " | ||||||
|  |             "archive, originals or thumbnails", | ||||||
|  |         ) | ||||||
|  | 
 | ||||||
|         parser.add_argument( |         parser.add_argument( | ||||||
|             "-d", |             "-d", | ||||||
|             "--delete", |             "--delete", | ||||||
| @ -97,6 +106,7 @@ class Command(BaseCommand): | |||||||
|             action="store_true", |             action="store_true", | ||||||
|             help="Avoid exporting thumbnail files", |             help="Avoid exporting thumbnail files", | ||||||
|         ) |         ) | ||||||
|  | 
 | ||||||
|         parser.add_argument( |         parser.add_argument( | ||||||
|             "--no-progress-bar", |             "--no-progress-bar", | ||||||
|             default=False, |             default=False, | ||||||
| @ -119,6 +129,7 @@ class Command(BaseCommand): | |||||||
|         self.exported_files: List[Path] = [] |         self.exported_files: List[Path] = [] | ||||||
|         self.compare_checksums = False |         self.compare_checksums = False | ||||||
|         self.use_filename_format = False |         self.use_filename_format = False | ||||||
|  |         self.use_filename_prefix = False | ||||||
|         self.delete = False |         self.delete = False | ||||||
|         self.no_archive = False |         self.no_archive = False | ||||||
|         self.no_thumbnail = False |         self.no_thumbnail = False | ||||||
| @ -128,6 +139,7 @@ class Command(BaseCommand): | |||||||
|         self.target = Path(options["target"]).resolve() |         self.target = Path(options["target"]).resolve() | ||||||
|         self.compare_checksums = options["compare_checksums"] |         self.compare_checksums = options["compare_checksums"] | ||||||
|         self.use_filename_format = options["use_filename_format"] |         self.use_filename_format = options["use_filename_format"] | ||||||
|  |         self.use_filename_prefix = options["use_filename_prefix"] | ||||||
|         self.delete = options["delete"] |         self.delete = options["delete"] | ||||||
|         self.no_archive = options["no_archive"] |         self.no_archive = options["no_archive"] | ||||||
|         self.no_thumbnail = options["no_thumbnail"] |         self.no_thumbnail = options["no_thumbnail"] | ||||||
| @ -262,11 +274,15 @@ class Command(BaseCommand): | |||||||
| 
 | 
 | ||||||
|             # 3.3. write filenames into manifest |             # 3.3. write filenames into manifest | ||||||
|             original_name = base_name |             original_name = base_name | ||||||
|  |             if self.use_filename_prefix: | ||||||
|  |                 original_name = ("originals" / Path(original_name)).resolve() | ||||||
|             original_target = (self.target / Path(original_name)).resolve() |             original_target = (self.target / Path(original_name)).resolve() | ||||||
|             document_dict[EXPORTER_FILE_NAME] = original_name |             document_dict[EXPORTER_FILE_NAME] = original_name | ||||||
| 
 | 
 | ||||||
|             if not self.no_thumbnail: |             if not self.no_thumbnail: | ||||||
|                 thumbnail_name = base_name + "-thumbnail.webp" |                 thumbnail_name = base_name + "-thumbnail.webp" | ||||||
|  |                 if self.use_filename_prefix: | ||||||
|  |                     thumbnail_name = ("thumbnails" / Path(thumbnail_name)).resolve() | ||||||
|                 thumbnail_target = (self.target / Path(thumbnail_name)).resolve() |                 thumbnail_target = (self.target / Path(thumbnail_name)).resolve() | ||||||
|                 document_dict[EXPORTER_THUMBNAIL_NAME] = thumbnail_name |                 document_dict[EXPORTER_THUMBNAIL_NAME] = thumbnail_name | ||||||
|             else: |             else: | ||||||
| @ -274,6 +290,8 @@ class Command(BaseCommand): | |||||||
| 
 | 
 | ||||||
|             if not self.no_archive and document.has_archive_version: |             if not self.no_archive and document.has_archive_version: | ||||||
|                 archive_name = base_name + "-archive.pdf" |                 archive_name = base_name + "-archive.pdf" | ||||||
|  |                 if self.use_filename_prefix: | ||||||
|  |                     archive_name = ("archive" / Path(archive_name)).resolve() | ||||||
|                 archive_target = (self.target / Path(archive_name)).resolve() |                 archive_target = (self.target / Path(archive_name)).resolve() | ||||||
|                 document_dict[EXPORTER_ARCHIVE_NAME] = archive_name |                 document_dict[EXPORTER_ARCHIVE_NAME] = archive_name | ||||||
|             else: |             else: | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user