Code Coverage
 
Classes and Traits
Functions and Methods
Lines
Total
100.00% covered (success)
100.00%
1 / 1
100.00% covered (success)
100.00%
6 / 6
CRAP
100.00% covered (success)
100.00%
25 / 25
DataSource
100.00% covered (success)
100.00%
1 / 1
100.00% covered (success)
100.00%
6 / 6
15
100.00% covered (success)
100.00%
25 / 25
 __construct
100.00% covered (success)
100.00%
1 / 1
6
100.00% covered (success)
100.00%
12 / 12
 ref
100.00% covered (success)
100.00%
1 / 1
1
100.00% covered (success)
100.00%
1 / 1
 createQueryBuilder
100.00% covered (success)
100.00%
1 / 1
1
100.00% covered (success)
100.00%
1 / 1
 loadData
100.00% covered (success)
100.00%
1 / 1
5
100.00% covered (success)
100.00%
9 / 9
 invalidateCache
100.00% covered (success)
100.00%
1 / 1
1
100.00% covered (success)
100.00%
1 / 1
 getConnection
100.00% covered (success)
100.00%
1 / 1
1
100.00% covered (success)
100.00%
1 / 1
<?php declare(strict_types = 1);
/*
 * Copyright (c) 2019, Josef Kufner  <josef@kufner.cz>
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 * 
 *     http://www.apache.org/licenses/LICENSE-2.0
 * 
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 *
 */
namespace Smalldb\StateMachine\SqlExtension\ReferenceDataSource;
use Doctrine\DBAL\Connection;
use Doctrine\DBAL\Driver\Statement;
use Doctrine\DBAL\FetchMode;
use Smalldb\StateMachine\Provider\SmalldbProviderInterface;
use Smalldb\StateMachine\ReferenceDataSource\ReferenceDataSourceInterface;
use Smalldb\StateMachine\ReferenceInterface;
use Smalldb\StateMachine\Smalldb;
class DataSource implements ReferenceDataSourceInterface
{
    protected Smalldb $smalldb;
    protected SmalldbProviderInterface $machineProvider;
    protected string $refClass;
    private Connection $db;
    public function __construct(?DataSource $originalDataSource, Smalldb $smalldb = null, SmalldbProviderInterface $machineProvider = null, Connection $db = null)
    {
        if ($originalDataSource === null) {
            if ($smalldb && $machineProvider && $db) {
                $this->smalldb = $smalldb;
                $this->machineProvider = $machineProvider;
                $this->refClass = $this->machineProvider->getReferenceClass();
                $this->db = $db;
            } else {
                throw new \InvalidArgumentException("Missing argument(s).");
            }
        } else {
            $this->smalldb = $originalDataSource->smalldb;
            $this->machineProvider = $originalDataSource->machineProvider;
            $this->refClass = $originalDataSource->refClass;
            $this->db = $originalDataSource->db;
        }
    }
    public function ref($id): ReferenceInterface
    {
        return new $this->refClass($this->smalldb, $this->machineProvider, $this, $id);
    }
    public function createQueryBuilder(string $tableAlias = 'this'): ReferenceQueryBuilder
    {
        return new ReferenceQueryBuilder($this->smalldb, $this->machineProvider, $this, $tableAlias);
    }
    /**
     * Load data for the state machine and set the state
     */
    public function loadData($id): ?array
    {
        if ($id === null) {
            return null;
        }
        $q = $this->createQueryBuilder()
            ->addSelectFromStatements()
            ->andWhereId($id);
        $stmt = $q->execute();
        if ($stmt instanceof Statement) {
            $data = $stmt->fetch(FetchMode::ASSOCIATIVE);
        } else {
            throw new LogicException("Load data select does not return a result set.");  // @codeCoverageIgnore
        }
        return $data ?: null;
    }
    /**
     * Invalidate cached data
     */
    public function invalidateCache($id = null)
    {
        // No caching nor preloading.
    }
    /**
     * @return Connection
     */
    public function getConnection(): Connection
    {
        return $this->db;
    }
}