Source of file BasePlanManager.php
Size: 4,841 Bytes - Last Modified: 2020-10-24T02:46:31+00:00
/home/travis/build/NextDom/nextdom-core/src/Managers/Parents/BasePlanManager.php
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162 | <?php /* This file is part of Jeedom. * * Jeedom is free software: you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * Jeedom is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with Jeedom. If not, see <http://www.gnu.org/licenses/>. */ /* This file is part of NextDom Software. * * NextDom is free software: you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * NextDom is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with NextDom. If not, see <http://www.gnu.org/licenses/>. */ namespace NextDom\Managers\Parents; use NextDom\Enums\SQLField; use NextDom\Exceptions\CoreException; use NextDom\Helpers\DBHelper; /** * Base planmanager with commons functions * * @package NextDom\Managers */ abstract class BasePlanManager extends BaseManager { const PLANHEADER_ID = ''; use CommonManager; /** * Get by plan header * * @param $planHeaderId * * @return mixed|null * * @throws CoreException * @throws \ReflectionException */ public static function byPlanHeaderId($planHeaderId) { return static::getMultipleByClauses([static::PLANHEADER_ID => $planHeaderId]); } /** * Get plan filtered by link type, link id and plan header * @param $linkType * @param $linkId * @param $planHeaderId * @return mixed|null * @throws CoreException * @throws \ReflectionException */ public static function byLinkTypeLinkIdPlanHeaderId($linkType, $linkId, $planHeaderId) { return static::getMultipleByClauses([ SQLField::LINK_TYPE => $linkType, SQLField::LINK_ID => $linkId, static::PLANHEADER_ID => $planHeaderId ]); } /** * @param $linkType * @param $linkId * @param $planHeaderId * @return mixed|null * @throws CoreException */ public static function removeByLinkTypeLinkIdPlanHeaderId($linkType, $linkId, $planHeaderId) { $params = [ SQLField::LINK_TYPE => $linkType, SQLField::LINK_ID => $linkId, 'planHeader_id' => $planHeaderId ]; $sql = 'DELETE FROM ' . static::DB_CLASS_NAME . ' WHERE `link_type` = :link_type AND `link_id` = :link_id AND `' . static::PLANHEADER_ID . '` = :planHeader_id'; return DBHelper::getOneObject($sql, $params, static::CLASS_NAME); } /** * @return array|mixed|null * @throws \NextDom\Exceptions\CoreException * @throws \ReflectionException */ public static function all() { return static::getAll(); } /** * @param $_link_type * @param $_link_id * @return array|mixed|null * @throws \NextDom\Exceptions\CoreException * @throws \ReflectionException */ public static function byLinkTypeLinkId($_link_type, $_link_id) { return static::getMultipleByClauses([ SQLField::LINK_TYPE => $_link_type, SQLField::LINK_ID => $_link_id, ]); } /** * @param $_search * @return array|mixed|null * @throws \NextDom\Exceptions\CoreException * @throws \ReflectionException */ public static function searchByDisplay($_search) { $clauses = [ SQLField::DISPLAY => '%' . $_search . '%', ]; return static::searchMultipleByClauses($clauses); } /** * @param $_search * @param string $_not * @return array|mixed|null * @throws \NextDom\Exceptions\CoreException * @throws \ReflectionException */ public static function searchByConfiguration($_search, $_not = '') { $value = [ 'search' => '%' . $_search . '%', 'not' => $_not, ]; $sql = static::getBaseSQL() . ' WHERE `configuration` LIKE :search AND `link_type` != :not'; return DBHelper::getAllObjects($sql, $value, static::CLASS_NAME); } } |