-
Notifications
You must be signed in to change notification settings - Fork 2
Expand file tree
/
Copy pathCalendarPlanRruleValidateBehavior.php
More file actions
206 lines (189 loc) · 7.11 KB
/
CalendarPlanRruleValidateBehavior.php
File metadata and controls
206 lines (189 loc) · 7.11 KB
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
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
<?php
/**
* CalendarPlanRruleValidate Behavior
*
* @author Noriko Arai <arai@nii.ac.jp>
* @author Allcreator <info@allcreator.net>
* @link http://www.netcommons.org NetCommons Project
* @license http://www.netcommons.org/license.txt NetCommons License
* @copyright Copyright 2014, NetCommons Project
*/
App::uses('CalendarValidateAppBehavior', 'Calendars.Model/Behavior');
/**
* CalendarPlanRruleValidate Behavior
*
* @package Calendars\Calendars\Model\Befavior
* @author Allcreator <info@allcreator.net>
*/
class CalendarPlanRruleValidateBehavior extends CalendarValidateAppBehavior {
/**
* __checkRruleTerm
*
* Rrule規則の繰返しの終了指定チェック(日、週、月、年単位共通)
*
* @param Model $model モデル変数
* @param array $check 入力配列
* @return bool 成功時true, 失敗時false
*/
private function __checkRruleTerm(Model $model, $check) {
if (!isset($model->CalendarActionPlan)) {
$model->loadModels(['CalendarActionPlan' => 'Calendars.CalendarActionPlan']);
}
switch ($model->data[$model->alias]['rrule_term']) {
case 'COUNT': //回数指定
//繰返し回数 'rrule_until'
$rruleCount = intval($model->data[$model->alias]['rrule_count']);
if (empty($model->data[$model->alias]['rrule_count'])) {
$model->CalendarActionPlan->calendarProofreadValidationErrors['rrule_count'] = array();
$model->CalendarActionPlan->calendarProofreadValidationErrors['rrule_count'][] =
__d('calendars', 'Input required. (Times repeated)');
return false;
}
if (preg_match('/^\d+$/', $model->data[$model->alias]['rrule_count']) !== 1) {
$model->CalendarActionPlan->calendarProofreadValidationErrors['rrule_count'] = array();
$model->CalendarActionPlan->calendarProofreadValidationErrors['rrule_count'][] =
__d('calendars', 'Only numbers can be entered.');
//CakeLog::debug("DBG: error case. calendarProofreadValidationErros[" . print_r($model->CalendarActionPlan->calendarProofreadValidationErrors, true) . "]");
return false;
}
if ($rruleCount < CalendarsComponent::CALENDAR_RRULE_COUNT_MIN ||
$rruleCount > CalendarsComponent::CALENDAR_RRULE_COUNT_MAX) {
$model->CalendarActionPlan->calendarProofreadValidationErrors['rrule_count'] = array();
$model->CalendarActionPlan->calendarProofreadValidationErrors['rrule_count'][] =
sprintf(__d('calendars',
'The number of repetition is %d or more and %d or less.'),
CalendarsComponent::CALENDAR_RRULE_COUNT_MIN,
CalendarsComponent::CALENDAR_RRULE_COUNT_MAX);
return false;
}
break;
case 'UNTIL': //終了日指定
//繰返し終了日 'rrule_until'
$rruleUntil = $model->data[$model->alias]['rrule_until'];
$msg = $this->_checkUntilDate($model, $rruleUntil);
if ($msg !== '') {
$model->CalendarActionPlan->calendarProofreadValidationErrors['rrule_until'] = array();
$model->CalendarActionPlan->calendarProofreadValidationErrors['rrule_until'][] = $msg;
return false;
}
break;
default:
//CakeLog::error(sprintf(__d('calendars', 'サポートしていない終了期限タイプ[%s]です'), $model->data[$model->alias]['rrule_term']));
return false;
}
return true;
}
/**
* checkRrule
*
* Rrule規則のチェック
*
* @param Model $model モデル変数
* @param array $check 入力配列
* @return bool 成功時true, 失敗時false
*/
public function checkRrule(Model $model, $check) {
$isRepeat = (isset($model->data[$model->alias]['is_repeat']) &&
$model->data[$model->alias]['is_repeat']) ? true : false;
if (!$isRepeat) {
return true; //繰返し「無し」なら、true
}
//繰返しの終了指定(日、週、月、年単位共通)
if (!$this->__checkRruleTerm($model, $check)) {
//CakeLog::debug("DBG: model 1 [" . print_r($model->proofreadValidationErrors, true) . "]");
return false;
}
//繰返し周期 'repeat_freq'
if (!$this->_checkRepateFreq($model, $check)) {
//CakeLog::debug("DBG: model 2 [" . print_r($model->proofreadValidationErrors, true) . "]");
return false;
}
return true;
}
/**
* nopCheck
*
* NOPチェック関数
*
* @param Model $model モデル変数
* @param array $check 入力配列
* @return bool trueのみ返す
*/
public function nopCheck(Model $model, $check) {
return true;
}
/**
* _checkUntilDate
*
* Until日付Pチェック関数
*
* @param Model $model model
* @param string $rruleUntil UNTILの日付
* @return string チェックOkなら空文字、チェックNGならエラーメッセージ文字列
*/
protected function _checkUntilDate($model, $rruleUntil) {
if (preg_match('/^(\d{4})-(\d{2})-(\d{2})$/', $rruleUntil, $matches) !== 1) {
return __d('calendars', 'It is not in the YYYY-MM-DD format.');
}
if (!checkdate(intval($matches[2]), intval($matches[3]), intval($matches[1]))) {
return __d('calendars', 'Invalid input. Day that does not exist has been specified.');
}
//繰返し期限日が、開始日より前になっていないかどうかのチェック
//
$startDate = $model->data[$model->alias]['detail_start_datetime'];
if (strpos($startDate, ':') === false) {
//ユーザー系 YYYY-MM-DD
$startDate .= ' 00:00:00';
} else {
//ユーザー系 YYYY-MM-DD hh:mm
$startDate .= ':00';
}
//開始日(時刻)をサーバー系に直す
$nctm = new NetCommonsTime();
$serverStartDate = $nctm->toServerDatetime(
$startDate, $model->data[$model->alias]['timezone_offset']);
//until日の翌日を求める
//Y-m-d H:i:s形式にする。
$untilDateStr = $model->data[$model->alias]['rrule_until'] . ' 00:00:00';
$untilDateAry = CalendarTime::transFromYmdHisToArray($untilDateStr);
list($yearOfNextDay, $monthOfNextDay, $nextDay) =
CalendarTime::getNextDay(
$untilDateAry['year'], $untilDateAry['month'], $untilDateAry['day']);
$nextDayOfUntilDate = sprintf("%04d-%02d-%02d 00:00:00",
(int)$yearOfNextDay, (int)$monthOfNextDay, (int)$nextDay);
//untilDateの翌日00:00:00を作り出し、サーバー系に直す
$svrNxtDayOfUntilDt = $nctm->toServerDatetime(
$nextDayOfUntilDate, $model->data[$model->alias]['timezone_offset']);
if ($svrNxtDayOfUntilDt <= $serverStartDate) {
return __d('calendars', 'Invalid input. Term end date is earlier than the start date.');
}
//範囲チェック
if ($serverStartDate < CalendarsComponent::CALENDAR_RRULE_TERM_UNTIL_MIN ||
CalendarsComponent::CALENDAR_RRULE_TERM_UNTIL_MAX < $svrNxtDayOfUntilDt) {
return sprintf(
__d('calendars', 'date that can be specified is %s or more and %s or less.'),
CalendarsComponent::CALENDAR_RRULE_TERM_UNTIL_MIN,
CalendarsComponent::CALENDAR_RRULE_TERM_UNTIL_MAX);
}
return '';
}
/**
* _makeArrayOfWdayInNthWeek
*
* 1SU, ... , -1SA の配列生成関数
*
* @return array 生成した配列
*/
protected function _makeArrayOfWdayInNthWeek() {
//1SU, ... , -1SA の配列生成
$bydayMonthly = array();
$weeks = array (1, 2, 3, 4, -1);
$wdays = explode('|', CalendarsComponent::CALENDAR_REPEAT_WDAY);
foreach ($weeks as $week) {
foreach ($wdays as $wday) {
$bydayMonthly[] = $week . $wday;
}
}
return $bydayMonthly;
}
}