Skip to main content

Host your own local PDF server applying OCR and duplex scanning on your documents

Project description

pyPDFserver

PyPI - Version Docker Image Version

pyPDFserver provides a bridge FTP server that accepts PDFs (for example, from your network printer) and applies OCR, image optimization, and/or merging to duplex scans. The final PDF is uploaded to your target machine (e.g., your NAS) via FTP.

Installation

pyPDFserver is designed to run in a Docker container, but you can also host it manually.

  1. Install Python (>= 3.10) and install pyPDFserver via pip:
pip install pyPDFserver
  1. Install the external dependencies for OCRmyPDF (e.g., Tesseract, Ghostscript) by following the manual: https://ocrmypdf.readthedocs.io/en/latest/installation.html

  2. Run pyPDFserver:

python -m pyPDFserver

After the first run, two configuration files will be created in your system's configuration folder (refer to the console output to see the exact paths) named pyPDFserver.ini and profiles.ini. You need to modify them with your settings and restart pyPDFserver.

Docker

A Docker image is available, including some popular languages (English, French, Spanish, German, Italian, Portuguese, Dutch, Polish). It also includes jbig2dec and pngquant for OCRmyPDF optimization.

After pulling the image, adjust the following settings in your Docker container:

  • Map the settings folder to your machine. Depending on your OS, it may be located at:
Platform Default Config Path (platformdirs.site_config_dir)
Windows C:\ProgramData\pyPDFserver
macOS /Library/Application Support/pyPDFserver
Linux /etc/xdg/pyPDFserver
  • Create the pyPDFserver.ini and profiles.ini files in the config dir.
    • You can skip this step and run pyPDFserver first—it will crash due to missing settings but will create the files with default values.
  • Map the ports for FTP server (default 21) and web interface (default 80) to your desired ports. You can also change the default internal ports in the pyPDFserver.ini.
  • Map the ports for the passive FTP server (default 23000–23010) to the same ports. It's important to use the same ports locally and externally.
  • Set the entry point to python -m pyPDFserver

Usage

Connect to your FTP server and upload files. OCR processing may take several minutes. Processed files will be uploaded to your external server. You can view the status of recent jobs via the web interface (default port 80).

OCR

pyPDFserver uses OCRmyPDF to apply OCR to your PDFs. Enable OCR in your profile by setting ocr_enabled = True. Define the OCR language in profiles.ini for best results.

Duplex scan

pyPDFserver can automatically merge front and back page scans (duplex 1 and duplex 2) into a single PDF, suitable for Automatic Document Feeders (ADF).

  • Uploaded files must match the input_duplex1_name and input_duplex2_name templates in your profile.
  • Back pages must be reversed (you simply turn them around for scanning).
  • Page counts must match or the task will be rejected.

Commands

User Commands:

  • exit: Terminate the server and clear temporary files.
  • version: Display the installed version.
  • tasks abort: Abort all scheduled tasks (currently running tasks cannot be aborted).

Internal Commands (rarely needed):

  • tasks list: List all running, finished, or failed tasks.
  • tasks clean: Clean old tasks and remove temporary files (automatically performed every 5 minutes).
  • tasks clear: Abort all scheduled tasks and clear finished tasks.
  • artifacts list: List all artifacts.
  • artifacts clean: Remove untracked artifacts to release storage.

Configruation

pyPDFserver.ini
[SETTINGS]
# Set the desired log level (CRITICAL, ERROR, WARNING, INFO, DEBUG)
log_level = INFO
# If set to False, disable interactive console input
interactive_shell = False
# If set to True, enable colored console output
log_colors = True
# If set to True, create log files
log_to_file = True
# Time (in seconds) to wait for the back pages of a duplex scan after the
# front page upload before timing out. Set to zero to disable the timeout.
duplex_timeout = 600
# If set to True, pyPDFserver will search for old temporary files at startup
# and delete them
clean_old_temporary_files = True
# Set a time limit in minutes to keep old tasks in cache before garbage collecting them
tasks_keep_time = 180

[FTP]
local_ip = 127.0.0.1
port = 21
# If pyPDFserver is running behind a NAT, you may need to set the IP address
# that clients use to connect to the FTP server to prevent foreign address errors.
public_ip = 
# In FTP passive mode, clients open both control and data connections to bypass
# NATs on the client side. If pyPDFserver itself is running behind a NAT, you
# need to open the passive ports. By default, FTP servers use random ports, but
# you can define a custom list or range of ports.
# Write them as a comma-separated list (e.g. 6000,6010-6020,6030).
passive_ports = 23001-23010

[EXPORT_FTP_SERVER]
# Set the address and credentials for the external FTP server
host = 
port = 
username = 
password = 

