sunspikes / clamav-validator
Custom Laravel 5 anti-virus validator for file uploads.
Installs: 1 134 582
Dependents: 1
Suggesters: 0
Security: 0
Stars: 318
Watchers: 10
Forks: 68
Open Issues: 11
Requires
- php: ^7.3|^8.0
- ext-sockets: *
- illuminate/support: ~5.0 || ^6.0 || ^7.0 || ^8.0 || ^9.0 || ^10.0 || ^11.0
- illuminate/validation: ~5.0 || ^6.0 || ^7.0 || ^8.0 || ^9.0 || ^10.0 || ^11.0
- xenolope/quahog: ^3.0
Requires (Dev)
- mockery/mockery: ^1.5.0
- phpunit/phpunit: ^9.5.10
- roave/security-advisories: dev-master
- scrutinizer/ocular: dev-master
README
A custom Laravel virus validator based on ClamAV anti-virus scanner for file uploads.
Requirements
You must have ClamAV anti-virus scanner running on the server to make this package work.
You can see the ClamAV installation instructions on the official ClamAV documentation.
For example on an Ubuntu machine, you can do:
# Install clamav virus scanner sudo apt-get update && sudo apt-get install -y clamav-daemon # Update virus definitions sudo freshclam # Start the scanner service sudo systemctl enable --now clamav-daemon clamav-freshclam
This package is not tested on Windows, but if you have ClamAV running (usually on port 3310) it should work.
You will also need to have sockets
extension installed and enabled (all executions without this module will fail with this error - "Use of undefined constant 'AF_INET'"
).
Installation
1. Install the package through Composer.
$ composer require sunspikes/clamav-validator
2. Add the service provider (for Laravel 5.4 or below)
This package supports Laravel new Package Discovery.
If you are using Laravel < 5.5, you need to add Sunspikes\ClamavValidator\ClamavValidatorServiceProvider::class
to your providers
array in config/app.php
:
'providers' => [ // ... Sunspikes\ClamavValidator\ClamavValidatorServiceProvider::class, ],
3. Publish assets from the vendor package
Config file
The default configuration file does use ENV
to override the defaults. If you want to change the configuration file
anyway you run the following command to publish the package config file:
php artisan vendor:publish --provider="Sunspikes\ClamavValidator\ClamavValidatorServiceProvider" --tag=config
Once the command is finished you should have a config/clamav.php
file that will be used as well.
Language files
If you want to customize the translation or add your own language you can run the following command to publish the language files to a folder you maintain:
php artisan vendor:publish --provider="Sunspikes\ClamavValidator\ClamavValidatorServiceProvider" --tag=lang
This will copy the language files to resources/lang/vendor/clamav-validator
for Laravel >= 5.1
Usage
Use it like any Validator
rule:
$rules = [ 'file' => 'clamav', ];
ClamavValidator
will automatically run multiple files one-by-one through ClamAV in case file
represent multiple uploaded files.
Author
Krishnaprasad MG [@sunspikes] and other awesome contributors