mirror of
				https://github.com/paperless-ngx/paperless-ngx.git
				synced 2025-10-24 23:39:05 -04:00 
			
		
		
		
	Further cleanup of docs, including fixing autoconvert issues and general cleanups
This commit is contained in:
		
							parent
							
								
									32d546740b
								
							
						
					
					
						commit
						7788d93227
					
				| @ -9,7 +9,7 @@ Before making backups, make sure that paperless is not running. | |||||||
| 
 | 
 | ||||||
| Options available to any installation of paperless: | Options available to any installation of paperless: | ||||||
| 
 | 
 | ||||||
| - Use the [document exporter](administration#exporter). The document exporter exports all your documents, | - Use the [document exporter](#exporter). The document exporter exports all your documents, | ||||||
|   thumbnails and metadata to a specific folder. You may import your |   thumbnails and metadata to a specific folder. You may import your | ||||||
|   documents into a fresh instance of paperless again or store your |   documents into a fresh instance of paperless again or store your | ||||||
|   documents in another DMS with this export. |   documents in another DMS with this export. | ||||||
| @ -52,7 +52,7 @@ Options available to bare-metal and non-docker installations: | |||||||
| 
 | 
 | ||||||
| ## Updating Paperless {#updating} | ## Updating Paperless {#updating} | ||||||
| 
 | 
 | ||||||
| ### Docker Route | ### Docker Route {#docker-updating} | ||||||
| 
 | 
 | ||||||
| If a new release of paperless-ngx is available, upgrading depends on how | If a new release of paperless-ngx is available, upgrading depends on how | ||||||
| you installed paperless-ngx in the first place. The releases are | you installed paperless-ngx in the first place. The releases are | ||||||
| @ -131,7 +131,7 @@ the background. | |||||||
|     image: ghcr.io/paperless-ngx/paperless-ngx:1.7 |     image: ghcr.io/paperless-ngx/paperless-ngx:1.7 | ||||||
|     ``` |     ``` | ||||||
| 
 | 
 | ||||||
| ### Bare Metal Route | ### Bare Metal Route {#bare-metal-updating} | ||||||
| 
 | 
 | ||||||
| After grabbing the new release and unpacking the contents, do the | After grabbing the new release and unpacking the contents, do the | ||||||
| following: | following: | ||||||
| @ -158,7 +158,7 @@ following: | |||||||
|     This might not actually do anything. Not every new paperless version |     This might not actually do anything. Not every new paperless version | ||||||
|     comes with new database migrations. |     comes with new database migrations. | ||||||
| 
 | 
 | ||||||
| ## Downgrading Paperless | ## Downgrading Paperless {#downgrade-paperless} | ||||||
| 
 | 
 | ||||||
| Downgrades are possible. However, some updates also contain database | Downgrades are possible. However, some updates also contain database | ||||||
| migrations (these change the layout of the database and may move data). | migrations (these change the layout of the database and may move data). | ||||||
| @ -366,7 +366,7 @@ task scheduler. | |||||||
| ### Managing filenames {#renamer} | ### Managing filenames {#renamer} | ||||||
| 
 | 
 | ||||||
| If you use paperless' feature to | If you use paperless' feature to | ||||||
| [assign custom filenames to your documents](/advanced_usage#file_name_handling), you can use this command to move all your files after | [assign custom filenames to your documents](/advanced_usage#file-name-handling), you can use this command to move all your files after | ||||||
| changing the naming scheme. | changing the naming scheme. | ||||||
| 
 | 
 | ||||||
| !!! warning | !!! warning | ||||||
| @ -430,9 +430,7 @@ rules. | |||||||
|     As of October 2022 Microsoft no longer supports IMAP authentication |     As of October 2022 Microsoft no longer supports IMAP authentication | ||||||
|     for Exchange servers, thus Exchange is no longer supported until a |     for Exchange servers, thus Exchange is no longer supported until a | ||||||
|     solution is implemented in the Python IMAP library used by Paperless. |     solution is implemented in the Python IMAP library used by Paperless. | ||||||
|     See |     See [learn.microsoft.com](https://learn.microsoft.com/en-us/exchange/clients-and-mobile-in-exchange-online/deprecation-of-basic-authentication-exchange-online) | ||||||
| 
 |  | ||||||
| [learn.microsoft.com](https://learn.microsoft.com/en-us/exchange/clients-and-mobile-in-exchange-online/deprecation-of-basic-authentication-exchange-online) |  | ||||||
| 
 | 
 | ||||||
| ### Creating archived documents {#archiver} | ### Creating archived documents {#archiver} | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -50,7 +50,7 @@ and run another document through the consumer. Once complete, you should | |||||||
| see the newly-created document, automatically tagged with the | see the newly-created document, automatically tagged with the | ||||||
| appropriate data. | appropriate data. | ||||||
| 
 | 
 | ||||||
| ### Automatic matching {#automatic_matching} | ### Automatic matching {#automatic-matching} | ||||||
| 
 | 
 | ||||||
| Paperless-ngx comes with a new matching algorithm called _Auto_. This | Paperless-ngx comes with a new matching algorithm called _Auto_. This | ||||||
| matching algorithm tries to assign tags, correspondents, document types, | matching algorithm tries to assign tags, correspondents, document types, | ||||||
| @ -59,8 +59,8 @@ assigned these on existing documents. It uses a neural network under the | |||||||
| hood. | hood. | ||||||
| 
 | 
 | ||||||
| If, for example, all your bank statements of your account 123 at the | If, for example, all your bank statements of your account 123 at the | ||||||
| Bank of America are tagged with the tag "bofa*123" and the matching | Bank of America are tagged with the tag "bofa123" and the matching | ||||||
| algorithm of this tag is set to \_Auto*, this neural network will examine | algorithm of this tag is set to _Auto_, this neural network will examine | ||||||
| your documents and automatically learn when to assign this tag. | your documents and automatically learn when to assign this tag. | ||||||
| 
 | 
 | ||||||
| Paperless tries to hide much of the involved complexity with this | Paperless tries to hide much of the involved complexity with this | ||||||
| @ -95,7 +95,7 @@ when using this feature: | |||||||
|   of these correspondents to ANY new document, if both are set to |   of these correspondents to ANY new document, if both are set to | ||||||
|   automatic matching. |   automatic matching. | ||||||
| 
 | 
 | ||||||
| ## Hooking into the consumption process | ## Hooking into the consumption process {#consume-hooks} | ||||||
| 
 | 
 | ||||||
| Sometimes you may want to do something arbitrary whenever a document is | Sometimes you may want to do something arbitrary whenever a document is | ||||||
| consumed. Rather than try to predict what you may want to do, Paperless | consumed. Rather than try to predict what you may want to do, Paperless | ||||||
| @ -115,7 +115,7 @@ and then put the path to that script in `paperless.conf` or | |||||||
|     asynchronously, you'll have to fork the process in your script and |     asynchronously, you'll have to fork the process in your script and | ||||||
|     exit. |     exit. | ||||||
| 
 | 
 | ||||||
| ### Pre-consumption script | ### Pre-consumption script {#pre-consume-script} | ||||||
| 
 | 
 | ||||||
| Executed after the consumer sees a new document in the consumption | Executed after the consumer sees a new document in the consumption | ||||||
| folder, but before any processing of the document is performed. This | folder, but before any processing of the document is performed. This | ||||||
| @ -151,7 +151,7 @@ with the newly modified file. | |||||||
| The script's stdout and stderr will be logged line by line to the | The script's stdout and stderr will be logged line by line to the | ||||||
| webserver log, along with the exit code of the script. | webserver log, along with the exit code of the script. | ||||||
| 
 | 
 | ||||||
| ### Post-consumption script {#post_consume_script} | ### Post-consumption script {#post-consume-script} | ||||||
| 
 | 
 | ||||||
| Executed after the consumer has successfully processed a document and | Executed after the consumer has successfully processed a document and | ||||||
| has moved it into paperless. It receives the following environment | has moved it into paperless. It receives the following environment | ||||||
| @ -181,33 +181,34 @@ The post consumption script cannot cancel the consumption process. | |||||||
| The script's stdout and stderr will be logged line by line to the | The script's stdout and stderr will be logged line by line to the | ||||||
| webserver log, along with the exit code of the script. | webserver log, along with the exit code of the script. | ||||||
| 
 | 
 | ||||||
| #### Docker | ### Docker {#docker-consume-hooks} | ||||||
| 
 | 
 | ||||||
| Assumed you have | To hook into the consumption process when using Docker, you | ||||||
| `/home/foo/paperless-ngx/scripts/post-consumption-example.sh`. | will need to pass the scripts into the container via a host mount | ||||||
|  | in your `docker-compose.yml`. | ||||||
| 
 | 
 | ||||||
| You can pass that script into the consumer container via a host mount in | Assuming you have | ||||||
| your `docker-compose.yml`. | `/home/paperless-ngx/scripts/post-consumption-example.sh` as a | ||||||
|  | script which you'd like to run. | ||||||
| 
 | 
 | ||||||
| ```bash | You can pass that script into the consumer container via a host mount: | ||||||
|  | 
 | ||||||
|  | ```yaml | ||||||
| ... | ... | ||||||
| consumer: | webserver: | ||||||
|   ... |   ... | ||||||
|   volumes: |   volumes: | ||||||
|     ... |     ... | ||||||
|     - /home/paperless-ngx/scripts:/path/in/container/scripts/ |     - /home/paperless-ngx/scripts:/path/in/container/scripts/ # (1)! | ||||||
|  |   environment: # (3)! | ||||||
|  |     ... | ||||||
|  |     PAPERLESS_POST_CONSUME_SCRIPT: /path/in/container/scripts/post-consumption-example.sh # (2)! | ||||||
| ... | ... | ||||||
| ``` | ``` | ||||||
| 
 | 
 | ||||||
| Example (docker-compose.yml): | 1. The external scripts directory is mounted to a location inside the container. | ||||||
| `- /home/foo/paperless-ngx/scripts:/usr/src/paperless/scripts` | 2. The internal location of the script is used to set the script to run | ||||||
| 
 | 3. This can also be set in `docker-compose.env` | ||||||
| which in turn requires the variable `PAPERLESS_POST_CONSUME_SCRIPT` in |  | ||||||
| `docker-compose.env` to point to |  | ||||||
| `/path/in/container/scripts/post-consumption-example.sh`. |  | ||||||
| 
 |  | ||||||
| Example (docker-compose.env): |  | ||||||
| `PAPERLESS_POST_CONSUME_SCRIPT=/usr/src/paperless/scripts/post-consumption-example.sh` |  | ||||||
| 
 | 
 | ||||||
| Troubleshooting: | Troubleshooting: | ||||||
| 
 | 
 | ||||||
| @ -218,7 +219,7 @@ Troubleshooting: | |||||||
| - Pipe your scripts's output to a log file e.g. | - Pipe your scripts's output to a log file e.g. | ||||||
|   `echo "${DOCUMENT_ID}" | tee --append /usr/src/paperless/scripts/post-consumption-example.log` |   `echo "${DOCUMENT_ID}" | tee --append /usr/src/paperless/scripts/post-consumption-example.log` | ||||||
| 
 | 
 | ||||||
| ## File name handling {#file_name_handling} | ## File name handling {#file-name-handling} | ||||||
| 
 | 
 | ||||||
| By default, paperless stores your documents in the media directory and | By default, paperless stores your documents in the media directory and | ||||||
| renames them using the identifier which it has assigned to each | renames them using the identifier which it has assigned to each | ||||||
| @ -316,7 +317,7 @@ value. | |||||||
|     Paperless checks the filename of a document whenever it is saved. |     Paperless checks the filename of a document whenever it is saved. | ||||||
|     Therefore, you need to update the filenames of your documents and move |     Therefore, you need to update the filenames of your documents and move | ||||||
|     them after altering this setting by invoking the |     them after altering this setting by invoking the | ||||||
|     [`document renamer <utilities-renamer>`](). |     [`document renamer`](administration#renamer). | ||||||
| 
 | 
 | ||||||
| !!! warning | !!! warning | ||||||
| 
 | 
 | ||||||
| @ -344,7 +345,7 @@ When as single storage layout is not sufficient for your use case, | |||||||
| storage paths come to the rescue. Storage paths allow you to configure | storage paths come to the rescue. Storage paths allow you to configure | ||||||
| more precisely where each document is stored in the file system. | more precisely where each document is stored in the file system. | ||||||
| 
 | 
 | ||||||
| - Each storage path is a [PAPERLESS_FILENAME_FORMAT]{.title-ref} and | - Each storage path is a `PAPERLESS_FILENAME_FORMAT` and | ||||||
|   follows the rules described above |   follows the rules described above | ||||||
| - Each document is assigned a storage path using the matching | - Each document is assigned a storage path using the matching | ||||||
|   algorithms described above, but can be overwritten at any time |   algorithms described above, but can be overwritten at any time | ||||||
| @ -352,7 +353,7 @@ more precisely where each document is stored in the file system. | |||||||
| For example, you could define the following two storage paths: | For example, you could define the following two storage paths: | ||||||
| 
 | 
 | ||||||
| 1.  Normal communications are put into a folder structure sorted by | 1.  Normal communications are put into a folder structure sorted by | ||||||
|     [year/correspondent]{.title-ref} |     `year/correspondent` | ||||||
| 2.  Communications with insurance companies are stored in a flat | 2.  Communications with insurance companies are stored in a flat | ||||||
|     structure with longer file names, but containing the full date of |     structure with longer file names, but containing the full date of | ||||||
|     the correspondence. |     the correspondence. | ||||||
| @ -384,7 +385,7 @@ structure as in the previous example above. | |||||||
| !!! tip | !!! tip | ||||||
| 
 | 
 | ||||||
|     Defining a storage path is optional. If no storage path is defined for a |     Defining a storage path is optional. If no storage path is defined for a | ||||||
|     document, the global [PAPERLESS_FILENAME_FORMAT]{.title-ref} is applied. |     document, the global `PAPERLESS_FILENAME_FORMAT` is applied. | ||||||
| 
 | 
 | ||||||
| !!! warning | !!! warning | ||||||
| 
 | 
 | ||||||
| @ -403,27 +404,32 @@ queued and completed tasks, timing and more. Flower can also be used | |||||||
| with Prometheus, as it exports metrics. For details on its capabilities, | with Prometheus, as it exports metrics. For details on its capabilities, | ||||||
| refer to the Flower documentation. | refer to the Flower documentation. | ||||||
| 
 | 
 | ||||||
| To configure Flower further, create a [flowerconfig.py]{.title-ref} and | To configure Flower further, create a `flowerconfig.py` and | ||||||
| place it into the [src/paperless]{.title-ref} directory. For a Docker | place it into the `src/paperless` directory. For a Docker | ||||||
| installation, you can use volumes to accomplish this: | installation, you can use volumes to accomplish this: | ||||||
| 
 | 
 | ||||||
| ```yaml | ```yaml | ||||||
| services: | services: | ||||||
|   # ... |   # ... | ||||||
|   webserver: |   webserver: | ||||||
|  |     ports: | ||||||
|  |       - 5555:5555 # (2)! | ||||||
|     # ... |     # ... | ||||||
|     volumes: |     volumes: | ||||||
|       - /path/to/my/flowerconfig.py:/usr/src/paperless/src/paperless/flowerconfig.py:ro |       - /path/to/my/flowerconfig.py:/usr/src/paperless/src/paperless/flowerconfig.py:ro # (1)! | ||||||
| ``` | ``` | ||||||
| 
 | 
 | ||||||
|  | 1. Note the `:ro` tag means the file will be mounted as read only. | ||||||
|  | 2. `flower` runs by default on port 5555, but this can be configured | ||||||
|  | 
 | ||||||
| ## Custom Container Initialization | ## Custom Container Initialization | ||||||
| 
 | 
 | ||||||
| The Docker image includes the ability to run custom user scripts during | The Docker image includes the ability to run custom user scripts during | ||||||
| startup. This could be utilized for installing additional tools or | startup. This could be utilized for installing additional tools or | ||||||
| Python packages, for example. | Python packages, for example. Scripts are expected to be shell scripts. | ||||||
| 
 | 
 | ||||||
| To utilize this, mount a folder containing your scripts to the custom | To utilize this, mount a folder containing your scripts to the custom | ||||||
| initialization directory, [/custom-cont-init.d]{.title-ref} and place | initialization directory, `/custom-cont-init.d` and place | ||||||
| scripts you wish to run inside. For security, the folder must be owned | scripts you wish to run inside. For security, the folder must be owned | ||||||
| by `root` and should have permissions of `a=rx`. Additionally, scripts | by `root` and should have permissions of `a=rx`. Additionally, scripts | ||||||
| must only be writable by `root`. | must only be writable by `root`. | ||||||
| @ -445,9 +451,11 @@ services: | |||||||
|   webserver: |   webserver: | ||||||
|     # ... |     # ... | ||||||
|     volumes: |     volumes: | ||||||
|       - /path/to/my/scripts:/custom-cont-init.d:ro |       - /path/to/my/scripts:/custom-cont-init.d:ro # (1)! | ||||||
| ``` | ``` | ||||||
| 
 | 
 | ||||||
|  | 1. Note the `:ro` tag means the folder will be mounted as read only. This is for extra security against changes | ||||||
|  | 
 | ||||||
| ## MySQL Caveats {#mysql-caveats} | ## MySQL Caveats {#mysql-caveats} | ||||||
| 
 | 
 | ||||||
| ### Case Sensitivity | ### Case Sensitivity | ||||||
|  | |||||||
| @ -225,7 +225,7 @@ Query parameters: | |||||||
| 
 | 
 | ||||||
| Results returned by the endpoint are ordered by importance of the term | Results returned by the endpoint are ordered by importance of the term | ||||||
| in the document index. The first result is the term that has the highest | in the document index. The first result is the term that has the highest | ||||||
| Tf/Idf score in the index. | [Tf/Idf](https://en.wikipedia.org/wiki/Tf%E2%80%93idf) score in the index. | ||||||
| 
 | 
 | ||||||
| ```json | ```json | ||||||
| ["term1", "term3", "term6", "term4"] | ["term1", "term3", "term6", "term4"] | ||||||
|  | |||||||
| @ -33,15 +33,15 @@ matcher. | |||||||
|     [More information on securing your Redis |     [More information on securing your Redis | ||||||
|     Instance](https://redis.io/docs/getting-started/#securing-redis). |     Instance](https://redis.io/docs/getting-started/#securing-redis). | ||||||
| 
 | 
 | ||||||
|     Defaults to <redis://localhost:6379>. |     Defaults to `redis://localhost:6379`. | ||||||
| 
 | 
 | ||||||
| `PAPERLESS_DBENGINE=<engine_name>` | `PAPERLESS_DBENGINE=<engine_name>` | ||||||
| 
 | 
 | ||||||
| : Optional, gives the ability to choose Postgres or MariaDB for | : Optional, gives the ability to choose Postgres or MariaDB for | ||||||
| database engine. Available options are [postgresql]{.title-ref} and | database engine. Available options are `postgresql` and | ||||||
| [mariadb]{.title-ref}. | `mariadb`. | ||||||
| 
 | 
 | ||||||
|     Default is [postgresql]{.title-ref}. |     Default is `postgresql`. | ||||||
| 
 | 
 | ||||||
|     !!! warning |     !!! warning | ||||||
| 
 | 
 | ||||||
| @ -150,25 +150,25 @@ files created using "collectstatic" manager command are stored. | |||||||
| `PAPERLESS_FILENAME_FORMAT=<format>` | `PAPERLESS_FILENAME_FORMAT=<format>` | ||||||
| 
 | 
 | ||||||
| : Changes the filenames paperless uses to store documents in the media | : Changes the filenames paperless uses to store documents in the media | ||||||
| directory. See [File name handling](advanced_usage#file_name_handling) for details. | directory. See [File name handling](advanced_usage#file-name-handling) for details. | ||||||
| 
 | 
 | ||||||
|     Default is none, which disables this feature. |     Default is none, which disables this feature. | ||||||
| 
 | 
 | ||||||
| `PAPERLESS_FILENAME_FORMAT_REMOVE_NONE=<bool>` | `PAPERLESS_FILENAME_FORMAT_REMOVE_NONE=<bool>` | ||||||
| 
 | 
 | ||||||
| : Tells paperless to replace placeholders in | : Tells paperless to replace placeholders in | ||||||
| [PAPERLESS_FILENAME_FORMAT]{.title-ref} that would resolve to | `PAPERLESS_FILENAME_FORMAT` that would resolve to | ||||||
| 'none' to be omitted from the resulting filename. This also holds | 'none' to be omitted from the resulting filename. This also holds | ||||||
| true for directory names. See [File name handling](advanced_usage#file_name_handling) for | true for directory names. See [File name handling](advanced_usage#file-name-handling) for | ||||||
| details. | details. | ||||||
| 
 | 
 | ||||||
|     Defaults to [false]{.title-ref} which disables this feature. |     Defaults to `false` which disables this feature. | ||||||
| 
 | 
 | ||||||
| `PAPERLESS_LOGGING_DIR=<path>` | `PAPERLESS_LOGGING_DIR=<path>` | ||||||
| 
 | 
 | ||||||
| : This is where paperless will store log files. | : This is where paperless will store log files. | ||||||
| 
 | 
 | ||||||
|     Defaults to "`PAPERLESS_DATA_DIR`/log/". |     Defaults to `PAPERLESS_DATA_DIR/log/`. | ||||||
| 
 | 
 | ||||||
| ## Logging | ## Logging | ||||||
| 
 | 
 | ||||||
| @ -283,10 +283,10 @@ login with the selected user. | |||||||
| : If this environment variable is specified, Paperless automatically | : If this environment variable is specified, Paperless automatically | ||||||
| creates a superuser with the provided username at start. This is | creates a superuser with the provided username at start. This is | ||||||
| useful in cases where you can not run the | useful in cases where you can not run the | ||||||
| [createsuperuser]{.title-ref} command separately, such as Kubernetes | `createsuperuser` command separately, such as Kubernetes | ||||||
| or AWS ECS. | or AWS ECS. | ||||||
| 
 | 
 | ||||||
|     Requires [PAPERLESS_ADMIN_PASSWORD]{.title-ref} to be set. |     Requires PAPERLESS_ADMIN_PASSWORD be set. | ||||||
| 
 | 
 | ||||||
|     !!! note |     !!! note | ||||||
| 
 | 
 | ||||||
| @ -297,13 +297,13 @@ or AWS ECS. | |||||||
| `PAPERLESS_ADMIN_MAIL=<email>` | `PAPERLESS_ADMIN_MAIL=<email>` | ||||||
| 
 | 
 | ||||||
| : (Optional) Specify superuser email address. Only used when | : (Optional) Specify superuser email address. Only used when | ||||||
| [PAPERLESS_ADMIN_USER]{.title-ref} is set. | PAPERLESS_ADMIN_USER is set. | ||||||
| 
 | 
 | ||||||
|     Defaults to `root@localhost`. |     Defaults to `root@localhost`. | ||||||
| 
 | 
 | ||||||
| `PAPERLESS_ADMIN_PASSWORD=<password>` | `PAPERLESS_ADMIN_PASSWORD=<password>` | ||||||
| 
 | 
 | ||||||
| : Only used when [PAPERLESS_ADMIN_USER]{.title-ref} is set. This will | : Only used when PAPERLESS_ADMIN_USER is set. This will | ||||||
| be the password of the automatically created superuser. | be the password of the automatically created superuser. | ||||||
| 
 | 
 | ||||||
| `PAPERLESS_COOKIE_PREFIX=<str>` | `PAPERLESS_COOKIE_PREFIX=<str>` | ||||||
| @ -331,26 +331,25 @@ applications. | |||||||
|         If you're exposing paperless to the internet directly, do not use |         If you're exposing paperless to the internet directly, do not use | ||||||
|         this. |         this. | ||||||
| 
 | 
 | ||||||
|         Also see the warning [in the official documentation |         Also see the warning [in the official documentation](https://docs.djangoproject.com/en/3.1/howto/auth-remote-user/#configuration). | ||||||
|         <https://docs.djangoproject.com/en/3.1/howto/auth-remote-user/#configuration>]{.title-ref}. |  | ||||||
| 
 | 
 | ||||||
|     Defaults to [false]{.title-ref} which disables this feature. |     Defaults to "false" which disables this feature. | ||||||
| 
 | 
 | ||||||
| `PAPERLESS_HTTP_REMOTE_USER_HEADER_NAME=<str>` | `PAPERLESS_HTTP_REMOTE_USER_HEADER_NAME=<str>` | ||||||
| 
 | 
 | ||||||
| : If [PAPERLESS_ENABLE_HTTP_REMOTE_USER]{.title-ref} is enabled, this | : If "PAPERLESS*ENABLE_HTTP_REMOTE_USER" is enabled, this | ||||||
| property allows to customize the name of the HTTP header from which | property allows to customize the name of the HTTP header from which | ||||||
| the authenticated username is extracted. Values are in terms of | the authenticated username is extracted. Values are in terms of | ||||||
| \[HttpRequest.META\](<https://docs.djangoproject.com/en/3.1/ref/request-response/#django.http.HttpRequest.META>). | [HttpRequest.META](https://docs.djangoproject.com/en/3.1/ref/request-response/#django.http.HttpRequest.META). | ||||||
| Thus, the configured value must start with [HTTP\_]{.title-ref} | Thus, the configured value must start with `HTTP*` | ||||||
| followed by the normalized actual header name. | followed by the normalized actual header name. | ||||||
| 
 | 
 | ||||||
|     Defaults to [HTTP_REMOTE_USER]{.title-ref}. |     Defaults to "HTTP_REMOTE_USER". | ||||||
| 
 | 
 | ||||||
| `PAPERLESS_LOGOUT_REDIRECT_URL=<str>` | `PAPERLESS_LOGOUT_REDIRECT_URL=<str>` | ||||||
| 
 | 
 | ||||||
| : URL to redirect the user to after a logout. This can be used | : URL to redirect the user to after a logout. This can be used | ||||||
| together with [PAPERLESS_ENABLE_HTTP_REMOTE_USER]{.title-ref} to | together with PAPERLESS_ENABLE_HTTP_REMOTE_USER to | ||||||
| redirect the user back to the SSO application's logout page. | redirect the user back to the SSO application's logout page. | ||||||
| 
 | 
 | ||||||
|     Defaults to None, which disables this feature. |     Defaults to None, which disables this feature. | ||||||
| @ -368,7 +367,7 @@ needs. | |||||||
| parsing documents. | parsing documents. | ||||||
| 
 | 
 | ||||||
|     It should be a 3-letter language code consistent with ISO 639: |     It should be a 3-letter language code consistent with ISO 639: | ||||||
|     <https://www.loc.gov/standards/iso639-2/php/code_list.php> |     https://www.loc.gov/standards/iso639-2/php/code_list.php | ||||||
| 
 | 
 | ||||||
|     Set this to the language most of your documents are written in. |     Set this to the language most of your documents are written in. | ||||||
| 
 | 
 | ||||||
| @ -624,8 +623,7 @@ Add the configuration variables to the environment of the webserver | |||||||
| and add the additional services below the webserver service. Watch out | and add the additional services below the webserver service. Watch out | ||||||
| for indentation. | for indentation. | ||||||
| 
 | 
 | ||||||
| Make sure to use the correct format [PAPERLESS_TIKA_ENABLED = | Make sure to use the correct format `PAPERLESS_TIKA_ENABLED = 1` so python_dotenv can parse the statement correctly. | ||||||
| 1]{.title-ref} so python_dotenv can parse the statement correctly. |  | ||||||
| 
 | 
 | ||||||
| ## Software tweaks {#software_tweaks} | ## Software tweaks {#software_tweaks} | ||||||
| 
 | 
 | ||||||
| @ -648,7 +646,7 @@ paperless will process in parallel on a single document. | |||||||
| 
 | 
 | ||||||
|         Ensure that the product |         Ensure that the product | ||||||
| 
 | 
 | ||||||
|         `PAPERLESS_TASK_WORKERS \:   PAPERLESS_THREADS_PER_WORKER` |         `PAPERLESS_TASK_WORKERS * PAPERLESS_THREADS_PER_WORKER` | ||||||
| 
 | 
 | ||||||
|         does not exceed your CPU core count or else paperless will be |         does not exceed your CPU core count or else paperless will be | ||||||
|         extremely slow. If you want paperless to process many documents in |         extremely slow. If you want paperless to process many documents in | ||||||
| @ -752,7 +750,7 @@ consumption directory as well. | |||||||
| `PAPERLESS_CONSUMER_SUBDIRS_AS_TAGS=<bool>` | `PAPERLESS_CONSUMER_SUBDIRS_AS_TAGS=<bool>` | ||||||
| 
 | 
 | ||||||
| : Set the names of subdirectories as tags for consumed files. E.g. | : Set the names of subdirectories as tags for consumed files. E.g. | ||||||
| <CONSUMPTION_DIR>/foo/bar/file.pdf will add the tags "foo" and | `<CONSUMPTION_DIR>/foo/bar/file.pdf` will add the tags "foo" and | ||||||
| "bar" to the consumed file. Paperless will create any tags that | "bar" to the consumed file. Paperless will create any tags that | ||||||
| don't exist yet. | don't exist yet. | ||||||
| 
 | 
 | ||||||
| @ -827,7 +825,7 @@ documents. | |||||||
| 
 | 
 | ||||||
| : After a document is consumed, Paperless can trigger an arbitrary | : After a document is consumed, Paperless can trigger an arbitrary | ||||||
| script if you like. This script will be passed a number of arguments | script if you like. This script will be passed a number of arguments | ||||||
| for you to work with. For more information, take a look at [Post-consumption script](advanced_usage#post_consume_script). | for you to work with. For more information, take a look at [Post-consumption script](advanced_usage#post-consume-script). | ||||||
| 
 | 
 | ||||||
|     The default is blank, which means nothing will be executed. |     The default is blank, which means nothing will be executed. | ||||||
| 
 | 
 | ||||||
| @ -841,8 +839,7 @@ option as specified in | |||||||
| The filename will be checked first, and if nothing is found, the | The filename will be checked first, and if nothing is found, the | ||||||
| document text will be checked as normal. | document text will be checked as normal. | ||||||
| 
 | 
 | ||||||
|     A date in a filename must have some separators ([.]{.title-ref}, |     A date in a filename must have some separators (`.`, `,`, `-`, `/`, etc) for it to be parsed. | ||||||
|     [-]{.title-ref}, [/]{.title-ref}, etc) for it to be parsed. |  | ||||||
| 
 | 
 | ||||||
|     Defaults to none, which disables this feature. |     Defaults to none, which disables this feature. | ||||||
| 
 | 
 | ||||||
| @ -928,7 +925,7 @@ the literal path for that program. | |||||||
| 
 | 
 | ||||||
| These options don't have any effect in `paperless.conf`. These options | These options don't have any effect in `paperless.conf`. These options | ||||||
| adjust the behavior of the docker container. Configure these in | adjust the behavior of the docker container. Configure these in | ||||||
| [docker-compose.env]{.title-ref}. | `docker-compose.env`. | ||||||
| 
 | 
 | ||||||
| `PAPERLESS_WEBSERVER_WORKERS=<num>` | `PAPERLESS_WEBSERVER_WORKERS=<num>` | ||||||
| 
 | 
 | ||||||
| @ -946,7 +943,7 @@ increase RAM usage. | |||||||
| There are special setups where you may need to configure this value | There are special setups where you may need to configure this value | ||||||
| to restrict the Ip address or interface the webserver listens on. | to restrict the Ip address or interface the webserver listens on. | ||||||
| 
 | 
 | ||||||
|     Defaults to \[::\], meaning all interfaces, including IPv6. |     Defaults to `[::]`, meaning all interfaces, including IPv6. | ||||||
| 
 | 
 | ||||||
| `PAPERLESS_PORT=<port>` | `PAPERLESS_PORT=<port>` | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -39,16 +39,16 @@ guidelines](https://github.com/paperless-ngx/paperless-ngx/blob/main/CONTRIBUTIN | |||||||
| ## Code formatting with pre-commit Hooks | ## Code formatting with pre-commit Hooks | ||||||
| 
 | 
 | ||||||
| To ensure a consistent style and formatting across the project source, | To ensure a consistent style and formatting across the project source, | ||||||
| the project utilizes a Git [pre-commit]{.title-ref} hook to perform some | the project utilizes a Git [`pre-commit`](https://git-scm.com/book/en/v2/Customizing-Git-Git-Hooks) | ||||||
| formatting and linting before a commit is allowed. That way, everyone | hook to perform some formatting and linting before a commit is allowed. | ||||||
| uses the same style and some common issues can be caught early on. See | That way, everyone uses the same style and some common issues can be caught | ||||||
| below for installation instructions. | early on. See below for installation instructions. | ||||||
| 
 | 
 | ||||||
| Once installed, hooks will run when you commit. If the formatting isn't | Once installed, hooks will run when you commit. If the formatting isn't | ||||||
| quite right or a linter catches something, the commit will be rejected. | quite right or a linter catches something, the commit will be rejected. | ||||||
| You'll need to look at the output and fix the issue. Some hooks, such | You'll need to look at the output and fix the issue. Some hooks, such | ||||||
| as the Python formatting tool [black]{.title-ref}, will format failing | as the Python formatting tool `black`, will format failing | ||||||
| files, so all you need to do is [git add]{.title-ref} those files again | files, so all you need to do is `git add` those files again | ||||||
| and retry your commit. | and retry your commit. | ||||||
| 
 | 
 | ||||||
| ## Initial setup and first start | ## Initial setup and first start | ||||||
| @ -58,7 +58,7 @@ first-time setup. To do the setup you need to perform the steps from the | |||||||
| following chapters in a certain order: | following chapters in a certain order: | ||||||
| 
 | 
 | ||||||
| 1.  Install prerequisites + pipenv as mentioned in | 1.  Install prerequisites + pipenv as mentioned in | ||||||
|     `[Bare metal route](/setup#bare_metal) |     [Bare metal route](/setup#bare_metal) | ||||||
| 
 | 
 | ||||||
| 2.  Copy `paperless.conf.example` to `paperless.conf` and enable debug | 2.  Copy `paperless.conf.example` to `paperless.conf` and enable debug | ||||||
|     mode. |     mode. | ||||||
| @ -69,7 +69,7 @@ following chapters in a certain order: | |||||||
|     $ npm install -g @angular/cli |     $ npm install -g @angular/cli | ||||||
|     ``` |     ``` | ||||||
| 
 | 
 | ||||||
| 4.  Install pre-commit | 4.  Install pre-commit hooks | ||||||
| 
 | 
 | ||||||
|     ```shell-session |     ```shell-session | ||||||
|     pre-commit install |     pre-commit install | ||||||
| @ -81,7 +81,7 @@ following chapters in a certain order: | |||||||
|     mkdir -p consume media |     mkdir -p consume media | ||||||
|     ``` |     ``` | ||||||
| 
 | 
 | ||||||
| 6.  You can now either \... | 6.  You can now either ... | ||||||
| 
 | 
 | ||||||
|     - install redis or |     - install redis or | ||||||
| 
 | 
 | ||||||
| @ -91,9 +91,9 @@ following chapters in a certain order: | |||||||
| 
 | 
 | ||||||
|     - spin up a bare redis container |     - spin up a bare redis container | ||||||
| 
 | 
 | ||||||
|       > ```shell-session |       ```shell-session | ||||||
|       > docker run -d -p 6379:6379 --restart unless-stopped redis:latest |       docker run -d -p 6379:6379 --restart unless-stopped redis:latest | ||||||
|       > ``` |       ``` | ||||||
| 
 | 
 | ||||||
| 7.  Install the python dependencies by performing in the src/ directory. | 7.  Install the python dependencies by performing in the src/ directory. | ||||||
| 
 | 
 | ||||||
| @ -101,10 +101,12 @@ following chapters in a certain order: | |||||||
|     pipenv install --dev |     pipenv install --dev | ||||||
|     ``` |     ``` | ||||||
| 
 | 
 | ||||||
| > - Make sure you're using python 3.9.x or lower. Otherwise you might | !!! note | ||||||
| >   get issues with building dependencies. You can use | 
 | ||||||
| >   [pyenv](https://github.com/pyenv/pyenv) to install a specific |     Make sure you're using python 3.10.x or lower. Otherwise you might | ||||||
| >   python version. |     get issues with building dependencies. You can use | ||||||
|  |     [pyenv](https://github.com/pyenv/pyenv) to install a specific | ||||||
|  |     python version. | ||||||
| 
 | 
 | ||||||
| 8.  Generate the static UI so you can perform a login to get session | 8.  Generate the static UI so you can perform a login to get session | ||||||
|     that is required for frontend development (this needs to be done one |     that is required for frontend development (this needs to be done one | ||||||
| @ -126,9 +128,9 @@ following chapters in a certain order: | |||||||
|     you're developing for, you need to have some or all of them |     you're developing for, you need to have some or all of them | ||||||
|     running. |     running. | ||||||
| 
 | 
 | ||||||
| > ```shell-session |     ```shell-session | ||||||
| > python3 manage.py runserver & python3 manage.py document_consumer & celery --app paperless worker |     python3 manage.py runserver & python3 manage.py document_consumer & celery --app paperless worker | ||||||
| > ``` |     ``` | ||||||
| 
 | 
 | ||||||
| 11. Login with the superuser credentials provided in step 8 at | 11. Login with the superuser credentials provided in step 8 at | ||||||
|     `http://localhost:8000` to create a session that enables you to use |     `http://localhost:8000` to create a session that enables you to use | ||||||
| @ -140,15 +142,15 @@ development go to `/src-ui` and run `ng serve`. From there you can use | |||||||
| 
 | 
 | ||||||
| ## Back end development | ## Back end development | ||||||
| 
 | 
 | ||||||
| The backend is a django application. PyCharm works well for development, | The backend is a [Django](https://www.djangoproject.com/) application. PyCharm works well for development, | ||||||
| but you can use whatever you want. | but you can use whatever you want. | ||||||
| 
 | 
 | ||||||
| Configure the IDE to use the src/ folder as the base source folder. | Configure the IDE to use the src/ folder as the base source folder. | ||||||
| Configure the following launch configurations in your IDE: | Configure the following launch configurations in your IDE: | ||||||
| 
 | 
 | ||||||
| - python3 manage.py runserver | - `python3 manage.py runserver` | ||||||
| - celery \--app paperless worker | - `celery --app paperless worker` | ||||||
| - python3 manage.py document_consumer | - `python3 manage.py document_consumer` | ||||||
| 
 | 
 | ||||||
| To start them all: | To start them all: | ||||||
| 
 | 
 | ||||||
| @ -158,24 +160,26 @@ python3 manage.py runserver & python3 manage.py document_consumer & celery --app | |||||||
| 
 | 
 | ||||||
| Testing and code style: | Testing and code style: | ||||||
| 
 | 
 | ||||||
| - Run `pytest` in the src/ directory to execute all tests. This also | - Run `pytest` in the `src/` directory to execute all tests. This also | ||||||
|   generates a HTML coverage report. When runnings test, paperless.conf |   generates a HTML coverage report. When runnings test, paperless.conf | ||||||
|   is loaded as well. However: the tests rely on the default |   is loaded as well. However: the tests rely on the default | ||||||
|   configuration. This is not ideal. But for now, make sure no settings |   configuration. This is not ideal. But for now, make sure no settings | ||||||
|   except for DEBUG are overridden when testing. |   except for DEBUG are overridden when testing. | ||||||
| 
 | 
 | ||||||
| - Coding style is enforced by the Git pre-commit hooks. These will | - Coding style is enforced by the Git pre-commit hooks. These will | ||||||
|   ensure your code is formatted and do some linting when you do a [git |   ensure your code is formatted and do some linting when you do a `git commit`. | ||||||
|   commit]{.title-ref}. |  | ||||||
| 
 | 
 | ||||||
| - You can also run `black` manually to format your code | - You can also run `black` manually to format your code | ||||||
| 
 | 
 | ||||||
|  | - The `pre-commit` hooks will modify files and interact with each other. | ||||||
|  |   It may take a couple of `git add`, `git commit` cycle to satisfy them. | ||||||
|  | 
 | ||||||
| !!! note | !!! note | ||||||
| 
 | 
 | ||||||
|       The line length rule E501 is generally useful for getting multiple |       The line length rule E501 is generally useful for getting multiple | ||||||
|       source files next to each other on the screen. However, in some |       source files next to each other on the screen. However, in some | ||||||
|       cases, its just not possible to make some lines fit, especially |       cases, its just not possible to make some lines fit, especially | ||||||
|       complicated IF cases. Append `# NOQA: E501` to disable this check |       complicated IF cases. Append `# noqa: E501` to disable this check | ||||||
|       for certain lines. |       for certain lines. | ||||||
| 
 | 
 | ||||||
| ## Front end development | ## Front end development | ||||||
| @ -353,7 +357,8 @@ LANGUAGES = [ | |||||||
| 
 | 
 | ||||||
| ## Building the documentation | ## Building the documentation | ||||||
| 
 | 
 | ||||||
| The documentation is built using material-mkdocs, see their [documentation](https://squidfunk.github.io/mkdocs-material/reference/). If you want to build the documentation locally, this is how you do it: | The documentation is built using material-mkdocs, see their [documentation](https://squidfunk.github.io/mkdocs-material/reference/). | ||||||
|  | If you want to build the documentation locally, this is how you do it: | ||||||
| 
 | 
 | ||||||
| 1.  Install python dependencies. | 1.  Install python dependencies. | ||||||
| 
 | 
 | ||||||
| @ -366,7 +371,7 @@ The documentation is built using material-mkdocs, see their [documentation](http | |||||||
| 
 | 
 | ||||||
|     ```shell-session |     ```shell-session | ||||||
|     $ cd /path/to/paperless |     $ cd /path/to/paperless | ||||||
|     $ pipenv mkdocs build |     $ pipenv mkdocs build --config-file mkdocs.yml | ||||||
|     ``` |     ``` | ||||||
| 
 | 
 | ||||||
| ## Building the Docker image | ## Building the Docker image | ||||||
| @ -379,9 +384,9 @@ helper script `build-docker-image.sh`. | |||||||
| 
 | 
 | ||||||
| Building the docker image from source: | Building the docker image from source: | ||||||
| 
 | 
 | ||||||
| > ```shell-session | ```shell-session | ||||||
| > ./build-docker-image.sh Dockerfile -t <your-tag> | ./build-docker-image.sh Dockerfile -t <your-tag> | ||||||
| > ``` | ``` | ||||||
| 
 | 
 | ||||||
| ## Extending Paperless | ## Extending Paperless | ||||||
| 
 | 
 | ||||||
| @ -428,7 +433,7 @@ class MyCustomParser(DocumentParser): | |||||||
|     def get_thumbnail(self, document_path, mime_type): |     def get_thumbnail(self, document_path, mime_type): | ||||||
|         # This should return the path to a thumbnail you created for this |         # This should return the path to a thumbnail you created for this | ||||||
|         # document. |         # document. | ||||||
|         return os.path.join(self.tempdir, "thumb.png") |         return os.path.join(self.tempdir, "thumb.webp") | ||||||
| ``` | ``` | ||||||
| 
 | 
 | ||||||
| If you encounter any issues during parsing, raise a | If you encounter any issues during parsing, raise a | ||||||
|  | |||||||
							
								
								
									
										32
									
								
								docs/faq.md
									
									
									
									
									
								
							
							
						
						
									
										32
									
								
								docs/faq.md
									
									
									
									
									
								
							| @ -1,6 +1,6 @@ | |||||||
| # Frequently Asked Questions | # Frequently Asked Questions | ||||||
| 
 | 
 | ||||||
| ### _What's the general plan for Paperless-ngx?_ | ## _What's the general plan for Paperless-ngx?_ | ||||||
| 
 | 
 | ||||||
| **A:** While Paperless-ngx is already considered largely | **A:** While Paperless-ngx is already considered largely | ||||||
| "feature-complete" it is a community-driven project and development | "feature-complete" it is a community-driven project and development | ||||||
| @ -9,7 +9,7 @@ discussions and "up-voted" by the community but this is not a | |||||||
| guarantee the feature will be implemented. This project will always be | guarantee the feature will be implemented. This project will always be | ||||||
| open to collaboration in the form of PRs, ideas etc. | open to collaboration in the form of PRs, ideas etc. | ||||||
| 
 | 
 | ||||||
| ### _I'm using docker. Where are my documents?_ | ## _I'm using docker. Where are my documents?_ | ||||||
| 
 | 
 | ||||||
| **A:** Your documents are stored inside the docker volume | **A:** Your documents are stored inside the docker volume | ||||||
| `paperless_media`. Docker manages this volume automatically for you. It | `paperless_media`. Docker manages this volume automatically for you. It | ||||||
| @ -27,9 +27,7 @@ system. On Linux, chances are high that this location is | |||||||
|     files around manually. This folder is meant to be entirely managed by |     files around manually. This folder is meant to be entirely managed by | ||||||
|     docker and paperless. |     docker and paperless. | ||||||
| 
 | 
 | ||||||
| ### Let's say I want to switch tools in a year. Can I easily move | ## Let's say I want to switch tools in a year. Can I easily move to other systems? | ||||||
| 
 |  | ||||||
| to other systems?\* |  | ||||||
| 
 | 
 | ||||||
| **A:** Your documents are stored as plain files inside the media folder. | **A:** Your documents are stored as plain files inside the media folder. | ||||||
| You can always drag those files out of that folder to use them | You can always drag those files out of that folder to use them | ||||||
| @ -41,17 +39,17 @@ elsewhere. Here are a couple notes about that. | |||||||
| - By default, paperless uses the internal ID of each document as its | - By default, paperless uses the internal ID of each document as its | ||||||
|   filename. This might not be very convenient for export. However, you |   filename. This might not be very convenient for export. However, you | ||||||
|   can adjust the way files are stored in paperless by |   can adjust the way files are stored in paperless by | ||||||
|   [configuring the filename format](advanced_usage#file_name_handling). |   [configuring the filename format](advanced_usage#file-name-handling). | ||||||
| - [The exporter](administration#exporter) is | - [The exporter](administration#exporter) is | ||||||
|   another easy way to get your files out of paperless with reasonable |   another easy way to get your files out of paperless with reasonable | ||||||
|   file names. |   file names. | ||||||
| 
 | 
 | ||||||
| ### _What file types does paperless-ngx support?_ | ## _What file types does paperless-ngx support?_ | ||||||
| 
 | 
 | ||||||
| **A:** Currently, the following files are supported: | **A:** Currently, the following files are supported: | ||||||
| 
 | 
 | ||||||
| - PDF documents, PNG images, JPEG images, TIFF images and GIF images | - PDF documents, PNG images, JPEG images, TIFF images, GIF images and | ||||||
|   are processed with OCR and converted into PDF documents. |   WebP images are processed with OCR and converted into PDF documents. | ||||||
| - Plain text documents are supported as well and are added verbatim to | - Plain text documents are supported as well and are added verbatim to | ||||||
|   paperless. |   paperless. | ||||||
| - With the optional Tika integration enabled (see [Tika configuration](configuration#tika), | - With the optional Tika integration enabled (see [Tika configuration](configuration#tika), | ||||||
| @ -61,7 +59,7 @@ elsewhere. Here are a couple notes about that. | |||||||
| Paperless-ngx determines the type of a file by inspecting its content. | Paperless-ngx determines the type of a file by inspecting its content. | ||||||
| The file extensions do not matter. | The file extensions do not matter. | ||||||
| 
 | 
 | ||||||
| ### _Will paperless-ngx run on Raspberry Pi?_ | ## _Will paperless-ngx run on Raspberry Pi?_ | ||||||
| 
 | 
 | ||||||
| **A:** The short answer is yes. I've tested it on a Raspberry Pi 3 B. | **A:** The short answer is yes. I've tested it on a Raspberry Pi 3 B. | ||||||
| The long answer is that certain parts of Paperless will run very slow, | The long answer is that certain parts of Paperless will run very slow, | ||||||
| @ -73,11 +71,11 @@ has to do much less work to serve the data. | |||||||
| !!! note | !!! note | ||||||
| 
 | 
 | ||||||
|     You can adjust some of the settings so that paperless uses less |     You can adjust some of the settings so that paperless uses less | ||||||
|     processing power. See [setup](setup#less_powerful_devices) for details. |     processing power. See [setup](setup#less-powerful-devices) for details. | ||||||
| 
 | 
 | ||||||
| ### _How do I install paperless-ngx on Raspberry Pi?_ | ## _How do I install paperless-ngx on Raspberry Pi?_ | ||||||
| 
 | 
 | ||||||
| **A:** Docker images are available for arm and arm64 hardware, so just | **A:** Docker images are available for armv7 and arm64 hardware, so just | ||||||
| follow the docker-compose instructions. Apart from more required disk | follow the docker-compose instructions. Apart from more required disk | ||||||
| space compared to a bare metal installation, docker comes with close to | space compared to a bare metal installation, docker comes with close to | ||||||
| zero overhead, even on Raspberry Pi. | zero overhead, even on Raspberry Pi. | ||||||
| @ -87,13 +85,13 @@ the python requirements do not have precompiled packages for ARM / | |||||||
| ARM64. Installation of these will require additional development | ARM64. Installation of these will require additional development | ||||||
| libraries and compilation will take a long time. | libraries and compilation will take a long time. | ||||||
| 
 | 
 | ||||||
| ### _How do I run this on Unraid?_ | ## _How do I run this on Unraid?_ | ||||||
| 
 | 
 | ||||||
| **A:** Paperless-ngx is available as [community | **A:** Paperless-ngx is available as [community | ||||||
| app](https://unraid.net/community/apps?q=paperless-ngx) in Unraid. [Uli | app](https://unraid.net/community/apps?q=paperless-ngx) in Unraid. [Uli | ||||||
| Fahrer](https://github.com/Tooa) created a container template for that. | Fahrer](https://github.com/Tooa) created a container template for that. | ||||||
| 
 | 
 | ||||||
| ### _How do I run this on my toaster?_ | ## _How do I run this on my toaster?_ | ||||||
| 
 | 
 | ||||||
| **A:** I honestly don't know! As for all other devices that might be | **A:** I honestly don't know! As for all other devices that might be | ||||||
| able to run paperless, you're a bit on your own. If you can't run the | able to run paperless, you're a bit on your own. If you can't run the | ||||||
| @ -103,11 +101,11 @@ This is also what I use to test new releases with. Apart from that, I | |||||||
| also have a Raspberry Pi, which I occasionally build the image on and | also have a Raspberry Pi, which I occasionally build the image on and | ||||||
| see if it works. | see if it works. | ||||||
| 
 | 
 | ||||||
| ### _How do I proxy this with NGINX?_ | ## _How do I proxy this with NGINX?_ | ||||||
| 
 | 
 | ||||||
| **A:** See [here](setup#nginx). | **A:** See [here](setup#nginx). | ||||||
| 
 | 
 | ||||||
| ### _How do I get WebSocket support with Apache mod_wsgi_? | ## _How do I get WebSocket support with Apache mod_wsgi_? | ||||||
| 
 | 
 | ||||||
| **A:** `mod_wsgi` by itself does not support ASGI. Paperless will | **A:** `mod_wsgi` by itself does not support ASGI. Paperless will | ||||||
| continue to work with WSGI, but certain features such as status | continue to work with WSGI, but certain features such as status | ||||||
|  | |||||||
| @ -50,7 +50,7 @@ If you want to learn about what's different in paperless-ngx from | |||||||
| Paperless, check out these resources in the documentation: | Paperless, check out these resources in the documentation: | ||||||
| 
 | 
 | ||||||
| - [Some screenshots](#screenshots) of the new UI are available. | - [Some screenshots](#screenshots) of the new UI are available. | ||||||
| - Read [this section](/advanced_usage/#advanced-automatic_matching) if you want to learn about how paperless automates all | - Read [this section](/advanced_usage/#advanced-automatic-matching) if you want to learn about how paperless automates all | ||||||
|   tagging using machine learning. |   tagging using machine learning. | ||||||
| - Paperless now comes with a [proper email consumer](/usage/#usage-email) that's fully tested and production ready. | - Paperless now comes with a [proper email consumer](/usage/#usage-email) that's fully tested and production ready. | ||||||
| - Paperless creates searchable PDF/A documents from whatever you put into the consumption directory. This means | - Paperless creates searchable PDF/A documents from whatever you put into the consumption directory. This means | ||||||
|  | |||||||
| @ -767,7 +767,7 @@ After that, you need to clear your cookies (Paperless-ngx comes with | |||||||
| updated dependencies that do cookie-processing differently) and probably | updated dependencies that do cookie-processing differently) and probably | ||||||
| your cache as well. | your cache as well. | ||||||
| 
 | 
 | ||||||
| # Considerations for less powerful devices {#less_powerful_devices} | # Considerations for less powerful devices {#less-powerful-devices} | ||||||
| 
 | 
 | ||||||
| Paperless runs on Raspberry Pi. However, some things are rather slow on | Paperless runs on Raspberry Pi. However, some things are rather slow on | ||||||
| the Pi and configuring some options in paperless can help improve | the Pi and configuring some options in paperless can help improve | ||||||
| @ -803,7 +803,7 @@ For details, refer to [configuration](configuration). | |||||||
| !!! note | !!! note | ||||||
| 
 | 
 | ||||||
|     Updating the |     Updating the | ||||||
|     [automatic matching algorithm](/advanced_usage#automatic_matching) takes quite a bit of time. However, the update mechanism |     [automatic matching algorithm](/advanced_usage#automatic-matching) takes quite a bit of time. However, the update mechanism | ||||||
|     checks if your data has changed before doing the heavy lifting. If you |     checks if your data has changed before doing the heavy lifting. If you | ||||||
|     experience the algorithm taking too much cpu time, consider changing the |     experience the algorithm taking too much cpu time, consider changing the | ||||||
|     schedule in the admin interface to daily. You can also manually invoke |     schedule in the admin interface to daily. You can also manually invoke | ||||||
|  | |||||||
| @ -1,9 +1,9 @@ | |||||||
| # Usage Overview | # Usage Overview | ||||||
| 
 | 
 | ||||||
| Paperless is an application that manages your personal documents. With | Paperless is an application that manages your personal documents. With | ||||||
| the help of a document scanner (see [the scanners wiki](https://github.com/paperless-ngx/paperless-ngx/wiki/Scanner-&-Software-Recommendations)), paperless transforms your wieldy physical document binders | the help of a document scanner (see [the scanners wiki](https://github.com/paperless-ngx/paperless-ngx/wiki/Scanner-&-Software-Recommendations)), | ||||||
| into a searchable archive and provides many utilities for finding and | paperless transforms your unwieldy physical document binders into a searchable archive | ||||||
| managing your documents. | and provides many utilities for finding and managing your documents. | ||||||
| 
 | 
 | ||||||
| ## Terms and definitions | ## Terms and definitions | ||||||
| 
 | 
 | ||||||
| @ -37,7 +37,7 @@ Each document has a couple of fields that you can assign to them: | |||||||
|   date you signed a contract, or the date a letter was sent to you. |   date you signed a contract, or the date a letter was sent to you. | ||||||
| - The _archive serial number_ (short: ASN) of a document is the | - The _archive serial number_ (short: ASN) of a document is the | ||||||
|   identifier of the document in your physical document binders. See |   identifier of the document in your physical document binders. See | ||||||
|   [recommended workflow](#usage-reccomended_workflow) below. |   [recommended workflow](#usage-recommended-workflow) below. | ||||||
| - The _content_ of a document is the text that was OCR'ed from the | - The _content_ of a document is the text that was OCR'ed from the | ||||||
|   document. This text is fed into the search engine and is used for |   document. This text is fed into the search engine and is used for | ||||||
|   matching tags, correspondents and document types. |   matching tags, correspondents and document types. | ||||||
| @ -74,8 +74,8 @@ following operations on your documents: | |||||||
| ### The consumption directory | ### The consumption directory | ||||||
| 
 | 
 | ||||||
| The primary method of getting documents into your database is by putting | The primary method of getting documents into your database is by putting | ||||||
| them in the consumption directory. The consumer runs in an infinite | them in the consumption directory. The consumer waits patiently, looking | ||||||
| loop, looking for new additions to this directory. When it finds them, | for new additions to this directory. When it finds them, | ||||||
| the consumer goes about the process of parsing them with the OCR, | the consumer goes about the process of parsing them with the OCR, | ||||||
| indexing what it finds, and storing it in the media directory. | indexing what it finds, and storing it in the media directory. | ||||||
| 
 | 
 | ||||||
| @ -99,7 +99,7 @@ dragging-and-dropping files into your browser window. | |||||||
| 
 | 
 | ||||||
| ### Mobile upload {#usage-mobile_upload} | ### Mobile upload {#usage-mobile_upload} | ||||||
| 
 | 
 | ||||||
| The mobile app over at <https://github.com/qcasey/paperless_share> | The mobile app over at [https://github.com/qcasey/paperless_share](https://github.com/qcasey/paperless_share) | ||||||
| allows Android users to share any documents with paperless. This can be | allows Android users to share any documents with paperless. This can be | ||||||
| combined with any of the mobile scanning apps out there, such as Office | combined with any of the mobile scanning apps out there, such as Office | ||||||
| Lens. | Lens. | ||||||
| @ -325,7 +325,7 @@ language](https://whoosh.readthedocs.io/en/latest/querylang.html). For | |||||||
| details on what date parsing utilities are available, see [Date | details on what date parsing utilities are available, see [Date | ||||||
| parsing](https://whoosh.readthedocs.io/en/latest/dates.html#parsing-date-queries). | parsing](https://whoosh.readthedocs.io/en/latest/dates.html#parsing-date-queries). | ||||||
| 
 | 
 | ||||||
| ## The recommended workflow {#usage-recommended_workflow} | ## The recommended workflow {#usage-recommended-workflow} | ||||||
| 
 | 
 | ||||||
| Once you have familiarized yourself with paperless and are ready to use | Once you have familiarized yourself with paperless and are ready to use | ||||||
| it for all your documents, the recommended workflow for managing your | it for all your documents, the recommended workflow for managing your | ||||||
|  | |||||||
| @ -23,6 +23,7 @@ theme: | |||||||
|     - navigation.tabs |     - navigation.tabs | ||||||
|     - navigation.top |     - navigation.top | ||||||
|     - toc.integrate |     - toc.integrate | ||||||
|  |     - content.code.annotate | ||||||
|   icon: |   icon: | ||||||
|     repo: fontawesome/brands/github |     repo: fontawesome/brands/github | ||||||
|   favicon: assets/favicon.png |   favicon: assets/favicon.png | ||||||
| @ -39,6 +40,8 @@ markdown_extensions: | |||||||
|   - pymdownx.highlight: |   - pymdownx.highlight: | ||||||
|       anchor_linenums: true |       anchor_linenums: true | ||||||
|   - pymdownx.superfences |   - pymdownx.superfences | ||||||
|  |   - pymdownx.inlinehilite | ||||||
|  | strict: true | ||||||
| nav: | nav: | ||||||
|     - index.md |     - index.md | ||||||
|     - setup.md |     - setup.md | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user