-
Notifications
You must be signed in to change notification settings - Fork 8
/
Copy pathext.php
141 lines (131 loc) · 4.1 KB
/
ext.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
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
<?php
/**
*
* PayPal Donation extension for the phpBB Forum Software package.
*
* @copyright (c) 2015-2020 Skouat
* @license GNU General Public License, version 2 (GPL-2.0)
*
*/
namespace skouat\ppde;
/**
* Extension class for custom enable/disable/purge actions
*
* NOTE TO EXTENSION DEVELOPERS:
* Normally it is not necessary to define any functions inside the ext class below.
* The ext class may contain special (un)installation commands in the methods
* enable_step(), disable_step() and purge_step(). As it is, these methods are defined
* in phpbb_extension_base, which this class extends, but you can overwrite them to
* give special instructions for those cases.
*/
class ext extends \phpbb\extension\base
{
/**
* Check whether or not the extension can be enabled.
* The current phpBB version should meet or exceed
* the minimum version required by this extension:
*
* Requires phpBB 3.3.11 and PHP 7.2.0
*
* @return bool
* @access public
*/
public function is_enableable()
{
$config = $this->container->get('config');
return phpbb_version_compare($config['version'], '3.3.11', '>=') && PHP_VERSION_ID >= 70200;
}
/**
* Overwrite enable_step to enable extension notifications before any included migrations are installed.
*
* @param mixed $old_state State returned by previous call of this method
*
* @return bool|string Returns false after last step, otherwise temporary state
* @access public
*/
public function enable_step($old_state)
{
// Empty means nothing has run yet
if ($old_state == '')
{
// Enable notifications
return $this->notification_handler('enable', $this->notification_types());
}
// Run parent enable step method
return parent::enable_step($old_state);
}
/**
* Overwrite disable_step to disable extension notifications before the extension is disabled.
*
* @param mixed $old_state State returned by previous call of this method
*
* @return false|string Returns false after last step, otherwise temporary state
* @access public
*/
public function disable_step($old_state)
{
// Empty means nothing has run yet
if ($old_state == '')
{
// Disable notifications
return $this->notification_handler('disable', $this->notification_types());
}
// Run parent disable step method
return parent::disable_step($old_state);
}
/**
* Overwrite purge_step to purge extension notifications before any included and installed migrations are reverted.
*
* @param mixed $old_state State returned by previous call of this method
*
* @return bool|string Returns false after last step, otherwise temporary state
* @access public
*/
public function purge_step($old_state)
{
// Empty means nothing has run yet
if ($old_state == '')
{
// Purge notifications
return $this->notification_handler('purge', $this->notification_types());
}
// Run parent purge step method
return parent::purge_step($old_state);
}
/**
* Notification handler to call notification enable/disable/purge steps
*
* @param string $step The step (enable, disable, purge)
* @param array $notification_types The notification type names
*
* @return string Return notifications as temporary state
* @access protected
* @author VSEphpbb (Matt Friedman)
* @copyright (c) 2014 phpBB Limited <https://www.phpbb.com>
* @license GNU General Public License, version 2 (GPL-2.0)
*/
protected function notification_handler($step, $notification_types): string
{
/** @type \phpbb\notification\manager $phpbb_notifications */
$phpbb_notifications = $this->container->get('notification_manager');
foreach ($notification_types as $notification_type)
{
call_user_func([$phpbb_notifications, $step . '_notifications'], $notification_type);
}
return 'notifications';
}
/**
* Returns the list of notification types
*
* @return array
* @access protected
*/
protected function notification_types(): array
{
return [
'skouat.ppde.notification.type.admin_donation_errors',
'skouat.ppde.notification.type.admin_donation_received',
'skouat.ppde.notification.type.donor_donation_received',
];
}
}