MongoDB

webman utiliza por defecto mongodb/laravel-mongodb como componente de mongodb, que se ha extraído de un proyecto de laravel y su uso es el mismo que en laravel.

Antes de utilizar jenssegers/mongodb, debes instalar la extensión de mongodb para php-cli.

Nota
Este manual es para la versión v2 de webman. Si estás utilizando la versión v1 de webman, consulta el manual de la versión v1.
Utiliza el comando php -m | grep mongodb para verificar si la extensión de mongodb está instalada en php-cli. Nota: incluso si has instalado la extensión de mongodb en php-fpm, no significa que puedas usarla en php-cli, ya que php-cli y php-fpm son aplicaciones diferentes y pueden usar configuraciones de php.ini distintas. Utiliza el comando php --ini para ver qué archivo de configuración php.ini está utilizando tu php-cli.

Instalación

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

Después de la instalación, es necesario reiniciar (reload no es efectivo).

Configuración

En config/database.php, agrega la conexión mongodb, similar a lo siguiente:

return [

    'default' => 'mysql',

    'connections' => [

         ...se omiten otras configuraciones...

        'mongodb' => [
            'driver'   => 'mongodb',
            'host'     => '127.0.0.1',
            'port'     =>  27017,
            'database' => 'test',
            'username' => null,
            'password' => null,
            'options' => [
                // aquí puedes pasar más configuraciones al Administrador de Controladores de Mongo
                // consulta https://www.php.net/manual/en/mongodb-driver-manager.construct.php en "Uri Options" para una lista completa de parámetros que puedes utilizar

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

Ejemplo

<?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());
    }
}

Ejemplo de Modelo

<?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');
    }
}

Para más contenido, visita

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