2016-05-11 01:10:06 +05:30
|
|
|
|
<?php
|
|
|
|
|
namespace common\behaviors;
|
|
|
|
|
|
|
|
|
|
use yii\base\Behavior;
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* @property \common\models\EmailActivation $owner
|
|
|
|
|
*/
|
|
|
|
|
class EmailActivationExpirationBehavior extends Behavior {
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* @var int количество секунд, прежде чем можно будет повторить отправку кода
|
|
|
|
|
* @see EmailActivation::canRepeat()
|
|
|
|
|
*/
|
|
|
|
|
public $repeatTimeout;
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* @var int количество секунд, прежде чем это подтверждение истечёт
|
|
|
|
|
* @see EmailActivation::isExpired()
|
|
|
|
|
*/
|
|
|
|
|
public $expirationTimeout;
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Можно ли повторить отправку письма текущего типа?
|
|
|
|
|
* Для проверки используется значение EmailActivation::$repeatTimeout и интерпретируется как:
|
|
|
|
|
* - <0 запретит повторную отправку этого кода
|
|
|
|
|
* - =0 позволит отправлять сообщения в любой момент
|
|
|
|
|
* - >0 будет проверять, сколько секунд прошло с момента создания модели
|
|
|
|
|
*
|
|
|
|
|
* @see EmailActivation::compareTime()
|
|
|
|
|
* @return bool
|
|
|
|
|
*/
|
2018-04-18 02:17:25 +05:30
|
|
|
|
public function canRepeat(): bool {
|
2016-05-11 01:10:06 +05:30
|
|
|
|
return $this->compareTime($this->repeatTimeout);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Истёк ли срок кода?
|
|
|
|
|
* Для проверки используется значение EmailActivation::$expirationTimeout и интерпретируется как:
|
|
|
|
|
* - <0 означает, что код никогда не истечёт
|
|
|
|
|
* - =0 всегда будет говорить, что код истёк
|
|
|
|
|
* - >0 будет проверять, сколько секунд прошло с момента создания модели
|
|
|
|
|
*
|
|
|
|
|
* @see EmailActivation::compareTime()
|
|
|
|
|
* @return bool
|
|
|
|
|
*/
|
2018-04-18 02:17:25 +05:30
|
|
|
|
public function isExpired(): bool {
|
2016-05-11 01:10:06 +05:30
|
|
|
|
return $this->compareTime($this->expirationTimeout);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Вычисляет, во сколько можно будет выполнить повторную отправку кода
|
|
|
|
|
*
|
|
|
|
|
* @return int
|
|
|
|
|
*/
|
2018-04-18 02:17:25 +05:30
|
|
|
|
public function canRepeatIn(): int {
|
2016-05-11 01:10:06 +05:30
|
|
|
|
return $this->calculateTime($this->repeatTimeout);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Вычисляет, во сколько код истечёт
|
|
|
|
|
*
|
|
|
|
|
* @return int
|
|
|
|
|
*/
|
2018-04-18 02:17:25 +05:30
|
|
|
|
public function expireIn(): int {
|
2016-05-11 01:10:06 +05:30
|
|
|
|
return $this->calculateTime($this->expirationTimeout);
|
|
|
|
|
}
|
|
|
|
|
|
2018-04-18 02:17:25 +05:30
|
|
|
|
protected function compareTime(int $value): bool {
|
2016-05-11 01:10:06 +05:30
|
|
|
|
if ($value < 0) {
|
|
|
|
|
return false;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if ($value === 0) {
|
|
|
|
|
return true;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return time() > $this->calculateTime($value);
|
|
|
|
|
}
|
|
|
|
|
|
2018-04-18 02:17:25 +05:30
|
|
|
|
protected function calculateTime(int $value): int {
|
2016-05-11 01:10:06 +05:30
|
|
|
|
return $this->owner->created_at + $value;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
}
|