Linux server.jmdstrack.com 3.10.0-1160.119.1.el7.tuxcare.els10.x86_64 #1 SMP Fri Oct 11 21:40:41 UTC 2024 x86_64
/ home/ jmdstrac/ public_html/ devices/ src/ |
|
<?php /** * --------------------------------------------------------------------- * * GLPI - Gestionnaire Libre de Parc Informatique * * http://glpi-project.org * * @copyright 2015-2023 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/>. * * --------------------------------------------------------------------- */ use Glpi\Application\View\TemplateRenderer; /** * Monitor Class **/ class Monitor extends CommonDBTM { use Glpi\Features\DCBreadcrumb; use Glpi\Features\Clonable; use Glpi\Features\Inventoriable; // From CommonDBTM public $dohistory = true; protected static $forward_entity_to = ['Infocom', 'ReservationItem', 'Item_OperatingSystem', 'NetworkPort', 'Item_SoftwareVersion' ]; public static $rightname = 'monitor'; protected $usenotepad = true; public function getCloneRelations(): array { return [ Item_OperatingSystem::class, Item_Devices::class, Infocom::class, Contract_Item::class, Document_Item::class, Computer_Item::class, KnowbaseItem_Item::class ]; } /** * Name of the type * * @param $nb string number of item in the type **/ public static function getTypeName($nb = 0) { return _n('Monitor', 'Monitors', $nb); } /** * @see CommonDBTM::useDeletedToLockIfDynamic() * * @since 0.84 **/ public function useDeletedToLockIfDynamic() { return false; } public function defineTabs($options = []) { $ong = []; $this->addDefaultFormTab($ong); $this->addImpactTab($ong, $options); $this->addStandardTab('Item_OperatingSystem', $ong, $options); $this->addStandardTab('Item_SoftwareVersion', $ong, $options); $this->addStandardTab('Item_Devices', $ong, $options); $this->addStandardTab('Computer_Item', $ong, $options); $this->addStandardTab('NetworkPort', $ong, $options); $this->addStandardTab('Infocom', $ong, $options); $this->addStandardTab('Contract_Item', $ong, $options); $this->addStandardTab('Document_Item', $ong, $options); $this->addStandardTab('KnowbaseItem_Item', $ong, $options); $this->addStandardTab('Ticket', $ong, $options); $this->addStandardTab('Item_Problem', $ong, $options); $this->addStandardTab('Change_Item', $ong, $options); $this->addStandardTab('ManualLink', $ong, $options); $this->addStandardTab('Lock', $ong, $options); $this->addStandardTab('Notepad', $ong, $options); $this->addStandardTab('Reservation', $ong, $options); $this->addStandardTab('Domain_Item', $ong, $options); $this->addStandardTab('Appliance_Item', $ong, $options); $this->addStandardTab('RuleMatchedLog', $ong, $options); $this->addStandardTab('Log', $ong, $options); return $ong; } public function prepareInputForAdd($input) { if (isset($input["id"]) && ($input["id"] > 0)) { $input["_oldID"] = $input["id"]; } if (isset($input["size"]) && ($input["size"] == '')) { unset($input["size"]); } unset($input['id']); unset($input['withtemplate']); return $input; } /** * Print the monitor form * * @param $ID integer ID of the item * @param $options array * - target filename : where to go when done. * - withtemplate boolean : template or basic item * * @return boolean item found **/ public function showForm($ID, array $options = []) { $this->initForm($ID, $options); TemplateRenderer::getInstance()->display('pages/assets/monitor.html.twig', [ 'item' => $this, 'params' => $options, ]); return true; } /** * Return the linked items (in computers_items) * * @return array of linked items like array('Computer' => array(1,2), 'Printer' => array(5,6)) * @since 0.84.4 **/ public function getLinkedItems() { global $DB; $iterator = $DB->request([ 'SELECT' => 'computers_id', 'FROM' => 'glpi_computers_items', 'WHERE' => [ 'itemtype' => $this->getType(), 'items_id' => $this->fields['id'] ] ]); $tab = []; foreach ($iterator as $data) { $tab['Computer'][$data['computers_id']] = $data['computers_id']; } return $tab; } public function getSpecificMassiveActions($checkitem = null) { $actions = parent::getSpecificMassiveActions($checkitem); if (static::canUpdate()) { Computer_Item::getMassiveActionsForItemtype($actions, __CLASS__, 0, $checkitem); $actions += [ 'Item_SoftwareLicense' . MassiveAction::CLASS_ACTION_SEPARATOR . 'add' => "<i class='ma-icon fas fa-key'></i>" . _x('button', 'Add a license') ]; KnowbaseItem_Item::getMassiveActionsForItemtype($actions, __CLASS__, 0, $checkitem); } return $actions; } public function rawSearchOptions() { $tab = parent::rawSearchOptions(); $tab[] = [ 'id' => '2', 'table' => $this->getTable(), 'field' => 'id', 'name' => __('ID'), 'massiveaction' => false, 'datatype' => 'number' ]; $tab = array_merge($tab, Location::rawSearchOptionsToAdd()); $tab[] = [ 'id' => '4', 'table' => 'glpi_monitortypes', 'field' => 'name', 'name' => _n('Type', 'Types', 1), 'datatype' => 'dropdown' ]; $tab[] = [ 'id' => '40', 'table' => 'glpi_monitormodels', 'field' => 'name', 'name' => _n('Model', 'Models', 1), 'datatype' => 'dropdown' ]; $tab[] = [ 'id' => '31', 'table' => 'glpi_states', 'field' => 'completename', 'name' => __('Status'), 'datatype' => 'dropdown', 'condition' => ['is_visible_monitor' => 1] ]; $tab[] = [ 'id' => '5', 'table' => $this->getTable(), 'field' => 'serial', 'name' => __('Serial number'), 'datatype' => 'string', ]; $tab[] = [ 'id' => '6', 'table' => $this->getTable(), 'field' => 'otherserial', 'name' => __('Inventory number'), 'datatype' => 'string', ]; $tab[] = [ 'id' => '7', 'table' => $this->getTable(), 'field' => 'contact', 'name' => __('Alternate username'), 'datatype' => 'string', ]; $tab[] = [ 'id' => '8', 'table' => $this->getTable(), 'field' => 'contact_num', 'name' => __('Alternate username number'), 'datatype' => 'string', ]; $tab[] = [ 'id' => '10', 'table' => $this->getTable(), 'field' => 'uuid', 'name' => __('UUID'), 'datatype' => 'string', ]; $tab[] = [ 'id' => '70', 'table' => 'glpi_users', 'field' => 'name', 'name' => User::getTypeName(1), 'datatype' => 'dropdown', 'right' => 'all' ]; $tab[] = [ 'id' => '71', 'table' => 'glpi_groups', 'field' => 'completename', 'name' => Group::getTypeName(1), 'condition' => ['is_itemgroup' => 1], 'datatype' => 'dropdown' ]; $tab[] = [ 'id' => '19', 'table' => $this->getTable(), 'field' => 'date_mod', 'name' => __('Last update'), 'datatype' => 'datetime', 'massiveaction' => false ]; $tab[] = [ 'id' => '121', 'table' => $this->getTable(), 'field' => 'date_creation', 'name' => __('Creation date'), 'datatype' => 'datetime', 'massiveaction' => false ]; $tab[] = [ 'id' => '16', 'table' => $this->getTable(), 'field' => 'comment', 'name' => __('Comments'), 'datatype' => 'text' ]; $tab[] = [ 'id' => '11', 'table' => $this->getTable(), 'field' => 'size', 'name' => __('Size'), 'datatype' => 'decimal', ]; $tab[] = [ 'id' => '41', 'table' => $this->getTable(), 'field' => 'have_micro', 'name' => __('Microphone'), 'datatype' => 'bool' ]; $tab[] = [ 'id' => '42', 'table' => $this->getTable(), 'field' => 'have_speaker', 'name' => __('Speakers'), 'datatype' => 'bool' ]; $tab[] = [ 'id' => '43', 'table' => $this->getTable(), 'field' => 'have_subd', 'name' => __('Sub-D'), 'datatype' => 'bool' ]; $tab[] = [ 'id' => '44', 'table' => $this->getTable(), 'field' => 'have_bnc', 'name' => __('BNC'), 'datatype' => 'bool' ]; $tab[] = [ 'id' => '45', 'table' => $this->getTable(), 'field' => 'have_dvi', 'name' => __('DVI'), 'datatype' => 'bool' ]; $tab[] = [ 'id' => '46', 'table' => $this->getTable(), 'field' => 'have_pivot', 'name' => __('Pivot'), 'datatype' => 'bool' ]; $tab[] = [ 'id' => '47', 'table' => $this->getTable(), 'field' => 'have_hdmi', 'name' => __('HDMI'), 'datatype' => 'bool' ]; $tab[] = [ 'id' => '48', 'table' => $this->getTable(), 'field' => 'have_displayport', 'name' => __('DisplayPort'), 'datatype' => 'bool' ]; $tab[] = [ 'id' => '23', 'table' => 'glpi_manufacturers', 'field' => 'name', 'name' => Manufacturer::getTypeName(1), 'datatype' => 'dropdown' ]; $tab[] = [ 'id' => '24', 'table' => 'glpi_users', 'field' => 'name', 'linkfield' => 'users_id_tech', 'name' => __('Technician in charge of the hardware'), 'datatype' => 'dropdown', 'right' => 'own_ticket' ]; $tab[] = [ 'id' => '49', 'table' => 'glpi_groups', 'field' => 'completename', 'linkfield' => 'groups_id_tech', 'name' => __('Group in charge of the hardware'), 'condition' => ['is_assign' => 1], 'datatype' => 'dropdown' ]; $tab[] = [ 'id' => '61', 'table' => $this->getTable(), 'field' => 'template_name', 'name' => __('Template name'), 'datatype' => 'text', 'massiveaction' => false, 'nosearch' => true, 'nodisplay' => true, ]; $tab[] = [ 'id' => '80', 'table' => 'glpi_entities', 'field' => 'completename', 'name' => Entity::getTypeName(1), 'massiveaction' => false, 'datatype' => 'dropdown' ]; $tab[] = [ 'id' => '82', 'table' => $this->getTable(), 'field' => 'is_global', 'name' => __('Global management'), 'datatype' => 'bool', 'massiveaction' => false ]; $tab = array_merge($tab, Notepad::rawSearchOptionsToAdd()); $tab = array_merge($tab, Datacenter::rawSearchOptionsToAdd(get_class($this))); $tab = array_merge($tab, Rack::rawSearchOptionsToAdd(get_class($this))); return $tab; } /** * @param $itemtype * * @return array */ public static function rawSearchOptionsToAdd($itemtype = null) { $tab = []; $tab[] = [ 'id' => 'monitor', 'name' => self::getTypeName(Session::getPluralNumber()) ]; $tab[] = [ 'id' => '129', 'table' => 'glpi_computers_items', 'field' => 'id', 'name' => _x('quantity', 'Number of monitors'), 'forcegroupby' => true, 'usehaving' => true, 'datatype' => 'count', 'massiveaction' => false, 'joinparams' => [ 'jointype' => 'child', 'condition' => ['NEWTABLE.itemtype' => 'Monitor'] ] ]; return $tab; } public static function getIcon() { return "ti ti-device-desktop"; } }