MongoDB

webman по умолчанию использует mongodb/laravel-mongodb в качестве компонента mongodb, который был извлечен из проекта laravel, и используется так же, как и в laravel.

Перед использованием jenssegers/mongodb необходимо сначала установить расширение mongodb для php-cli.

Внимание
Данный мануал предназначен для версии webman v2. Если вы используете версию webman v1, пожалуйста, посмотрите руководство по версии v1
Используйте команду php -m | grep mongodb, чтобы проверить, установлено ли расширение mongodb для php-cli. Обратите внимание: даже если вы установили расширение mongodb для php-fpm, это не означает, что вы можете использовать его в php-cli, так как php-cli и php-fpm — это разные приложения, и они могут использовать разные файлы конфигурации php.ini. Используйте команду php --ini, чтобы узнать, какой файл конфигурации php.ini используется вашим php-cli.

Установка

composer require -W webman/database mongodb/laravel-mongodb ^4.8

После установки необходимо перезапустить (reload не сработает)

Конфигурация

В config/database.php добавьте соединение mongodb, аналогично следующему:

return [

    'default' => 'mysql',

    'connections' => [

         ...здесь пропущены другие конфигурации...

        'mongodb' => [
            'driver'   => 'mongodb',
            'host'     => '127.0.0.1',
            'port'     =>  27017,
            'database' => 'test',
            'username' => null,
            'password' => null,
            'options' => [
                // здесь вы можете передать дополнительные параметры менеджеру драйвера Mongo
                // смотрите https://www.php.net/manual/en/mongodb-driver-manager.construct.php в разделе "Uri Options" для получения полного списка параметров, которые вы можете использовать

                'appname' => 'homestead'
            ],
        ],
    ],
];

Пример

<?php
namespace app\controller;

use support\Request;
use support\Db;

class UserController
{
    public function db(Request $request)
    {
        Db::connection('mongodb')->table('test')->insert([1,2,3]);
        return json(Db::connection('mongodb')->table('test')->get());
    }
}

Пример модели

<?php
namespace app\model;

use DateTimeInterface;
use support\MongoModel as Model;

class Test extends Model
{
    protected $connection = 'mongodb';

    protected $table = 'test';

    public $timestamps = true;

    /**
     * @param DateTimeInterface $date
     * @return string
     */
    protected function serializeDate(DateTimeInterface $date): string
    {
        return $date->format('Y-m-d H:i:s');
    }
}

Дополнительную информацию вы можете найти по адресу

https://github.com/mongodb/laravel-mongodb