Documentation enhancement: add direct links for all config vars (#4237)

This commit is contained in:
shamoon 2023-09-22 11:12:47 -07:00 committed by GitHub
parent 7c8b501c40
commit 379b4f8cd3
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
7 changed files with 163 additions and 142 deletions

View File

@ -286,7 +286,7 @@ other files.
The filenames generated by this command follow the format The filenames generated by this command follow the format
`[date created] [correspondent] [title].[extension]`. If you want `[date created] [correspondent] [title].[extension]`. If you want
paperless to use `PAPERLESS_FILENAME_FORMAT` for exported filenames paperless to use [`PAPERLESS_FILENAME_FORMAT`](/configuration#PAPERLESS_FILENAME_FORMAT) for exported filenames
instead, specify `-f` or `--use-filename-format`. instead, specify `-f` or `--use-filename-format`.
If `-na` or `--no-archive` is provided, no archive files will be exported, If `-na` or `--no-archive` is provided, no archive files will be exported,
@ -560,7 +560,7 @@ Enabling encryption is no longer supported.
Basic usage to disable encryption of your document store: Basic usage to disable encryption of your document store:
(Note: If `PAPERLESS_PASSPHRASE` isn't set already, you need to specify (Note: If [`PAPERLESS_PASSPHRASE`](/configuration#PAPERLESS_PASSPHRASE) isn't set already, you need to specify
it here) it here)
``` ```

View File

@ -107,7 +107,7 @@ document is consumed using a couple of simple hooks.
Just write a script, put it somewhere that Paperless can read & execute, Just write a script, put it somewhere that Paperless can read & execute,
and then put the path to that script in `paperless.conf` or and then put the path to that script in `paperless.conf` or
`docker-compose.env` with the variable name of either `docker-compose.env` with the variable name of either
`PAPERLESS_PRE_CONSUME_SCRIPT` or `PAPERLESS_POST_CONSUME_SCRIPT`. [`PAPERLESS_PRE_CONSUME_SCRIPT`](/configuration#PAPERLESS_PRE_CONSUME_SCRIPT) or [`PAPERLESS_POST_CONSUME_SCRIPT`](/configuration#PAPERLESS_POST_CONSUME_SCRIPT).
!!! info !!! info
@ -249,7 +249,7 @@ document. You will end up getting files like `0000123.pdf` in your media
directory. This isn't necessarily a bad thing, because you normally directory. This isn't necessarily a bad thing, because you normally
don't have to access these files manually. However, if you wish to name don't have to access these files manually. However, if you wish to name
your files differently, you can do that by adjusting the your files differently, you can do that by adjusting the
`PAPERLESS_FILENAME_FORMAT` configuration option. Paperless adds the [`PAPERLESS_FILENAME_FORMAT`](/configuration#PAPERLESS_FILENAME_FORMAT) configuration option. Paperless adds the
correct file extension e.g. `.pdf`, `.jpg` automatically. correct file extension e.g. `.pdf`, `.jpg` automatically.
This variable allows you to configure the filename (folders are allowed) This variable allows you to configure the filename (folders are allowed)
@ -377,7 +377,7 @@ When a 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` and - Each storage path is a [`PAPERLESS_FILENAME_FORMAT`](/configuration#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
@ -417,7 +417,7 @@ Insurances/ # Insurances
!!! 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` is applied. document, the global [`PAPERLESS_FILENAME_FORMAT`](/configuration#PAPERLESS_FILENAME_FORMAT) is applied.
## Celery Monitoring {#celery-monitoring} ## Celery Monitoring {#celery-monitoring}

View File

@ -34,3 +34,24 @@
.index-callout { .index-callout {
margin-right: .5rem; margin-right: .5rem;
} }
/* make code in headers not bold */
h4 code {
font-weight: normal;
}
/* Hide config vars from sidebar, toc and move the border on mobile case their hidden */
.md-nav.md-nav--secondary .md-nav__item .md-nav__link[href*="PAPERLESS_"],
.md-nav.md-nav--secondary .md-nav__item .md-nav__link[href*="USERMAP_"] {
display: none;
}
@media screen and (max-width: 76.1875em) {
.md-nav--primary .md-nav__item {
border-top: none;
}
.md-nav--primary .md-nav__link {
border-top: .05rem solid var(--md-default-fg-color--lightest);
}
}

View File

@ -19,7 +19,7 @@ run paperless, these settings have to be defined in different places.
### Redis Broker ### Redis Broker
`PAPERLESS_REDIS=<url>` #### [`PAPERLESS_REDIS=<url>`](#PAPERLESS_REDIS) {#PAPERLESS_REDIS}
: This is required for processing scheduled tasks such as email : This is required for processing scheduled tasks such as email
fetching, index optimization and for training the automatic document fetching, index optimization and for training the automatic document
@ -35,7 +35,7 @@ matcher.
Defaults to `redis://localhost:6379`. Defaults to `redis://localhost:6379`.
`PAPERLESS_REDIS_PREFIX=<prefix>` #### [`PAPERLESS_REDIS_PREFIX=<prefix>`](#PAPERLESS_REDIS_PREFIX) {#PAPERLESS_REDIS_PREFIX}
: Prefix to be used in Redis for keys and channels. Useful for sharing one Redis server among multiple Paperless instances. : Prefix to be used in Redis for keys and channels. Useful for sharing one Redis server among multiple Paperless instances.
@ -43,7 +43,7 @@ matcher.
### Database ### Database
`PAPERLESS_DBENGINE=<engine_name>` #### [`PAPERLESS_DBENGINE=<engine_name>`](#PAPERLESS_DBENGINE) {#PAPERLESS_DBENGINE}
: 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` and database engine. Available options are `postgresql` and
@ -55,7 +55,7 @@ database engine. Available options are `postgresql` and
Using MariaDB comes with some caveats. See [MySQL Caveats](/advanced_usage#mysql-caveats). Using MariaDB comes with some caveats. See [MySQL Caveats](/advanced_usage#mysql-caveats).
`PAPERLESS_DBHOST=<hostname>` #### [`PAPERLESS_DBHOST=<hostname>`](#PAPERLESS_DBHOST) {#PAPERLESS_DBHOST}
: By default, sqlite is used as the database backend. This can be : By default, sqlite is used as the database backend. This can be
changed here. changed here.
@ -63,31 +63,31 @@ changed here.
Set PAPERLESS_DBHOST and another database will be used instead of Set PAPERLESS_DBHOST and another database will be used instead of
sqlite. sqlite.
`PAPERLESS_DBPORT=<port>` #### [`PAPERLESS_DBPORT=<port>`](#PAPERLESS_DBPORT) {#PAPERLESS_DBPORT}
: Adjust port if necessary. : Adjust port if necessary.
Default is 5432. Default is 5432.
`PAPERLESS_DBNAME=<name>` #### [`PAPERLESS_DBNAME=<name>`](#PAPERLESS_DBNAME) {#PAPERLESS_DBNAME}
: Database name in PostgreSQL or MariaDB. : Database name in PostgreSQL or MariaDB.
Defaults to "paperless". Defaults to "paperless".
`PAPERLESS_DBUSER=<name>` #### [`PAPERLESS_DBUSER=<name>`](#PAPERLESS_DBUSER) {#PAPERLESS_DBUSER}
: Database user in PostgreSQL or MariaDB. : Database user in PostgreSQL or MariaDB.
Defaults to "paperless". Defaults to "paperless".
`PAPERLESS_DBPASS=<password>` #### [`PAPERLESS_DBPASS=<password>`](#PAPERLESS_DBPASS) {#PAPERLESS_DBPASS}
: Database password for PostgreSQL or MariaDB. : Database password for PostgreSQL or MariaDB.
Defaults to "paperless". Defaults to "paperless".
`PAPERLESS_DBSSLMODE=<mode>` #### [`PAPERLESS_DBSSLMODE=<mode>`](#PAPERLESS_DBSSLMODE) {#PAPERLESS_DBSSLMODE}
: SSL mode to use when connecting to PostgreSQL or MariaDB. : SSL mode to use when connecting to PostgreSQL or MariaDB.
@ -101,7 +101,7 @@ changed here.
Default is `prefer` for PostgreSQL and `PREFERRED` for MariaDB. Default is `prefer` for PostgreSQL and `PREFERRED` for MariaDB.
`PAPERLESS_DBSSLROOTCERT=<ca-path>` #### [`PAPERLESS_DBSSLROOTCERT=<ca-path>`](#PAPERLESS_DBSSLROOTCERT) {#PAPERLESS_DBSSLROOTCERT}
: SSL root certificate path : SSL root certificate path
@ -114,7 +114,7 @@ changed here.
Defaults to unset, using the documented path in the home directory. Defaults to unset, using the documented path in the home directory.
`PAPERLESS_DBSSLCERT=<client-cert-path>` #### [`PAPERLESS_DBSSLCERT=<client-cert-path>`](#PAPERLESS_DBSSLCERT) {#PAPERLESS_DBSSLCERT}
: SSL client certificate path : SSL client certificate path
@ -128,7 +128,7 @@ changed here.
Defaults to unset, using the documented path in the home directory. Defaults to unset, using the documented path in the home directory.
`PAPERLESS_DBSSLKEY=<client-cert-key>` #### [`PAPERLESS_DBSSLKEY=<client-cert-key>`](#PAPERLESS_DBSSLKEY) {#PAPERLESS_DBSSLKEY}
: SSL client key path : SSL client key path
@ -142,7 +142,7 @@ changed here.
Defaults to unset, using the documented path in the home directory. Defaults to unset, using the documented path in the home directory.
`PAPERLESS_DB_TIMEOUT=<int>` #### [`PAPERLESS_DB_TIMEOUT=<int>`](#PAPERLESS_DB_TIMEOUT) {#PAPERLESS_DB_TIMEOUT}
: Amount of time for a database connection to wait for the database to : Amount of time for a database connection to wait for the database to
unlock. Mostly applicable for sqlite based installation. Consider changing unlock. Mostly applicable for sqlite based installation. Consider changing
@ -162,19 +162,19 @@ Tika and Gotenberg are also needed to allow parsing of E-Mails (.eml).
If you wish to use this, you must provide a Tika server and a Gotenberg server, If you wish to use this, you must provide a Tika server and a Gotenberg server,
configure their endpoints, and enable the feature. configure their endpoints, and enable the feature.
`PAPERLESS_TIKA_ENABLED=<bool>` #### [`PAPERLESS_TIKA_ENABLED=<bool>`](#PAPERLESS_TIKA_ENABLED) {#PAPERLESS_TIKA_ENABLED}
: Enable (or disable) the Tika parser. : Enable (or disable) the Tika parser.
Defaults to false. Defaults to false.
`PAPERLESS_TIKA_ENDPOINT=<url>` #### [`PAPERLESS_TIKA_ENDPOINT=<url>`](#PAPERLESS_TIKA_ENDPOINT) {#PAPERLESS_TIKA_ENDPOINT}
: Set the endpoint URL were Paperless can reach your Tika server. : Set the endpoint URL were Paperless can reach your Tika server.
Defaults to "<http://localhost:9998>". Defaults to "<http://localhost:9998>".
`PAPERLESS_TIKA_GOTENBERG_ENDPOINT=<url>` #### [`PAPERLESS_TIKA_GOTENBERG_ENDPOINT=<url>`](#PAPERLESS_TIKA_GOTENBERG_ENDPOINT) {#PAPERLESS_TIKA_GOTENBERG_ENDPOINT}
: Set the endpoint URL were Paperless can reach your Gotenberg server. : Set the endpoint URL were Paperless can reach your Gotenberg server.
@ -193,7 +193,7 @@ and watch out for indentation if editing the YAML file.
## Paths and folders ## Paths and folders
`PAPERLESS_CONSUMPTION_DIR=<path>` #### [`PAPERLESS_CONSUMPTION_DIR=<path>`](#PAPERLESS_CONSUMPTION_DIR) {#PAPERLESS_CONSUMPTION_DIR}
: This where your documents should go to be consumed. Make sure that : This where your documents should go to be consumed. Make sure that
it exists and that the user running the paperless service can it exists and that the user running the paperless service can
@ -205,14 +205,14 @@ read/write its contents before you start Paperless.
Defaults to "../consume/", relative to the "src" directory. Defaults to "../consume/", relative to the "src" directory.
`PAPERLESS_DATA_DIR=<path>` #### [`PAPERLESS_DATA_DIR=<path>`](#PAPERLESS_DATA_DIR) {#PAPERLESS_DATA_DIR}
: This is where paperless stores all its data (search index, SQLite : This is where paperless stores all its data (search index, SQLite
database, classification model, etc). database, classification model, etc).
Defaults to "../data/", relative to the "src" directory. Defaults to "../data/", relative to the "src" directory.
`PAPERLESS_TRASH_DIR=<path>` #### [`PAPERLESS_TRASH_DIR=<path>`](#PAPERLESS_TRASH_DIR) {#PAPERLESS_TRASH_DIR}
: Instead of removing deleted documents, they are moved to this : Instead of removing deleted documents, they are moved to this
directory. directory.
@ -223,7 +223,7 @@ directory.
Defaults to empty (i.e. really delete documents). Defaults to empty (i.e. really delete documents).
`PAPERLESS_MEDIA_ROOT=<path>` #### [`PAPERLESS_MEDIA_ROOT=<path>`](#PAPERLESS_MEDIA_ROOT) {#PAPERLESS_MEDIA_ROOT}
: This is where your documents and thumbnails are stored. : This is where your documents and thumbnails are stored.
@ -232,7 +232,7 @@ directory.
Defaults to "../media/", relative to the "src" directory. Defaults to "../media/", relative to the "src" directory.
`PAPERLESS_STATICDIR=<path>` #### [`PAPERLESS_STATICDIR=<path>`](#PAPERLESS_STATICDIR) {#PAPERLESS_STATICDIR}
: Override the default STATIC_ROOT here. This is where all static : Override the default STATIC_ROOT here. This is where all static
files created using "collectstatic" manager command are stored. files created using "collectstatic" manager command are stored.
@ -243,14 +243,14 @@ files created using "collectstatic" manager command are stored.
Defaults to "../static/", relative to the "src" directory. Defaults to "../static/", relative to the "src" directory.
`PAPERLESS_FILENAME_FORMAT=<format>` #### [`PAPERLESS_FILENAME_FORMAT=<format>`](#PAPERLESS_FILENAME_FORMAT) {#PAPERLESS_FILENAME_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>`](#PAPERLESS_FILENAME_FORMAT_REMOVE_NONE) {#PAPERLESS_FILENAME_FORMAT_REMOVE_NONE}
: Tells paperless to replace placeholders in : Tells paperless to replace placeholders in
`PAPERLESS_FILENAME_FORMAT` that would resolve to `PAPERLESS_FILENAME_FORMAT` that would resolve to
@ -260,13 +260,13 @@ details.
Defaults to `false` which disables this feature. Defaults to `false` which disables this feature.
`PAPERLESS_LOGGING_DIR=<path>` #### [`PAPERLESS_LOGGING_DIR=<path>`](#PAPERLESS_LOGGING_DIR) {#PAPERLESS_LOGGING_DIR}
: 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/`.
`PAPERLESS_NLTK_DIR=<path>` #### [`PAPERLESS_NLTK_DIR=<path>`](#PAPERLESS_NLTK_DIR) {#PAPERLESS_NLTK_DIR}
: This is where paperless will search for the data required for NLTK : This is where paperless will search for the data required for NLTK
processing, if you are using it. If you are using the Docker image, processing, if you are using it. If you are using the Docker image,
@ -281,13 +281,13 @@ Defaults to `/usr/share/nltk_data`
## Logging ## Logging
`PAPERLESS_LOGROTATE_MAX_SIZE=<num>` #### [`PAPERLESS_LOGROTATE_MAX_SIZE=<num>`](#PAPERLESS_LOGROTATE_MAX_SIZE) {#PAPERLESS_LOGROTATE_MAX_SIZE}
: Maximum file size for log files before they are rotated, in bytes. : Maximum file size for log files before they are rotated, in bytes.
Defaults to 1 MiB. Defaults to 1 MiB.
`PAPERLESS_LOGROTATE_MAX_BACKUPS=<num>` #### [`PAPERLESS_LOGROTATE_MAX_BACKUPS=<num>`](#PAPERLESS_LOGROTATE_MAX_BACKUPS) {#PAPERLESS_LOGROTATE_MAX_BACKUPS}
: Number of rotated log files to keep. : Number of rotated log files to keep.
@ -295,7 +295,7 @@ Defaults to `/usr/share/nltk_data`
## Hosting & Security {#hosting-and-security} ## Hosting & Security {#hosting-and-security}
`PAPERLESS_SECRET_KEY=<key>` #### [`PAPERLESS_SECRET_KEY=<key>`](#PAPERLESS_SECRET_KEY) {#PAPERLESS_SECRET_KEY}
: Paperless uses this to make session tokens. If you expose paperless : Paperless uses this to make session tokens. If you expose paperless
on the internet, you need to change this, since the default secret on the internet, you need to change this, since the default secret
@ -306,7 +306,7 @@ is well known.
Default is listed in the file `src/paperless/settings.py`. Default is listed in the file `src/paperless/settings.py`.
`PAPERLESS_URL=<url>` #### [`PAPERLESS_URL=<url>`](#PAPERLESS_URL) {#PAPERLESS_URL}
: This setting can be used to set the three options below : This setting can be used to set the three options below
(ALLOWED_HOSTS, CORS_ALLOWED_HOSTS and CSRF_TRUSTED_ORIGINS). If the (ALLOWED_HOSTS, CORS_ALLOWED_HOSTS and CSRF_TRUSTED_ORIGINS). If the
@ -320,7 +320,7 @@ not include a trailing slash. E.g. <https://paperless.domain.com>
This value cannot contain a path (e.g. domain.com/path), even if This value cannot contain a path (e.g. domain.com/path), even if
you are installing paperless-ngx at a subpath. you are installing paperless-ngx at a subpath.
`PAPERLESS_CSRF_TRUSTED_ORIGINS=<comma-separated-list>` #### [`PAPERLESS_CSRF_TRUSTED_ORIGINS=<comma-separated-list>`](#PAPERLESS_CSRF_TRUSTED_ORIGINS) {#PAPERLESS_CSRF_TRUSTED_ORIGINS}
: A list of trusted origins for unsafe requests (e.g. POST). As of : A list of trusted origins for unsafe requests (e.g. POST). As of
Django 4.0 this is required to access the Django admin via the web. Django 4.0 this is required to access the Django admin via the web.
@ -331,7 +331,7 @@ See the [Django project documentation on the settings](https://docs.djangoprojec
Defaults to empty string, which does not add any origins to the Defaults to empty string, which does not add any origins to the
trusted list. trusted list.
`PAPERLESS_ALLOWED_HOSTS=<comma-separated-list>` #### [`PAPERLESS_ALLOWED_HOSTS=<comma-separated-list>`](#PAPERLESS_ALLOWED_HOSTS) {#PAPERLESS_ALLOWED_HOSTS}
: If you're planning on putting Paperless on the open internet, then : If you're planning on putting Paperless on the open internet, then
you really should set this value to the domain name you're using. you really should set this value to the domain name you're using.
@ -348,7 +348,7 @@ You can read more about this in [the Django project's documentation](https://doc
Defaults to "\*", which is all hosts. Defaults to "\*", which is all hosts.
`PAPERLESS_CORS_ALLOWED_HOSTS=<comma-separated-list>` #### [`PAPERLESS_CORS_ALLOWED_HOSTS=<comma-separated-list>`](#PAPERLESS_CORS_ALLOWED_HOSTS) {#PAPERLESS_CORS_ALLOWED_HOSTS}
: You need to add your servers to the list of allowed hosts that can : You need to add your servers to the list of allowed hosts that can
do CORS calls. Set this to your public domain name. do CORS calls. Set this to your public domain name.
@ -357,7 +357,7 @@ do CORS calls. Set this to your public domain name.
Defaults to "<http://localhost:8000>". Defaults to "<http://localhost:8000>".
`PAPERLESS_TRUSTED_PROXIES=<comma-separated-list>` #### [`PAPERLESS_TRUSTED_PROXIES=<comma-separated-list>`](#PAPERLESS_TRUSTED_PROXIES) {#PAPERLESS_TRUSTED_PROXIES}
: This may be needed to prevent IP address spoofing if you are using e.g. : This may be needed to prevent IP address spoofing if you are using e.g.
fail2ban with log entries for failed authorization attempts. Value should be fail2ban with log entries for failed authorization attempts. Value should be
@ -365,14 +365,14 @@ IP address(es).
Defaults to empty string. Defaults to empty string.
`PAPERLESS_FORCE_SCRIPT_NAME=<path>` #### [`PAPERLESS_FORCE_SCRIPT_NAME=<path>`](#PAPERLESS_FORCE_SCRIPT_NAME) {#PAPERLESS_FORCE_SCRIPT_NAME}
: To host paperless under a subpath url like example.com/paperless you : To host paperless under a subpath url like example.com/paperless you
set this value to /paperless. No trailing slash! set this value to /paperless. No trailing slash!
Defaults to none, which hosts paperless at "/". Defaults to none, which hosts paperless at "/".
`PAPERLESS_STATIC_URL=<path>` #### [`PAPERLESS_STATIC_URL=<path>`](#PAPERLESS_STATIC_URL) {#PAPERLESS_STATIC_URL}
: Override the STATIC_URL here. Unless you're hosting Paperless off a : Override the STATIC_URL here. Unless you're hosting Paperless off a
subdomain like /paperless/, you probably don't need to change this. subdomain like /paperless/, you probably don't need to change this.
@ -386,7 +386,7 @@ If you do change it, be sure to include the trailing slash.
at a subpath e.g. example.com/paperlessngx you will also need to set at a subpath e.g. example.com/paperlessngx you will also need to set
`PAPERLESS_FORCE_SCRIPT_NAME` (see above). `PAPERLESS_FORCE_SCRIPT_NAME` (see above).
`PAPERLESS_AUTO_LOGIN_USERNAME=<username>` #### [`PAPERLESS_AUTO_LOGIN_USERNAME=<username>`](#PAPERLESS_AUTO_LOGIN_USERNAME) {#PAPERLESS_AUTO_LOGIN_USERNAME}
: Specify a username here so that paperless will automatically perform : Specify a username here so that paperless will automatically perform
login with the selected user. login with the selected user.
@ -398,7 +398,7 @@ login with the selected user.
Defaults to none, which disables this feature. Defaults to none, which disables this feature.
`PAPERLESS_ADMIN_USER=<username>` #### [`PAPERLESS_ADMIN_USER=<username>`](#PAPERLESS_ADMIN_USER) {#PAPERLESS_ADMIN_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
@ -414,19 +414,19 @@ or AWS ECS.
it recreate a user that already exists. You can leave this it recreate a user that already exists. You can leave this
throughout the lifecycle of the containers. throughout the lifecycle of the containers.
`PAPERLESS_ADMIN_MAIL=<email>` #### [`PAPERLESS_ADMIN_MAIL=<email>`](#PAPERLESS_ADMIN_MAIL) {#PAPERLESS_ADMIN_MAIL}
: (Optional) Specify superuser email address. Only used when : (Optional) Specify superuser email address. Only used when
PAPERLESS_ADMIN_USER is set. PAPERLESS_ADMIN_USER is set.
Defaults to `root@localhost`. Defaults to `root@localhost`.
`PAPERLESS_ADMIN_PASSWORD=<password>` #### [`PAPERLESS_ADMIN_PASSWORD=<password>`](#PAPERLESS_ADMIN_PASSWORD) {#PAPERLESS_ADMIN_PASSWORD}
: Only used when PAPERLESS_ADMIN_USER 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>`](#PAPERLESS_COOKIE_PREFIX) {#PAPERLESS_COOKIE_PREFIX}
: Specify a prefix that is added to the cookies used by paperless to : Specify a prefix that is added to the cookies used by paperless to
identify the currently logged in user. This is useful for when identify the currently logged in user. This is useful for when
@ -436,7 +436,7 @@ you're running two instances of paperless on the same host.
Defaults to `""`, which does not alter the cookie names. Defaults to `""`, which does not alter the cookie names.
`PAPERLESS_ENABLE_HTTP_REMOTE_USER=<bool>` #### [`PAPERLESS_ENABLE_HTTP_REMOTE_USER=<bool>`](#PAPERLESS_ENABLE_HTTP_REMOTE_USER) {#PAPERLESS_ENABLE_HTTP_REMOTE_USER}
: Allows authentication via HTTP_REMOTE_USER which is used by some SSO : Allows authentication via HTTP_REMOTE_USER which is used by some SSO
applications. applications.
@ -455,7 +455,7 @@ applications.
Defaults to "false" 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>`](#PAPERLESS_HTTP_REMOTE_USER_HEADER_NAME) {#PAPERLESS_HTTP_REMOTE_USER_HEADER_NAME}
: If "PAPERLESS_ENABLE_HTTP_REMOTE_USER" 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
@ -466,7 +466,7 @@ followed by the normalized actual header name.
Defaults to "HTTP_REMOTE_USER". Defaults to "HTTP_REMOTE_USER".
`PAPERLESS_LOGOUT_REDIRECT_URL=<str>` #### [`PAPERLESS_LOGOUT_REDIRECT_URL=<str>`](#PAPERLESS_LOGOUT_REDIRECT_URL) {#PAPERLESS_LOGOUT_REDIRECT_URL}
: 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 to together with PAPERLESS_ENABLE_HTTP_REMOTE_USER to
@ -474,21 +474,21 @@ 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.
`PAPERLESS_USE_X_FORWARD_HOST=<bool>` #### [`PAPERLESS_USE_X_FORWARD_HOST=<bool>`](#PAPERLESS_USE_X_FORWARD_HOST) {#PAPERLESS_USE_X_FORWARD_HOST}
: Configures the Django setting [USE_X_FORWARDED_HOST](https://docs.djangoproject.com/en/4.2/ref/settings/#use-x-forwarded-host) : Configures the Django setting [USE_X_FORWARDED_HOST](https://docs.djangoproject.com/en/4.2/ref/settings/#use-x-forwarded-host)
which may be needed for hosting behind a proxy. which may be needed for hosting behind a proxy.
Defaults to False Defaults to False
`PAPERLESS_USE_X_FORWARD_PORT=<bool>` #### [`PAPERLESS_USE_X_FORWARD_PORT=<bool>`](#PAPERLESS_USE_X_FORWARD_PORT) {#PAPERLESS_USE_X_FORWARD_PORT}
: Configures the Django setting [USE_X_FORWARDED_PORT](https://docs.djangoproject.com/en/4.2/ref/settings/#use-x-forwarded-port) : Configures the Django setting [USE_X_FORWARDED_PORT](https://docs.djangoproject.com/en/4.2/ref/settings/#use-x-forwarded-port)
which may be needed for hosting behind a proxy. which may be needed for hosting behind a proxy.
Defaults to False Defaults to False
`PAPERLESS_PROXY_SSL_HEADER=<json-list>` #### [`PAPERLESS_PROXY_SSL_HEADER=<json-list>`](#PAPERLESS_PROXY_SSL_HEADER) {#PAPERLESS_PROXY_SSL_HEADER}
: Configures the Django setting [SECURE_PROXY_SSL_HEADER](https://docs.djangoproject.com/en/4.2/ref/settings/#secure-proxy-ssl-header) : Configures the Django setting [SECURE_PROXY_SSL_HEADER](https://docs.djangoproject.com/en/4.2/ref/settings/#secure-proxy-ssl-header)
which may be needed for hosting behind a proxy. The two values in the list will form the tuple of which may be needed for hosting behind a proxy. The two values in the list will form the tuple of
@ -501,7 +501,7 @@ HTTP header/value expected by Django, eg `'["HTTP_X_FORWARDED_PROTO", "https"]'`
Settings this value has security implications. Read the Django documentation Settings this value has security implications. Read the Django documentation
and be sure you understand its usage before setting it. and be sure you understand its usage before setting it.
`PAPERLESS_EMAIL_CERTIFICATE_FILE=<path>` #### [`PAPERLESS_EMAIL_CERTIFICATE_FILE=<path>`](#PAPERLESS_EMAIL_CERTIFICATE_FILE) {#PAPERLESS_EMAIL_CERTIFICATE_FILE}
: Configures an additional SSL certificate file containing a [certificate](https://docs.python.org/3/library/ssl.html#certificates) : Configures an additional SSL certificate file containing a [certificate](https://docs.python.org/3/library/ssl.html#certificates)
or certificate chain which should be trusted for validating SSL connections against mail providers. or certificate chain which should be trusted for validating SSL connections against mail providers.
@ -521,7 +521,7 @@ for performing OCR on documents and images. Paperless uses sensible
defaults for most settings, but all of them can be configured to your defaults for most settings, but all of them can be configured to your
needs. needs.
`PAPERLESS_OCR_LANGUAGE=<lang>` #### [`PAPERLESS_OCR_LANGUAGE=<lang>`](#PAPERLESS_OCR_LANGUAGE) {#PAPERLESS_OCR_LANGUAGE}
: Customize the language that paperless will attempt to use when : Customize the language that paperless will attempt to use when
parsing documents. parsing documents.
@ -541,7 +541,7 @@ parsing documents.
If your language contains a '-' such as chi-sim, you must use `chi_sim`. If your language contains a '-' such as chi-sim, you must use `chi_sim`.
`PAPERLESS_OCR_MODE=<mode>` #### [`PAPERLESS_OCR_MODE=<mode>`](#PAPERLESS_OCR_MODE) {#PAPERLESS_OCR_MODE}
: Tell paperless when and how to perform ocr on your documents. Three : Tell paperless when and how to perform ocr on your documents. Three
modes are available: modes are available:
@ -571,7 +571,7 @@ modes are available:
Read more about this in the [OCRmyPDF Read more about this in the [OCRmyPDF
documentation](https://ocrmypdf.readthedocs.io/en/latest/advanced.html#when-ocr-is-skipped). documentation](https://ocrmypdf.readthedocs.io/en/latest/advanced.html#when-ocr-is-skipped).
`PAPERLESS_OCR_SKIP_ARCHIVE_FILE=<mode>` #### [`PAPERLESS_OCR_SKIP_ARCHIVE_FILE=<mode>`](#PAPERLESS_OCR_SKIP_ARCHIVE_FILE) {#PAPERLESS_OCR_SKIP_ARCHIVE_FILE}
: Specify when you would like paperless to skip creating an archived : Specify when you would like paperless to skip creating an archived
version of your documents. This is useful if you don't want to have two version of your documents. This is useful if you don't want to have two
@ -584,7 +584,7 @@ almost-identical versions of your documents in the media folder.
The default is `never`. The default is `never`.
`PAPERLESS_OCR_CLEAN=<mode>` #### [`PAPERLESS_OCR_CLEAN=<mode>`](#PAPERLESS_OCR_CLEAN) {#PAPERLESS_OCR_CLEAN}
: Tells paperless to use `unpaper` to clean any input document before : Tells paperless to use `unpaper` to clean any input document before
sending it to tesseract. This uses more resources, but generally sending it to tesseract. This uses more resources, but generally
@ -603,7 +603,7 @@ results in better OCR results. The following modes are available:
`clean-final` and the ocr mode `redo` is configured, `clean` is used `clean-final` and the ocr mode `redo` is configured, `clean` is used
instead. instead.
`PAPERLESS_OCR_DESKEW=<bool>` #### [`PAPERLESS_OCR_DESKEW=<bool>`](#PAPERLESS_OCR_DESKEW) {#PAPERLESS_OCR_DESKEW}
: Tells paperless to correct skewing (slight rotation of input images : Tells paperless to correct skewing (slight rotation of input images
mainly due to improper scanning) mainly due to improper scanning)
@ -615,7 +615,7 @@ mainly due to improper scanning)
Deskewing is incompatible with ocr mode `redo`. Deskewing will get Deskewing is incompatible with ocr mode `redo`. Deskewing will get
disabled automatically if `redo` is used as the ocr mode. disabled automatically if `redo` is used as the ocr mode.
`PAPERLESS_OCR_ROTATE_PAGES=<bool>` #### [`PAPERLESS_OCR_ROTATE_PAGES=<bool>`](#PAPERLESS_OCR_ROTATE_PAGES) {#PAPERLESS_OCR_ROTATE_PAGES}
: Tells paperless to correct page rotation (90°, 180° and 270° : Tells paperless to correct page rotation (90°, 180° and 270°
rotation). rotation).
@ -626,7 +626,7 @@ rotation).
Defaults to `true`, which enables this feature. Defaults to `true`, which enables this feature.
`PAPERLESS_OCR_ROTATE_PAGES_THRESHOLD=<num>` #### [`PAPERLESS_OCR_ROTATE_PAGES_THRESHOLD=<num>`](#PAPERLESS_OCR_ROTATE_PAGES_THRESHOLD) {#PAPERLESS_OCR_ROTATE_PAGES_THRESHOLD}
: Adjust the threshold for automatic page rotation by : Adjust the threshold for automatic page rotation by
`PAPERLESS_OCR_ROTATE_PAGES`. This is an arbitrary value reported by `PAPERLESS_OCR_ROTATE_PAGES`. This is an arbitrary value reported by
@ -636,7 +636,7 @@ pages being rotated as well.
Defaults to "12". Defaults to "12".
`PAPERLESS_OCR_OUTPUT_TYPE=<type>` #### [`PAPERLESS_OCR_OUTPUT_TYPE=<type>`](#PAPERLESS_OCR_OUTPUT_TYPE) {#PAPERLESS_OCR_OUTPUT_TYPE}
: Specify the the type of PDF documents that paperless should produce. : Specify the the type of PDF documents that paperless should produce.
@ -650,7 +650,7 @@ pages being rotated as well.
If not specified, `pdfa` is used. Remember that paperless also keeps If not specified, `pdfa` is used. Remember that paperless also keeps
the original input file as well as the archived version. the original input file as well as the archived version.
`PAPERLESS_OCR_PAGES=<num>` #### [`PAPERLESS_OCR_PAGES=<num>`](#PAPERLESS_OCR_PAGES) {#PAPERLESS_OCR_PAGES}
: Tells paperless to use only the specified amount of pages for OCR. : Tells paperless to use only the specified amount of pages for OCR.
Documents with less than the specified amount of pages get OCR'ed Documents with less than the specified amount of pages get OCR'ed
@ -665,7 +665,7 @@ completely.
Defaults to 0, which disables this feature and always uses all Defaults to 0, which disables this feature and always uses all
pages. pages.
`PAPERLESS_OCR_IMAGE_DPI=<num>` #### [`PAPERLESS_OCR_IMAGE_DPI=<num>`](#PAPERLESS_OCR_IMAGE_DPI) {#PAPERLESS_OCR_IMAGE_DPI}
: Paperless will OCR any images you put into the system and convert : Paperless will OCR any images you put into the system and convert
them into PDF documents. This is useful if your scanner produces them into PDF documents. This is useful if your scanner produces
@ -679,7 +679,7 @@ fails, it uses this value as a fallback.
Default is none, which will automatically calculate image DPI so Default is none, which will automatically calculate image DPI so
that the produced PDF documents are A4 sized. that the produced PDF documents are A4 sized.
`PAPERLESS_OCR_MAX_IMAGE_PIXELS=<num>` #### [`PAPERLESS_OCR_MAX_IMAGE_PIXELS=<num>`](#PAPERLESS_OCR_MAX_IMAGE_PIXELS) {#PAPERLESS_OCR_MAX_IMAGE_PIXELS}
: Paperless will raise a warning when OCRing images which are over : Paperless will raise a warning when OCRing images which are over
this limit and will not OCR images which are more than twice this this limit and will not OCR images which are more than twice this
@ -702,7 +702,7 @@ but could result in missing text content.
this value if you are certain your documents are not malicious and this value if you are certain your documents are not malicious and
you need the text which was not OCRed you need the text which was not OCRed
`PAPERLESS_OCR_USER_ARGS=<json>` #### [`PAPERLESS_OCR_USER_ARGS=<json>`](#PAPERLESS_OCR_USER_ARGS) {#PAPERLESS_OCR_USER_ARGS}
: OCRmyPDF offers many more options. Use this parameter to specify any : OCRmyPDF offers many more options. Use this parameter to specify any
additional arguments you wish to pass to OCRmyPDF. Since Paperless additional arguments you wish to pass to OCRmyPDF. Since Paperless
@ -728,7 +728,7 @@ they use underscores instead of dashes.
## Software tweaks {#software_tweaks} ## Software tweaks {#software_tweaks}
`PAPERLESS_TASK_WORKERS=<num>` #### [`PAPERLESS_TASK_WORKERS=<num>`](#PAPERLESS_TASK_WORKERS) {#PAPERLESS_TASK_WORKERS}
: Paperless does multiple things in the background: Maintain the : Paperless does multiple things in the background: Maintain the
search index, maintain the automatic matching algorithm, check search index, maintain the automatic matching algorithm, check
@ -737,7 +737,7 @@ things it will do in parallel.
Defaults to 1 Defaults to 1
`PAPERLESS_THREADS_PER_WORKER=<num>` #### [`PAPERLESS_THREADS_PER_WORKER=<num>`](#PAPERLESS_THREADS_PER_WORKER) {#PAPERLESS_THREADS_PER_WORKER}
: Furthermore, paperless uses multiple threads when consuming : Furthermore, paperless uses multiple threads when consuming
documents to speed up OCR. This variable specifies how many pages documents to speed up OCR. This variable specifies how many pages
@ -771,13 +771,13 @@ paperless will process in parallel on a single document.
If you only specify PAPERLESS_TASK_WORKERS, paperless will adjust If you only specify PAPERLESS_TASK_WORKERS, paperless will adjust
PAPERLESS_THREADS_PER_WORKER automatically. PAPERLESS_THREADS_PER_WORKER automatically.
`PAPERLESS_WORKER_TIMEOUT=<num>` #### [`PAPERLESS_WORKER_TIMEOUT=<num>`](#PAPERLESS_WORKER_TIMEOUT) {#PAPERLESS_WORKER_TIMEOUT}
: Machines with few cores or weak ones might not be able to finish OCR : Machines with few cores or weak ones might not be able to finish OCR
on large documents within the default 1800 seconds. So extending on large documents within the default 1800 seconds. So extending
this timeout may prove to be useful on weak hardware setups. this timeout may prove to be useful on weak hardware setups.
`PAPERLESS_TIME_ZONE=<timezone>` #### [`PAPERLESS_TIME_ZONE=<timezone>`](#PAPERLESS_TIME_ZONE) {#PAPERLESS_TIME_ZONE}
: Set the time zone here. See more details on : Set the time zone here. See more details on
why and how to set it [in the Django project documentation](https://docs.djangoproject.com/en/4.1/ref/settings/#std:setting-TIME_ZONE) why and how to set it [in the Django project documentation](https://docs.djangoproject.com/en/4.1/ref/settings/#std:setting-TIME_ZONE)
@ -785,7 +785,7 @@ for details on how to set it.
Defaults to UTC. Defaults to UTC.
`PAPERLESS_ENABLE_NLTK=<bool>` #### [`PAPERLESS_ENABLE_NLTK=<bool>`](#PAPERLESS_ENABLE_NLTK) {#PAPERLESS_ENABLE_NLTK}
: Enables or disables the advanced natural language processing : Enables or disables the advanced natural language processing
used during automatic classification. If disabled, paperless will used during automatic classification. If disabled, paperless will
@ -795,7 +795,7 @@ still perform some basic text pre-processing before matching.
Defaults to 1. Defaults to 1.
`PAPERLESS_EMAIL_TASK_CRON=<cron expression>` #### [`PAPERLESS_EMAIL_TASK_CRON=<cron expression>`](#PAPERLESS_EMAIL_TASK_CRON) {#PAPERLESS_EMAIL_TASK_CRON}
: Configures the scheduled email fetching frequency. The value : Configures the scheduled email fetching frequency. The value
should be a valid crontab(5) expression describing when to run. should be a valid crontab(5) expression describing when to run.
@ -804,7 +804,7 @@ should be a valid crontab(5) expression describing when to run.
Defaults to `*/10 * * * *` or every ten minutes. Defaults to `*/10 * * * *` or every ten minutes.
`PAPERLESS_TRAIN_TASK_CRON=<cron expression>` #### [`PAPERLESS_TRAIN_TASK_CRON=<cron expression>`](#PAPERLESS_TRAIN_TASK_CRON) {#PAPERLESS_TRAIN_TASK_CRON}
: Configures the scheduled automatic classifier training frequency. The value : Configures the scheduled automatic classifier training frequency. The value
should be a valid crontab(5) expression describing when to run. should be a valid crontab(5) expression describing when to run.
@ -813,7 +813,7 @@ should be a valid crontab(5) expression describing when to run.
Defaults to `5 */1 * * *` or every hour at 5 minutes past the hour. Defaults to `5 */1 * * *` or every hour at 5 minutes past the hour.
`PAPERLESS_INDEX_TASK_CRON=<cron expression>` #### [`PAPERLESS_INDEX_TASK_CRON=<cron expression>`](#PAPERLESS_INDEX_TASK_CRON) {#PAPERLESS_INDEX_TASK_CRON}
: Configures the scheduled search index update frequency. The value : Configures the scheduled search index update frequency. The value
should be a valid crontab(5) expression describing when to run. should be a valid crontab(5) expression describing when to run.
@ -822,7 +822,7 @@ should be a valid crontab(5) expression describing when to run.
Defaults to `0 0 * * *` or daily at midnight. Defaults to `0 0 * * *` or daily at midnight.
`PAPERLESS_SANITY_TASK_CRON=<cron expression>` #### [`PAPERLESS_SANITY_TASK_CRON=<cron expression>`](#PAPERLESS_SANITY_TASK_CRON) {#PAPERLESS_SANITY_TASK_CRON}
: Configures the scheduled sanity checker frequency. : Configures the scheduled sanity checker frequency.
@ -830,7 +830,7 @@ should be a valid crontab(5) expression describing when to run.
Defaults to `30 0 * * sun` or Sunday at 30 minutes past midnight. Defaults to `30 0 * * sun` or Sunday at 30 minutes past midnight.
`PAPERLESS_ENABLE_COMPRESSION=<bool>` #### [`PAPERLESS_ENABLE_COMPRESSION=<bool>`](#PAPERLESS_ENABLE_COMPRESSION) {#PAPERLESS_ENABLE_COMPRESSION}
: Enables compression of the responses from the webserver. : Enables compression of the responses from the webserver.
@ -842,7 +842,7 @@ should be a valid crontab(5) expression describing when to run.
to enable compression in your proxy configuration rather than to enable compression in your proxy configuration rather than
the webserver the webserver
`PAPERLESS_CONVERT_MEMORY_LIMIT=<num>` #### [`PAPERLESS_CONVERT_MEMORY_LIMIT=<num>`](#PAPERLESS_CONVERT_MEMORY_LIMIT) {#PAPERLESS_CONVERT_MEMORY_LIMIT}
: On smaller systems, or even in the case of Very Large Documents, the : On smaller systems, or even in the case of Very Large Documents, the
consumer may explode, complaining about how it's "unable to extend consumer may explode, complaining about how it's "unable to extend
@ -855,7 +855,7 @@ everything without writing to disk, and units are in megabytes.
Defaults to 0, which disables the limit. Defaults to 0, which disables the limit.
`PAPERLESS_CONVERT_TMPDIR=<path>` #### [`PAPERLESS_CONVERT_TMPDIR=<path>`](#PAPERLESS_CONVERT_TMPDIR) {#PAPERLESS_CONVERT_TMPDIR}
: Similar to the memory limit, if you've got a small system and your : Similar to the memory limit, if you've got a small system and your
OS mounts /tmp as tmpfs, you should set this to a path that's on a OS mounts /tmp as tmpfs, you should set this to a path that's on a
@ -870,14 +870,14 @@ documents.
## Document Consumption {#consume_config} ## Document Consumption {#consume_config}
`PAPERLESS_CONSUMER_DELETE_DUPLICATES=<bool>` #### [`PAPERLESS_CONSUMER_DELETE_DUPLICATES=<bool>`](#PAPERLESS_CONSUMER_DELETE_DUPLICATES) {#PAPERLESS_CONSUMER_DELETE_DUPLICATES}
: When the consumer detects a duplicate document, it will not touch : When the consumer detects a duplicate document, it will not touch
the original document. This default behavior can be changed here. the original document. This default behavior can be changed here.
Defaults to false. Defaults to false.
`PAPERLESS_CONSUMER_RECURSIVE=<bool>` #### [`PAPERLESS_CONSUMER_RECURSIVE=<bool>`](#PAPERLESS_CONSUMER_RECURSIVE) {#PAPERLESS_CONSUMER_RECURSIVE}
: Enable recursive watching of the consumption directory. Paperless : Enable recursive watching of the consumption directory. Paperless
will then pickup files from files in subdirectories within your will then pickup files from files in subdirectories within your
@ -885,7 +885,7 @@ consumption directory as well.
Defaults to false. Defaults to false.
`PAPERLESS_CONSUMER_SUBDIRS_AS_TAGS=<bool>` #### [`PAPERLESS_CONSUMER_SUBDIRS_AS_TAGS=<bool>`](#PAPERLESS_CONSUMER_SUBDIRS_AS_TAGS) {#PAPERLESS_CONSUMER_SUBDIRS_AS_TAGS}
: 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
@ -899,7 +899,7 @@ don't exist yet.
Defaults to false. Defaults to false.
`PAPERLESS_CONSUMER_IGNORE_PATTERNS=<json>` #### [`PAPERLESS_CONSUMER_IGNORE_PATTERNS=<json>`](#PAPERLESS_CONSUMER_IGNORE_PATTERNS) {#PAPERLESS_CONSUMER_IGNORE_PATTERNS}
: By default, paperless ignores certain files and folders in the : By default, paperless ignores certain files and folders in the
consumption directory, such as system files created by the Mac OS consumption directory, such as system files created by the Mac OS
@ -917,7 +917,7 @@ or hidden folders some tools use to store data.
Defaults to Defaults to
`[".DS_STORE/*", "._*", ".stfolder/*", ".stversions/*", ".localized/*", "desktop.ini", "@eaDir/*"]`. `[".DS_STORE/*", "._*", ".stfolder/*", ".stversions/*", ".localized/*", "desktop.ini", "@eaDir/*"]`.
`PAPERLESS_CONSUMER_BARCODE_SCANNER=<string>` #### [`PAPERLESS_CONSUMER_BARCODE_SCANNER=<string>`](#PAPERLESS_CONSUMER_BARCODE_SCANNER) {#PAPERLESS_CONSUMER_BARCODE_SCANNER}
: Sets the barcode scanner used for barcode functionality. : Sets the barcode scanner used for barcode functionality.
@ -927,7 +927,7 @@ or hidden folders some tools use to store data.
zxing is not available on all platforms. zxing is not available on all platforms.
`PAPERLESS_PRE_CONSUME_SCRIPT=<filename>` #### [`PAPERLESS_PRE_CONSUME_SCRIPT=<filename>`](#PAPERLESS_PRE_CONSUME_SCRIPT) {#PAPERLESS_PRE_CONSUME_SCRIPT}
: After some initial validation, Paperless can trigger an arbitrary : After some initial validation, Paperless can trigger an arbitrary
script if you like before beginning consumption. This script will be provided script if you like before beginning consumption. This script will be provided
@ -937,7 +937,7 @@ data for it to work with via the environment.
The default is blank, which means nothing will be executed. The default is blank, which means nothing will be executed.
`PAPERLESS_POST_CONSUME_SCRIPT=<filename>` #### [`PAPERLESS_POST_CONSUME_SCRIPT=<filename>`](#PAPERLESS_POST_CONSUME_SCRIPT) {#PAPERLESS_POST_CONSUME_SCRIPT}
: 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 provided script if you like. This script will be provided
@ -947,7 +947,7 @@ data for it to work with via the environment.
The default is blank, which means nothing will be executed. The default is blank, which means nothing will be executed.
`PAPERLESS_FILENAME_DATE_ORDER=<format>` #### [`PAPERLESS_FILENAME_DATE_ORDER=<format>`](#PAPERLESS_FILENAME_DATE_ORDER) {#PAPERLESS_FILENAME_DATE_ORDER}
: Paperless will check the document text for document date : Paperless will check the document text for document date
information. Use this setting to enable checking the document information. Use this setting to enable checking the document
@ -961,7 +961,7 @@ document text will be checked as normal.
Defaults to none, which disables this feature. Defaults to none, which disables this feature.
`PAPERLESS_NUMBER_OF_SUGGESTED_DATES=<num>` #### [`PAPERLESS_NUMBER_OF_SUGGESTED_DATES=<num>`](#PAPERLESS_NUMBER_OF_SUGGESTED_DATES) {#PAPERLESS_NUMBER_OF_SUGGESTED_DATES}
: Paperless searches an entire document for dates. The first date : Paperless searches an entire document for dates. The first date
found will be used as the initial value for the created date. When found will be used as the initial value for the created date. When
@ -976,7 +976,7 @@ setting value.
Defaults to 3. Set to 0 to disable this feature. Defaults to 3. Set to 0 to disable this feature.
`PAPERLESS_THUMBNAIL_FONT_NAME=<filename>` #### [`PAPERLESS_THUMBNAIL_FONT_NAME=<filename>`](#PAPERLESS_THUMBNAIL_FONT_NAME) {#PAPERLESS_THUMBNAIL_FONT_NAME}
: Paperless creates thumbnails for plain text files by rendering the : Paperless creates thumbnails for plain text files by rendering the
content of the file on an image and uses a predefined font for that. content of the file on an image and uses a predefined font for that.
@ -988,7 +988,7 @@ This font can be changed here.
Defaults to Defaults to
`/usr/share/fonts/liberation/LiberationSerif-Regular.ttf`. `/usr/share/fonts/liberation/LiberationSerif-Regular.ttf`.
`PAPERLESS_IGNORE_DATES=<string>` #### [`PAPERLESS_IGNORE_DATES=<string>`](#PAPERLESS_IGNORE_DATES) {#PAPERLESS_IGNORE_DATES}
: Paperless parses a documents creation date from filename and file : Paperless parses a documents creation date from filename and file
content. You may specify a comma separated list of dates that should content. You may specify a comma separated list of dates that should
@ -1000,7 +1000,7 @@ unlikely to be the documents creation date.
Defaults to an empty string to not ignore any dates. Defaults to an empty string to not ignore any dates.
`PAPERLESS_DATE_ORDER=<format>` #### [`PAPERLESS_DATE_ORDER=<format>`](#PAPERLESS_DATE_ORDER) {#PAPERLESS_DATE_ORDER}
: Paperless will try to determine the document creation date from its : Paperless will try to determine the document creation date from its
contents. Specify the date format Paperless should expect to see contents. Specify the date format Paperless should expect to see
@ -1012,7 +1012,7 @@ within your documents.
### Polling {#polling} ### Polling {#polling}
`PAPERLESS_CONSUMER_POLLING=<num>` #### [`PAPERLESS_CONSUMER_POLLING=<num>`](#PAPERLESS_CONSUMER_POLLING) {#PAPERLESS_CONSUMER_POLLING}
: If paperless won't find documents added to your consume folder, it : If paperless won't find documents added to your consume folder, it
might not be able to automatically detect filesystem changes. In might not be able to automatically detect filesystem changes. In
@ -1024,14 +1024,14 @@ system changes with `inotify`.
Defaults to 0, which disables polling and uses filesystem Defaults to 0, which disables polling and uses filesystem
notifications. notifications.
`PAPERLESS_CONSUMER_POLLING_RETRY_COUNT=<num>` #### [`PAPERLESS_CONSUMER_POLLING_RETRY_COUNT=<num>`](#PAPERLESS_CONSUMER_POLLING_RETRY_COUNT) {#PAPERLESS_CONSUMER_POLLING_RETRY_COUNT}
: If consumer polling is enabled, sets the number of times paperless : If consumer polling is enabled, sets the number of times paperless
will check for a file to remain unmodified. will check for a file to remain unmodified.
Defaults to 5. Defaults to 5.
`PAPERLESS_CONSUMER_POLLING_DELAY=<num>` #### [`PAPERLESS_CONSUMER_POLLING_DELAY=<num>`](#PAPERLESS_CONSUMER_POLLING_DELAY) {#PAPERLESS_CONSUMER_POLLING_DELAY}
: If consumer polling is enabled, sets the delay in seconds between : If consumer polling is enabled, sets the delay in seconds between
each check (above) paperless will do while waiting for a file to each check (above) paperless will do while waiting for a file to
@ -1041,7 +1041,7 @@ remain unmodified.
### iNotify {#inotify} ### iNotify {#inotify}
`PAPERLESS_CONSUMER_INOTIFY_DELAY=<num>` #### [`PAPERLESS_CONSUMER_INOTIFY_DELAY=<num>`](#PAPERLESS_CONSUMER_INOTIFY_DELAY) {#PAPERLESS_CONSUMER_INOTIFY_DELAY}
: Sets the time in seconds the consumer will wait for additional : Sets the time in seconds the consumer will wait for additional
events from inotify before the consumer will consider a file ready events from inotify before the consumer will consider a file ready
@ -1053,7 +1053,7 @@ consumers working on the same file. Configure this to prevent that.
## Barcodes {#barcodes} ## Barcodes {#barcodes}
`PAPERLESS_CONSUMER_ENABLE_BARCODES=<bool>` #### [`PAPERLESS_CONSUMER_ENABLE_BARCODES=<bool>`](#PAPERLESS_CONSUMER_ENABLE_BARCODES) {#PAPERLESS_CONSUMER_ENABLE_BARCODES}
: Enables the scanning and page separation based on detected barcodes. : Enables the scanning and page separation based on detected barcodes.
This allows for scanning and adding multiple documents per uploaded This allows for scanning and adding multiple documents per uploaded
@ -1072,7 +1072,7 @@ file, which are separated by one or multiple barcode pages.
Defaults to false. Defaults to false.
`PAPERLESS_CONSUMER_BARCODE_TIFF_SUPPORT=<bool>` #### [`PAPERLESS_CONSUMER_BARCODE_TIFF_SUPPORT=<bool>`](#PAPERLESS_CONSUMER_BARCODE_TIFF_SUPPORT) {#PAPERLESS_CONSUMER_BARCODE_TIFF_SUPPORT}
: Whether TIFF image files should be scanned for barcodes. This will : Whether TIFF image files should be scanned for barcodes. This will
automatically convert any TIFF image(s) to pdfs for later automatically convert any TIFF image(s) to pdfs for later
@ -1081,7 +1081,7 @@ PAPERLESS_CONSUMER_ENABLE_BARCODES has been enabled.
Defaults to false. Defaults to false.
`PAPERLESS_CONSUMER_BARCODE_STRING=<string>` #### [`PAPERLESS_CONSUMER_BARCODE_STRING=<string>`](#PAPERLESS_CONSUMER_BARCODE_STRING) {#PAPERLESS_CONSUMER_BARCODE_STRING}
: Defines the string to be detected as a separator barcode. If : Defines the string to be detected as a separator barcode. If
paperless is used with the PATCH-T separator pages, users shouldn't paperless is used with the PATCH-T separator pages, users shouldn't
@ -1089,7 +1089,7 @@ change this.
Defaults to "PATCHT" Defaults to "PATCHT"
`PAPERLESS_CONSUMER_ENABLE_ASN_BARCODE=<bool>` #### [`PAPERLESS_CONSUMER_ENABLE_ASN_BARCODE=<bool>`](#PAPERLESS_CONSUMER_ENABLE_ASN_BARCODE) {#PAPERLESS_CONSUMER_ENABLE_ASN_BARCODE}
: Enables the detection of barcodes in the scanned document and : Enables the detection of barcodes in the scanned document and
setting the ASN (archive serial number) if a properly formatted setting the ASN (archive serial number) if a properly formatted
@ -1107,14 +1107,14 @@ barcode is detected.
Defaults to false. Defaults to false.
`PAPERLESS_CONSUMER_ASN_BARCODE_PREFIX=<string>` #### [`PAPERLESS_CONSUMER_ASN_BARCODE_PREFIX=<string>`](#PAPERLESS_CONSUMER_ASN_BARCODE_PREFIX) {#PAPERLESS_CONSUMER_ASN_BARCODE_PREFIX}
: Defines the prefix that is used to identify a barcode as an ASN : Defines the prefix that is used to identify a barcode as an ASN
barcode. barcode.
Defaults to "ASN" Defaults to "ASN"
`PAPERLESS_CONSUMER_BARCODE_UPSCALE=<float>` #### [`PAPERLESS_CONSUMER_BARCODE_UPSCALE=<float>`](#PAPERLESS_CONSUMER_BARCODE_UPSCALE) {#PAPERLESS_CONSUMER_BARCODE_UPSCALE}
: Defines the upscale factor used in barcode detection. : Defines the upscale factor used in barcode detection.
Improves the detection of small barcodes, i.e. with a value of 1.5 by Improves the detection of small barcodes, i.e. with a value of 1.5 by
@ -1125,7 +1125,7 @@ PAPERLESS_CONSUMER_BARCODE_DPI set to a value higher than default.
Defaults to 0.0 Defaults to 0.0
`PAPERLESS_CONSUMER_BARCODE_DPI=<int>` #### [`PAPERLESS_CONSUMER_BARCODE_DPI=<int>`](#PAPERLESS_CONSUMER_BARCODE_DPI) {#PAPERLESS_CONSUMER_BARCODE_DPI}
: During barcode detection every page from a PDF document needs : During barcode detection every page from a PDF document needs
to be converted to an image. A dpi value can be specified in the to be converted to an image. A dpi value can be specified in the
@ -1137,7 +1137,7 @@ combination with PAPERLESS_CONSUMER_BARCODE_UPSCALE bigger than 1.0.
## Collate Double-Sided Documents {#collate} ## Collate Double-Sided Documents {#collate}
`PAPERLESS_CONSUMER_ENABLE_COLLATE_DOUBLE_SIDED=<bool>` #### [`PAPERLESS_CONSUMER_ENABLE_COLLATE_DOUBLE_SIDED=<bool>`](#PAPERLESS_CONSUMER_ENABLE_COLLATE_DOUBLE_SIDED) {#PAPERLESS_CONSUMER_ENABLE_COLLATE_DOUBLE_SIDED}
: Enables automatic collation of two single-sided scans into a double-sided : Enables automatic collation of two single-sided scans into a double-sided
document. document.
@ -1153,7 +1153,7 @@ document.
Defaults to false. Defaults to false.
`PAPERLESS_CONSUMER_COLLATE_DOUBLE_SIDED_SUBDIR_NAME=<str>` #### [`PAPERLESS_CONSUMER_COLLATE_DOUBLE_SIDED_SUBDIR_NAME=<str>`](#PAPERLESS_CONSUMER_COLLATE_DOUBLE_SIDED_SUBDIR_NAME) {#PAPERLESS_CONSUMER_COLLATE_DOUBLE_SIDED_SUBDIR_NAME}
: The name of the subdirectory that the collate feature expects documents to : The name of the subdirectory that the collate feature expects documents to
arrive. arrive.
@ -1164,7 +1164,8 @@ arrive.
Defaults to "double-sided". Defaults to "double-sided".
`PAPERLESS_CONSUMER_COLLATE_DOUBLE_SIDED_TIFF_SUPPORT=<bool>` #### [`PAPERLESS_CONSUMER_COLLATE_DOUBLE_SIDED_TIFF_SUPPORT=<bool>`](#PAPERLESS_CONSUMER_COLLATE_DOUBLE_SIDED_TIFF_SUPPORT) {#PAPERLESS_CONSUMER_COLLATE_DOUBLE_SIDED_TIFF_SUPPORT}
: Whether TIFF image files should be supported when collating documents. : Whether TIFF image files should be supported when collating documents.
This will automatically convert any TIFF image(s) to pdfs for later This will automatically convert any TIFF image(s) to pdfs for later
processing. This only has an effect if processing. This only has an effect if
@ -1182,11 +1183,11 @@ simply typing the name of the program doesn't automatically execute it
(ie. the program isn't in your $PATH), then you'll need to specify (ie. the program isn't in your $PATH), then you'll need to specify
the literal path for that program. the literal path for that program.
`PAPERLESS_CONVERT_BINARY=<path>` #### [`PAPERLESS_CONVERT_BINARY=<path>`](#PAPERLESS_CONVERT_BINARY) {#PAPERLESS_CONVERT_BINARY}
: Defaults to "convert". : Defaults to "convert".
`PAPERLESS_GS_BINARY=<path>` #### [`PAPERLESS_GS_BINARY=<path>`](#PAPERLESS_GS_BINARY) {#PAPERLESS_GS_BINARY}
: Defaults to "gs". : Defaults to "gs".
@ -1196,7 +1197,7 @@ 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`. `docker-compose.env`.
`PAPERLESS_WEBSERVER_WORKERS=<num>` #### [`PAPERLESS_WEBSERVER_WORKERS=<num>`](#PAPERLESS_WEBSERVER_WORKERS) {#PAPERLESS_WEBSERVER_WORKERS}
: The number of worker processes the webserver should spawn. More : The number of worker processes the webserver should spawn. More
worker processes usually result in the front end to load data much worker processes usually result in the front end to load data much
@ -1206,7 +1207,7 @@ increase RAM usage.
Defaults to 1. Defaults to 1.
`PAPERLESS_BIND_ADDR=<ip address>` #### [`PAPERLESS_BIND_ADDR=<ip address>`](#PAPERLESS_BIND_ADDR) {#PAPERLESS_BIND_ADDR}
: The IP address the webserver will listen on inside the container. : The IP address the webserver will listen on inside the container.
There are special setups where you may need to configure this value There are special setups where you may need to configure this value
@ -1214,7 +1215,7 @@ 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>`](#PAPERLESS_PORT) {#PAPERLESS_PORT}
: The port number the webserver will listen on inside the container. : The port number the webserver will listen on inside the container.
There are special setups where you may need this to avoid collisions There are special setups where you may need this to avoid collisions
@ -1227,7 +1228,7 @@ one pod).
Defaults to 8000. Defaults to 8000.
`USERMAP_UID=<uid>` #### [`USERMAP_UID=<uid>`](#USERMAP_UID) {#USERMAP_UID}
: The ID of the paperless user in the container. Set this to your : The ID of the paperless user in the container. Set this to your
actual user ID on the host system, which you can get by executing actual user ID on the host system, which you can get by executing
@ -1242,7 +1243,7 @@ actual user ID on the host system, which you can get by executing
Defaults to 1000. Defaults to 1000.
`USERMAP_GID=<gid>` #### [`USERMAP_GID=<gid>`](#USERMAP_GID) {#USERMAP_GID}
: The ID of the paperless Group in the container. Set this to your : The ID of the paperless Group in the container. Set this to your
actual group ID on the host system, which you can get by executing actual group ID on the host system, which you can get by executing
@ -1257,7 +1258,7 @@ actual group ID on the host system, which you can get by executing
Defaults to 1000. Defaults to 1000.
`PAPERLESS_OCR_LANGUAGES=<list>` #### [`PAPERLESS_OCR_LANGUAGES=<list>`](#PAPERLESS_OCR_LANGUAGES) {#PAPERLESS_OCR_LANGUAGES}
: Additional OCR languages to install. By default, paperless comes : Additional OCR languages to install. By default, paperless comes
with English, German, Italian, Spanish and French. If your language with English, German, Italian, Spanish and French. If your language
@ -1282,7 +1283,7 @@ specified as "chi-tra".
Defaults to none, which does not install any additional languages. Defaults to none, which does not install any additional languages.
`PAPERLESS_ENABLE_FLOWER=<defined>` #### [`PAPERLESS_ENABLE_FLOWER=<defined>`](#PAPERLESS_ENABLE_FLOWER) {#PAPERLESS_ENABLE_FLOWER}
: If this environment variable is defined, the Celery monitoring tool : If this environment variable is defined, the Celery monitoring tool
[Flower](https://flower.readthedocs.io/en/latest/index.html) will be [Flower](https://flower.readthedocs.io/en/latest/index.html) will be
@ -1292,7 +1293,7 @@ started by the container.
## Update Checking {#update-checking} ## Update Checking {#update-checking}
`PAPERLESS_ENABLE_UPDATE_CHECK=<bool>` #### [`PAPERLESS_ENABLE_UPDATE_CHECK=<bool>`](#PAPERLESS_ENABLE_UPDATE_CHECK) {#PAPERLESS_ENABLE_UPDATE_CHECK}
!!! note !!! note

View File

@ -153,7 +153,7 @@ steps described in [Docker setup](#docker_hub) automatically.
!!! note !!! note
You can utilize Docker secrets for configuration settings by You can utilize Docker secrets for configuration settings by
appending `_FILE` to configuration values. For example `PAPERLESS_DBUSER` appending `_FILE` to configuration values. For example [`PAPERLESS_DBUSER`](/configuration#PAPERLESS_DBUSER)
can be set using `PAPERLESS_DBUSER_FILE=/var/run/secrets/password.txt`. can be set using `PAPERLESS_DBUSER_FILE=/var/run/secrets/password.txt`.
!!! warning !!! warning
@ -162,7 +162,7 @@ steps described in [Docker setup](#docker_hub) automatically.
system notifications with `inotify`. When storing the consumption system notifications with `inotify`. When storing the consumption
directory on such a file system, paperless will not pick up new directory on such a file system, paperless will not pick up new
files with the default configuration. You will need to use files with the default configuration. You will need to use
`PAPERLESS_CONSUMER_POLLING`, which will disable inotify. See [`PAPERLESS_CONSUMER_POLLING`](/configuration#PAPERLESS_CONSUMER_POLLING), which will disable inotify. See
[here](/configuration#polling). [here](/configuration#polling).
6. Run `docker-compose pull`. This will pull the image. 6. Run `docker-compose pull`. This will pull the image.
@ -350,23 +350,23 @@ supported.
needs. Required settings for getting needs. Required settings for getting
paperless running are: paperless running are:
- `PAPERLESS_REDIS` should point to your redis server, such as - [`PAPERLESS_REDIS`](/configuration#PAPERLESS_REDIS) should point to your redis server, such as
<redis://localhost:6379>. <redis://localhost:6379>.
- `PAPERLESS_DBENGINE` optional, and should be one of `postgres`, - [`PAPERLESS_DBENGINE`](/configuration#PAPERLESS_DBENGINE) optional, and should be one of `postgres`,
`mariadb`, or `sqlite` `mariadb`, or `sqlite`
- `PAPERLESS_DBHOST` should be the hostname on which your - [`PAPERLESS_DBHOST`](/configuration#PAPERLESS_DBHOST) should be the hostname on which your
PostgreSQL server is running. Do not configure this to use PostgreSQL server is running. Do not configure this to use
SQLite instead. Also configure port, database name, user and SQLite instead. Also configure port, database name, user and
password as necessary. password as necessary.
- `PAPERLESS_CONSUMPTION_DIR` should point to a folder which - [`PAPERLESS_CONSUMPTION_DIR`](/configuration#PAPERLESS_CONSUMPTION_DIR) should point to a folder which
paperless should watch for documents. You might want to have paperless should watch for documents. You might want to have
this somewhere else. Likewise, `PAPERLESS_DATA_DIR` and this somewhere else. Likewise, [`PAPERLESS_DATA_DIR`](/configuration#PAPERLESS_DATA_DIR) and
`PAPERLESS_MEDIA_ROOT` define where paperless stores its data. [`PAPERLESS_MEDIA_ROOT`](/configuration#PAPERLESS_MEDIA_ROOT) define where paperless stores its data.
If you like, you can point both to the same directory. If you like, you can point both to the same directory.
- `PAPERLESS_SECRET_KEY` should be a random sequence of - [`PAPERLESS_SECRET_KEY`](/configuration#PAPERLESS_SECRET_KEY) should be a random sequence of
characters. It's used for authentication. Failure to do so characters. It's used for authentication. Failure to do so
allows third parties to forge authentication credentials. allows third parties to forge authentication credentials.
- `PAPERLESS_URL` if you are behind a reverse proxy. This should - [`PAPERLESS_URL`](/configuration#PAPERLESS_URL) if you are behind a reverse proxy. This should
point to your domain. Please see point to your domain. Please see
[configuration](/configuration) for more [configuration](/configuration) for more
information. information.
@ -374,9 +374,9 @@ supported.
Many more adjustments can be made to paperless, especially the OCR Many more adjustments can be made to paperless, especially the OCR
part. The following options are recommended for everyone: part. The following options are recommended for everyone:
- Set `PAPERLESS_OCR_LANGUAGE` to the language most of your - Set [`PAPERLESS_OCR_LANGUAGE`](/configuration#PAPERLESS_OCR_LANGUAGE) to the language most of your
documents are written in. documents are written in.
- Set `PAPERLESS_TIME_ZONE` to your local time zone. - Set [`PAPERLESS_TIME_ZONE`](/configuration#PAPERLESS_TIME_ZONE) to your local time zone.
!!! warning !!! warning
@ -522,7 +522,7 @@ supported.
not available for most distributions. not available for most distributions.
15. Optional: If using the NLTK machine learning processing (see 15. Optional: If using the NLTK machine learning processing (see
`PAPERLESS_ENABLE_NLTK` in [configuration](/configuration#software_tweaks) for details), [`PAPERLESS_ENABLE_NLTK`](/configuration#PAPERLESS_ENABLE_NLTK) for details),
download the NLTK data for the Snowball download the NLTK data for the Snowball
Stemmer, Stopwords and Punkt tokenizer to your Stemmer, Stopwords and Punkt tokenizer to your
`PAPERLESS_DATA_DIR/nltk`. Refer to the [NLTK `PAPERLESS_DATA_DIR/nltk`. Refer to the [NLTK
@ -670,23 +670,23 @@ commands as well.
1. Stop and remove the paperless container 1. Stop and remove the paperless container
2. If using an external database, stop the container 2. If using an external database, stop the container
3. Update Redis configuration 3. Update Redis configuration
a) If `REDIS_URL` is already set, change it to `PAPERLESS_REDIS` a) If `REDIS_URL` is already set, change it to [`PAPERLESS_REDIS`](/configuration#PAPERLESS_REDIS)
and continue to step 4. and continue to step 4.
b) Otherwise, in the `docker-compose.yml` add a new service for b) Otherwise, in the `docker-compose.yml` add a new service for
Redis, following [the example compose Redis, following [the example compose
files](https://github.com/paperless-ngx/paperless-ngx/tree/main/docker/compose) files](https://github.com/paperless-ngx/paperless-ngx/tree/main/docker/compose)
c) Set the environment variable `PAPERLESS_REDIS` so it points to c) Set the environment variable [`PAPERLESS_REDIS`](/configuration#PAPERLESS_REDIS) so it points to
the new Redis container the new Redis container
4. Update user mapping 4. Update user mapping
a) If set, change the environment variable `PUID` to `USERMAP_UID` a) If set, change the environment variable `PUID` to `USERMAP_UID`
b) If set, change the environment variable `PGID` to `USERMAP_GID` b) If set, change the environment variable `PGID` to `USERMAP_GID`
5. Update configuration paths 5. Update configuration paths
a) Set the environment variable `PAPERLESS_DATA_DIR` to `/config` a) Set the environment variable [`PAPERLESS_DATA_DIR`](/configuration#PAPERLESS_DATA_DIR) to `/config`
6. Update media paths 6. Update media paths
a) Set the environment variable `PAPERLESS_MEDIA_ROOT` to a) Set the environment variable [`PAPERLESS_MEDIA_ROOT`](/configuration#PAPERLESS_MEDIA_ROOT) to
`/data/media` `/data/media`
7. Update timezone 7. Update timezone
a) Set the environment variable `PAPERLESS_TIME_ZONE` to the same a) Set the environment variable [`PAPERLESS_TIME_ZONE`](/configuration#PAPERLESS_TIME_ZONE) to the same
value as `TZ` value as `TZ`
8. Modify the `image:` to point to 8. Modify the `image:` to point to
`ghcr.io/paperless-ngx/paperless-ngx:latest` or a specific version `ghcr.io/paperless-ngx/paperless-ngx:latest` or a specific version
@ -823,27 +823,27 @@ the Pi and configuring some options in paperless can help improve
performance immensely: performance immensely:
- Stick with SQLite to save some resources. - Stick with SQLite to save some resources.
- Consider setting `PAPERLESS_OCR_PAGES` to 1, so that paperless will - Consider setting [`PAPERLESS_OCR_PAGES`](/configuration#PAPERLESS_OCR_PAGES) to 1, so that paperless will
only OCR the first page of your documents. In most cases, this page only OCR the first page of your documents. In most cases, this page
contains enough information to be able to find it. contains enough information to be able to find it.
- `PAPERLESS_TASK_WORKERS` and `PAPERLESS_THREADS_PER_WORKER` are - [`PAPERLESS_TASK_WORKERS`](/configuration#PAPERLESS_TASK_WORKERS) and [`PAPERLESS_THREADS_PER_WORKER`](/configuration#PAPERLESS_THREADS_PER_WORKER) are
configured to use all cores. The Raspberry Pi models 3 and up have 4 configured to use all cores. The Raspberry Pi models 3 and up have 4
cores, meaning that paperless will use 2 workers and 2 threads per cores, meaning that paperless will use 2 workers and 2 threads per
worker. This may result in sluggish response times during worker. This may result in sluggish response times during
consumption, so you might want to lower these settings (example: 2 consumption, so you might want to lower these settings (example: 2
workers and 1 thread to always have some computing power left for workers and 1 thread to always have some computing power left for
other tasks). other tasks).
- Keep `PAPERLESS_OCR_MODE` at its default value `skip` and consider - Keep [`PAPERLESS_OCR_MODE`](/configuration#PAPERLESS_OCR_MODE) at its default value `skip` and consider
OCR'ing your documents before feeding them into paperless. Some OCR'ing your documents before feeding them into paperless. Some
scanners are able to do this! scanners are able to do this!
- Set `PAPERLESS_OCR_SKIP_ARCHIVE_FILE` to `with_text` to skip archive - Set [`PAPERLESS_OCR_SKIP_ARCHIVE_FILE`](/configuration#PAPERLESS_OCR_SKIP_ARCHIVE_FILE) to `with_text` to skip archive
file generation for already ocr'ed documents, or `always` to skip it file generation for already ocr'ed documents, or `always` to skip it
for all documents. for all documents.
- If you want to perform OCR on the device, consider using - If you want to perform OCR on the device, consider using
`PAPERLESS_OCR_CLEAN=none`. This will speed up OCR times and use `PAPERLESS_OCR_CLEAN=none`. This will speed up OCR times and use
less memory at the expense of slightly worse OCR results. less memory at the expense of slightly worse OCR results.
- If using docker, consider setting `PAPERLESS_WEBSERVER_WORKERS` to 1. This will save some memory. - If using docker, consider setting [`PAPERLESS_WEBSERVER_WORKERS`](/configuration#PAPERLESS_WEBSERVER_WORKERS) to 1. This will save some memory.
- Consider setting `PAPERLESS_ENABLE_NLTK` to false, to disable the - Consider setting [`PAPERLESS_ENABLE_NLTK`](/configuration#PAPERLESS_ENABLE_NLTK) to false, to disable the
more advanced language processing, which can take more memory and more advanced language processing, which can take more memory and
processing time. processing time.

View File

@ -46,8 +46,7 @@ run:
If you notice that the consumer will only pickup files in the If you notice that the consumer will only pickup files in the
consumption directory at startup, but won't find any other files added consumption directory at startup, but won't find any other files added
later, you will need to enable filesystem polling with the configuration later, you will need to enable filesystem polling with the configuration
option `PAPERLESS_CONSUMER_POLLING`, see option [`PAPERLESS_CONSUMER_POLLING`](/configuration#PAPERLESS_CONSUMER_POLLING).
`[here](/configuration#polling).
This will disable listening to filesystem changes with inotify and This will disable listening to filesystem changes with inotify and
paperless will manually check the consumption directory for changes paperless will manually check the consumption directory for changes
@ -320,7 +319,7 @@ many workers attempting to access the database simultaneously.
Consider changing to the PostgreSQL database if you will be processing Consider changing to the PostgreSQL database if you will be processing
many documents at once often. Otherwise, try tweaking the many documents at once often. Otherwise, try tweaking the
`PAPERLESS_DB_TIMEOUT` setting to allow more time for the database to [`PAPERLESS_DB_TIMEOUT`](/configuration#PAPERLESS_DB_TIMEOUT) setting to allow more time for the database to
unlock. This may have minor performance implications. unlock. This may have minor performance implications.
## gunicorn fails to start with "is not a valid port number" ## gunicorn fails to start with "is not a valid port number"
@ -330,7 +329,7 @@ environment variable named `${serviceName}_PORT`. This is
the same environment variable which is used by Paperless to optionally the same environment variable which is used by Paperless to optionally
change the port gunicorn listens on. change the port gunicorn listens on.
To fix this, set `PAPERLESS_PORT` again to your desired port, or the To fix this, set [`PAPERLESS_PORT`](/configuration#PAPERLESS_PORT) again to your desired port, or the
default of 8000. default of 8000.
## Database Warns about unique constraint "documents_tag_name_uniq ## Database Warns about unique constraint "documents_tag_name_uniq

View File

@ -208,7 +208,7 @@ different means. These are as follows:
them further. them further.
Paperless is set up to check your mails every 10 minutes. This can be Paperless is set up to check your mails every 10 minutes. This can be
configured via `PAPERLESS_EMAIL_TASK_CRON` (see [software tweaks](/configuration#software_tweaks)) configured via [`PAPERLESS_EMAIL_TASK_CRON`](/configuration#PAPERLESS_EMAIL_TASK_CRON)
### REST API ### REST API