* @package PHPCI * @subpackage Plugins */ class Sqlite implements Plugin { /** * @var \PHPCensor\Builder */ protected $phpci; /** * @var \PHPCensor\Model\Build */ protected $build; /** * @var array */ protected $queries = []; /** * @var string */ protected $path; /** * @param Builder $phpci * @param Build $build * @param array $options */ public function __construct(Builder $phpci, Build $build, array $options = []) { $this->phpci = $phpci; $this->build = $build; $this->queries = $options; $buildSettings = $phpci->getConfig('build_settings'); if (isset($buildSettings['sqlite'])) { $sql = $buildSettings['sqlite']; $this->path = $sql['path']; } $this->phpci->logDebug('Plugin options: ' . json_encode($options)); } /** * Connects to SQLite and runs a specified set of queries. * @return boolean */ public function execute() { try { $opts = [PDO::ATTR_ERRMODE => PDO::ERRMODE_EXCEPTION]; $pdo = new PDO('sqlite:' . $this->path, $opts); foreach ($this->queries as $query) { $pdo->query($this->phpci->interpolate($query)); } } catch (\Exception $ex) { $this->phpci->logFailure($ex->getMessage()); return false; } return true; } }