PluginProbe ʕ •ᴥ•ʔ
Matomo Analytics – Powerful, Privacy-First Insights for WordPress / 1.3.1
Matomo Analytics – Powerful, Privacy-First Insights for WordPress v1.3.1
5.11.1 5.11.0 5.10.2 5.10.1 trunk 1.0.2 1.0.3 1.0.4 1.0.5 1.0.6 1.1.0 1.1.1 1.1.2 1.1.3 1.2.0 1.3.0 1.3.1 1.3.2 4.0.0 4.0.1 4.0.2 4.0.3 4.0.4 4.1.0 4.1.1 4.1.2 4.1.3 4.10.0 4.11.0 4.12.0 4.13.0 4.13.2 4.13.3 4.13.4 4.13.5 4.14.0 4.14.1 4.14.2 4.15.0 4.15.1 4.15.2 4.15.3 4.2.0 4.3.0 4.3.1 4.4.1 4.4.2 4.5.0 4.6.0 5.0.1 5.0.2 5.0.3 5.0.4 5.0.5 5.0.6 5.0.7 5.0.8 5.1.0 5.1.1 5.1.2 5.1.3 5.1.4 5.1.5 5.1.6 5.1.7 5.10.0 5.2.0 5.2.1 5.2.2 5.3.0 5.3.1 5.3.2 5.3.3 5.6.0 5.6.1 5.7.0 5.7.1 5.8.0 5.8.1 5.8.2
matomo / app / core / Period / Factory.php
matomo / app / core / Period Last commit date
Day.php 6 years ago Factory.php 6 years ago Month.php 6 years ago PeriodValidator.php 6 years ago Range.php 6 years ago Week.php 6 years ago Year.php 6 years ago
Factory.php
201 lines
1 <?php
2 /**
3 * Piwik - free/libre analytics platform
4 *
5 * @link https://matomo.org
6 * @license http://www.gnu.org/licenses/gpl-3.0.html GPL v3 or later
7 *
8 */
9 namespace Piwik\Period;
10
11 use Exception;
12 use Piwik\Container\StaticContainer;
13 use Piwik\Date;
14 use Piwik\Period;
15 use Piwik\Piwik;
16 use Piwik\Plugin;
17
18 /**
19 * Creates Period instances using the values used for the 'period' and 'date'
20 * query parameters.
21 *
22 * ## Custom Periods
23 *
24 * Plugins can define their own period factories all plugins to define new period types, in addition
25 * to "day", "week", "month", "year" and "range".
26 *
27 * To define a new period type:
28 *
29 * 1. create a new period class that derives from {@see \Piwik\Period}.
30 * 2. extend this class in a new PeriodFactory class and put it in /path/to/piwik/plugins/MyPlugin/PeriodFactory.php
31 *
32 * Period name collisions:
33 *
34 * If two plugins try to handle the same period label, the first one encountered will
35 * be used. In other words, avoid using another plugin's period label.
36 */
37 abstract class Factory
38 {
39 public function __construct()
40 {
41 // empty
42 }
43
44 /**
45 * Returns true if this factory should handle the period/date string combination.
46 *
47 * @return bool
48 */
49 public abstract function shouldHandle($strPeriod, $strDate);
50
51 /**
52 * Creates a period using the value of the 'date' query parameter.
53 *
54 * @param string $strPeriod
55 * @param string|Date $date
56 * @param string $timezone
57 * @return Period
58 */
59 public abstract function make($strPeriod, $date, $timezone);
60
61 /**
62 * Creates a new Period instance with a period ID and {@link Date} instance.
63 *
64 * _Note: This method cannot create {@link Period\Range} periods._
65 *
66 * @param string $period `"day"`, `"week"`, `"month"`, `"year"`, `"range"`.
67 * @param Date|string $date A date within the period or the range of dates.
68 * @param Date|string $timezone Optional timezone that will be used only when $period is 'range' or $date is 'last|previous'
69 * @throws Exception If `$strPeriod` is invalid or $date is invalid.
70 * @return \Piwik\Period
71 */
72 public static function build($period, $date, $timezone = 'UTC')
73 {
74 self::checkPeriodIsEnabled($period);
75
76 if (is_string($date)) {
77 list($period, $date) = self::convertRangeToDateIfNeeded($period, $date);
78 if (Period::isMultiplePeriod($date, $period)
79 || $period == 'range'
80 ) {
81
82 return new Range($period, $date, $timezone);
83 }
84
85 $dateObject = Date::factory($date);
86 } else if ($date instanceof Date) {
87 $dateObject = $date;
88 } else {
89 throw new \Exception("Invalid date supplied to Period\Factory::build(): " . gettype($date));
90 }
91
92 switch ($period) {
93 case 'day':
94 return new Day($dateObject);
95 case 'week':
96 return new Week($dateObject);
97 case 'month':
98 return new Month($dateObject);
99 case 'year':
100 return new Year($dateObject);
101 }
102
103 /** @var string[] $customPeriodFactories */
104 $customPeriodFactories = Plugin\Manager::getInstance()->findComponents('PeriodFactory', self::class);
105 foreach ($customPeriodFactories as $customPeriodFactoryClass) {
106 $customPeriodFactory = StaticContainer::get($customPeriodFactoryClass);
107 if ($customPeriodFactory->shouldHandle($period, $date)) {
108 return $customPeriodFactory->make($period, $date, $timezone);
109 }
110 }
111
112 throw new \Exception("Don't know how to create a '$period' period!");
113 }
114
115 public static function checkPeriodIsEnabled($period)
116 {
117 if (!self::isPeriodEnabledForAPI($period)) {
118 self::throwExceptionInvalidPeriod($period);
119 }
120 }
121
122 /**
123 * @param $strPeriod
124 * @throws \Exception
125 */
126 private static function throwExceptionInvalidPeriod($strPeriod)
127 {
128 $periods = self::getPeriodsEnabledForAPI();
129 $periods = implode(", ", $periods);
130 $message = Piwik::translate('General_ExceptionInvalidPeriod', array($strPeriod, $periods));
131 throw new Exception($message);
132 }
133
134 private static function convertRangeToDateIfNeeded($period, $date)
135 {
136 if (is_string($period) && is_string($date) && $period === 'range') {
137 $dates = explode(',', $date);
138 if (count($dates) === 2 && $dates[0] === $dates[1]) {
139 $period = 'day';
140 $date = $dates[0];
141 }
142 }
143
144 return array($period, $date);
145 }
146
147 /**
148 * Creates a Period instance using a period, date and timezone.
149 *
150 * @param string $timezone The timezone of the date. Only used if `$date` is `'now'`, `'today'`,
151 * `'yesterday'` or `'yesterdaySameTime'`.
152 * @param string $period The period string: `"day"`, `"week"`, `"month"`, `"year"`, `"range"`.
153 * @param string $date The date or date range string. Can be a special value including
154 * `'now'`, `'today'`, `'yesterday'`, `'yesterdaySameTime'`.
155 * @return \Piwik\Period
156 */
157 public static function makePeriodFromQueryParams($timezone, $period, $date)
158 {
159 if (empty($timezone)) {
160 $timezone = 'UTC';
161 }
162
163 list($period, $date) = self::convertRangeToDateIfNeeded($period, $date);
164
165 if ($period == 'range') {
166 self::checkPeriodIsEnabled('range');
167 $oPeriod = new Range('range', $date, $timezone, Date::factory('today', $timezone));
168 } else {
169 if (!($date instanceof Date)) {
170 if ($date == 'now' || $date == 'today') {
171 $date = date('Y-m-d', Date::factory('now', $timezone)->getTimestamp());
172 } elseif ($date == 'yesterday' || $date == 'yesterdaySameTime') {
173 $date = date('Y-m-d', Date::factory('now', $timezone)->subDay(1)->getTimestamp());
174 }
175 $date = Date::factory($date);
176 }
177 $oPeriod = Factory::build($period, $date);
178 }
179 return $oPeriod;
180 }
181
182 /**
183 * @param $period
184 * @return bool
185 */
186 public static function isPeriodEnabledForAPI($period)
187 {
188 $periodValidator = new PeriodValidator();
189 return $periodValidator->isPeriodAllowedForAPI($period);
190 }
191
192 /**
193 * @return array
194 */
195 public static function getPeriodsEnabledForAPI()
196 {
197 $periodValidator = new PeriodValidator();
198 return $periodValidator->getPeriodsAllowedForAPI();
199 }
200 }
201