Passes the stream representing an asset to a backend that can perform scanning. If the scan fails, information is logged for further review and the request to store the asset fails.
This works with assets being stored via:
- Uploads
- File::setFrom* operations
The module ships with a ClamAV backend where clamd can be contacted via a unix socket or TCP socket. The system allows for custom scanning backends to be created and configured.
To use clamd, you need to have that installed, configured and working.
composer require nswdpc/silverstripe-asset-scan
To use the replacement asset store, add configuration to your project.
The name of the configuration block is up to you.
---
Name: 'app-scanning-assetstore'
After:
- '#assetscore'
---
SilverStripe\Core\Injector\Injector:
SilverStripe\Assets\Storage\AssetStore:
class: 'NSWDPC\AssetScan\ScanningFlysystemAssetStore'
After configuration flush, the project will be configured to use the asset store provided by this module. It will inherit the properties defined in #assetscore
configuration.
To use the ClamAVBackend, you must set the socket address value:
---
Name: 'app-asset-scan-handling'
After:
- '#nswdpc-asset-scan-handling'
---
NSWDPC\AssetScan\ClamAVBackend:
# specify a unix socket location
address: 'unix:///some/path/to/clamd.sock'
You can also set a limit to avoid large files being passed to the backend:
NSWDPC\AssetScan\ClamAVBackend:
# null: all scanned
# 0: not passed to backend
# files over this size are not passed to the backend
bypass_over_size_bytes: 10485760
You can configure the maximum chunk size, for use with backends that do chunked scans.
---
Name: 'app-asset-scan-handling'
After:
- '#nswdpc-asset-scan-handling'
---
NSWDPC\AssetScan\Backend:
# increase chunk size to 20M, value is in bytes
max_chunk_size: 20971520
You can use your own scanning backend via Injector, for instance to extend the ClamAVBackend class or have a completely different backend. It must be a subclass of \NSWDPC\AssetScan\Backend
:
---
Name: 'app-asset-scan-handling'
After:
- '#nswdpc-asset-scan-handling'
---
SilverStripe\Core\Injector\Injector:
NSWDPC\AssetScan\Backend:
# set default backend
class: 'My\App\CustomScanBackend'
We welcome bug reports, pull requests and feature requests on the Github Issue tracker for this project.
Please review the code of conduct prior to opening a new issue.
If you have found a security issue with this module, please email digital[@]dpc.nsw.gov.au in the first instance, detailing your findings.
If you would like to make contributions to the module please ensure you raise a pull request and discuss with the module maintainers.
Please review the code of conduct prior to completing a pull request.