 Maslosoft Mangan API
	Maslosoft Mangan API
 1  2  3  4  5  6  7  8  9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 <?php
/**
 * This software package is licensed under AGPL or Commercial license.
 *
 * @package maslosoft/mangan
 * @licence AGPL or Commercial
 * @copyright Copyright (c) Piotr Masełkowski <pmaselkowski@gmail.com>
 * @copyright Copyright (c) Maslosoft
 * @copyright Copyright (c) Others as mentioned in code
 * @link https://maslosoft.com/mangan/
 */
namespace Maslosoft\Mangan;
use Maslosoft\Addendum\Interfaces\AnnotatedInterface;
use Maslosoft\Mangan\Abstracts\AbstractFinder;
use Maslosoft\Mangan\Adapters\Finder\MongoAdapter;
use Maslosoft\Mangan\Exceptions\ManganException;
use Maslosoft\Mangan\Helpers\FinderEvents;
use Maslosoft\Mangan\Interfaces\EntityManagerInterface;
use Maslosoft\Mangan\Interfaces\FinderInterface;
use Maslosoft\Mangan\Meta\ManganMeta;
use Maslosoft\Mangan\Traits\Finder\FinderHelpers;
use Maslosoft\Mangan\Transformers\RawArray;
/**
 * Basic Finder implementation
 *
 * @author Piotr Maselkowski <pmaselkowski at gmail.com>
 */
class Finder extends AbstractFinder
{
    use FinderHelpers;
    /**
     * Constructor
     *
     * @param object $model Model instance
     * @param EntityManagerInterface $em
     * @param Mangan $mangan
     */
    public function __construct($model, $em = null, $mangan = null)
    {
        if (null === $mangan)
        {
            $mangan = Mangan::fromModel($model);
        }
        $this->setModel($model);
        $this->setScopeManager(new ScopeManager($model));
        $this->setAdapter(new MongoAdapter($model, $mangan, $em));
        $this->setProfiler($mangan->getProfiler());
        $this->setFinderEvents(new FinderEvents);
        $this->withCursor($mangan->useCursor);
    }
    /**
     * Create model related finder.
     * This will create customized finder if defined in model with Finder annotation.
     * If no custom finder is defined this will return default Finder.
     *
     * @param AnnotatedInterface $model
     * @param EntityManagerInterface $em
     * @param Mangan $mangan
     * @return FinderInterface
     */
    public static function create(AnnotatedInterface $model, $em = null, Mangan $mangan = null)
    {
        $finderClass = ManganMeta::create($model)->type()->finder ?: static::class;
        return new $finderClass($model, $em, $mangan);
    }
    protected function createModel($data)
    {
        if (!empty($data['$err']))
        {
            throw new ManganException(sprintf("There is an error in query: %s", $data['$err']));
        }
        // By default create instances of same
        // type as provided model
        $model = $this->getModel();
        // For non homogeneous collections class
        // need to be taken from data, not defined
        // by model
        if(ManganMeta::create($model)->type()->homogenous === false)
        {
            $model = null;
        }
        return RawArray::toModel($data, $model);
    }
}
	 API documentation generated by ApiGen
