How to Encrypt/Add Password & Permissions to PDF Files
Securing PDF files with passwords and specific permissions is vital for protecting sensitive documents from unauthorized access and manipulation. The [POST] Encrypt/Add Password & Permissions API from IronSecure Doc provides an efficient way to encrypt PDF files with user and owner passwords while configuring permissions for printing, form filling, annotations, and more. This API ensures that the PDF is fully protected and access is controlled, making it ideal for legal, financial, or personal documents.
How to Encrypt/Add Password & Permissions to PDF Files
- Pull and start the IronSecureDoc Docker Image
- Test the API using Swagger
- Specify the parameters for password and permissions
- Execute the API call to apply the changes
- Export the encrypted PDF document
Pull and Start IronSecureDoc
If you don't have IronSecureDoc running yet, please follow the links below to get it set up:
Host Locally | Deploy to Cloud |
---|---|
The [POST] Encrypt/Add Password & Permissions API
The [POST] Encrypt/Add Password & Permissions API allows you to add security layers to PDF documents by encrypting them with passwords and setting specific permissions for various operations. Whether it's granting read access, allowing form filling, or disabling printing, this API gives you control over how your PDF files are accessed and modified.
Swagger
Swagger offers a user-friendly interface to test this API interactively. You can use it to send test requests and receive responses without writing code, making it a great tool for developers.
Steps to Redact Text with Swagger
- Access the Swagger UI:
If your API server is running locally, you can access Swagger by navigating to http://localhost:8080/swagger/index.html
in your web browser.
- Locate the API:
Find the [POST] /v1/document-services/pdfs/encrypt API, which corresponds to Encrypt/Add Password & Permissions.
- Input Parameters:
Provide the required parameters for the API. You can upload a sample PDF file and specify the desired permissions.
- Upload PDF File:
In the request body, upload a PDF file as pdf_file and define the necessary permissions, such as allowing or restricting printing, form filling, and content extraction.
- Execute the Request:
Once all parameters are set, click "Execute" to send the request. The response will return the encrypted PDF with the specified security settings.
- Check the Output PDF:
Type in 'password' to view the PDF content.
Understanding Input Parameters
The API requires specific parameters to encrypt the PDF and assign permissions. Below is a breakdown of both required and optional parameters:
Required Parameters
Name | Data Type | Description |
---|---|---|
pdf_file | application/pdf | The PDF file you want to encrypt. |
allow_extracting_content | boolean | Indicate whether content extraction is allowed. |
allow_form_filling | boolean | Indicate whether form filling is allowed. |
allow_annotations | boolean | Indicate whether annotations are allowed. |
allow_printing | boolean | Indicate whether printing is allowed. |
allow_modifications | boolean | Indicate whether modifications are allowed. |
new_owner_password | string | The new owner password for the PDF, which grants full access and the ability to change permissions. |
Optional Parameters
Name | Data Type | Description |
---|---|---|
user_password | string | The current user password, required if the PDF has a user password to grant read access. |
owner_password | string | The current owner password, required if the PDF has an owner password to grant full access. |
new_user_password | string | The new user password for read access. |
save_as_pdfa | boolean | Save the PDF as PDF/A-3 compliant. |
save_as_pdfua | boolean | Save the PDF as PDF/UA compliant. |
author | string | Set the PDF metadata Author property. |
title | string | Set the PDF metadata Title property. |
subject | string | Set the PDF metadata Subject property. |
API Integration: Python Example
Once you're familiar with the input parameters, you can call the API using Python or any other preferred language. Below is an example of how to integrate this API using Python.
import requests
# Endpoint URL
url = 'http://localhost:8080/v1/document-services/pdfs/encrypt'
# Headers with metadata information
headers = {
'accept': '*/*',
'author': 'IronSoftware',
'title': 'ENCRYPTION DEMO 2024',
'subject': 'DEMO EXAMPLE'
}
# Files to be sent in the request
files = {
'pdf_file': ('sample.pdf', open('sample.pdf', 'rb'), 'application/pdf')
}
# Parameters for encryption and permissions
data = {
'allow_extracting_content': 'true',
'allow_form_filling': 'true',
'allow_annotations': 'false',
'allow_printing': 'false',
'allow_modifications': 'true',
'new_owner_password': 'password',
'new_user_password': 'password',
'save_as_pdfa': 'false',
'save_as_pdfua': 'false'
}
# Send POST request with parameters
response = requests.post(url, headers=headers, files=files, data=data)
# Save the encrypted PDF to file system
with open('sample_encrypted.pdf', 'wb') as f:
f.write(response.content)
print('PDF encrypted successfully.')
import requests
# Endpoint URL
url = 'http://localhost:8080/v1/document-services/pdfs/encrypt'
# Headers with metadata information
headers = {
'accept': '*/*',
'author': 'IronSoftware',
'title': 'ENCRYPTION DEMO 2024',
'subject': 'DEMO EXAMPLE'
}
# Files to be sent in the request
files = {
'pdf_file': ('sample.pdf', open('sample.pdf', 'rb'), 'application/pdf')
}
# Parameters for encryption and permissions
data = {
'allow_extracting_content': 'true',
'allow_form_filling': 'true',
'allow_annotations': 'false',
'allow_printing': 'false',
'allow_modifications': 'true',
'new_owner_password': 'password',
'new_user_password': 'password',
'save_as_pdfa': 'false',
'save_as_pdfua': 'false'
}
# Send POST request with parameters
response = requests.post(url, headers=headers, files=files, data=data)
# Save the encrypted PDF to file system
with open('sample_encrypted.pdf', 'wb') as f:
f.write(response.content)
print('PDF encrypted successfully.')
Steps Explained:
- Load the PDF: The PDF file to be encrypted is loaded from the local file system.
- Set Encryption Parameters: Define permissions like allowing printing, form filling, and content extraction, as well as setting new passwords.
- Call the API: The [POST] Encrypt/Add Password & Permissions API is called, passing the necessary parameters.
- Save the Result: The encrypted PDF is saved as a new file.
The PDF file is encrypted as shown below. Type in 'password' to view the PDF content.
Frequently Asked Questions
What is the purpose of the Encrypt/Add Password & Permissions API?
The Encrypt/Add Password & Permissions API allows you to secure PDF files by encrypting them with passwords and setting specific permissions to control access and modifications, making it ideal for protecting sensitive documents.
How can I start using IronSecureDoc?
You can start using IronSecureDoc by pulling and starting the IronSecureDoc Docker Image. Follow the setup instructions for hosting locally or deploying to the cloud on platforms like Azure or AWS.
What permissions can be configured using the API?
The API allows you to configure permissions for printing, form filling, annotations, content extraction, and modifications on the PDF files.
How do I test the API using Swagger?
You can use Swagger to test the API interactively by accessing the Swagger UI, locating the appropriate API endpoint, inputting the necessary parameters, and executing the request to see the response.
What are the required parameters for encrypting a PDF?
Required parameters include the PDF file you want to encrypt, and boolean indicators for allowing content extraction, form filling, annotations, printing, and modifications. You also need to set a new owner password.
Can I save the encrypted PDF as PDF/A or PDF/UA compliant?
Yes, the API provides optional parameters to save the encrypted PDF as PDF/A-3 or PDF/UA compliant.
What is the role of user and owner passwords in PDF encryption?
The user password grants read access to the PDF, while the owner password provides full access and the ability to change permissions. You can set new passwords for enhanced security.
How do I integrate the API using Python?
To integrate the API using Python, you can use the requests library to send a POST request to the specified API endpoint, including headers, files, and data parameters. The response will contain the encrypted PDF.
What tools are necessary for hosting IronSecureDoc locally?
IronSecureDoc can be hosted locally on Windows, Mac, or Linux. You need to follow the specific tutorials for your operating system to set it up correctly.
Is it possible to modify the metadata of the PDF during encryption?
Yes, you can modify the PDF metadata by setting properties like author, title, and subject using the API's optional parameters.