jeroen-de-dauw / file-fetcher
Simple file fetching interface
Fund package maintenance!
JeroenDeDauw
Installs: 943
Dependents: 0
Suggesters: 0
Security: 0
Stars: 6
Watchers: 4
Forks: 3
Open Issues: 1
pkg:composer/jeroen-de-dauw/file-fetcher
Requires
- php: >=7.3
- psr/log: ~3.0|~2.0|~1.0
Requires (Dev)
- jeroen/psr-log-test-doubles: ~3.0|~2.2
- phpstan/phpstan: ~1.6.0
- phpunit/phpunit: ~9.5
- squizlabs/php_codesniffer: ~3.2
- vimeo/psalm: ^4.22.0
Suggests
- jeroen/file-fetcher-cache: Provides a SimpleCache (PSR-16) decorator for file fetchers
- jeroen/file-fetcher-stopwatch: Provides a Symfony Stopwatch decorator for file fetchers
README
The philosophy behind this library is to provide a very basic interface
(FileFetcher) that is ideal for 95%
of network access cases, such as your typical file_get_contents call. It explicitly does not try to deal with the more complex cases.
Several basic implementations are provided. These include the test doubles you typically need to test services
that use the FileFetcher interface. You can easily create an adapter to a more heavy network access library
(such as Guzzle) in your own codebase.
Usage
$fileContent = $fileFetcher->fetchFile($fileLocation);
The library provides some trivial implementations of the FileFetcher interface at its heart:
SimpleFileFetcher: Adapter aroundfile_get_contentsInMemoryFileFetcher: Adapter around an array provided to its constructorThrowingFileFetcher: Throws aFileFetchingExceptionfor all callsNullFileFetcher: Returns an empty string for all callsStubFileFetcher: Returns a stub value for all callsCallbackFileFetcher: Adapter around a callbackLazyStubFileFetcher: Return a lazily retrieved stub value for all calls
It also provides a number of decorators:
ErrorLoggingFileFetcher: Logs errors via the PSR-3 LoggerInterfaceSpyingFileFetcher: A spy (test double)
Decorators provided by jeroen/file-fetcher-cache:
PsrCacheFileFetcher: Caches file contents via PSR-16 SimpleCacheCachingFileFetcher: Caches file contents. Requiresjeroen/simple-cacheto be loaded
Decorators provided by jeroen/file-fetcher-stopwatch:
StopwatchFileFetcher: Profiles calls using Symfony Stopwatch. Requiressymfony/stopwatchto be loaded
Installation
You can use Composer to download and install this package as well as its dependencies.
To add this package as a local, per-project dependency to your project, simply add a
dependency on jeroen/file-fetcher to your project's composer.json file.
Here is a minimal example of a composer.json file that just defines a dependency on
FileFetcher 6.x:
{
"require": {
"jeroen/file-fetcher": "~6.0"
}
}
Development
Start by installing the project dependencies by executing
composer update
You can run the tests by executing
make test
You can run the style checks by executing
make cs
To run all CI checks, execute
make ci
You can also invoke PHPUnit directly to pass it arguments, as follows
vendor/bin/phpunit --filter SomeClassNameOrFilter
Release notes
6.1.1 (2025-02-27)
- Improved PHP 8.4+ compatibility by explicitly defining nullable types
6.1.0 (2022-04-26)
- Added support for installation with
psr/log2.x and 3.x - Raised minimum PHP version from 7.1 to 7.3
- Improved type documentation
6.0.0 (2019-01-17)
Breaking changes to increase package stability and avoid the need for breaking changes in the future.
- Removed
PsrCacheFileFetcher, now part ofjeroen/file-fetcher-cache - Removed
CachingFileFetcher, now part ofjeroen/file-fetcher-cache - Removed
StopwatchFileFetcher, now part ofjeroen/file-fetcher-stopwatch
5.0.1 (2019-01-16)
PsrCacheFileFetchernow ensures cache keys are valid
5.0.0 (2019-01-16)
- Added
PsrCacheFileFetcher - Added
StopwatchFileFetcher jeroen/simple-cache, which is needed byCachingFileFetcheris no longer loaded by default
4.5.0 (2018-12-19)
- Switched License from GPL-2.0-or-later to BSD-3-Clause
4.4.0 (2018-05-31)
- Dropped support for PHP 7.0
- Added
CallbackFileFetcher - Added
LazyStubFileFetcher
4.3.0 (2017-06-10)
- Added
getFirstFetchedUrltoSpyingFileFetcher - Added
$defaultContentconstructor parameter toInMemoryFileFetcher
4.2.0 (2017-06-07)
- Added
StubFileFetcher
4.1.0 (2017-05-11)
- Added
ThrowingFileFetcher - Added
NullFileFetcher
4.0.0 (2017-05-09)
Breaking changes:
- Added scalar type hints to the
FileFetcherinterface and its implementations - Added scalar type hints to
FileFetchingException
Other changes:
- Dropped support for PHP 5.x
- Added
ErrorLoggingFileFetcher - Added
SpyingFileFetcher
3.1.0 (2016-01-07)
- Added
InMemoryFileFetcher
3.0.0 (2015-08-21)
- Added
FileFetchingException, which should now be thrown by implementations ofFileFetcheron error - The non-public fields and methods of
CachingFileFetcherare now private rather than protected - Added PHPCS and PHPMD integration
2.0.0 (2014-08-19)
- Removed
FileFetcher.phpentry point. Autoloading is now done via Composers PSR-4 support.
1.0.1 (2013-07-06)
- Added
SimpleFileFetcherimplementation
1.0.0 (2013-07-06)
- Initial release with
FileFetcherinterface andCachingFileFetcherimplementation