mirror of
https://github.com/pluginsGLPI/example.git
synced 2025-05-04 18:08:42 +02:00
global code update : namespace and src folder
This commit is contained in:
parent
3351d0f268
commit
9f415e0d32
@ -37,8 +37,7 @@
|
|||||||
//header("Location:../../central.php");
|
//header("Location:../../central.php");
|
||||||
|
|
||||||
// Entry menu case
|
// Entry menu case
|
||||||
define('GLPI_ROOT', '../..');
|
include ("../../../inc/includes.php");
|
||||||
include (GLPI_ROOT . "/inc/includes.php");
|
|
||||||
|
|
||||||
Session::checkRight("config", UPDATE);
|
Session::checkRight("config", UPDATE);
|
||||||
|
|
@ -33,7 +33,9 @@
|
|||||||
// Purpose of file:
|
// Purpose of file:
|
||||||
// ----------------------------------------------------------------------
|
// ----------------------------------------------------------------------
|
||||||
|
|
||||||
|
use GlpiPlugin\Example\DeviceCamera;
|
||||||
|
|
||||||
include ('../../../inc/includes.php');
|
include ('../../../inc/includes.php');
|
||||||
|
|
||||||
$dropdown = new PluginExampleDeviceCamera();
|
$dropdown = new DeviceCamera();
|
||||||
include (GLPI_ROOT . "/front/dropdown.common.form.php");
|
include (GLPI_ROOT . "/front/dropdown.common.form.php");
|
||||||
|
@ -35,5 +35,5 @@
|
|||||||
|
|
||||||
include ('../../../inc/includes.php');
|
include ('../../../inc/includes.php');
|
||||||
|
|
||||||
$dropdown = new PluginExampleDeviceCamera();
|
$dropdown = new DeviceCamera();
|
||||||
include (GLPI_ROOT . "/front/dropdown.common.php");
|
include (GLPI_ROOT . "/front/dropdown.common.php");
|
||||||
|
@ -33,10 +33,11 @@
|
|||||||
// Purpose of file:
|
// Purpose of file:
|
||||||
// ----------------------------------------------------------------------
|
// ----------------------------------------------------------------------
|
||||||
|
|
||||||
|
use GlpiPlugin\Example\Dropdown;
|
||||||
|
|
||||||
include ('../../../inc/includes.php');
|
include ('../../../inc/includes.php');
|
||||||
|
|
||||||
Plugin::load('example', true);
|
Plugin::load('example', true);
|
||||||
|
|
||||||
$dropdown = new PluginExampleDropdown();
|
$dropdown = new Dropdown();
|
||||||
include (GLPI_ROOT . "/front/dropdown.common.form.php");
|
include (GLPI_ROOT . "/front/dropdown.common.form.php");
|
||||||
|
@ -33,10 +33,11 @@
|
|||||||
// Purpose of file:
|
// Purpose of file:
|
||||||
// ----------------------------------------------------------------------
|
// ----------------------------------------------------------------------
|
||||||
|
|
||||||
|
use GlpiPlugin\Example\Dropdown;
|
||||||
|
|
||||||
include ('../../../inc/includes.php');
|
include ('../../../inc/includes.php');
|
||||||
|
|
||||||
Plugin::load('example', true);
|
Plugin::load('example', true);
|
||||||
|
|
||||||
$dropdown = new PluginExampleDropdown();
|
$dropdown = new Dropdown();
|
||||||
include (GLPI_ROOT . "/front/dropdown.common.php");
|
include (GLPI_ROOT . "/front/dropdown.common.php");
|
||||||
|
@ -33,15 +33,17 @@
|
|||||||
// Purpose of file:
|
// Purpose of file:
|
||||||
// ----------------------------------------------------------------------
|
// ----------------------------------------------------------------------
|
||||||
|
|
||||||
|
use GlpiPlugin\Example\Example;
|
||||||
|
|
||||||
include ('../../../inc/includes.php');
|
include ('../../../inc/includes.php');
|
||||||
|
|
||||||
if ($_SESSION["glpiactiveprofile"]["interface"] == "central") {
|
if ($_SESSION["glpiactiveprofile"]["interface"] == "central") {
|
||||||
Html::header("TITRE", $_SERVER['PHP_SELF'], "plugins", "pluginexampleexample", "");
|
Html::header("TITRE", $_SERVER['PHP_SELF'], "plugins", Example::class, "");
|
||||||
} else {
|
} else {
|
||||||
Html::helpHeader("TITRE", $_SERVER['PHP_SELF']);
|
Html::helpHeader("TITRE", $_SERVER['PHP_SELF']);
|
||||||
}
|
}
|
||||||
|
|
||||||
$example = new PluginExampleExample();
|
$example = new Example();
|
||||||
$example->display($_GET);
|
$example->display($_GET);
|
||||||
|
|
||||||
Html::footer();
|
Html::footer();
|
||||||
|
@ -33,17 +33,19 @@
|
|||||||
// Purpose of file:
|
// Purpose of file:
|
||||||
// ----------------------------------------------------------------------
|
// ----------------------------------------------------------------------
|
||||||
|
|
||||||
|
use GlpiPlugin\Example\Example;
|
||||||
|
|
||||||
include ('../../../inc/includes.php');
|
include ('../../../inc/includes.php');
|
||||||
|
|
||||||
if ($_SESSION["glpiactiveprofile"]["interface"] == "central") {
|
if ($_SESSION["glpiactiveprofile"]["interface"] == "central") {
|
||||||
Html::header("TITRE", $_SERVER['PHP_SELF'], "plugins", "pluginexampleexample", "");
|
Html::header("TITRE", $_SERVER['PHP_SELF'], "plugins", Example::class, "");
|
||||||
} else {
|
} else {
|
||||||
Html::helpHeader("TITRE", $_SERVER['PHP_SELF']);
|
Html::helpHeader("TITRE", $_SERVER['PHP_SELF']);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
//checkTypeRight('PluginExampleExample',"r");
|
//checkTypeRight(Example::class,"r");
|
||||||
|
|
||||||
Search::show('PluginExampleExample');
|
Search::show(Example::class);
|
||||||
|
|
||||||
Html::footer();
|
Html::footer();
|
||||||
|
@ -33,9 +33,10 @@
|
|||||||
// Purpose of file:
|
// Purpose of file:
|
||||||
// ----------------------------------------------------------------------
|
// ----------------------------------------------------------------------
|
||||||
|
|
||||||
|
use GlpiPlugin\Example\RuleTestCollection;
|
||||||
|
|
||||||
include ('../../../inc/includes.php');
|
include ('../../../inc/includes.php');
|
||||||
|
|
||||||
$rulecollection = new PluginExampleRuleTestCollection();
|
$rulecollection = new RuleTestCollection();
|
||||||
|
|
||||||
include (GLPI_ROOT . "/front/rule.common.form.php");
|
include (GLPI_ROOT . "/front/rule.common.form.php");
|
||||||
|
@ -33,9 +33,10 @@
|
|||||||
// Purpose of file:
|
// Purpose of file:
|
||||||
// ----------------------------------------------------------------------
|
// ----------------------------------------------------------------------
|
||||||
|
|
||||||
|
use GlpiPlugin\Example\RuleTestCollection;
|
||||||
|
|
||||||
include ('../../../inc/includes.php');
|
include ('../../../inc/includes.php');
|
||||||
|
|
||||||
$rulecollection = new PluginExampleRuleTestCollection();
|
$rulecollection = new RuleTestCollection();
|
||||||
|
|
||||||
include (GLPI_ROOT . "/front/rule.common.php");
|
include (GLPI_ROOT . "/front/rule.common.php");
|
||||||
|
30
hook.php
30
hook.php
@ -33,6 +33,10 @@
|
|||||||
// Purpose of file:
|
// Purpose of file:
|
||||||
// ----------------------------------------------------------------------
|
// ----------------------------------------------------------------------
|
||||||
|
|
||||||
|
use GlpiPlugin\Example\Dropdown;
|
||||||
|
use GlpiPlugin\Example\Example;
|
||||||
|
use Dropdown as GlpiDropdown;
|
||||||
|
|
||||||
// Hook called on profile change
|
// Hook called on profile change
|
||||||
// Good place to evaluate the user right on this plugin
|
// Good place to evaluate the user right on this plugin
|
||||||
// And to save it in the session
|
// And to save it in the session
|
||||||
@ -59,7 +63,7 @@ function plugin_example_getDatabaseRelations() {
|
|||||||
// Define Dropdown tables to be manage in GLPI :
|
// Define Dropdown tables to be manage in GLPI :
|
||||||
function plugin_example_getDropdown() {
|
function plugin_example_getDropdown() {
|
||||||
// Table => Name
|
// Table => Name
|
||||||
return ['PluginExampleDropdown' => __("Plugin Example Dropdown", 'example')];
|
return [Dropdown::class => __("Plugin Example Dropdown", 'example')];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -94,7 +98,7 @@ function plugin_example_getAddSearchOptionsNew($itemtype) {
|
|||||||
return $options;
|
return $options;
|
||||||
}
|
}
|
||||||
|
|
||||||
// See also PluginExampleExample::getSpecificValueToDisplay()
|
// See also GlpiPlugin\Example\Example::getSpecificValueToDisplay()
|
||||||
function plugin_example_giveItem($type, $ID, $data, $num) {
|
function plugin_example_giveItem($type, $ID, $data, $num) {
|
||||||
$searchopt = &Search::getOptions($type);
|
$searchopt = &Search::getOptions($type);
|
||||||
$table = $searchopt[$ID]["table"];
|
$table = $searchopt[$ID]["table"];
|
||||||
@ -102,7 +106,7 @@ function plugin_example_giveItem($type, $ID, $data, $num) {
|
|||||||
|
|
||||||
switch ($table.'.'.$field) {
|
switch ($table.'.'.$field) {
|
||||||
case "glpi_plugin_example_examples.name" :
|
case "glpi_plugin_example_examples.name" :
|
||||||
$out = "<a href='".Toolbox::getItemTypeFormURL('PluginExampleExample')."?id=".$data['id']."'>";
|
$out = "<a href='".Toolbox::getItemTypeFormURL(Example::class)."?id=".$data['id']."'>";
|
||||||
$out .= $data[$num][0]['name'];
|
$out .= $data[$num][0]['name'];
|
||||||
if ($_SESSION["glpiis_ids_visible"] || empty($data[$num][0]['name'])) {
|
if ($_SESSION["glpiis_ids_visible"] || empty($data[$num][0]['name'])) {
|
||||||
$out .= " (".$data["id"].")";
|
$out .= " (".$data["id"].")";
|
||||||
@ -133,7 +137,7 @@ function plugin_example_addDefaultJoin($type, $ref_table, &$already_link_tables)
|
|||||||
// Example of default JOIN clause
|
// Example of default JOIN clause
|
||||||
// No need of the function if you do not have specific cases
|
// No need of the function if you do not have specific cases
|
||||||
switch ($type) {
|
switch ($type) {
|
||||||
// case "PluginExampleExample" :
|
// case Example::class :
|
||||||
case "MyType" :
|
case "MyType" :
|
||||||
return Search::addLeftJoin($type, $ref_table, $already_link_tables,
|
return Search::addLeftJoin($type, $ref_table, $already_link_tables,
|
||||||
"newtable", "linkfield");
|
"newtable", "linkfield");
|
||||||
@ -146,7 +150,7 @@ function plugin_example_addDefaultSelect($type) {
|
|||||||
// Example of default SELECT item to be added
|
// Example of default SELECT item to be added
|
||||||
// No need of the function if you do not have specific cases
|
// No need of the function if you do not have specific cases
|
||||||
switch ($type) {
|
switch ($type) {
|
||||||
// case "PluginExampleExample" :
|
// case Example::class :
|
||||||
case "MyType" :
|
case "MyType" :
|
||||||
return "`mytable`.`myfield` = 'myvalue' AS MYNAME, ";
|
return "`mytable`.`myfield` = 'myvalue' AS MYNAME, ";
|
||||||
}
|
}
|
||||||
@ -158,7 +162,7 @@ function plugin_example_addDefaultWhere($type) {
|
|||||||
// Example of default WHERE item to be added
|
// Example of default WHERE item to be added
|
||||||
// No need of the function if you do not have specific cases
|
// No need of the function if you do not have specific cases
|
||||||
switch ($type) {
|
switch ($type) {
|
||||||
// case "PluginExampleExample" :
|
// case Example::class :
|
||||||
case "MyType" :
|
case "MyType" :
|
||||||
return " `mytable`.`myfield` = 'myvalue' ";
|
return " `mytable`.`myfield` = 'myvalue' ";
|
||||||
}
|
}
|
||||||
@ -179,7 +183,7 @@ function plugin_example_addLeftJoin($type, $ref_table, $new_table, $linkfield) {
|
|||||||
|
|
||||||
function plugin_example_forceGroupBy($type) {
|
function plugin_example_forceGroupBy($type) {
|
||||||
switch ($type) {
|
switch ($type) {
|
||||||
case 'PluginExampleExample' :
|
case Example::class :
|
||||||
// Force add GROUP BY IN REQUEST
|
// Force add GROUP BY IN REQUEST
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
@ -272,7 +276,7 @@ function plugin_example_MassiveActions($type) {
|
|||||||
switch ($type) {
|
switch ($type) {
|
||||||
// New action for core and other plugin types : name = plugin_PLUGINNAME_actionname
|
// New action for core and other plugin types : name = plugin_PLUGINNAME_actionname
|
||||||
case 'Computer' :
|
case 'Computer' :
|
||||||
return ['PluginExampleExample'.MassiveAction::CLASS_ACTION_SEPARATOR.'DoIt' =>
|
return [Example::class . MassiveAction::CLASS_ACTION_SEPARATOR . 'DoIt' =>
|
||||||
__("plugin_example_DoIt", 'example')];
|
__("plugin_example_DoIt", 'example')];
|
||||||
|
|
||||||
// Actions for types provided by the plugin are included inside the classes
|
// Actions for types provided by the plugin are included inside the classes
|
||||||
@ -325,7 +329,7 @@ function plugin_example_searchOptionsValues($options = []) {
|
|||||||
switch ($table.".".$field) {
|
switch ($table.".".$field) {
|
||||||
case "glpi_plugin_example_examples.serial" :
|
case "glpi_plugin_example_examples.serial" :
|
||||||
echo __("Not really specific - Use your own dropdown - Just for example", 'example');
|
echo __("Not really specific - Use your own dropdown - Just for example", 'example');
|
||||||
Dropdown::show(getItemTypeForTable($options['searchoption']['table']),
|
GlpiDropdown::show(getItemTypeForTable($options['searchoption']['table']),
|
||||||
['value' => $options['value'],
|
['value' => $options['value'],
|
||||||
'name' => $options['name'],
|
'name' => $options['name'],
|
||||||
'comments' => 0]);
|
'comments' => 0]);
|
||||||
@ -427,7 +431,7 @@ function plugin_item_transfer_example($parm) {
|
|||||||
|
|
||||||
// Do special actions for dynamic report
|
// Do special actions for dynamic report
|
||||||
function plugin_example_dynamicReport($parm) {
|
function plugin_example_dynamicReport($parm) {
|
||||||
if ($parm["item_type"] == 'PluginExampleExample') {
|
if ($parm["item_type"] == Example::class) {
|
||||||
// Do all what you want for export depending on $parm
|
// Do all what you want for export depending on $parm
|
||||||
echo "Personalized export for type ".$parm["display_type"];
|
echo "Personalized export for type ".$parm["display_type"];
|
||||||
echo 'with additional datas : <br>';
|
echo 'with additional datas : <br>';
|
||||||
@ -445,7 +449,7 @@ function plugin_example_dynamicReport($parm) {
|
|||||||
|
|
||||||
// Add parameters to Html::printPager in search system
|
// Add parameters to Html::printPager in search system
|
||||||
function plugin_example_addParamFordynamicReport($itemtype) {
|
function plugin_example_addParamFordynamicReport($itemtype) {
|
||||||
if ($itemtype == 'PluginExampleExample') {
|
if ($itemtype == Example::class) {
|
||||||
// Return array data containing all params to add : may be single data or array data
|
// Return array data containing all params to add : may be single data or array data
|
||||||
// Search config are available from session variable
|
// Search config are available from session variable
|
||||||
return ['add1' => $_SESSION['glpisearch'][$itemtype]['order'],
|
return ['add1' => $_SESSION['glpisearch'][$itemtype]['order'],
|
||||||
@ -551,7 +555,7 @@ function plugin_example_install() {
|
|||||||
|
|
||||||
// To be called for each task the plugin manage
|
// To be called for each task the plugin manage
|
||||||
// task in class
|
// task in class
|
||||||
CronTask::Register('PluginExampleExample', 'Sample', DAY_TIMESTAMP, ['param' => 50]);
|
CronTask::Register(Example::class, 'Sample', DAY_TIMESTAMP, ['param' => 50]);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -607,7 +611,7 @@ function plugin_example_uninstall() {
|
|||||||
|
|
||||||
|
|
||||||
function plugin_example_AssignToTicket($types) {
|
function plugin_example_AssignToTicket($types) {
|
||||||
$types['PluginExampleExample'] = "Example";
|
$types[Example::class] = "Example";
|
||||||
return $types;
|
return $types;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
114
setup.php
114
setup.php
@ -29,6 +29,14 @@
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
use Glpi\Plugin\Hooks;
|
use Glpi\Plugin\Hooks;
|
||||||
|
use GlpiPlugin\Example\Computer;
|
||||||
|
use GlpiPlugin\Example\Config;
|
||||||
|
use GlpiPlugin\Example\Dropdown;
|
||||||
|
use GlpiPlugin\Example\DeviceCamera;
|
||||||
|
use GlpiPlugin\Example\Example;
|
||||||
|
use GlpiPlugin\Example\ItemForm;
|
||||||
|
use GlpiPlugin\Example\RuleTestCollection;
|
||||||
|
use GlpiPlugin\Example\Showtabitem;
|
||||||
|
|
||||||
define('PLUGIN_EXAMPLE_VERSION', '0.0.1');
|
define('PLUGIN_EXAMPLE_VERSION', '0.0.1');
|
||||||
|
|
||||||
@ -48,38 +56,38 @@ function plugin_init_example() {
|
|||||||
|
|
||||||
// Params : plugin name - string type - ID - Array of attributes
|
// Params : plugin name - string type - ID - Array of attributes
|
||||||
// No specific information passed so not needed
|
// No specific information passed so not needed
|
||||||
//Plugin::registerClass('PluginExampleExample',
|
//Plugin::registerClass(Example::getType(),
|
||||||
// array('classname' => 'PluginExampleExample',
|
// array('classname' => Example::class,
|
||||||
// ));
|
// ));
|
||||||
|
|
||||||
Plugin::registerClass('PluginExampleConfig', ['addtabon' => 'Config']);
|
Plugin::registerClass(Config::class, ['addtabon' => 'Config']);
|
||||||
|
|
||||||
// Params : plugin name - string type - ID - Array of attributes
|
// Params : plugin name - string type - ID - Array of attributes
|
||||||
Plugin::registerClass('PluginExampleDropdown');
|
Plugin::registerClass(Dropdown::class);
|
||||||
|
|
||||||
$types = ['Central', 'Computer', 'ComputerDisk', 'Notification', 'Phone',
|
$types = ['Central', 'Computer', 'ComputerDisk', 'Notification', 'Phone',
|
||||||
'Preference', 'Profile', 'Supplier'];
|
'Preference', 'Profile', 'Supplier'];
|
||||||
Plugin::registerClass('PluginExampleExample',
|
Plugin::registerClass(Example::class,
|
||||||
['notificationtemplates_types' => true,
|
['notificationtemplates_types' => true,
|
||||||
'addtabon' => $types,
|
'addtabon' => $types,
|
||||||
'link_types' => true]);
|
'link_types' => true]);
|
||||||
|
|
||||||
Plugin::registerClass('PluginExampleRuleTestCollection',
|
Plugin::registerClass(RuleTestCollection::class,
|
||||||
['rulecollections_types' => true]);
|
['rulecollections_types' => true]);
|
||||||
|
|
||||||
Plugin::registerClass('PluginExampleDeviceCamera',
|
Plugin::registerClass(DeviceCamera::class,
|
||||||
['device_types' => true]);
|
['device_types' => true]);
|
||||||
|
|
||||||
if (version_compare(GLPI_VERSION, '9.1', 'ge')) {
|
if (version_compare(GLPI_VERSION, '9.1', 'ge')) {
|
||||||
if (class_exists('PluginExampleExample')) {
|
if (class_exists(Example::class)) {
|
||||||
Link::registerTag(PluginExampleExample::$tags);
|
Link::registerTag(Example::$tags);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
// Display a menu entry ?
|
// Display a menu entry ?
|
||||||
$_SESSION["glpi_plugin_example_profile"]['example'] = 'w';
|
$_SESSION["glpi_plugin_example_profile"]['example'] = 'w';
|
||||||
if (isset($_SESSION["glpi_plugin_example_profile"])) { // Right set in change_profile hook
|
if (isset($_SESSION["glpi_plugin_example_profile"])) { // Right set in change_profile hook
|
||||||
$PLUGIN_HOOKS['menu_toadd']['example'] = ['plugins' => 'PluginExampleExample',
|
$PLUGIN_HOOKS['menu_toadd']['example'] = ['plugins' => Example::class,
|
||||||
'tools' => 'PluginExampleExample'];
|
'tools' => Example::class];
|
||||||
|
|
||||||
// Old menu style
|
// Old menu style
|
||||||
// $PLUGIN_HOOKS['menu_entry']['example'] = 'front/example.php';
|
// $PLUGIN_HOOKS['menu_entry']['example'] = 'front/example.php';
|
||||||
@ -92,13 +100,13 @@ function plugin_init_example() {
|
|||||||
// $PLUGIN_HOOKS['submenu_entry']['example']['options']['optionname']['links']["<img src='".$CFG_GLPI["root_doc"]."/pics/menu_showall.png' title='".__s('Show all')."' alt='".__s('Show all')."'>"] = '/plugins/example/index.php';
|
// $PLUGIN_HOOKS['submenu_entry']['example']['options']['optionname']['links']["<img src='".$CFG_GLPI["root_doc"]."/pics/menu_showall.png' title='".__s('Show all')."' alt='".__s('Show all')."'>"] = '/plugins/example/index.php';
|
||||||
// $PLUGIN_HOOKS['submenu_entry']['example']['options']['optionname']['links'][__s('Test link', 'example')] = '/plugins/example/index.php';
|
// $PLUGIN_HOOKS['submenu_entry']['example']['options']['optionname']['links'][__s('Test link', 'example')] = '/plugins/example/index.php';
|
||||||
|
|
||||||
$PLUGIN_HOOKS["helpdesk_menu_entry"]['example'] = true;
|
$PLUGIN_HOOKS[Hooks::HELPDESK_MENU_ENTRY]['example'] = true;
|
||||||
$PLUGIN_HOOKS["helpdesk_menu_entry_icon"]['example'] = 'fas fa-puzzle-piece';
|
$PLUGIN_HOOKS[Hooks::HELPDESK_MENU_ENTRY_ICON]['example'] = 'fas fa-puzzle-piece';
|
||||||
}
|
}
|
||||||
|
|
||||||
// Config page
|
// Config page
|
||||||
if (Session::haveRight('config', UPDATE)) {
|
if (Session::haveRight('config', UPDATE)) {
|
||||||
$PLUGIN_HOOKS['config_page']['example'] = 'config.php';
|
$PLUGIN_HOOKS['config_page']['example'] = 'front/config.php';
|
||||||
}
|
}
|
||||||
|
|
||||||
// Init session
|
// Init session
|
||||||
@ -109,53 +117,53 @@ function plugin_init_example() {
|
|||||||
//$PLUGIN_HOOKS['change_entity']['example'] = 'plugin_change_entity_example';
|
//$PLUGIN_HOOKS['change_entity']['example'] = 'plugin_change_entity_example';
|
||||||
|
|
||||||
// Item action event // See define.php for defined ITEM_TYPE
|
// Item action event // See define.php for defined ITEM_TYPE
|
||||||
$PLUGIN_HOOKS['pre_item_update']['example'] = ['Computer' => 'plugin_pre_item_update_example'];
|
$PLUGIN_HOOKS[Hooks::PRE_ITEM_UPDATE]['example'] = [Computer::class => 'plugin_pre_item_update_example'];
|
||||||
$PLUGIN_HOOKS['item_update']['example'] = ['Computer' => 'plugin_item_update_example'];
|
$PLUGIN_HOOKS[hooks::ITEM_UPDATE]['example'] = [Computer::class => 'plugin_item_update_example'];
|
||||||
|
|
||||||
$PLUGIN_HOOKS['item_empty']['example'] = ['Computer' => 'plugin_item_empty_example'];
|
$PLUGIN_HOOKS[Hooks::ITEM_EMPTY]['example'] = [Computer::class => 'plugin_item_empty_example'];
|
||||||
|
|
||||||
// Restrict right
|
// Restrict right
|
||||||
$PLUGIN_HOOKS['item_can']['example'] = ['Computer' => ['PluginExampleComputer', 'item_can']];
|
$PLUGIN_HOOKS[Hooks::ITEM_CAN]['example'] = [Computer::class => [Example::class, 'item_can']];
|
||||||
$PLUGIN_HOOKS['add_default_where']['example'] = ['Computer' => ['PluginExampleComputer', 'add_default_where']];
|
$PLUGIN_HOOKS['add_default_where']['example'] = [Computer::class => [Example::class, 'add_default_where']];
|
||||||
|
|
||||||
// Example using a method in class
|
// Example using a method in class
|
||||||
$PLUGIN_HOOKS['pre_item_add']['example'] = ['Computer' => ['PluginExampleExample',
|
$PLUGIN_HOOKS[Hooks::PRE_ITEM_ADD]['example'] = [Computer::class => [Example::class,
|
||||||
'pre_item_add_computer']];
|
'pre_item_add_computer']];
|
||||||
$PLUGIN_HOOKS['post_prepareadd']['example'] = ['Computer' => ['PluginExampleExample',
|
$PLUGIN_HOOKS[Hooks::POST_PREPAREADD]['example'] = [Computer::class => [Example::class,
|
||||||
'post_prepareadd_computer']];
|
'post_prepareadd_computer']];
|
||||||
$PLUGIN_HOOKS['item_add']['example'] = ['Computer' => ['PluginExampleExample',
|
$PLUGIN_HOOKS[Hooks::ITEM_ADD]['example'] = [Computer::class => [Example::class,
|
||||||
'item_add_computer']];
|
'item_add_computer']];
|
||||||
|
|
||||||
$PLUGIN_HOOKS['pre_item_delete']['example'] = ['Computer' => 'plugin_pre_item_delete_example'];
|
$PLUGIN_HOOKS[Hooks::PRE_ITEM_DELETE]['example'] = [Computer::class => 'plugin_pre_item_delete_example'];
|
||||||
$PLUGIN_HOOKS['item_delete']['example'] = ['Computer' => 'plugin_item_delete_example'];
|
$PLUGIN_HOOKS[Hooks::ITEM_DELETE]['example'] = [Computer::class => 'plugin_item_delete_example'];
|
||||||
|
|
||||||
// Example using the same function
|
// Example using the same function
|
||||||
$PLUGIN_HOOKS['pre_item_purge']['example'] = ['Computer' => 'plugin_pre_item_purge_example',
|
$PLUGIN_HOOKS[Hooks::PRE_ITEM_PURGE]['example'] = [Computer::class => 'plugin_pre_item_purge_example',
|
||||||
'Phone' => 'plugin_pre_item_purge_example'];
|
'Phone' => 'plugin_pre_item_purge_example'];
|
||||||
$PLUGIN_HOOKS['item_purge']['example'] = ['Computer' => 'plugin_item_purge_example',
|
$PLUGIN_HOOKS[Hooks::ITEM_PURGE]['example'] = [Computer::class => 'plugin_item_purge_example',
|
||||||
'Phone' => 'plugin_item_purge_example'];
|
'Phone' => 'plugin_item_purge_example'];
|
||||||
|
|
||||||
// Example with 2 different functions
|
// Example with 2 different functions
|
||||||
$PLUGIN_HOOKS['pre_item_restore']['example'] = ['Computer' => 'plugin_pre_item_restore_example',
|
$PLUGIN_HOOKS[Hooks::PRE_ITEM_RESTORE]['example'] = [Computer::class => 'plugin_pre_item_restore_example',
|
||||||
'Phone' => 'plugin_pre_item_restore_example2'];
|
'Phone' => 'plugin_pre_item_restore_example2'];
|
||||||
$PLUGIN_HOOKS['item_restore']['example'] = ['Computer' => 'plugin_item_restore_example'];
|
$PLUGIN_HOOKS[Hooks::ITEM_RESTORE]['example'] = [Computer::class => 'plugin_item_restore_example'];
|
||||||
|
|
||||||
// Add event to GLPI core itemtype, event will be raised by the plugin.
|
// Add event to GLPI core itemtype, event will be raised by the plugin.
|
||||||
// See plugin_example_uninstall for cleanup of notification
|
// See plugin_example_uninstall for cleanup of notification
|
||||||
$PLUGIN_HOOKS['item_get_events']['example']
|
$PLUGIN_HOOKS[Hooks::ITEM_GET_EVENTS]['example']
|
||||||
= ['NotificationTargetTicket' => 'plugin_example_get_events'];
|
= ['NotificationTargetTicket' => 'plugin_example_get_events'];
|
||||||
|
|
||||||
// Add datas to GLPI core itemtype for notifications template.
|
// Add datas to GLPI core itemtype for notifications template.
|
||||||
$PLUGIN_HOOKS['item_get_datas']['example']
|
$PLUGIN_HOOKS[Hooks::ITEM_GET_DATA]['example']
|
||||||
= ['NotificationTargetTicket' => 'plugin_example_get_datas'];
|
= ['NotificationTargetTicket' => 'plugin_example_get_datas'];
|
||||||
|
|
||||||
$PLUGIN_HOOKS['item_transfer']['example'] = 'plugin_item_transfer_example';
|
$PLUGIN_HOOKS[Hooks::ITEM_TRANSFER]['example'] = 'plugin_item_transfer_example';
|
||||||
|
|
||||||
// function to populate planning
|
// function to populate planning
|
||||||
// No more used since GLPI 0.84
|
// No more used since GLPI 0.84
|
||||||
// $PLUGIN_HOOKS['planning_populate']['example'] = 'plugin_planning_populate_example';
|
// $PLUGIN_HOOKS['planning_populate']['example'] = 'plugin_planning_populate_example';
|
||||||
// Use instead : add class to planning types and define populatePlanning in class
|
// Use instead : add class to planning types and define populatePlanning in class
|
||||||
$CFG_GLPI['planning_types'][] = 'PluginExampleExample';
|
$CFG_GLPI['planning_types'][] = Example::class;
|
||||||
|
|
||||||
//function to display planning items
|
//function to display planning items
|
||||||
// No more used sinc GLPi 0.84
|
// No more used sinc GLPi 0.84
|
||||||
@ -168,8 +176,8 @@ function plugin_init_example() {
|
|||||||
$PLUGIN_HOOKS['assign_to_ticket']['example'] = 1;
|
$PLUGIN_HOOKS['assign_to_ticket']['example'] = 1;
|
||||||
|
|
||||||
// Add specific files to add to the header : javascript or css
|
// Add specific files to add to the header : javascript or css
|
||||||
$PLUGIN_HOOKS['add_javascript']['example'] = 'example.js';
|
$PLUGIN_HOOKS[Hooks::ADD_JAVASCRIPT]['example'] = 'example.js';
|
||||||
$PLUGIN_HOOKS['add_css']['example'] = 'example.css';
|
$PLUGIN_HOOKS[Hooks::ADD_CSS]['example'] = 'example.css';
|
||||||
|
|
||||||
// request more attributes from ldap
|
// request more attributes from ldap
|
||||||
//$PLUGIN_HOOKS['retrieve_more_field_from_ldap']['example']="plugin_retrieve_more_field_from_ldap_example";
|
//$PLUGIN_HOOKS['retrieve_more_field_from_ldap']['example']="plugin_retrieve_more_field_from_ldap_example";
|
||||||
@ -185,45 +193,45 @@ function plugin_init_example() {
|
|||||||
$PLUGIN_HOOKS['stats']['example'] = ['stat.php' => 'New stat',
|
$PLUGIN_HOOKS['stats']['example'] = ['stat.php' => 'New stat',
|
||||||
'stat.php?other' => 'New stats 2',];
|
'stat.php?other' => 'New stats 2',];
|
||||||
|
|
||||||
$PLUGIN_HOOKS['post_init']['example'] = 'plugin_example_postinit';
|
$PLUGIN_HOOKS[Hooks::POST_INIT]['example'] = 'plugin_example_postinit';
|
||||||
|
|
||||||
$PLUGIN_HOOKS['status']['example'] = 'plugin_example_Status';
|
$PLUGIN_HOOKS['status']['example'] = 'plugin_example_Status';
|
||||||
|
|
||||||
// CSRF compliance : All actions must be done via POST and forms closed by Html::closeForm();
|
// CSRF compliance : All actions must be done via POST and forms closed by Html::closeForm();
|
||||||
$PLUGIN_HOOKS['csrf_compliant']['example'] = true;
|
$PLUGIN_HOOKS[Hooks::CSRF_COMPLIANT]['example'] = true;
|
||||||
|
|
||||||
$PLUGIN_HOOKS['display_central']['example'] = "plugin_example_display_central";
|
$PLUGIN_HOOKS[Hooks::DISPLAY_CENTRAL]['example'] = "plugin_example_display_central";
|
||||||
$PLUGIN_HOOKS['display_login']['example'] = "plugin_example_display_login";
|
$PLUGIN_HOOKS[Hooks::DISPLAY_LOGIN]['example'] = "plugin_example_display_login";
|
||||||
$PLUGIN_HOOKS['infocom']['example'] = "plugin_example_infocom_hook";
|
$PLUGIN_HOOKS[Hooks::INFOCOM]['example'] = "plugin_example_infocom_hook";
|
||||||
|
|
||||||
// pre_show and post_show for tabs and items,
|
// pre_show and post_show for tabs and items,
|
||||||
// see PluginExampleShowtabitem class for implementation explanations
|
// see GlpiPlugin\Example\Showtabitem class for implementation explanations
|
||||||
$PLUGIN_HOOKS['pre_show_tab']['example'] = ['PluginExampleShowtabitem', 'pre_show_tab'];
|
$PLUGIN_HOOKS[Hooks::PRE_SHOW_TAB]['example'] = [Showtabitem::class, 'pre_show_tab'];
|
||||||
$PLUGIN_HOOKS['post_show_tab']['example'] = ['PluginExampleShowtabitem', 'post_show_tab'];
|
$PLUGIN_HOOKS[Hooks::POST_SHOW_TAB]['example'] = [Showtabitem::class, 'post_show_tab'];
|
||||||
$PLUGIN_HOOKS['pre_show_item']['example'] = ['PluginExampleShowtabitem', 'pre_show_item'];
|
$PLUGIN_HOOKS[Hooks::PRE_SHOW_ITEM]['example'] = [Showtabitem::class, 'pre_show_item'];
|
||||||
$PLUGIN_HOOKS['post_show_item']['example'] = ['PluginExampleShowtabitem', 'post_show_item'];
|
$PLUGIN_HOOKS[Hooks::POST_SHOW_ITEM]['example'] = [Showtabitem::class, 'post_show_item'];
|
||||||
|
|
||||||
$PLUGIN_HOOKS['pre_item_form']['example'] = ['PluginExampleItemForm', 'preItemForm'];
|
$PLUGIN_HOOKS[Hooks::PRE_ITEM_FORM]['example'] = [ItemForm::class, 'preItemForm'];
|
||||||
$PLUGIN_HOOKS['post_item_form']['example'] = ['PluginExampleItemForm', 'postItemForm'];
|
$PLUGIN_HOOKS[Hooks::POST_ITEM_FORM]['example'] = [ItemForm::class, 'postItemForm'];
|
||||||
|
|
||||||
// Add new actions to timeline
|
// Add new actions to timeline
|
||||||
$PLUGIN_HOOKS['timeline_actions']['example'] = [
|
$PLUGIN_HOOKS[Hooks::TIMELINE_ACTIONS]['example'] = [
|
||||||
'PluginExampleItemForm', 'timelineActions'
|
ItemForm::class, 'timelineActions'
|
||||||
];
|
];
|
||||||
|
|
||||||
// declare this plugin as an import plugin for Computer itemtype
|
// declare this plugin as an import plugin for Computer itemtype
|
||||||
$PLUGIN_HOOKS['import_item']['example'] = ['Computer' => ['Plugin']];
|
$PLUGIN_HOOKS['import_item']['example'] = [Computer::class => ['Plugin']];
|
||||||
|
|
||||||
// add additional informations on Computer::showForm
|
// add additional informations on Computer::showForm
|
||||||
$PLUGIN_HOOKS['autoinventory_information']['example'] = [
|
$PLUGIN_HOOKS[Hooks::AUTOINVENTORY_INFORMATION]['example'] = [
|
||||||
'Computer' => ['PluginExampleComputer', 'showInfo']
|
Computer::class => [Computer::class, 'showInfo']
|
||||||
];
|
];
|
||||||
|
|
||||||
$PLUGIN_HOOKS[Hooks::FILTER_ACTORS]['example'] = "plugin_example_filter_actors";
|
$PLUGIN_HOOKS[Hooks::FILTER_ACTORS]['example'] = "plugin_example_filter_actors";
|
||||||
|
|
||||||
// add new cards to dashboard grid
|
// add new cards to dashboard grid
|
||||||
$PLUGIN_HOOKS['dashboard_types']['example'] = ['PluginExampleExample', 'dashboardTypes'];
|
$PLUGIN_HOOKS['dashboard_types']['example'] = [Example::class, 'dashboardTypes'];
|
||||||
$PLUGIN_HOOKS['dashboard_cards']['example'] = ['PluginExampleExample', 'dashboardCards'];
|
$PLUGIN_HOOKS['dashboard_cards']['example'] = [Example::class, 'dashboardCards'];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -33,13 +33,17 @@
|
|||||||
// Purpose of file:
|
// Purpose of file:
|
||||||
// ----------------------------------------------------------------------
|
// ----------------------------------------------------------------------
|
||||||
|
|
||||||
|
namespace GlpiPlugin\Example;
|
||||||
|
use CommonDBChild;
|
||||||
|
use Session;
|
||||||
|
|
||||||
// Sample of class that inherit from CommonDBChild. The behaviour of CommonRelation is similar.
|
// Sample of class that inherit from CommonDBChild. The behaviour of CommonRelation is similar.
|
||||||
// The main evolution introduced by 0.84 version of GLPI is a stronger control and log of
|
// The main evolution introduced by 0.84 version of GLPI is a stronger control and log of
|
||||||
// interactions. We suggest you to refer to the header of CommonDBConnexity class to see these
|
// interactions. We suggest you to refer to the header of CommonDBConnexity class to see these
|
||||||
// enhancements.
|
// enhancements.
|
||||||
// For CommonDBRelation, the variable are quiet equivalent, but they use _1 and _2 for each side
|
// For CommonDBRelation, the variable are quiet equivalent, but they use _1 and _2 for each side
|
||||||
// parent
|
// parent
|
||||||
class PluginExampleChild extends CommonDBChild {
|
class Child extends CommonDBChild {
|
||||||
|
|
||||||
// A child rely on an item. If $itemtype=='itemtype', then that is a variable item.
|
// A child rely on an item. If $itemtype=='itemtype', then that is a variable item.
|
||||||
static public $itemtype = 'itemtype';
|
static public $itemtype = 'itemtype';
|
@ -33,13 +33,16 @@
|
|||||||
// Purpose of file:
|
// Purpose of file:
|
||||||
// ----------------------------------------------------------------------
|
// ----------------------------------------------------------------------
|
||||||
|
|
||||||
|
namespace GlpiPlugin\Example;
|
||||||
|
use CommonDBTM;
|
||||||
|
|
||||||
// Class of the defined type
|
// Class of the defined type
|
||||||
|
|
||||||
if (!defined('GLPI_ROOT')) {
|
if (!defined('GLPI_ROOT')) {
|
||||||
die("Sorry. You can't access directly to this file");
|
die("Sorry. You can't access directly to this file");
|
||||||
}
|
}
|
||||||
|
|
||||||
class PluginExampleComputer extends CommonDBTM {
|
class Computer extends CommonDBTM {
|
||||||
|
|
||||||
static function showInfo() {
|
static function showInfo() {
|
||||||
|
|
||||||
@ -78,4 +81,3 @@ class PluginExampleComputer extends CommonDBTM {
|
|||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
@ -28,7 +28,16 @@
|
|||||||
* -------------------------------------------------------------------------
|
* -------------------------------------------------------------------------
|
||||||
*/
|
*/
|
||||||
|
|
||||||
class PluginExampleConfig extends CommonDBTM {
|
namespace GlpiPlugin\Example;
|
||||||
|
use CommonDBTM;
|
||||||
|
use CommonGLPI;
|
||||||
|
use Config as GlpiConfig;
|
||||||
|
use Dropdown;
|
||||||
|
use Html;
|
||||||
|
use Session;
|
||||||
|
use Toolbox;
|
||||||
|
|
||||||
|
class Config extends CommonDBTM {
|
||||||
|
|
||||||
static protected $notable = true;
|
static protected $notable = true;
|
||||||
|
|
||||||
@ -54,7 +63,7 @@ class PluginExampleConfig extends CommonDBTM {
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
$my_config = Config::getConfigurationValues('plugin:Example');
|
$my_config = GlpiConfig::getConfigurationValues('plugin:Example');
|
||||||
|
|
||||||
echo "<form name='form' action=\"".Toolbox::getItemTypeFormURL('Config')."\" method='post'>";
|
echo "<form name='form' action=\"".Toolbox::getItemTypeFormURL('Config')."\" method='post'>";
|
||||||
echo "<div class='center' id='tabsbody'>";
|
echo "<div class='center' id='tabsbody'>";
|
@ -33,6 +33,9 @@
|
|||||||
// Purpose of file:
|
// Purpose of file:
|
||||||
// ----------------------------------------------------------------------
|
// ----------------------------------------------------------------------
|
||||||
|
|
||||||
|
namespace GlpiPlugin\Example;
|
||||||
|
use CommonDevice;
|
||||||
|
|
||||||
// Class of the defined type
|
// Class of the defined type
|
||||||
|
|
||||||
if (!defined('GLPI_ROOT')) {
|
if (!defined('GLPI_ROOT')) {
|
||||||
@ -40,7 +43,7 @@ if (!defined('GLPI_ROOT')) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/// Class DeviceCamera
|
/// Class DeviceCamera
|
||||||
class PluginExampleDeviceCamera extends CommonDevice {
|
class DeviceCamera extends CommonDevice {
|
||||||
|
|
||||||
static function getTypeName($nb = 0) {
|
static function getTypeName($nb = 0) {
|
||||||
return _n('Camera', 'Cameras', $nb);
|
return _n('Camera', 'Cameras', $nb);
|
@ -54,11 +54,14 @@ along with GLPI. If not, see <http://www.gnu.org/licenses/>.
|
|||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
namespace GlpiPlugin\Example;
|
||||||
|
use Document as GlpiDocument;
|
||||||
|
|
||||||
if (!defined('GLPI_ROOT')) {
|
if (!defined('GLPI_ROOT')) {
|
||||||
die("Sorry. You can't access this file directly");
|
die("Sorry. You can't access this file directly");
|
||||||
}
|
}
|
||||||
|
|
||||||
class PluginExampleDocument extends Document {
|
class Document extends GlpiDocument {
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Return the table used to store this object. Overloads the implementation in CommonDBTM
|
* Return the table used to store this object. Overloads the implementation in CommonDBTM
|
@ -32,9 +32,11 @@
|
|||||||
// Original Author of file:
|
// Original Author of file:
|
||||||
// Purpose of file:
|
// Purpose of file:
|
||||||
// ----------------------------------------------------------------------
|
// ----------------------------------------------------------------------
|
||||||
|
namespace GlpiPlugin\Example;
|
||||||
|
use CommonDropdown;
|
||||||
|
|
||||||
// Class for a Dropdown
|
// Class for a Dropdown
|
||||||
class PluginExampleDropdown extends CommonDropdown {
|
class Dropdown extends CommonDropdown {
|
||||||
|
|
||||||
|
|
||||||
static function getTypeName($nb = 0) {
|
static function getTypeName($nb = 0) {
|
@ -33,8 +33,17 @@
|
|||||||
// Purpose of file:
|
// Purpose of file:
|
||||||
// ----------------------------------------------------------------------
|
// ----------------------------------------------------------------------
|
||||||
|
|
||||||
|
namespace GlpiPlugin\Example;
|
||||||
|
use CommonDBTM;
|
||||||
|
use CommonGLPI;
|
||||||
|
use Computer;
|
||||||
|
use Html;
|
||||||
|
use Log;
|
||||||
|
use MassiveAction;
|
||||||
|
use Session;
|
||||||
|
|
||||||
// Class of the defined type
|
// Class of the defined type
|
||||||
class PluginExampleExample extends CommonDBTM {
|
class Example extends CommonDBTM {
|
||||||
|
|
||||||
static $tags = '[EXAMPLE_ID]';
|
static $tags = '[EXAMPLE_ID]';
|
||||||
|
|
||||||
@ -330,9 +339,9 @@ class PluginExampleExample extends CommonDBTM {
|
|||||||
$output[$key]["end"] = date("Y-m-d 18:00:00");
|
$output[$key]["end"] = date("Y-m-d 18:00:00");
|
||||||
$output[$key]["name"] = __("test planning example 1", 'example');
|
$output[$key]["name"] = __("test planning example 1", 'example');
|
||||||
// Specify the itemtype to be able to use specific display system
|
// Specify the itemtype to be able to use specific display system
|
||||||
$output[$key]["itemtype"] = "PluginExampleExample";
|
$output[$key]["itemtype"] = Example::class;
|
||||||
// Set the ID using the ID of the item in the database to have unique ID
|
// Set the ID using the ID of the item in the database to have unique ID
|
||||||
$output[$key][getForeignKeyFieldForItemType('PluginExampleExample')] = 1;
|
$output[$key][getForeignKeyFieldForItemType(Example::class)] = 1;
|
||||||
return $output;
|
return $output;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -455,7 +464,7 @@ class PluginExampleExample extends CommonDBTM {
|
|||||||
foreach ($ids as $id) {
|
foreach ($ids as $id) {
|
||||||
if ($item->getFromDB($id)) {
|
if ($item->getFromDB($id)) {
|
||||||
Session::addMessageAfterRedirect("- ".$item->getField("name"));
|
Session::addMessageAfterRedirect("- ".$item->getField("name"));
|
||||||
Log::history($id, 'Computer', $changes, 'PluginExampleExample',
|
Log::history($id, 'Computer', $changes, Example::class,
|
||||||
Log::HISTORY_PLUGIN);
|
Log::HISTORY_PLUGIN);
|
||||||
$ma->itemDone($item->getType(), $id, MassiveAction::ACTION_OK);
|
$ma->itemDone($item->getType(), $id, MassiveAction::ACTION_OK);
|
||||||
} else {
|
} else {
|
||||||
@ -470,7 +479,7 @@ class PluginExampleExample extends CommonDBTM {
|
|||||||
return;
|
return;
|
||||||
|
|
||||||
case 'do_nothing' :
|
case 'do_nothing' :
|
||||||
If ($item->getType() == 'PluginExampleExample') {
|
If ($item->getType() == Example::class) {
|
||||||
Session::addMessageAfterRedirect(__("Right it is the type I want...", 'example'));
|
Session::addMessageAfterRedirect(__("Right it is the type I want...", 'example'));
|
||||||
Session::addMessageAfterRedirect(__("But... I say I will do nothing for:",
|
Session::addMessageAfterRedirect(__("But... I say I will do nothing for:",
|
||||||
'example'));
|
'example'));
|
||||||
@ -506,12 +515,12 @@ class PluginExampleExample extends CommonDBTM {
|
|||||||
return [
|
return [
|
||||||
'example' => [
|
'example' => [
|
||||||
'label' => __("Plugin Example", 'example'),
|
'label' => __("Plugin Example", 'example'),
|
||||||
'function' => "PluginExampleExample::cardWidget",
|
'function' => Example::class . "::cardWidget",
|
||||||
'image' => "https://via.placeholder.com/100x86?text=example",
|
'image' => "https://via.placeholder.com/100x86?text=example",
|
||||||
],
|
],
|
||||||
'example_static' => [
|
'example_static' => [
|
||||||
'label' => __("Plugin Example (static)", 'example'),
|
'label' => __("Plugin Example (static)", 'example'),
|
||||||
'function' => "PluginExampleExample::cardWidgetWithoutProvider",
|
'function' => Example::class . "::cardWidgetWithoutProvider",
|
||||||
'image' => "https://via.placeholder.com/100x86?text=example+static",
|
'image' => "https://via.placeholder.com/100x86?text=example+static",
|
||||||
],
|
],
|
||||||
];
|
];
|
||||||
@ -526,7 +535,7 @@ class PluginExampleExample extends CommonDBTM {
|
|||||||
'plugin_example_card' => [
|
'plugin_example_card' => [
|
||||||
'widgettype' => ["example"],
|
'widgettype' => ["example"],
|
||||||
'label' => __("Plugin Example card"),
|
'label' => __("Plugin Example card"),
|
||||||
'provider' => "PluginExampleExample::cardDataProvider",
|
'provider' => Example::class . "::cardDataProvider",
|
||||||
],
|
],
|
||||||
'plugin_example_card_without_provider' => [
|
'plugin_example_card_without_provider' => [
|
||||||
'widgettype' => ["example_static"],
|
'widgettype' => ["example_static"],
|
||||||
@ -535,7 +544,7 @@ class PluginExampleExample extends CommonDBTM {
|
|||||||
'plugin_example_card_with_core_widget' => [
|
'plugin_example_card_with_core_widget' => [
|
||||||
'widgettype' => ["bigNumber"],
|
'widgettype' => ["bigNumber"],
|
||||||
'label' => __("Plugin Example card with core provider"),
|
'label' => __("Plugin Example card with core provider"),
|
||||||
'provider' => "PluginExampleExample::cardBigNumberProvider",
|
'provider' => Example::class . "::cardBigNumberProvider",
|
||||||
],
|
],
|
||||||
];
|
];
|
||||||
|
|
@ -28,12 +28,16 @@
|
|||||||
* -------------------------------------------------------------------------
|
* -------------------------------------------------------------------------
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
namespace GlpiPlugin\Example;
|
||||||
|
use Html;
|
||||||
|
use Ticket;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Summary of PluginExampleItemForm
|
* Summary of GlpiPlugin\Example\ItemForm
|
||||||
* Example of *_item_form implementation
|
* Example of *_item_form implementation
|
||||||
* @see http://glpi-developer-documentation.rtfd.io/en/master/plugins/hooks.html#items-display-related
|
* @see http://glpi-developer-documentation.rtfd.io/en/master/plugins/hooks.html#items-display-related
|
||||||
* */
|
* */
|
||||||
class PluginExampleItemForm {
|
class ItemForm {
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Display contents at the begining of item forms.
|
* Display contents at the begining of item forms.
|
||||||
@ -46,7 +50,7 @@ class PluginExampleItemForm {
|
|||||||
$item = $params['item'];
|
$item = $params['item'];
|
||||||
$options = $params['options'];
|
$options = $params['options'];
|
||||||
|
|
||||||
$firstelt = ($item::getType() == Ticket::getType() ? 'th' : 'td');
|
$firstelt = ($item::getType() == Ticket::class ? 'th' : 'td');
|
||||||
|
|
||||||
$out = '<tr><th colspan="' . (isset($options['colspan']) ? $options['colspan'] * 2 : '4') . '">';
|
$out = '<tr><th colspan="' . (isset($options['colspan']) ? $options['colspan'] * 2 : '4') . '">';
|
||||||
$out .= sprintf(
|
$out .= sprintf(
|
||||||
@ -88,7 +92,7 @@ class PluginExampleItemForm {
|
|||||||
$item = $params['item'];
|
$item = $params['item'];
|
||||||
$options = $params['options'];
|
$options = $params['options'];
|
||||||
|
|
||||||
$firstelt = ($item::getType() == Ticket::getType() ? 'th' : 'td');
|
$firstelt = ($item::getType() == Ticket::class ? 'th' : 'td');
|
||||||
|
|
||||||
$out = '<tr><th colspan="' . (isset($options['colspan']) ? $options['colspan'] * 2 : '4') . '">';
|
$out = '<tr><th colspan="' . (isset($options['colspan']) ? $options['colspan'] * 2 : '4') . '">';
|
||||||
$out .= sprintf(
|
$out .= sprintf(
|
@ -35,6 +35,10 @@
|
|||||||
|
|
||||||
// Class of the defined type
|
// Class of the defined type
|
||||||
|
|
||||||
|
namespace GlpiPlugin\Example;
|
||||||
|
use GlpiPlugin\Example\DeviceCamera;
|
||||||
|
use Item_Devices;
|
||||||
|
|
||||||
if (!defined('GLPI_ROOT')) {
|
if (!defined('GLPI_ROOT')) {
|
||||||
die("Sorry. You can't access directly to this file");
|
die("Sorry. You can't access directly to this file");
|
||||||
}
|
}
|
||||||
@ -42,9 +46,9 @@ if (!defined('GLPI_ROOT')) {
|
|||||||
/**
|
/**
|
||||||
* Relation between item and devices
|
* Relation between item and devices
|
||||||
**/
|
**/
|
||||||
class PluginExampleItem_DeviceCamera extends Item_Devices {
|
class Item_DeviceCamera extends Item_Devices {
|
||||||
|
|
||||||
static public $itemtype_2 = 'PluginExampleDeviceCamera';
|
static public $itemtype_2 = DeviceCamera::class;
|
||||||
static public $items_id_2 = 'plugin_example_devicecameras_id';
|
static public $items_id_2 = 'plugin_example_devicecameras_id';
|
||||||
|
|
||||||
static protected $notable = false;
|
static protected $notable = false;
|
@ -28,12 +28,15 @@
|
|||||||
* -------------------------------------------------------------------------
|
* -------------------------------------------------------------------------
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
namespace GlpiPlugin\Example;
|
||||||
|
use NotificationTarget;
|
||||||
|
|
||||||
if (!defined('GLPI_ROOT')) {
|
if (!defined('GLPI_ROOT')) {
|
||||||
die("Sorry. You can't access directly to this file");
|
die("Sorry. You can't access directly to this file");
|
||||||
}
|
}
|
||||||
|
|
||||||
// Class NotificationTarget
|
// Class NotificationTarget
|
||||||
class PluginExampleNotificationTargetExample extends NotificationTarget {
|
class NotificationTargetExample extends NotificationTarget {
|
||||||
|
|
||||||
function getEvents() {
|
function getEvents() {
|
||||||
return ['alert' => 'alert example'];
|
return ['alert' => 'alert example'];
|
@ -32,6 +32,10 @@
|
|||||||
// Original Author of file: Walid Nouh
|
// Original Author of file: Walid Nouh
|
||||||
// Purpose of file:
|
// Purpose of file:
|
||||||
// ----------------------------------------------------------------------
|
// ----------------------------------------------------------------------
|
||||||
|
|
||||||
|
namespace GlpiPlugin\Example;
|
||||||
|
use Rule;
|
||||||
|
|
||||||
if (!defined('GLPI_ROOT')) {
|
if (!defined('GLPI_ROOT')) {
|
||||||
die("Sorry. You can't access directly to this file");
|
die("Sorry. You can't access directly to this file");
|
||||||
}
|
}
|
||||||
@ -44,10 +48,10 @@ if (!defined('GLPI_ROOT')) {
|
|||||||
* - actions
|
* - actions
|
||||||
*
|
*
|
||||||
**/
|
**/
|
||||||
class PluginExampleRuleTest extends Rule {
|
class RuleTest extends Rule {
|
||||||
|
|
||||||
// From Rule
|
// From Rule
|
||||||
static public $right = 'rule_import';
|
public $rightname = 'rule_import';
|
||||||
public $can_sort = true;
|
public $can_sort = true;
|
||||||
|
|
||||||
|
|
@ -32,16 +32,20 @@
|
|||||||
// Original Author of file: Walid Nouh
|
// Original Author of file: Walid Nouh
|
||||||
// Purpose of file:
|
// Purpose of file:
|
||||||
// ----------------------------------------------------------------------
|
// ----------------------------------------------------------------------
|
||||||
|
|
||||||
|
namespace GlpiPlugin\Example;
|
||||||
|
use RuleCollection;
|
||||||
|
|
||||||
if (!defined('GLPI_ROOT')) {
|
if (!defined('GLPI_ROOT')) {
|
||||||
die("Sorry. You can't access directly to this file");
|
die("Sorry. You can't access directly to this file");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
class PluginExampleRuleTestCollection extends RuleCollection {
|
class RuleTestCollection extends RuleCollection {
|
||||||
|
|
||||||
// From RuleCollection
|
// From RuleCollection
|
||||||
public $stop_on_first_match = true;
|
public $stop_on_first_match = true;
|
||||||
static public $right = 'rule_import';
|
public static $rightname = 'rule_import';
|
||||||
public $menu_option = 'test';
|
public $menu_option = 'test';
|
||||||
|
|
||||||
function getTitle() {
|
function getTitle() {
|
@ -28,8 +28,10 @@
|
|||||||
* -------------------------------------------------------------------------
|
* -------------------------------------------------------------------------
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
namespace GlpiPlugin\Example;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Summary of PluginExampleShowtabitem
|
* Summary of GlpiPlugin\Example\Showtabitem
|
||||||
* Example of pre_show_xxx and post_show_xxx implementation
|
* Example of pre_show_xxx and post_show_xxx implementation
|
||||||
*
|
*
|
||||||
*
|
*
|
||||||
@ -49,7 +51,7 @@
|
|||||||
* post_show_tab will be fired after the tab show
|
* post_show_tab will be fired after the tab show
|
||||||
*
|
*
|
||||||
* */
|
* */
|
||||||
class PluginExampleShowtabitem {
|
class Showtabitem {
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Summary of pre_show_tab
|
* Summary of pre_show_tab
|
||||||
@ -65,7 +67,7 @@ class PluginExampleShowtabitem {
|
|||||||
static function pre_show_tab($params) {
|
static function pre_show_tab($params) {
|
||||||
switch ($params['item']->getType()) {
|
switch ($params['item']->getType()) {
|
||||||
case 'Ticket':
|
case 'Ticket':
|
||||||
if ($params['options']['itemtype']=='Ticket' && $params['options']['tabnum']==2) {
|
if ($params['options']['itemtype']=='TicketValidation' && $params['options']['tabnum']==2) {
|
||||||
// if tasks are not all done
|
// if tasks are not all done
|
||||||
// then prevent solution div to show
|
// then prevent solution div to show
|
||||||
// this is an example to prevent solving of ticket
|
// this is an example to prevent solving of ticket
|
Loading…
x
Reference in New Issue
Block a user