<?php namespace Kanboard\Model; use PicoDb\Database; /** * Base model class * * @package model * @author Frederic Guillot */ abstract class Base extends \Kanboard\Core\Base { /** * Save a record in the database * * @access public * @param string $table Table name * @param array $values Form values * @return boolean|integer */ public function persist($table, array $values) { return $this->db->transaction(function (Database $db) use ($table, $values) { if (! $db->table($table)->save($values)) { return false; } return (int) $db->getLastId(); }); } /** * Build SQL condition for a given time range * * @access protected * @param string $start_time Start timestamp * @param string $end_time End timestamp * @param string $start_column Start column name * @param string $end_column End column name * @return string */ protected function getCalendarCondition($start_time, $end_time, $start_column, $end_column) { $start_column = $this->db->escapeIdentifier($start_column); $end_column = $this->db->escapeIdentifier($end_column); $conditions = array( "($start_column >= '$start_time' AND $start_column <= '$end_time')", "($start_column <= '$start_time' AND $end_column >= '$start_time')", "($start_column <= '$start_time' AND ($end_column = '0' OR $end_column IS NULL))", ); return $start_column.' IS NOT NULL AND '.$start_column.' > 0 AND ('.implode(' OR ', $conditions).')'; } }