%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/GroupTechFilter.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 Group; use Problem; use Ticket; class GroupTechFilter extends AbstractFilter { public static function getName(): string { return __("Technician group"); } public static function getId(): string { return "group_tech"; } public static function canBeApplied(string $table): bool { /** @var \DBmysql $DB */ global $DB; return $DB->fieldExists($table, 'groups_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 = []; $groups_id = null; if ((int)$value > 0) { $groups_id = (int) $value; } else if ($value == 'mygroups') { $groups_id = $_SESSION['glpigroups']; } if ($groups_id != null) { if ($DB->fieldExists($table, 'groups_id_tech')) { $criteria["WHERE"] = [ "$table.groups_id_tech" => $groups_id ]; } else if (in_array($table, [Ticket::getTable(), Change::getTable(), Problem::getTable()])) { $itemtype = getItemTypeForTable($table); $main_item = getItemForItemtype($itemtype); $grouplink = $main_item->grouplinkclass; $gl_table = $grouplink::getTable(); $fk = $main_item->getForeignKeyField(); $criteria["JOIN"] = [ "$gl_table as gl" => [ 'ON' => [ 'gl' => $fk, $table => 'id', ] ] ]; $criteria["WHERE"] = [ "gl.type" => \CommonITILActor::ASSIGN, "gl.groups_id" => $groups_id ]; } } return $criteria; } public static function getSearchCriteria(string $table, $value): array { /** @var \DBmysql $DB */ global $DB; $criteria = []; $groups_id = null; if ((int) $value > 0) { $groups_id = (int) $value; } else if ($value == 'mygroups') { $groups_id = 'mygroups'; } if ($groups_id != null) { if ($DB->fieldExists($table, 'groups_id_tech')) { $criteria[] = [ 'link' => 'AND', 'field' => self::getSearchOptionID($table, 'groups_id_tech', 'glpi_groups'), 'searchtype' => 'equals', 'value' => $groups_id ]; } else if (in_array($table, [Ticket::getTable(), Change::getTable(),Problem::getTable()])) { $criteria[] = [ 'link' => 'AND', 'field' => 8, // group tech 'searchtype' => 'equals', 'value' => $groups_id ]; } } return $criteria; } public static function getHtml($value): string { return self::displayList( self::getName(), is_string($value) ? $value : "", 'group_tech', Group::class, [ 'toadd' => ['mygroups' => __("My groups")], ] ); } }