Download the PHP package hepplerdotnet/laravel-config-override without Composer
On this page you can find all versions of the php package hepplerdotnet/laravel-config-override. It is possible to download/install these versions without Composer. Possible dependencies are resolved automatically.
Download hepplerdotnet/laravel-config-override
More information about hepplerdotnet/laravel-config-override
Files in hepplerdotnet/laravel-config-override
Package laravel-config-override
Short Description Package to store Laravel Configuration in Database
License MIT
Homepage https://github.com/HepplerDotNet/laravel-config-override
Informations about the package laravel-config-override
Laravel Config Override
Store Laravel Configuration in Database and use it thru config()
helper
Important
This Package uses Illuminate\Vendor\HepplerDotNet\Providers\ConfigurationProvider
Before you start yelling "Using Illuminate namespace is bad practice!".
You're right, but let's take a look at Illuminate\Foundation\Application::registerConfiguredProviders
- It creates a collection from your App config providers array
- Splits this array in 2 chunks [Everything that starts with Illuminate\, rest of it]
- Adds all the composer packages service providers in between
This package derived from one of my projects which had some requirements:
- Login against Active Directory (solved easily with https://ldaprecord.com/docs/laravel/v2/)
- Make the whole App configuration maintainable thru Webgui, including ldap configuration
All "regular" options to register a Service Provider failed at some point, either Auth
facade failed or LDAP failed because config()
had no access to the configuration from database at this point.
So using Illuminate namespace was the only working solution. Period.
Installation
Requires at least laravel/framework 8.37 because of anonymous migrations
Run composer require hepplerdotnet/laravel-config-override
Note
key => values from database will have precedence over config or .env file!
Groups will be merged with existing configuration
Usage
Let's say you would change the app locale
Now you can access it with config("app.locale")
Or a more complex example with nested groups
Now you can access it with config("mail.mailers.smtp.host")
The Models
Group
Property | Description | Values |
---|---|---|
name | Name analog to config file e.g. app or mail | String |
root | Group is root element | true or false |
active | Configuration is active and should be loaded | true or false |
Entry
Property | Description | Values |
---|---|---|
key | Configuration Key | String |
value | Configuration Value | String, Password, Integer, Boolean, Array |
type | Value type | String, Password, Integer, Boolean, Array |
Type Password will be stored encrypted in database!
Config
Config is not a real Eloquent Model, it's just a Class which builds the config from database