ferdynator / clamav-constraint
This repository provides a virus scan validator constraint for Symfony-based projects.
Installs: 6 518
Dependents: 0
Suggesters: 0
Security: 0
Stars: 1
Watchers: 1
Forks: 0
Open Issues: 0
Requires
- php: >=7.2
- symfony/http-foundation: *
- symfony/validator: *
- xenolope/quahog: ^2.1
Requires (Dev)
- phpunit/phpunit: ^7.3
This package is auto-updated.
Last update: 2025-03-17 11:23:07 UTC
README
This is a custom Symfony anti-virus validator for file uploads. It uses the Quahog library to connect to a running clamav unix socket and scan the uploaded file.
This repository is strongly influenced by the clamav-validator for laravel and the TissueBundle.
Installation
composer require ferdynator/clamav-constraint
Also make sure you have ClamAv
installed.
Usage
Add this constraint in your entity of choice:
use ferdynator\ClamAvConstraint\Validator\Constraints as VirusAssert;
class JobImage {
...
/*
* ...
* @VirusAssert\ClamAv
*/
protected $file;
...
}
Configuration
Alternative socket
In case you are not using a unix socket or have it in a non-standard position you can pass an alternative socket-url:
/*
* ...
* @VirusAssert\ClamAv(
* socket="tcp://0.0.0.0:1234"
* )
*/
protected $file;
File permissions
The clamav
daemon needs read-access to the uploaded file. You can specify
a chmod-mode with the chmod
option of the constraint.
/*
* ...
* @VirusAssert\ClamAv(
* chmod=0600
* )
*/
protected $file;