. */ namespace SP\Repositories\EventLog; use SP\Core\Exceptions\ConstraintException; use SP\Core\Exceptions\QueryException; use SP\DataModel\EventlogData; use SP\DataModel\ItemSearchData; use SP\Repositories\Repository; use SP\Storage\Database\QueryData; use SP\Storage\Database\QueryResult; /** * Class EventlogRepository * * @package SP\Repositories\EventLog */ final class EventlogRepository extends Repository { /** * Clears the event log * * @return bool con el resultado * @throws QueryException * @throws ConstraintException */ public function clear() { $queryData = new QueryData(); $queryData->setQuery('TRUNCATE TABLE EventLog'); $queryData->setOnErrorMessage(__u('Error while clearing the event log out')); return $this->db->doQuery($queryData)->getAffectedNumRows() > 0; } /** * Searches for items by a given filter * * @param ItemSearchData $itemSearchData * * @return QueryResult * @throws ConstraintException * @throws QueryException */ public function search(ItemSearchData $itemSearchData) { $queryData = new QueryData(); $queryData->setSelect('id, FROM_UNIXTIME(date) AS date, action, level, login, ipAddress, description'); $queryData->setFrom('EventLog'); $queryData->setOrder('id DESC'); if ($itemSearchData->getSeachString() !== '') { $queryData->setWhere('action LIKE ? OR login LIKE ? OR ipAddress LIKE ? OR description LIKE ?'); $search = '%' . $itemSearchData->getSeachString() . '%'; $queryData->setParams(array_fill(0, 4, $search)); } $queryData->setLimit( '?,?', [$itemSearchData->getLimitStart(), $itemSearchData->getLimitCount()] ); return $this->db->doSelect($queryData, true); } /** * @param EventlogData $eventlogData * * @return int * @throws ConstraintException * @throws QueryException */ public function create(EventlogData $eventlogData) { $sql = 'INSERT INTO EventLog SET `date` = UNIX_TIMESTAMP(), login = ?, userId = ?, ipAddress = ?, `action` = ?, description = ?, `level` = ?'; $queryData = new QueryData(); $queryData->setQuery($sql); $queryData->setParams([ $eventlogData->getLogin(), $eventlogData->getUserId(), $eventlogData->getIpAddress(), $eventlogData->getAction(), $eventlogData->getDescription(), $eventlogData->getLevel()] ); return $this->db->doQuery($queryData)->getLastId(); } }