[WEBINTERFACE]
# If set to True, start a simple web interface to display currently scheduled,
# running, and finished tasks
enabled = True
# Set the port for the web server. If empty, it defaults to 80 or 443 (TLS enabled).
port = 
profiles.ini
# You can define multiple profiles to use different settings (e.g. different OCR languages,
# optimization levels, or file name templates). Each profile must have a unique username.
# Any fields not explicitly set will fall back to the DEFAULT profile.


[DEFAULT]
# Username for the FTP server
username = pyPDFserver
# Password for the FTP server. Note that after the first run it will be replaced with
# a hash value. To change the password later, remove its value and set a new password.
# After the next run, it will again be replaced with its hash value.
password = 

# OCR settings
# Refer to https://ocrmypdf.readthedocs.io/en/latest/optimizer.html for a more detailed explanation

ocr_enabled = False
# Set the three-letter language code for Tesseract OCR. You can provide multiple languages serperated by a plus
# You must install the corresponding Tesseract language pack first.
ocr_language = 
# Correct pages that were scanned at a skewed angle by rotating them into alignment
# (--deskew option for OCRmyPDF)
ocr_deskew = True
# Optimization level passed to OCRmyPDF
# (e.g. 0: no optimization, 1: lossless optimizations,
#  2: some lossy optimizations, 3: aggressive optimization)
ocr_optimize = 1
# JPEG quality in percent (integer from 0 to 100). Leave blank to use default. Is only used with ocr_optimize >= 1
ocr_jpg_quality =
# Attempt to determine the correct orientation for each page and rotate it if necessary
# (--rotate-pages parameter for OCRmyPDF)
ocr_rotate_pages = True
# Timeout (in seconds) for Tesseract processing per page
# (--tesseract-timeout parameter for OCRmyPDF)
ocr_tesseract_timeout = 60

# File name settings
# When uploading a file to pyPDFserver, it is matched against the defined template strings
# and rejected if it does not match any of them. You can use tags (which pyPDFserver replaces
# with regular expression patterns) to capture groups.
# Available tags:
#   (lang): capture a three-letter language code. Multiple languages can be given (seperated by comma)
#   (*): capture any content
# In export_duplex_name you can also use:
#   (*1): insert the (*) match from duplex1
#   (*2): insert the (*) match from duplex2

# If set to True, file name matching is case-sensitive
input_case_sensitive = True
# Template string for incoming PDF files
input_pdf_name = SCAN_(*).pdf
# Template string for exported PDF files
export_pdf_name = Scan_(*).pdf
# Template strings for duplex PDF files (1 = front pages, 2 = back pages)
input_duplex1_name = DUPLEX1_(*).pdf
input_duplex2_name = DUPLEX2_(*).pdf
# Template string for exported duplex PDF files
export_duplex_name = Scan_(*1)_(lang).pdf
# Target path on the external FTP server for uploaded files
export_path = 

# Two example profiles. You can define as many profiles as you like
[DE]
username = pyPDFserver_de
ocr_enabled = True
ocr_language = deu

[EN]
username = pyPDFserver_en
ocr_enabled = True
ocr_language = eng

# You can define multiple languages for OCR
[DE_EN]
username = pyPDFserver_de_en
ocr_enabled = True
ocr_language = deu+eng

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

pypdfserver-1.2.1.tar.gz (26.1 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

pypdfserver-1.2.1-py3-none-any.whl (27.0 kB view details)

Uploaded Python 3

File details

Details for the file pypdfserver-1.2.1.tar.gz.

File metadata

  • Download URL: pypdfserver-1.2.1.tar.gz
  • Upload date:
  • Size: 26.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for pypdfserver-1.2.1.tar.gz
Algorithm Hash digest
SHA256 f4d9e2a29850f8a4d55a16c4c6c2109294cd94a9dce939dd096c29e3f55d0b62
MD5 f9e4002f805d73a165021276a68c0b59
BLAKE2b-256 91582e0fb9275c7e5a268a82bf58f61310f2630649726752a5b4ffa970aefef4

See more details on using hashes here.

Provenance

The following attestation bundles were made for pypdfserver-1.2.1.tar.gz:

Publisher: build.yml on andreasmz/pyPDFserver

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file pypdfserver-1.2.1-py3-none-any.whl.

File metadata

  • Download URL: pypdfserver-1.2.1-py3-none-any.whl
  • Upload date:
  • Size: 27.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for pypdfserver-1.2.1-py3-none-any.whl
Algorithm Hash digest
SHA256 8664d3a9e4bbdbea2f30b25281b2b4f657e1643bee0bfc8780821f04d1d217ee
MD5 81e94af52ca48318f99cabef1a50953b
BLAKE2b-256 4456b4ef11a14151cd2cc12f66dd552ce0ab9c99b444642c3fd129a0d120ee9d

See more details on using hashes here.

Provenance

The following attestation bundles were made for pypdfserver-1.2.1-py3-none-any.whl:

Publisher: build.yml on andreasmz/pyPDFserver

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page