allenjd3/mongo-entries

There is no license information available for the latest version (dev-main) of this package.

An example package that allows you to store Statamic entries in a database.

dev-main 2023-11-29 13:15 UTC

This package is auto-updated.

Last update: 2024-10-29 15:10:10 UTC


README

Installation

composer require allenjd3/mongo-entries --with-all-dependencies

Set up you database connection in config/database.php.

'connections' => [
    'mongodb' => [
        'driver' => 'mongodb',
        'dsn' => env('DB_DSN'),
        'database' => env('DB_DATABASE'),
    ],
],

Add the following to your .env file.

DB_CONNECTION=mongodb
DB_DSN=mongodb://

Usage

Start by creating a new Statamic site. If you are planning to use mongodb to store users, you can skip creating a user.

statamic new my-site

If you'd like to use authentication, you will need to change some config values.

First register MongoAuthServiceProvider in config/app.php.

'providers' => [
    // ...
    \Allenjd3\Mongo\Providers\MongoAuthServiceProvider::class,
],

Then change the repository config in config/statamic/users.php.

'repository' => 'mongo',
'repositories' => [
    'mongo' => [
        'driver' => 'mongo',
    ],
],

Add the following to the providers array in config/auth.php.

        'users' => [
            'driver' => 'mongo',
            'model' => App\Models\User::class,
        ],

Then in your App\Model\User class, you will need to extend the Allenjd3\Mongo\Auth\User class as authenticatable

use Allenjd3\Mongo\Auth\User as Authenticatable;

and use the following trait-

//other traits
use HasUuids;

Cast the following in your App\Model\User class-

    protected $casts = [
        'preferences' => 'json',
        'super' => 'boolean',
    ];

    protected $dates = [
        'created_at',
        'updated_at',
        'email_verified_at',
    ];

Create a new user

php please make:user