%PDF- %PDF-
Direktori : /var/www/projetos/suporte.iigd.com.br/src/Dashboard/Filters/ |
Current File : //var/www/projetos/suporte.iigd.com.br/src/Dashboard/Filters/UserTechFilter.php |
<?php /** * --------------------------------------------------------------------- * * GLPI - Gestionnaire Libre de Parc Informatique * * http://glpi-project.org * * @copyright 2015-2024 Teclib' and contributors. * @copyright 2003-2014 by the INDEPNET Development Team. * @licence https://www.gnu.org/licenses/gpl-3.0.html * * --------------------------------------------------------------------- * * LICENSE * * This file is part of GLPI. * * This program 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. * * This program 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 this program. If not, see <https://www.gnu.org/licenses/>. * * --------------------------------------------------------------------- */ namespace Glpi\Dashboard\Filters; use Change; use Problem; use Session; use Ticket; use User; class UserTechFilter extends AbstractFilter { public static function getName(): string { return __("Technician"); } public static function getId(): string { return "user_tech"; } public static function canBeApplied(string $table): bool { /** @var \DBmysql $DB */ global $DB; return $DB->fieldExists($table, 'users_id_tech') || in_array($table, [Ticket::getTable(), Change::getTable(), Problem::getTable()]); } public static function getCriteria(string $table, $value): array { /** @var \DBmysql $DB */ global $DB; $criteria = []; $users_id = null; if ((int) $value > 0) { $users_id = (int) $value; } else if ($value === 'myself') { $users_id = $_SESSION['glpiID']; } if ($users_id !== null) { if ($DB->fieldExists($table, 'users_id_tech')) { $criteria["WHERE"] = [ "$table.users_id_tech" => $users_id, ]; } else if (in_array($table, [Ticket::getTable(), Change::getTable(), Problem::getTable()])) { $itemtype = getItemTypeForTable($table); $main_item = getItemForItemtype($itemtype); $userlink = $main_item->userlinkclass; $ul_table = $userlink::getTable(); $fk = $main_item->getForeignKeyField(); $criteria["JOIN"] = [ "$ul_table as ul" => [ 'ON' => [ 'ul' => $fk, $table => 'id', ] ] ]; $criteria["WHERE"] = [ "ul.type" => \CommonITILActor::ASSIGN, "ul.users_id" => $users_id, ]; } } return $criteria; } public static function getSearchCriteria(string $table, $value): array { /** @var \DBmysql $DB */ global $DB; $criteria = []; if ((int) $value > 0 || $value === 'myself') { if ($DB->fieldExists($table, 'users_id_tech')) { $criteria[] = [ 'link' => 'AND', 'field' => self::getSearchOptionID($table, 'users_id_tech', 'glpi_users'), 'searchtype' => 'equals', 'value' => $value === 'myself' ? (int) Session::getLoginUserID() : (int) $value ]; } elseif (in_array($table, [Ticket::getTable(), Change::getTable(), Problem::getTable()])) { $criteria[] = [ 'link' => 'AND', 'field' => 5,// tech 'searchtype' => 'equals', 'value' => is_numeric($value) ? (int) $value : $value ]; } } return $criteria; } public static function getHtml($value): string { return self::displayList( self::getName(), is_string($value) ? $value : "", 'user_tech', User::class, [ 'right' => 'own_ticket', 'toadd' => [ [ 'id' => 'myself', 'text' => __('Myself'), ] ] ] ); } }