devraeph / laravel-pdf-protect
Password protect PDF in Laravel
Installs: 70 694
Dependents: 0
Suggesters: 0
Security: 0
Stars: 6
Watchers: 1
Forks: 1
Open Issues: 0
pkg:composer/devraeph/laravel-pdf-protect
Requires
- php: ^8.1|^8.2|^8.3|^8.4
- illuminate/contracts: ^10.0|^11.0|^12.0
- illuminate/support: ^10.0|^11.0|^12.0
- mpdf/mpdf: ^8.1.3|^8.2.5
- spatie/laravel-package-tools: ^1.15.0
Requires (Dev)
- laravel/pint: ^1.13
- nunomaduro/collision: ^7.8
- nunomaduro/larastan: ^2.0.1
- orchestra/testbench: ^6.0|^7.0|^8.0|^8.8
- pestphp/pest: ^2.0
- pestphp/pest-plugin-arch: ^2.0
- pestphp/pest-plugin-laravel: ^2.0
- phpstan/extension-installer: ^1.1
- phpstan/phpstan-deprecation-rules: ^1.0
- phpstan/phpstan-phpunit: ^1.0
README
Simple wrapper package around MPDF's setProtection method that allows you to set password on PDF files.
Version Compatibilities
| Laravel PDF Protect | PHP Version | Laravel 6.* | Laravel 7.* | Laravel 8.* | Laravel 9.* | Laravel 10.* | Laravel 11.* | Laravel 12.* | 
|---|---|---|---|---|---|---|---|---|
| 3.x | >=8.1-<= 8.4 | ❌ | ❌ | ❌ | ❌ | ✅ | ✅ | ✅ | 
| 2.x | >=7.4-<= 8.2 | ❌ | ✅ | ✅ | ✅ | ✅ | ❌ | ❌ | 
| 1.1.2 | >=7.4-<= 8.1 | ❌ | ✅ | ✅ | ✅ | ❌ | ❌ | ❌ | 
| 1.0.0 | >=7.4-<= 8.0 | ✅ | ✅ | ✅ | ❌ | ❌ | ❌ | ❌ | 
Installation
You can install the package via composer:
composer require devraeph/laravel-pdf-protect
Usage
Version 3.x
In version 3.x the usage supports now multiple Storage support local, s3, ...
PDFPasswordProtect::setInputFile('pdf/LetterFormat.pdf','local|s3|...') ->setOutputFile('pdf/encrypted-123.pdf','local|s3|...') ->setPassword("1234") ->secure();
OLD Version 2.x
In version 2.x the usage is more common to use and simplified.
$inputFile = storage_path('pdf/LetterFormat.pdf'); $outputFile = storage_path('pdf/encrypted-123.pdf'); PDFPasswordProtect::setInputFile($inputFile) ->setOutputFile($outputFile) ->setPassword("1234") ->secure();
You can also add the optional method 'setOwnerPassword':
... PDFPasswordProtect::setInputFile($inputFile) ... ->setOwnerPassword("1234") ->secure();
Alternative new options are: 'setMode' and 'setFormat'.
setFormat is default 'auto' and will now detect the document format. Before v2.x it was set to 'A4'.
PDFPasswordProtect::setInputFile($inputFile) ... ->setMode("en_GB") //You can set different language values. Default is utf-8 ->setFormat("auto|A4|Letter") //You can set a Document format. Default is auto. ->secure();
Version 1.x
You can also use the old version from v1.x in v2.x, but it is deprecated and will no longer get any updates.
PdfPasswordProtect::encrypt(storage_path('pdf/document.pdf'),storage_path('pdf/'.'encrypted-documented.pdf'),'janedoe');
Encrypt method in detail
- $inputFile and $outputFile has to be a path like storage_path("pdf/document.pdf")
PdfPasswordProtect::encrypt($inputFile,$outputFile,$password)
The final file will be located in storage/pdf as encrypted-document.pdf
Testing
composer test
Credits
- Owen Jubilant (creator of the original package) - PDF Password Protect
- DevRaeph (refactored classes to comply with PSR-4)
Sponsor
License
The MIT License (MIT).