177 lines
5.6 KiB
PHP
177 lines
5.6 KiB
PHP
<?php
|
|
/**
|
|
* ---------------------------------------------------------------------
|
|
* GLPI - Gestionnaire Libre de Parc Informatique
|
|
* Copyright (C) 2015-2020 Teclib' and contributors.
|
|
*
|
|
* http://glpi-project.org
|
|
*
|
|
* based on GLPI - Gestionnaire Libre de Parc Informatique
|
|
* Copyright (C) 2003-2014 by the INDEPNET Development Team.
|
|
*
|
|
* ---------------------------------------------------------------------
|
|
*
|
|
* LICENSE
|
|
*
|
|
* This file is part of GLPI.
|
|
*
|
|
* GLPI 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 2 of the License, or
|
|
* (at your option) any later version.
|
|
*
|
|
* GLPI 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 GLPI. If not, see <http://www.gnu.org/licenses/>.
|
|
* ---------------------------------------------------------------------
|
|
*/
|
|
|
|
if (!defined('GLPI_ROOT')) {
|
|
die("Sorry. You can't access this file directly");
|
|
}
|
|
|
|
/**
|
|
* Rule class store all information about a GLPI rule :
|
|
* - description
|
|
* - criterias
|
|
* - actions
|
|
**/
|
|
class RuleDictionnarySoftware extends Rule {
|
|
|
|
public $additional_fields_for_dictionnary = ['manufacturer'];
|
|
public $can_sort = true;
|
|
|
|
static $rightname = 'rule_dictionnary_software';
|
|
|
|
|
|
|
|
/**
|
|
* @see Rule::getTitle()
|
|
**/
|
|
function getTitle() {
|
|
//TRANS: plural for software
|
|
return __('Dictionnary of software');
|
|
}
|
|
|
|
|
|
/**
|
|
* @see Rule::maxActionsCount()
|
|
**/
|
|
function maxActionsCount() {
|
|
return 4;
|
|
}
|
|
|
|
/**
|
|
* @see Rule::getCriterias()
|
|
**/
|
|
function getCriterias() {
|
|
|
|
static $criterias = [];
|
|
|
|
if (count($criterias)) {
|
|
return $criterias;
|
|
}
|
|
|
|
$criterias['name']['field'] = 'name';
|
|
$criterias['name']['name'] = _n('Software', 'Software', 1);
|
|
$criterias['name']['table'] = 'glpi_softwares';
|
|
|
|
$criterias['manufacturer']['field'] = 'name';
|
|
$criterias['manufacturer']['name'] = __('Publisher');
|
|
$criterias['manufacturer']['table'] = 'glpi_manufacturers';
|
|
|
|
$criterias['entities_id']['field'] = 'completename';
|
|
$criterias['entities_id']['name'] = Entity::getTypeName(1);
|
|
$criterias['entities_id']['table'] = 'glpi_entities';
|
|
$criterias['entities_id']['type'] = 'dropdown';
|
|
|
|
$criterias['_system_category']['field'] = 'name';
|
|
$criterias['_system_category']['name'] = __('Category from inventory tool');
|
|
|
|
return $criterias;
|
|
}
|
|
|
|
|
|
/**
|
|
* @see Rule::getActions()
|
|
**/
|
|
function getActions() {
|
|
|
|
$actions = [];
|
|
|
|
$actions['name']['name'] = _n('Software', 'Software', 1);
|
|
$actions['name']['force_actions'] = ['assign', 'regex_result'];
|
|
|
|
$actions['_ignore_import']['name'] = __('To be unaware of import');
|
|
$actions['_ignore_import']['type'] = 'yesonly';
|
|
|
|
$actions['version']['name'] = _n('Version', 'Versions', 1);
|
|
$actions['version']['force_actions'] = ['assign','regex_result',
|
|
'append_regex_result'];
|
|
|
|
$actions['manufacturer']['name'] = __('Publisher');
|
|
$actions['manufacturer']['table'] = 'glpi_manufacturers';
|
|
$actions['manufacturer']['force_actions'] = ['append_regex_result', 'assign','regex_result'];
|
|
|
|
$actions['is_helpdesk_visible']['name'] = __('Associable to a ticket');
|
|
$actions['is_helpdesk_visible']['table'] = 'glpi_softwares';
|
|
$actions['is_helpdesk_visible']['type'] = 'yesno';
|
|
|
|
$actions['new_entities_id']['name'] = Entity::getTypeName(1);
|
|
$actions['new_entities_id']['table'] = 'glpi_entities';
|
|
$actions['new_entities_id']['type'] = 'dropdown';
|
|
|
|
$actions['softwarecategories_id']['name'] = __('Category');
|
|
$actions['softwarecategories_id']['type'] = 'dropdown';
|
|
$actions['softwarecategories_id']['table'] = 'glpi_softwarecategories';
|
|
$actions['softwarecategories_id']['force_actions'] = ['assign','regex_result'];
|
|
|
|
return $actions;
|
|
}
|
|
|
|
|
|
/**
|
|
* @see Rule::addSpecificParamsForPreview()
|
|
**/
|
|
function addSpecificParamsForPreview($params) {
|
|
|
|
if (isset($_POST["version"])) {
|
|
$params["version"] = $_POST["version"];
|
|
}
|
|
return $params;
|
|
}
|
|
|
|
|
|
/**
|
|
* @see Rule::showSpecificCriteriasForPreview()
|
|
**/
|
|
function showSpecificCriteriasForPreview($fields) {
|
|
|
|
if (isset($this->fields['id'])) {
|
|
$this->getRuleWithCriteriasAndActions($this->fields['id'], 0, 1);
|
|
}
|
|
|
|
//if there's a least one action with type == append_regex_result, then need to display
|
|
//this field as a criteria
|
|
foreach ($this->actions as $action) {
|
|
if ($action->fields["action_type"] == "append_regex_result") {
|
|
$value = (isset($fields[$action->fields['field']])?$fields[$action->fields['field']]:'');
|
|
//Get actions for this type of rule
|
|
$actions = $this->getActions();
|
|
|
|
//display the additionnal field
|
|
echo "<tr class='tab_bg_1'>";
|
|
echo "<td>".$this->fields['match']."</td>";
|
|
echo "<td>".$actions[$action->fields['field']]['name']."</td>";
|
|
echo "<td><input type='text' name='version' value='$value'></td></tr>";
|
|
}
|
|
}
|
|
}
|
|
|
|
|
|
}
|