PDFGate's official Python SDK
Project description
PDFGate's official Python SDK
The PDFGate Python SDK provides convenient access to the PDFGate API from applications written in Python. It includes typed parameter objects, synchronous and asynchronous clients, response helpers, and webhook signature verification for common PDF generation, processing, and signing workflows.
📘 Documentation: https://pdfgate.com/documentation
🔑 Dashboard & API keys: https://dashboard.pdfgate.com
pdfgate
Table of Contents
- Installation
- Quick start
- Sync & Async
- Responses
- Webhook Verification
- Examples
- Development
- Support
- License
Installation
pip install pdfgate
Quick start
import os
from pdfgate import PDFGate, GeneratePDFParams
client = PDFGate(api_key=os.environ["PDFGATE_API_KEY"])
params = GeneratePDFParams(url="https://example.com")
document = client.generate_pdf(params)
print(document["id"])
Sync & Async
There are sync and async versions of all methods, the only difference is that the method name has an async suffix:
document_response = client.get_document(GetDocumentParams(document_id=document_id))
# VS
document_response = await client.get_document_async(GetDocumentParams(document_id=document_id))
Other than that, nothing changes and the interfaces are the same.
Responses
The SDK returns a PDFGateDocument for all processing endpoints:
generate_pdfflatten_pdfcompress_pdfwatermark_pdfprotect_pdfupload_file
To get raw PDF bytes, call get_file with a document ID.
Webhook Verification
Use verify_signature with the raw request body and the
x-pdfgate-signature header value received from PDFGate:
from pdfgate import verify_signature
event = verify_signature(
secret="whsecret_...",
signature_header=request.headers["x-pdfgate-signature"],
payload=request_body,
)
event_id = event["event_id"]
Examples
Generate PDF
params = GeneratePDFParams(html="<h1>Hello from PDFGate!</h1>")
document = client.generate_pdf(params)
print(document["id"])
Get document metadata
document_response = client.get_document(GetDocumentParams(document_id=document_id))
print(document_response["id"])
print(document_response["status"])
print(document_response.get("file_url"))
Download a stored PDF file
file_content = client.get_file(GetFileParams(document_id=document_id))
with open("output.pdf", "wb") as f:
f.write(file_content)
Upload a PDF file
file_param = FileParam.pdf(name="input.pdf", data=pdf_file_bytes)
document_response = client.upload_file(UploadFileParams(file=file_param))
If both file and url are provided, file is prioritized and the request is sent as multipart.
Flatten a PDF (make form-fields non-editable)
flatten_pdf_params = FlattenPDFParams(
document_id=document_id
)
flattened_document = client.flatten_pdf(flatten_pdf_params)
Compress a PDF
compress_pdf_params = CompressPDFParams(
document_id=document_id
)
response = client.compress_pdf(compress_pdf_params)
Watermark a PDF
watermark_pdf_params = WatermarkPDFParams(
document_id=document_id,
type=WatermarkType.IMAGE,
watermark=FileParam(name="watermark.jpg", data=jpg_file),
)
watermarked_pdf = client.watermark_pdf(watermark_pdf_params)
Protect (encrypt) a PDF
protect_pdf_params = ProtectPDFParams(
document_id=document_id,
user_password="user-password",
owner_password="owner-password",
)
response = client.protect_pdf(protect_pdf_params)
Extract PDF form fields values
html_form = """
<form>
<input type="text" name="first_name" value="John" />
<input type="text" name="last_name" value="Doe" />
</form>
"""
generate_pdf_params = GeneratePDFParams(
html=html_form, enable_form_fields=True
)
document_response = client.generate_pdf(generate_pdf_params)
document_id = document_response["id"]
extract_form_params = ExtractPDFFormDataParams(document_id=document_id)
response = client.extract_pdf_form_data(extract_form_params)
Development
Before doing anything, install pre-commit by running:
hatch run dev:pre-commit install
This will run several checks every time you try to git commit including:
- linting and formatting with
Ruff - type checking with
mypy
If you are on VS Code, it's recommended to install the Ruff extension so you'll get formatting on the fly.
Hatch is used as a build system and for dependency management, so all main actions are configured to be run with Hatch.
Tests
Unit tests:
hatch run test:test
Acceptance tests hit the PDFGate API so they are slower, and require an API key that is expected to be set as an env var named PDFGATE_API_KEY. You can set it on your Bash/zsh/fish profile or inline as in:
PDFGATE_API_KEY="test_123" hatch run test:test_acceptance
Manually run Ruff
Linting:
hatch run dev:lint
Formatting:
hatch run dev:ruff format .
Type checking
Run mypy manually:
hatch run dev:check
Docs
Docs are built using MkDocs, they live in the docs/ folder, and in the code. If you make any changes, and would like to see them live before publishing them, spin up a server locally with:
hatch run docs:serve
Changes to docs/** and mkdocs.yml trigger a new deployment of the docs site. If you change the code's documentation and want to manually update the docs site you can do it from the Actions tab of the repo or by running:
hatch run docs:mkdocs gh-deploy
Support
For support, contact support@pdfgate.com.
License
pdfgate is distributed under the terms of the MIT license.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file pdfgate-0.0.3.tar.gz.
File metadata
- Download URL: pdfgate-0.0.3.tar.gz
- Upload date:
- Size: 27.4 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
c3090f0799b99490f47fd6854c4143a5856dae5483494f35ff0bcf259d9f792f
|
|
| MD5 |
a9e737b2f440ded0ff300dfb64c74cf9
|
|
| BLAKE2b-256 |
e50f6c1f9abd2f6770657a6680c8a6978713bd1a491e594c8d067e6540b49669
|
Provenance
The following attestation bundles were made for pdfgate-0.0.3.tar.gz:
Publisher:
publish-to-pypi.yml on pdfgate/pdfgate-sdk-python
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
pdfgate-0.0.3.tar.gz -
Subject digest:
c3090f0799b99490f47fd6854c4143a5856dae5483494f35ff0bcf259d9f792f - Sigstore transparency entry: 1518418679
- Sigstore integration time:
-
Permalink:
pdfgate/pdfgate-sdk-python@3bcf9762c9283837c9e44af093c0d6bd1a9bfcf9 -
Branch / Tag:
refs/tags/v0.0.3 - Owner: https://github.com/pdfgate
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish-to-pypi.yml@3bcf9762c9283837c9e44af093c0d6bd1a9bfcf9 -
Trigger Event:
push
-
Statement type:
File details
Details for the file pdfgate-0.0.3-py3-none-any.whl.
File metadata
- Download URL: pdfgate-0.0.3-py3-none-any.whl
- Upload date:
- Size: 18.4 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
fb16fcfe2db41ee3c1987a86555a5d163b8d39ee4f72e7f9b895a1c234f20880
|
|
| MD5 |
eba8f1adadc89e21df934170ecb8a2ef
|
|
| BLAKE2b-256 |
eaab429e7f03259b9ff6f59f1e274d66cc2339cab2242ab09c4ca450030be86f
|
Provenance
The following attestation bundles were made for pdfgate-0.0.3-py3-none-any.whl:
Publisher:
publish-to-pypi.yml on pdfgate/pdfgate-sdk-python
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
pdfgate-0.0.3-py3-none-any.whl -
Subject digest:
fb16fcfe2db41ee3c1987a86555a5d163b8d39ee4f72e7f9b895a1c234f20880 - Sigstore transparency entry: 1518418703
- Sigstore integration time:
-
Permalink:
pdfgate/pdfgate-sdk-python@3bcf9762c9283837c9e44af093c0d6bd1a9bfcf9 -
Branch / Tag:
refs/tags/v0.0.3 - Owner: https://github.com/pdfgate
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish-to-pypi.yml@3bcf9762c9283837c9e44af093c0d6bd1a9bfcf9 -
Trigger Event:
push
-
Statement type: