lemaur / laravel-typed-config
Installs: 289
Dependents: 0
Suggesters: 0
Security: 0
Stars: 0
Watchers: 1
Forks: 0
Open Issues: 2
pkg:composer/lemaur/laravel-typed-config
Requires
- php: ^8.1
- illuminate/contracts: ^10.0
- spatie/laravel-package-tools: ^1.14.0
Requires (Dev)
- laravel/pint: ^1.0
- nunomaduro/collision: ^7.9
- nunomaduro/larastan: ^2.0.1
- orchestra/testbench: ^8.0
- 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
This package is auto-updated.
Last update: 2025-09-29 02:51:20 UTC
README
This package provides an object-oriented way to retrieve the configuration data with the right type.
If you are familiar with static analysis tool like phpstan, you've probably encountered Cannot cast mixed to string error (or similar).
This is usually happen when you try to cast a value returned from a method/function with a mixed return type.
Most of the time, in my personal case, the method is config() and following you can see an example:
$myValue = (string) config('my-app.my-value'); // or $myValue = (string) config()->get('my-app.my-value');
With this package you can get a string value (and not only string) directly from the configuration like:
$myValue = config()->string('my-app.my-value');
Support Me
Hey folks,
Do you like this package? Do you find it useful, and it fits well in your project?
I am glad to help you, and I would be so grateful if you considered supporting my work.
You can even choose 😃:
- You can sponsor me 😎 with a monthly subscription.
- You can buy me a coffee ☕ or a pizza 🍕 just for this package.
- You can plant trees 🌴. By using this link we will both receive 30 trees for free and the planet (and me) will thank you.
- You can "Star ⭐" this repository (it's free 😉).
Installation
You can install the package via composer:
composer require lemaur/laravel-typed-config
Usage
Retrieving Stringable Configuration Value
You may use the string method to retrieve the configuration data as an instance of Illuminate\Support\Stringable:
$name = config()->string('my-app.name');
Retrieving Boolean Configuration Value
You may use the boolean method to retrieve the configuration data as a boolean. The boolean method returns true for 1, "1", true, "true", "on", and "yes". All other values will return false:
$archived = config()->boolean('my-app.archived');
Retrieving Integer Configuration Value
You may use the integer method to retrieve the configuration data as an integer:
$count = config()->integer('my-app.count');
Retrieving Float Configuration Value
You may use the float method to retrieve the configuration data as a float:
$amount = config()->float('my-app.amount');
Retrieving Date Configuration Value
You may use the date method to retrieve the configuration data as a Carbon instance:
$birthday = config()->date('my-app.birthday');
The second and third arguments accepted by the date method may be used to specify the date's format and timezone, respectively:
$elapsed = config()->date('my-app.elapsed', '!H:i', 'Europe/Madrid');
In case of an invalid format, an InvalidArgumentException will be thrown.
Retrieving Enum Configuration Value
You may use the enum method to retrieve the configuration data as a PHP enum instance.
In case of an invalid value or the enum does not have a backing value that matches the input value, null will be returned.
The enum method accepts the name of the input value and the enum class as its first and second arguments:
use App\Enums\Status; $status = config()->enum('my-app.status', Status::class);
Retrieving Configuration Value as a Collection
You may use the collect method to retrieve the configuration data as an Illuminate\Support\Collection instance:
$data = config()->collect('my-app.data');
Testing
composer test
Changelog
Please see CHANGELOG for more information on what has changed recently.
Contributing
Please see CONTRIBUTING for details.
Security Vulnerabilities
Please review our security policy on how to report security vulnerabilities.
Credits
License
The MIT License (MIT). Please see License File for more information.