forked from glpi-project/glpi
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathupdate_922_923.php
104 lines (94 loc) · 3.56 KB
/
update_922_923.php
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
<?php
/**
* ---------------------------------------------------------------------
* GLPI - Gestionnaire Libre de Parc Informatique
* Copyright (C) 2015-2017 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/>.
* ---------------------------------------------------------------------
*/
/** @file
* @brief
*/
/**
* Update from 9.2.2 to 9.2.3
*
* @return bool for success (will die for most error)
**/
function update922to923() {
global $DB, $migration, $CFG_GLPI;
$current_config = Config::getConfigurationValues('core');
$updateresult = true;
$ADDTODISPLAYPREF = [];
//TRANS: %s is the number of new version
$migration->displayTitle(sprintf(__('Update to %s'), '9.2.3'));
$migration->setVersion('9.2.3');
//add a column for the model
if (!$DB->fieldExists("glpi_devicepcis", "devicenetworkcardmodels_id")) {
$migration->addField(
"glpi_devicepcis",
"devicenetworkcardmodels_id",
"int(11) NOT NULL DEFAULT '0'",
['after' => 'manufacturers_id']
);
$migration->addKey('glpi_devicepcis', 'devicenetworkcardmodels_id');
}
//fix notificationtemplates_id in translations table
$notifs = [
'Certificate',
'SavedSearch_Alert'
];
foreach ($notifs as $notif) {
$notification = new Notification();
$template = new NotificationTemplate();
if ($notification->getFromDBByCrit(['itemtype' => $notif, 'event' => 'alert'])
&& $template->getFromDBByCrit(['itemtype' => $notif])
) {
$query = "UPDATE glpi_notificationtemplatetranslations SET " .
"notificationtemplates_id = " . $template->fields['id'] .
" WHERE notificationtemplates_id = " . $notification->fields['id'];
$DB->queryOrDie($query);
if ($notif == 'SavedSearch_Alert'
&& countElementsInTable(
'glpi_notifications_notificationtemplates', [
'notifications_id' => $notification->fields['id'],
'notificationtemplates_id' => $template->fields['id'],
'mode' => Notification_NotificationTemplate::MODE_MAIL
]
) == 0
) {
//Add missing notification template link for saved searches
$query = "INSERT INTO glpi_notifications_notificationtemplates " .
"(notifications_id, mode, notificationtemplates_id) " .
"VALUES(".$notification->fields['id'].", '".Notification_NotificationTemplate::MODE_MAIL.
"', ".$template->fields['id'].")";
$DB->queryOrDie($query);
}
}
}
// ************ Keep it at the end **************
$migration->executeMigration();
return $updateresult;
}