Store Laravel Settings in a Database

Store Laravel Settings in a Database

Laravel Settings is a package by Spatie for storing strongly typed application settings in a repository and easily use them throughout your application.

To help you visualize how you’ll eventually use this package, here’s an example of injecting a settings class in a controller and accessing settings:

class IndexController
{
    public function __invoke(GeneralSettings $settings){
        return view('index', [
            'site_name' => $settings->site_name,
        ]);
    }
}

This package is built around strongly-typed settings classes, so naturally, you’re probably curious what GeneralSettings looks like in the above example:

use Spatie\LaravelSettings\Settings;

class GeneralSettings extends Settings
{
    public string $site_name;

    public bool $site_active;

    public static function group(): string
    {
        return 'general';
    }
}

You’ll likely want to provide a way for admins to update settings, and you can do so by simply setting properties on the class and calling save:

$settings->site_name = $request->input('site_name');
$settings->site_active = $request->boolean('site_active');

$settings->save();

You can even use casts, such as the DateTimeInterfaceCast that ships with this package. The DateTimeInterfaceCast can be used for properties that are DateTime, Carbon, etc. types.

Repositories

The Laravel Settings package persists data using either a database (i.e., MySQL, PostgresSQL) or Redis. You can also create a custom repository type if you need to support something besides the provided repositories.

You can support multiple database repositories in one application by configuring more than one repository in the package’s settings. You can also mix and match between Redis and database repositories and define which repository a class should use.

Learn More

This package is chalked full of features not mentioned in this post. I encourage you to read through the project’s readme and Store strongly typed settings in a Laravel app on Freek Van der Herten’s blog.

Filed in: News

Newsletter

Join 31,000+ others and never miss out on new tips, tutorials, and more.

Laravel News Partners

Laravel Jobs

Laravel Senior Developer
Remote, Canada Only
BeMo Academic Consulting
Senior Fullstack Developer / Architect (w/m/d)
Remote / Munich - Germany
envivo.select GmbH
Medior full stack developer (Laravel)
Deventer (or remote) in the Netherlands, Dutch speaking required.
MSML B.V.
Senior Full Stack PHP Developer (Laravel)
Remote
MAPPEN
Senior Laravel Developer
Remote
ACTO